opencv检测直线方法之形态学方法
在阅读文献中,偶然发现使用使用形态学方法也可以检测直线,故做实验并记录。
使用该方法,需要定义一个长度为L的结构元素element,其大小应足够大以保留图像中的字符笔划,然而又恰好能检测出图像中最短的表格线。
定义如下两个结构element用以检测图中水平、竖直的表格线:
Mat element1 = getStructuringElement(MORPH_RECT, Size(70, 1));// size的width应大于图像中的横向笔划
Mat element3 = getStructuringElement(MORPH_RECT, Size(1, 55));//size的height应大于图像中的竖直笔划
之后分别用以上结构元素对图像的水平以及竖直方向做闭运算以抹去水平或竖直表格线以外的细节:
morphologyEx(image, imageF1, MORPH_CLOSE, element1);
morphologyEx(image, imageF4, MORPH_CLOSE, element3);
下面附上整体代码:
#include "core/core.hpp" #include "highgui/highgui.hpp" #include "imgproc/imgproc.hpp" #include <iostream> using namespace std; using namespace cv; int main() { Mat image = imread("E:\\x.jpg", 1); Mat imageF1, imageF2, imageF3, imageF4, imageF5, imageF6, imageF7; cvtColor(image, image, CV_RGB2GRAY); namedWindow("原图"); imshow("原图", image); Mat element1 = getStructuringElement(MORPH_RECT, Size(73, 1)); Mat element3 = getStructuringElement(MORPH_RECT, Size(1, 80)); morphologyEx(image, imageF1, MORPH_CLOSE, element1); threshold(imageF1, imageF2, 200, 255, CV_THRESH_OTSU | CV_THRESH_BINARY_INV);//自适应阈值 morphologyEx(image, imageF4, MORPH_CLOSE, element3); threshold(imageF4, imageF5, 200, 255, CV_THRESH_OTSU | CV_THRESH_BINARY_INV); bitwise_or(imageF2, imageF5, imageF7); namedWindow("F1"); imshow("F1", imageF1); namedWindow("F2"); imshow("F2", imageF2); namedWindow("F4"); imshow("F4", imageF4); namedWindow("F7"); imshow("F7", imageF7); namedWindow("F5"); imshow("F5", imageF5); waitKey(0); return 0; }
实验结果如下:
记录内容如有不妥之处,望指正!
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。
上一篇:MFC实现连连看游戏之地图显示
栏 目:C语言
下一篇:OpenCV如何提取图片中曲线
本文标题:opencv检测直线方法之形态学方法
本文地址:https://www.xiuzhanwang.com/a1/Cyuyan/552.html
您可能感兴趣的文章
- 01-10Unix下C程序内存泄漏检测工具Valgrind的安装与使用详解
- 01-10C语言中的内存泄露 怎样避免与检测
- 01-10C++内存泄漏及检测工具详解
- 01-10使用dc画笔画矩形、直线与椭圆示例
- 01-10实现opencv图像裁剪分屏显示示例
- 01-10使用opencv拉伸图像扩大分辨率示例
- 01-10C++程序检测内存泄漏的方法分享
- 01-10基于C++实现kinect+opencv 获取深度及彩色数据
- 01-10for循环中删除map中的元素valgrind检测提示error:Invalid read of size
- 01-10浅谈CMake配置OpenCV 时静态链接与动态链接的选择
阅读排行
本栏相关
- 04-02c语言函数调用后清空内存 c语言调用
- 04-02func函数+在C语言 func函数在c语言中
- 04-02c语言的正则匹配函数 c语言正则表达
- 04-02c语言用函数写分段 用c语言表示分段
- 04-02c语言中对数函数的表达式 c语言中对
- 04-02c语言编写函数冒泡排序 c语言冒泡排
- 04-02c语言没有round函数 round c语言
- 04-02c语言分段函数怎么求 用c语言求分段
- 04-02C语言中怎么打出三角函数 c语言中怎
- 04-02c语言调用函数求fibo C语言调用函数求
随机阅读
- 04-02jquery与jsp,用jquery
- 01-10delphi制作wav文件的方法
- 08-05DEDE织梦data目录下的sessions文件夹有什
- 01-10使用C语言求解扑克牌的顺子及n个骰子
- 01-10C#中split用法实例总结
- 08-05织梦dedecms什么时候用栏目交叉功能?
- 01-10SublimeText编译C开发环境设置
- 08-05dedecms(织梦)副栏目数量限制代码修改
- 01-11ajax实现页面的局部加载
- 01-11Mac OSX 打开原生自带读写NTFS功能(图文