门牌识别(opencv)

这篇博客介绍了如何使用OpenCV进行门牌识别。首先通过imread加载图像并进行灰度化及均值滤波处理,然后根据需求对图片进行降采样。接着,使用ROI裁剪图片以减少噪声。通过二值化和Canny边缘检测,找到图像的轮廓。通过筛选轮廓大小,获取门牌轮廓并利用boundingRect绘制矩形。最后,提取数字并保存结果。
摘要由CSDN通过智能技术生成

之前数字图像处理大作业就是识别门牌或者车牌,用matlab写,直接就是搬运的!这次用opencv写了一下,基本思路大概如下:

1、利用imread() 来load图片,同时对图片进行灰度化,并进行均值滤波(本文用的图片噪声少,好像滤不滤波没啥影响)

2、图片过大的话进行降采样,resize()函数;

3、因为我们需要提取的只是车牌,所以可以将图片进行裁剪,尽可能地只保留门牌号区域,那样的话可以去除很多噪声,

可以利用ROI来进行图片大小的裁剪,ROI(Range(pic.rows, pic.rows), Range(pic.cols,pic.cols)),记住是先rows后cols;

4、二值化,前后背景比较简单,可以用threshold;

5、边缘检测Canny算子

6、然后开始找轮廓利用 findContous和drawContours两个函数,然后门牌最外面的轮廓和数字最里面的轮廓全绘制出来了,所以需要

根据尺寸大小来对轮廓进行筛选,用到了迭代器begin和end,操作迭代器的底端是指针,所以访问指针的大小这里用到->size()而不是.size(),

筛选出所有符合的轮廓之后,需要利用boundingRect()函数来绘制门牌号数字外围的矩形轮廓;

7、最后再进行数字的提取,利用getROI,在imwrite进行图片保存的时候,因为设计多个数字的保存,所以需要考虑到循环,

// 		char filename[255];
// 		sprintf(f
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值