OpenCV-Python击中击不中变换案例:绿叶轮廓提取

☞ ░ 前往老猿Python博客 https://blog.csdn.net/LaoYuanPython

一、引言

在前面的博文介绍了HMT变换的基础知识及理解HMT变换的关键知识点,在老猿学习过程中参考的博文《OpenCV中一个最容易搞错的形态学操作 》介绍了两个HMT变换的案例,在《https://blog.csdn.net/LaoYuanPython/article/details/110868988 OpenCV-Python击中击不中变换案例:长方形边界提取》详细介绍了其中的长方形边界提取,本文将简单介绍另一个案例:绿叶轮廓的提取。

老猿关于HMT击中击不中变换系列的博文入口:

https://blog.csdn.net/LaoYuanPython/article/details/110676764 OpenCV-Python击中击不中HITMISS形态变换详解

二、输入图像

本文中的输入图像为《OpenCV中一个最容易搞错的形态学操作 》中提供的图像截图,文件名为:绿叶.jpg:
在这里插入图片描述

三、图像处理

直接使用《https://blog.csdn.net/LaoYuanPython/article/details/110868988 OpenCV-Python击中击不中变换案例:长方形边界提取》的代码修改输入图像文件名进行提取,得到如下图:
在这里插入图片描述
可能由于从博文《OpenCV中一个最容易搞错的形态学操作 》中截图带来了图像质量损失,结果图像出现了噪点。为此将代码做了一下调整,先对二值图做闭运算,同时尝试使用另外一组核来处理,代码如下:

import cv2
import numpy as np

from opencvPublic import preparePreviewImg,previewImgList,readImgFile

def hitMissTest(imgObj,kernalObj,extendBorder=True):
    if isinstance(imgObj,str):
        img = readImgFile(imgObj,True,True)
    else:img = imgObj

    if isinstance(kernalObj,str):
        kernal = readImgFile(kernalObj,True,True)
    else:kernal = kernalObj

    if extendBorder:dest = cv2.morphologyEx(img, cv2.MORPH_HITMISS, kernal,borderType=cv2.BORDER_CONSTANT,borderValue=0)
    else:dest = cv2.morphologyEx(img, cv2.MORPH_HITMISS, kernal)

    return dest

def main():
    kernal1 = np.array([[0, 0, 0],
                       [ 0,-1, 1],
                       [ 0, 0, 0]])

    kernal2 = np.array([[0, 0, 0],
                        [1,-1, 0],
                        [0, 0, 0]])


    imgFName = r'f:\pic\绿叶.JPG'
    img = readImgFile(imgFName, True, True) #自定义函数,读取指定文件的图像,后面两个参数分别代表是否转为灰度图、是否转为二值图
    preparePreviewImg(img, imgFName + ': 二值图')
    kernal = cv2.getStructuringElement(cv2.MORPH_RECT, (3, 3))
    imgClose = cv2.morphologyEx(img,cv2.MORPH_CLOSE,kernal)
    preparePreviewImg(imgClose, imgFName + ': 闭运算')
    dest1 = hitMissTest(imgClose,kernal1,True)
    preparePreviewImg(dest1, '核1 HMT结果')
    dest2 = hitMissTest(imgClose, kernal2,True)
    preparePreviewImg(dest2, '核2 HMT结果')
    dest = cv2.add(dest1,dest2)
    preparePreviewImg(dest,'两次HMT变换相加结果')
    previewImgList()
    cv2.waitKey(5000)

main()

上述代码中,关于图像显示的相关函数preparePreviewImg、previewImgList的介绍请参考《https://blog.csdn.net/LaoYuanPython/article/details/109984045 OpenCV-Python图像运算变换处理:开运算和闭运算以及不同核矩阵的影响分析》。

得到的图像如下:

在这里插入图片描述
在这里插入图片描述

效果还比较满意,与上面一种代码的中间结果图像进行对比,可以看到不同核的影响。

四、小结

