• 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()构建旋转后的图像。

    旋转的角度如下图:

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

  • 相关阅读:
    Ubuntu “Failed to fetch”错误的解决方法
    #ifndef 与#pragma once
    vs TODO list使用
    window脚本编写bat程序执行
    vtk 的qt插件编译
    git bash 下载加速
    条件欧几里得聚类 pcl::ConditionalEuclideanClustering
    ANY数据类型的使用
    《C#编程风格》还记得多少
    驼峰命名法则
  • 原文地址:https://www.cnblogs.com/chenjianxiang/p/4301269.html
Copyright © 2020-2023  润新知