Opencv:10个步骤检测出图片中条形码

1. 原图像大小调整,提高运算效率

Opencv:10个步骤检测出图片中条形码_第1张图片


2. 转化为灰度图

Opencv:10个步骤检测出图片中条形码_第2张图片


3. 高斯平滑滤波

Opencv:10个步骤检测出图片中条形码_第3张图片


4.求得水平和垂直方向灰度图像的梯度差,使用Sobel算子

Opencv:10个步骤检测出图片中条形码_第4张图片Opencv:10个步骤检测出图片中条形码_第5张图片Opencv:10个步骤检测出图片中条形码_第6张图片


5.均值滤波,消除高频噪声

Opencv:10个步骤检测出图片中条形码_第7张图片


6.二值化

Opencv:10个步骤检测出图片中条形码_第8张图片


7.闭运算,填充条形码间隙

Opencv:10个步骤检测出图片中条形码_第9张图片


8. 腐蚀,去除孤立的点

Opencv:10个步骤检测出图片中条形码_第10张图片


9. 膨胀,填充条形码间空隙,根据核的大小,有可能需要2~3次膨胀操作

Opencv:10个步骤检测出图片中条形码_第11张图片


10.通过findContours找到条形码区域的矩形边界

Opencv:10个步骤检测出图片中条形码_第12张图片


实现:

#include "core/core.hpp"
#include "highgui/highgui.hpp"
#include "imgproc/imgproc.hpp"

using namespace cv;

int main(int argc,char *argv[])
{
	Mat image,imageGray,imageGuussian;
	Mat imageSobelX,imageSobelY,imageSobelOut;
	image=imread(argv[1]);

	//1. 原图像大小调整,提高运算效率
	resize(image,image,Size(500,300));
	imshow("1.原图像",image);

	//2. 转化为灰度图
	cvtColor(image,imageGray,CV_RGB2GRAY);
	imshow("2.灰度图",imageGray);

	//3. 高斯平滑滤波
	GaussianBlur(imageGray,imageGuussian,Size(3,3),0);
	imshow("3.高斯平衡滤波",imageGuussian);

	//4.求得水平和垂直方向灰度图像的梯度差,使用Sobel算子
	Mat imageX16S,imageY16S;
	Sobel(imageGuussian,imageX16S,CV_16S,1,0,3,1,0,4);
	Sobel(imageGuussian,imageY16S,CV_16S,0,1,3,1,0,4);
	convertScaleAbs(imageX16S,imageSobelX,1,0);
	convertScaleAbs(imageY16S,imageSobelY,1,0);
	imageSobelOut=imageSobelX-imageSobelY;
	imshow("4.X方向梯度",imageSobelX);
	imshow("4.Y方向梯度",imageSobelY);
	imshow("4.XY方向梯度差",imageSobelOut);	

	//5.均值滤波,消除高频噪声
	blur(imageSobelOut,imageSobelOut,Size(3,3));
	imshow("5.均值滤波",imageSobelOut);	

	//6.二值化
	Mat imageSobleOutThreshold;
	threshold(imageSobelOut,imageSobleOutThreshold,180,255,CV_THRESH_BINARY);	
	imshow("6.二值化",imageSobleOutThreshold);

	//7.闭运算,填充条形码间隙
	Mat  element=getStructuringElement(0,Size(7,7));
	morphologyEx(imageSobleOutThreshold,imageSobleOutThreshold,MORPH_CLOSE,element);	
	imshow("7.闭运算",imageSobleOutThreshold);

	//8. 腐蚀,去除孤立的点
	erode(imageSobleOutThreshold,imageSobleOutThreshold,element);
	imshow("8.腐蚀",imageSobleOutThreshold);

	//9. 膨胀,填充条形码间空隙,根据核的大小,有可能需要2~3次膨胀操作
	dilate(imageSobleOutThreshold,imageSobleOutThreshold,element);
	dilate(imageSobleOutThreshold,imageSobleOutThreshold,element);
	dilate(imageSobleOutThreshold,imageSobleOutThreshold,element);
	imshow("9.膨胀",imageSobleOutThreshold);		
	vector> contours;
	vector hiera;

	//10.通过findContours找到条形码区域的矩形边界
	findContours(imageSobleOutThreshold,contours,hiera,CV_RETR_EXTERNAL,CV_CHAIN_APPROX_NONE);
	for(int i=0;i

使用另一幅图片的效果如下:

Opencv:10个步骤检测出图片中条形码_第13张图片


底部的二维码左侧边界定位错位,检测发现在二值化的时候左侧第二个条码部分被归零了,导致在之后的腐蚀操作中被腐蚀掉了。调整阈值分界值180到160,重新运行正确:

Opencv:10个步骤检测出图片中条形码_第14张图片

你可能感兴趣的:(Opencv,条形码,findContours,外接矩形,OpenCV,OpenCV从入门到转行)