码迷,mamicode.com
首页 > 其他好文 > 详细

OpenCV文本图像的旋转矫正

时间:2015-02-26 16:27:49      阅读:224      评论:0      收藏:0      [点我收藏+]

标签:

用户在使用Android手机拍摄过程中难免会出现文本图像存在旋转角度。这里采用霍夫变换、边缘检测等数字图像处理算法检测图像的旋转角度,并根据计算结果对输入图像进行旋转矫正。

首先定义一个结构元素,再通过该结构元素对该图像进行开运算和闭运算(即腐蚀膨胀运算)。

Imgproc.cvtColor(matOri, matGray, Imgproc.COLOR_RGB2GRAY);
Mat kernel = Imgproc.getStructuringElement(Imgproc.CV_SHAPE_RECT, new Size(20,20)); 
Imgproc.morphologyEx(matGray, matGray, Imgproc.MORPH_OPEN, kernel);        
Imgproc.morphologyEx(matGray, matGray, Imgproc.MORPH_CLOSE, kernel);

 

然后调用Imgproc.threshold方法把原灰度图转换为二值图。

Imgproc.threshold(matGray, matGray, 80, 255, Imgproc.THRESH_BINARY);

 

接着通过Canny边缘检测算子来检测边界。参数为edges输出的边缘图像,threshold1和threshold2 当中的小阈值用来控制边缘连接。
利用霍夫变换在二值图中寻找直线,然后遍历所有的直线调用Math.atan来计算直线的角度。过滤掉一些角度过于大的直线和非法角度得到该图像该旋转的角度,再旋转该矩阵即可。

Mat edges = new Mat();
Imgproc.Canny(matGray, edges, 20, 160);
Mat lines = new Mat();//检测到的直线集合
Imgproc.HoughLinesP(edges, lines, 1, Math.PI/180, 45, 20, 20);

 

最后采用重投影技术矫正图像旋转:调用OpenCV函数Imgproc.getRotationMatrix2D()构建旋转矩阵,调用函数Imgproc.warpAffine()构建旋转后的图像。

旋转的角度如下图:

技术分享

采用重投影技术矫正图像旋转如图:

技术分享

 

OpenCV文本图像的旋转矫正

标签:

原文地址:http://www.cnblogs.com/chenjianxiang/p/4301269.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!