opencv-python常用函数解析及参数介绍(八)——轮廓与轮廓特征
创始人
2024-05-05 00:04:09
0

轮廓与轮廓特征

  • 前言
  • 1.获取轮廓
    • 通过膨胀与腐蚀获得轮廓
    • 通过梯度获取轮廓
    • 通过边缘检测获取轮廓
  • 2.寻找轮廓
    • 参数及作用对比
  • 3.轮廓特征


前言

在前面的文章中我们已经学会了使用膨胀与腐蚀、使用梯度、使用边缘检测的方式获得图像的轮廓,那么在获得轮廓后我们可以对图像进行什么样的操作呢?本文将介绍轮廓的绘制与轮廓特征的使用

1.获取轮廓

假设我们现在有这样一张名为feng.jpg的图片
在这里插入图片描述

同样为了表述方便,我们要先定义一个图像显示函数

def cv_show(img,name):cv2.imshow(name,img)cv2.waitKey()cv2.destroyAllWindows()

通过膨胀与腐蚀获得轮廓

在之前的博客:opencv-python常用函数解析及参数介绍(五)——腐蚀与膨胀中我们学到了三种获取轮廓的方式,大家可以查阅之前的博客获取细节,在本文中我们将使用膨胀减去腐蚀获取轮廓

img = cv2.imread('feng.jpg')
gray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)
ret, thresh = cv2.threshold(gray, 230, 255, cv2.THRESH_BINARY)
kernel = np.ones((5,5),np.uint8) 
dilate = cv2.dilate(thresh, kernel, 1)
erosion = cv2.erode(thresh, kernel, 1)
contour_img = dilate-erosion # 获取轮廓
cv_show(contour_img, 'c')

在这里插入图片描述

通过梯度获取轮廓

本文使用效果最好的Sobel算子获取轮廓,其他的梯度计算方式请参考:opencv-python常用函数解析及参数介绍(六)——图像梯度

img = cv2.imread('feng.jpg')
gray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)
ret, thresh = cv2.threshold(gray, 230, 255, cv2.THRESH_BINARY)# 获取轮廓
contour_x = cv2.Sobel(thresh, cv2.CV_64F, 1, 0, ksize=3) 
contour_x = cv2.convertScaleAbs(contour_x)
contour_y = cv2.Sobel(thresh, cv2.CV_64F, 0, 1, ksize=3)
contour_y = cv2.convertScaleAbs(contour_y)
contour_img = cv2.addWeighted(contour_x, 0.5, contour_y, 0.5, 0)
cv_show(contour_img, 'c')

在这里插入图片描述

通过边缘检测获取轮廓

边缘检测的细节请参照:opencv-python常用函数解析及参数介绍(七)——边缘检测

img = cv2.imread('feng.jpg')
gray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)
ret, thresh = cv2.threshold(gray, 230, 255, cv2.THRESH_BINARY)# 获取轮廓
contour_img = cv2.Canny(img, 200, 250)
cv_show(contour_img, 'c')

在这里插入图片描述

2.寻找轮廓

下面我们使用效果最好的边缘检测得到的结果寻找轮廓

我们留意到,这个符号由多个图形组成,我们可以使用cv2.findContours函数找到每一部分的轮廓
findContours的参数为(图像,mode, method)

其中mode为轮廓检索模式,参数和作用如下

参数作用
RETR_EXTERNAL只检索最外面的轮廓;
RETR_LIST检索所有的轮廓,并将其保存到一条链表当中;
RETR_CCOMP检索所有的轮廓,并将他们组织为两层:顶层是各部分的外部边界,第二层是空洞的边界;
RETR_TREE检索所有的轮廓,并重构嵌套轮廓的整个层次

其中method为轮廓逼近方法,参数和作用如下

参数作用
CHAIN_APPROX_NONE以Freeman链码的方式输出轮廓,所有其他方法输出多边形(顶点的序列)。
CHAIN_APPROX_SIMPLE压缩水平的、垂直的和斜的部分,也就是,函数只保留他们的终点部分。

我们可以使用cv2.drawContours函数画出轮廓,其参数有(轮廓,轮廓索引,颜色模式,线条厚度)
轮廓索引是只第几个轮廓,当为-1时则画出所有轮廓,需要注意的是在绘制前需要先copy一份原图,否则原图也会被画上轮廓

参数及作用对比

这个过程只是为了方便展示效果,如果不理解不必强求

import mathfor retr in ["cv2.RETR_EXTERNAL", "cv2.RETR_LIST", "cv2.RETR_CCOMP", "cv2.RETR_TREE"]:print(retr)contours, hierarchy = cv2.findContours(contour_img, eval(retr), cv2.CHAIN_APPROX_NONE)r_list = imgrow = int(math.sqrt(len(contours) + 2))col = math.ceil((len(contours) + 2) / row)+1plt.subplot(row,col, 1)plt.imshow(cv2.cvtColor(img, cv2.COLOR_BGR2RGB))plt.xticks([]), plt.yticks([])plt.title('origin')for i in range(len(contours)):res = cv2.drawContours(img.copy(), contours, i, (0, 0, 255), 2)plt.subplot(row, col, 2+i)plt.imshow(cv2.cvtColor(res, cv2.COLOR_BGR2RGB))plt.xticks([]), plt.yticks([])plt.title(str(i+1))plt.subplot(row, col, len(contours)+2)plt.imshow(cv2.cvtColor(cv2.drawContours(img.copy(), contours, -1, (0, 0, 255), 2), cv2.COLOR_BGR2RGB))plt.xticks([]), plt.yticks([])plt.title('all')plt.show()

