zoukankan      html  css  js  c++  java
  • OpenCV文本图像的旋转矫正

    用户在使用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()构建旋转后的图像。

    旋转的角度如下图:

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

  • 相关阅读:
    NSWindow,一些有的沒的
    IT单身男士必看【找女友单身程序员】
    Base 64 Encoding 编码
    如何成为一名优秀的C程序员
    iOS学习笔记—ObjectiveC 委托、非正式协议、正式协议
    程序员学习能力提升三要素
    工程师如何不被PM欺负
    最常被程序员们谎称读过的计算机书籍
    一些重要的算法
    asp调用.Net 托管代码
  • 原文地址:https://www.cnblogs.com/chenjianxiang/p/4301269.html
Copyright © 2011-2022 走看看