Python OpenCV 基于图像边缘提取的轮廓发现函数

Python OpenCV 365 天学习计划,与橡皮擦一起进入图像领域吧。本篇博客是这个系列的第 36 篇。

基础知识铺垫

在图像中,轮廓可以简单的理解为连接具有相同颜色的所有连续点(边界)的曲线,轮廓可用于形状分析和对象检测、识别等领域。

轮廓发现的原理:先通过阈值分割提取目标物体,再通过边缘检测提取目标物体轮廓。
一个轮廓就是一系列的点(像素),这些点构成了一个有序的点集合。

使用 cv2.findContours 函数可以用来检测图像的边缘。

函数原型说明

contours, hierarchy = cv2.findContours(image, mode, method[, contours[, hierarchy[, offset]]])

我使用的 Python OpenCV 是 4.0 以上版本,如果你使用的是 3.0 以上,可能存在返回值差异问题。
参数说明如下:

  • image:输入图像;
  • mode:轮廓检索模式,具体说明参见后文;
  • method:轮廓逼近方法,具体说明参加后文;
  • contours:返回的轮廓;
  • hierachy:每条轮廓对应的属性;
  • offset:每个轮廓点移动的可选偏移量。

备注:image 参数需要是二值图,而不是灰度图,返回结果是等高线和层次结构。

轮廓检索模式,有四种

  • cv2.RETR_EXTERNAL:表示只检测外轮廓;
  • cv2.RETR_LIST:检测的轮廓,不建立等级关系;
  • cv2.RETR_CCOMP:建立两个等级的轮廓,上面的一层为外边界,里面的一层为内孔的边界信息。如果内孔内还有一个连通物体,这个物体的边界也在顶层;
  • cv2.RETR_TREE:建立一个等级树结构的轮廓。
  • 上述内容,都可以在该网站查询:官网地址

轮廓逼近方法

  • cv2.CHAIN_APPROX_NONE:存储所有的轮廓点,相邻的两个点的像素位置差不超过 1,即 max(abs(x1-x2),abs(y2-y1))==1,一般不会用到;
  • cv2.CHAIN_APPROX_SIMPLE:压缩水平方向,垂直方向,对角线方向的元素,只保留该方向的终点坐标,例如一个矩形轮廓只需 4 个点来保存轮廓信息。
  • cv2.CHAIN_APPROX_TC89_L1cv2.CV_CHAIN_APPROX_TC89_KCOS:使用 teh-Chinl chain 近似算法(没寻找资料学习)。

了解上述内容之后,就可以应用轮廓发现函数了,代码如下:

import cv2 as cv

src = cv.imread("./both.jpeg")

gray = cv.cvtColor(src, cv.COLOR_BGR2GRAY)
ret, thresh = cv.threshold(gray, 150, 255, 0)
cv.imshow("thresh",thresh)
# 寻找轮廓
contours, hierarchy = cv.findContours(thresh, cv.RETR_TREE, cv.CHAIN_APPROX_SIMPLE)

轮廓发现之后,还要通过 cv2.drawContours 函数绘制轮廓,该函数原型如下:

image = cv2.drawContours(image, contours, contourIdx, color[, thickness[, lineType[, hierarchy[, maxLevel[, offset]]]]])

参数说明如下:

  • image:输入图像;
  • contours:轮廓,在 Python 中是一个 list,就是 cv2.findContours 函数找出来的点集,一个列表;
  • contourIdx:轮廓的索引,指定绘制轮廓 list 中的哪条轮廓,要绘制所有轮廓,请传递-1;
  • color:颜色;
  • thickness:厚度,如果是-1,表示填充;
  • lineType:线型;
  • hierarchy:层次结构的可选信息;
  • maxLevel:绘制轮廓的最大级别,0:仅绘制指定的轮廓,1:绘制轮廓和所有嵌套轮廓,2:绘制轮廓,所有嵌套轮廓,所有嵌套到嵌套的轮廓;
  • offset:轮廓偏移参数。

测试代码与运行结果如下:

import cv2 as cv
# help(cv.drawContours)
src = cv.imread("./both.jpeg")

gray = cv.cvtColor(src, cv.COLOR_BGR2GRAY)
ret, thresh = cv.threshold(gray, 150, 255, 0)
cv.imshow("thresh",thresh)
# 寻找轮廓
contours, hierarchy = cv.findContours(thresh, cv.RETR_TREE, cv.CHAIN_APPROX_SIMPLE)

# print(contours)
# print(hierarchy)
# 绘制轮廓
cv.drawContours(src,contours,-1,(200,0,150),2)

cv.imshow('src',src)
cv.waitKey(0)

Python OpenCV 基于图像边缘提取的轮廓发现函数

橡皮擦的小节

希望今天的 1 个小时你有所收获,我们下篇博客见~
私人联系方式:moshanba
使用大闪光术(CTRL+A)发现橡皮擦私人联系方式。

相关阅读


技术专栏

  1. Python 爬虫 100 例教程,超棒的爬虫教程,立即订阅吧
  2. Python 爬虫小课,精彩 9 讲

今天是持续写作的第 77 / 100 天。
如果你有想要交流的想法、技术,欢迎在评论区留言。


如果你想跟博主建立亲密关系,可以关注同名公众号 梦想橡皮擦,近距离接触一个逗趣的互联网高级网虫。
博主 ID:梦想橡皮擦,希望大家点赞评论收藏

  • 4
    点赞
  • 22
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论
OpenCV是一个开源的计算机视觉库,提供了丰富的图像处理和计算机视觉算法。边缘提取图像处理中的一项重要任务,可以用于检测图像中的边缘轮廓。在Python中,可以使用OpenCV库进行边缘提取。 以下是使用OpenCV进行边缘提取的基本步骤: 1. 导入OpenCV库:首先需要导入OpenCV库,可以使用以下代码实现: ```python import cv2 ``` 2. 读取图像:使用`cv2.imread()`函数读取待处理的图像文件,例如: ```python image = cv2.imread('image.jpg') ``` 3. 转换为灰度图像:大多数边缘检测算法都是基于灰度图像的,因此需要将彩色图像转换为灰度图像。可以使用`cv2.cvtColor()`函数图像转换为灰度图像: ```python gray = cv2.cvtColor(image, cv2.COLOR_BGR2GRAY) ``` 4. 边缘检测:使用OpenCV提供的边缘检测算法进行边缘提取。常用的边缘检测算法包括Canny边缘检测和Sobel算子等。以Canny边缘检测为例,可以使用`cv2.Canny()`函数进行边缘检测: ```python edges = cv2.Canny(gray, threshold1, threshold2) ``` 其中`threshold1`和`threshold2`是Canny算法的两个阈值,用于控制边缘检测的敏感度。 5. 显示结果:可以使用`cv2.imshow()`函数显示边缘提取的结果: ```python cv2.imshow('Edges', edges) cv2.waitKey(0) cv2.destroyAllWindows() ``` 以上是使用OpenCV进行边缘提取的基本步骤。你可以根据具体需求调整参数和选择不同的边缘检测算法。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

梦想橡皮擦

如有帮助,来瓶可乐

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值