在这里插入图片描述

可以看到除了第一个之外其他的效果相似,其实确实是这样的,其他的只不过是层次不一样,而第一个只取了外轮廓,所以看起来要比其他的轮廓少。
第二个参数只不过是存储方式不同,从描述上来看,一个适用于曲线较多的情况,另外一个适用于直线较多的情况。
同时我们还看到,这些图里面似乎有一些没什么变化的图,这是因为图中有噪点,所以有的点被误判成了轮廓,要去掉这种情况的点我们只需要求一下轮廓特征就好了,比如规定轮廓面积小于某个值就不算做轮廓或者周长小于某个值就不算做轮廓。

3.轮廓特征

在opencv中我们通过cv2.contourArea求面积,通过cv2.contourLength求周长,如果contoursLength第二个参数为True则求的周长为闭区间
我们来求一下第一个区间的面积和周长

contours, hierarchy=cv2.findContours(contour_img,cv2.RETR_TREE,cv2.CHAIN_APPROX_NONE)
res = cv2.drawContours(img.copy(), contours, 0, (0, 0, 255), 2)
cv_show(res,'res')
print(cv2.contourArea(contours[0]))
print(cv2.arcLength(contours[0], True))

在这里插入图片描述
在这里插入图片描述
下面看一下所有的面积和周长

contours, hierarchy=cv2.findContours(contour_img,cv2.RETR_TREE,cv2.CHAIN_APPROX_NONE)
for i in range(len(contours)):print(cv2.contourArea(contours[i]), cv2.arcLength(contours[i], True))

在这里插入图片描述
值为0的就是那些被误判成轮廓的点

相关内容

热门资讯

安卓系统自带的网页,功能与特色... 你有没有发现,每次打开安卓手机,那熟悉的系统界面里总有一个默默无闻的小家伙——安卓系统自带的网页浏览...
美咖云系统安卓版,开启智能生活... 你有没有发现,最近手机上多了一个叫“美咖云系统安卓版”的小家伙?它就像一个魔法师,轻轻一点,就能让你...
安卓系统推荐最好的手机,盘点性... 你有没有想过,拥有一部性能卓越的手机,就像是拥有了移动的宝藏库?在这个信息爆炸的时代,一部好手机不仅...
安卓11系统能精简吗,释放潜能 你有没有发现,随着手机越来越智能,系统也越来越庞大?安卓11系统,这个最新的操作系统,是不是也让你觉...
安卓自动重启系统软件,揭秘原因... 手机突然自动重启,是不是感觉整个人都不好了?别急,今天就来和你聊聊这个让人头疼的安卓自动重启系统软件...
苹果手机x刷安卓系统,探索安卓... 你有没有想过,你的苹果手机X竟然也能刷上安卓系统?是的,你没听错,就是那个一直以来都和我们苹果手机X...
安卓系统智商低吗,智商低下的真... 你有没有想过,为什么安卓系统的智商总被调侃得好像有点低呢?是不是觉得它总是慢吞吞的,有时候还犯点小错...
安卓系统手机联系人,揭秘你的社... 你有没有发现,手机里的联系人列表就像是一个小小的社交圈呢?里面藏着我们的亲朋好友、工作伙伴,甚至还有...
安卓系统免费铃声下载,打造个性... 手机里那首老掉牙的铃声是不是让你觉得有点out了呢?别急,今天就来给你支个招,让你轻松给安卓手机换上...
安卓系统用哪个桌面好,打造个性... 你有没有发现,手机桌面可是我们每天都要面对的“脸面”呢?换一个好看的桌面,心情都能跟着好起来。那么,...
虚拟大师是安卓10系统,功能与... 你知道吗?最近在手机圈里,有个新玩意儿引起了不小的轰动,那就是虚拟大师!而且,更让人惊喜的是,这个虚...
安卓系统与苹果优缺点,系统优缺... 说到手机操作系统,安卓和苹果绝对是两大巨头,它们各有各的特色,就像两道不同的美味佳肴,让人难以抉择。...
安卓win双系统主板,融合与创... 你有没有想过,一台电脑如果既能流畅运行安卓系统,又能轻松驾驭Windows系统,那该有多爽啊?没错,...
安卓系统可精简软件,轻松提升手... 你有没有发现,手机里的安卓系统越来越庞大,软件也越装越多,有时候感觉手机就像个“大肚子”,不仅运行速...
安卓系统基于linux的代码,... 你有没有想过,那个陪伴你每天刷抖音、玩游戏、办公的安卓系统,其实背后有着一套复杂的基于Linux的代...
苹果和安卓的拍照系统,谁更胜一... 你有没有发现,现在手机拍照已经成为我们生活中不可或缺的一部分呢?无论是记录生活的点滴,还是捕捉美丽的...
苹果和安卓系统不同吗,系统差异... 你有没有想过,为什么你的手机里装的是苹果的iOS系统,而朋友的手机却是安卓系统呢?这两种系统,看似都...
安卓系统有多少级,揭秘其多级架... 你有没有想过,那个陪伴我们日常生活的安卓系统,它其实有着丰富的层级结构呢?没错,就是那个让我们的手机...
华为鸿蒙系统与安卓的,技术融合... 你知道吗?最近科技圈可是炸开了锅,华为鸿蒙系统与安卓的较量成为了大家热议的话题。这不,今天我就来给你...
什么安卓手机是苹果系统,搭载苹... 你有没有想过,为什么有些人宁愿花大价钱买苹果手机,而有些人却对安卓手机情有独钟呢?其实,这个问题背后...