OpenCV形态学处理使用技巧与应用演示

小白学视觉

共 3293字,需浏览 7分钟

 ·

2021-02-19 07:56

点击上方小白学视觉”,选择加"星标"或“置顶

重磅干货,第一时间送达

 关于OpenCV形态学使用基础可以查看公众号免费的OpenCV视频教程,其中有详细介绍,本篇文章主要介绍形态学中一些实用但是容易被忽略的技巧与演示。

    形态学中常用的方法有膨胀,腐蚀,开运算,闭运算,形态学梯度,顶帽,黑帽和击中击不中,大多以膨胀和腐蚀为基础操作,需要注意的是膨胀和腐蚀都是对图像中的高亮部分(二值图白色部分)处理起作用,如果是白色背景黑色目标要做取反操作,否则得到的结果是相反的。进入正题,技巧与应用场景介绍:

    (1)膨胀的应用。膨胀的结果类似“领域扩张”,白色区域将会扩大,常用于断开区域的连接。如下图,假如想连接3条线

我们可以这么做:

Mat element = getStructuringElement(MORPH_RECT, Size(15, 15));dilate(gray, gray, element);

虽然3段线段连成了1段,但是线的宽度明细也增加了,如果我不想线的宽度明显增加怎么办?答案是修改结构元素的Size值,比如为Size(1,15),这样增大竖直方向的膨胀力度(反之增大水平方向膨胀力度),效果如下:

Mat element = getStructuringElement(MORPH_RECT, Size(1, 15));dilate(gray, gray, element);

(2)腐蚀的应用。腐蚀的结果类似“领域蚕食”,白色区域将会缩小,常用于连接区域的切断。下面的图像,假如只想保留水平线,该怎么操作?

同样在结构元素Size上做文章,设置Size()值为Size(60,1),不与它相似的区域结构将被腐蚀,效果如下:

Mat element = getStructuringElement(MORPH_RECT, Size(60, 1));erode(gray, gray, element);

    (3)开运算应用。比如下面的图像,如果想去除字母C区域周围的毛边,就可以用开运算。

代码与效果:

Mat element = getStructuringElement(MORPH_RECT, Size(5, 5));morphologyEx(gray, gray, MORPH_OPEN, element); //开运算

    (4)闭运算应用。比如下面的图像,如果想去除字母C区域内部的黑色孔洞,就可以用闭运算。

代码与效果:

Mat element = getStructuringElement(MORPH_RECT, Size(9, 9));morphologyEx(gray, gray, MORPH_CLOSE, element); //闭运算

    (5)形态学梯度应用。比如下面的图像,提取边缘或轮廓框架,就可以用形态学梯度。

代码与效果:

Mat element = getStructuringElement(MORPH_RECT, Size(3, 3));morphologyEx(gray, gray, MORPH_GRADIENT, element); //形态学梯度

  (6)顶帽应用。比如下面的图像,想提取C区域的边缘毛刺,就可以用顶帽操作。

代码与效果:

Mat element = getStructuringElement(MORPH_RECT, Size(7, 7));morphologyEx(gray, gray, MORPH_TOPHAT, element); //顶帽

  (7)黑帽应用。比如下面的图像,想提取C区域的内部黑洞区域,就可以用黑帽操作。


代码与效果:

Mat element = getStructuringElement(MORPH_RECT, Size(9, 9));morphologyEx(gray, gray, MORPH_BLACKHAT, element); //黑帽

  (8)自定义结构元素应用。特定的结构元素会特定的结构区域特别起作用。比如圆形结构元素对圆形区域效果特别好,但是OpenCV默认值提供了3中结构,不包含圆形,那么我们可以自己创建圆形结构元素,通过画圆或遍历像素的方法。如下图,我们分别用矩形结构元素和圆形结构元素腐蚀,查看对比效果:

矩形结构元素与效果:

Mat element = getStructuringElement(MORPH_RECT, Size(35, 35));erode(gray, gray, element);

自定义圆形结构元素与效果(更好的保留了圆形结构):

Mat element = Mat::zeros(Size(35, 35), CV_8UC1);circle(element, Point(17, 17), 18, Scalar::all(1), -1);erode(gray, gray, element);


下载1:OpenCV-Contrib扩展模块中文版教程
在「小白学视觉」公众号后台回复:扩展模块中文教程即可下载全网第一份OpenCV扩展模块教程中文版,涵盖扩展模块安装、SFM算法、立体视觉、目标跟踪、生物视觉、超分辨率处理等二十多章内容。

下载2:Python视觉实战项目52讲
小白学视觉公众号后台回复:Python视觉实战项目即可下载包括图像分割、口罩检测、车道线检测、车辆计数、添加眼线、车牌识别、字符识别、情绪检测、文本内容提取、面部识别等31个视觉实战项目,助力快速学校计算机视觉。

下载3:OpenCV实战项目20讲
小白学视觉公众号后台回复:OpenCV实战项目20讲即可下载含有20个基于OpenCV实现20个实战项目,实现OpenCV学习进阶。

交流群


欢迎加入公众号读者群一起和同行交流,目前有SLAM、三维视觉、传感器自动驾驶、计算摄影、检测、分割、识别、医学影像、GAN算法竞赛等微信群(以后会逐渐细分),请扫描下面微信号加群,备注:”昵称+学校/公司+研究方向“,例如:”张三 + 上海交大 + 视觉SLAM“。请按照格式备注,否则不予通过。添加成功后会根据研究方向邀请进入相关微信群。请勿在群内发送广告,否则会请出群,谢谢理解~


浏览 43
点赞
评论
收藏
分享

手机扫一扫分享

分享
举报
评论
图片
表情
推荐
点赞
评论
收藏
分享

手机扫一扫分享

分享
举报