cv2.findContours OpenCV图形轮廓函数python

contours, hierarchy = cv2.findContours(img, mode=cv2.RETR_EXTERNAL,                                                                                                          method=cv2.CHAIN_APPROX_NONE)

输入参数:

  1. img   : 单通道二值图像,白色是前景
  2. RETR_EXTERNAL  : 只返回最外边的轮廓, hierarchy[i][2]=hierarchy[i][3]=-1
  3. CHAIN_APPROX_NONE   :  存储轮廓上的所有点

输出参数:

  1. contours    : 轮廓  M*N  M是轮廓个数  N是每个轮廓的点
  2. hierarchy   : 轮廓等级关系 M*4

不同版本的opencv中输出参数个数有3个的,有2个的,我的版本是opencv-python 4.5.3.56 

这个函数输出数里的contours很好理解,主要是后面这个hierarchy(等级关系)和后面这个mode与method的关系不是很好理解,其中,method主要是表示存储方式的不同,如下

CV_CHAIN_APPROX_NONE  :存储轮廓的所有点

CV_CHAIN_APPROX_SIMPLE :不保存轮廓中水平、垂直、对角的线段,只保存轮廓的角点

CV_CHAIN_APPROX_TC89_L1,CV_CHAIN_APPROX_TC89_KCOS  应用了 Teh-Chin 链近  似算法的一种存储风格,这个我也没搞懂

剩下的就是重点,就是输出参数hierarchy和mode的关系到底是什么样的,hierarchy的四个参数到底表示的是什么意思,这四个值分别表示当前轮廓的“后前子父”对象的序号,下面看验证,首先看mode的四个选项,

  • CV_RETR_EXTERNAL :返回最外层轮廓, hierarchy[i][2]=hierarchy[i][3]=-1 
  • CV_RETR_LIST :返回所有的轮廓,但是没建立等级关系
  • CV_RETR_CCOMP :返回所有轮廓,包含两个层级结构
  • CV_RETR_TREE :返回所有轮廓,建立完整的层次结构

例子:采用图片如下:

验证1、 contours, hierarchy = cv2.findContours(fgmask, cv2

  • 43
    点赞
  • 101
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
`cv2.findContours()`是一个在图像中查找轮廓函数。它的语法如下: ```python contours, hierarchy = cv2.findContours(image, mode, method[, contours[, hierarchy[, offset]]]) ``` 其中,参数`image`是输入图像,必须是8位单通道图像。参数`mode`表示轮廓检索模式,有以下几种取值: - `cv2.RETR_EXTERNAL`:只检测外轮廓。 - `cv2.RETR_LIST`:检测的轮廓不建立等级关系。 - `cv2.RETR_CCOMP`:检测所有轮廓并将其组织为两级层次结构。 - `cv2.RETR_TREE`:检测所有轮廓并重构嵌套轮廓的整个层次。 参数`method`表示轮廓逼近方法,有以下几种取值: - `cv2.CHAIN_APPROX_NONE`:存储所有的轮廓点。 - `cv2.CHAIN_APPROX_SIMPLE`:仅存储水平、垂直和对角线方向的端点。 - `cv2.CHAIN_APPROX_TC89_L1`和`cv2.CHAIN_APPROX_TC89_KCOS`:使用Teh-Chin链逼近算法中的一种。 函数返回值`contours`是一个包含所有轮廓的列表,每个轮廓都是一个包含(x,y)坐标的数组。`hierarchy`是可选的输出向量,其中包含有关图像拓扑的信息。 下面是一个使用`cv2.findContours()`函数查找轮廓的例子: ```python import cv2 # 读取图像 img = cv2.imread('example.jpg') # 转换为灰度图像 gray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY) # 二值化 ret, thresh = cv2.threshold(gray, 127, 255, cv2.THRESH_BINARY) # 查找轮廓 contours, hierarchy = cv2.findContours(thresh, cv2.RETR_TREE, cv2.CHAIN_APPROX_NONE) # 绘制轮廓 cv2.drawContours(img, contours, -1, (0, 0, 255), 2) # 显示结果 cv2.imshow('image', img) cv2.waitKey(0) cv2.destroyAllWindows() ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值