本文在《https://blog.csdn.net/LaoYuanPython/article/details/110868988 OpenCV-Python击中击不中变换案例:长方形边界提取》基础上,介绍了使用击中击不中进行绿叶轮廓的提取案例,通过不同的核可以感知核对击中击不中变换的不同影响。

老猿关于HMT变换系列的博文入口:

https://blog.csdn.net/LaoYuanPython/article/details/110676764 OpenCV-Python击中击不中HITMISS形态变换详解

写博不易,敬请支持:

昨天到今天休假两天,既要处理家里事情,又要处理单位事情,还要写测试代码和博文。写博不易,敬请支持!
如果阅读本文于您有所获,敬请点赞、评论、收藏,谢谢大家的支持!

更多OpenCV-Python的介绍请参考专栏《OpenCV-Python图形图像处理 》
专栏网址https://blog.csdn.net/laoyuanpython/category_9979286.html

关于老猿的付费专栏

  1. 付费专栏《https://blog.csdn.net/laoyuanpython/category_9607725.html 使用PyQt开发图形界面Python应用》专门介绍基于Python的PyQt图形界面开发基础教程,对应文章目录为《 https://blog.csdn.net/LaoYuanPython/article/details/107580932 使用PyQt开发图形界面Python应用专栏目录》;
  2. 付费专栏《https://blog.csdn.net/laoyuanpython/category_10232926.html moviepy音视频开发专栏 )详细介绍moviepy音视频剪辑合成处理的类相关方法及使用相关方法进行相关剪辑合成场景的处理,对应文章目录为《https://blog.csdn.net/LaoYuanPython/article/details/107574583 moviepy音视频开发专栏文章目录》;
  3. 付费专栏《https://blog.csdn.net/laoyuanpython/category_10581071.html OpenCV-Python初学者疑难问题集》为《https://blog.csdn.net/laoyuanpython/category_9979286.html OpenCV-Python图形图像处理 》的伴生专栏,是笔者对OpenCV-Python图形图像处理学习中遇到的一些问题个人感悟的整合,相关资料基本上都是老猿反复研究的成果,有助于OpenCV-Python初学者比较深入地理解OpenCV,对应文章目录为《https://blog.csdn.net/LaoYuanPython/article/details/109713407 OpenCV-Python初学者疑难问题集专栏目录 》。

前两个专栏都适合有一定Python基础但无相关知识的小白读者学习,第三个专栏请大家结合《https://blog.csdn.net/laoyuanpython/category_9979286.html OpenCV-Python图形图像处理 》的学习使用。

对于缺乏Python基础的同仁,可以通过老猿的免费专栏《https://blog.csdn.net/laoyuanpython/category_9831699.html 专栏:Python基础教程目录)从零开始学习Python。

如果有兴趣也愿意支持老猿的读者,欢迎购买付费专栏。

跟老猿学Python、学OpenCV!

☞ ░ 前往老猿Python博文目录 https://blog.csdn.net/LaoYuanPython

LaoYuanPython CSDN认证博客专家 Python专家 CSDN博客专家 博客之星季军
侥幸获得CSDN 2020博客之星季军,博客主要聚焦Python相关知识,包括Python、爬虫、PyQt图形界面开发、Moviepy音视频剪辑、OpenCV图形图像处理等方向,内容都是老猿零基础学习相关知识的总结,许多内容是深入研究、测试甚至源码分析后的成果,在官网和网上都没有。有独特之见的专栏主要包括PyQt、Moviepy、Python、OpenCV相关专栏,特别是PyQt、Moviepy以及OpenCV疑难问题相关的付费专栏。另外博客内容还涉及5G、区块链和人工智能数学基础等非Python领域。欢迎大家批评指正!

如有疑问,请在 老猿Python 微信公号提问。谢谢!
已标记关键词 清除标记
相关推荐
©️2020 CSDN 皮肤主题: 酷酷鲨 设计师:CSDN官方博客 返回首页
实付 29.90元
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、C币套餐、付费专栏及课程。

余额充值