OpenCV轮廓形状匹配

这篇博客主要介绍了OpenCV中如何查找和绘制轮廓,包括不同类型的轮廓检索方法以及轮廓点的压缩方式。作者通过实例展示了如何筛选特定面积和长度的轮廓,并探讨了形状匹配的实现,如利用Hu特征进行形状匹配。此外,还详细讲解了轮廓的几何形状拟合,如矩形、最小包围矩形、圆形、椭圆和直线的拟合方法。
摘要由CSDN通过智能技术生成

案例来源于© Fu Xianjun. All Rights Reserved

目标:

  1. 能够掌握轮廓查找与绘制的方法
  2. 能够掌握轮廓面积及长度的计算方法
  3. 能够编程实现形状匹配
  4. 能够掌握轮廓的几何形状拟合方法

***— 查找轮廓

cv2.RETR_EXTERNAL 只检测外轮廓
cv2.RETR_LIST检测的轮廓不建立等级关系
cv2.RETR_CCOMP建立两个等级的轮廓
cv2.RETR_TREE建立一个等级树结构的轮廓
method:
cv2.CHAIN_APPROX_NONE存储所有的轮廓点
cv2.CHAIN_APPROX_SIMPLE压缩水平方向,垂直方向,对角线方向的元素,只保留该方向的终点坐标,例如一个矩形轮廓只需4个点来保存轮廓信息。

文章目录

img = cv2.imread("shape.jpg")
gray = cv2.cvtColor(img,cv2.COLOR_BGR2GRAY)
#-----------#阈值处理
ret,binary = cv2.threshold(gray,200,255,0)

#-----------#查找轮廓
contours,hierarchy = cv2.findContours(binary,cv2.RETR_LIST,\
                                     cv2.CHAIN_APPROX_SIMPLE)
img = cv2.drawContours(img,contours,-1,(255,255,0),5)
#计算图像的矩特征
retval = cv2.moments(contours[1])
print(retval["m00"])
area = cv2.contourArea(contours[1])
print(area)
cv2.imshow("img",img)
cv2.waitKey()
cv2.destroyAllWindows()

在这里插入图片描述

1.显示面积小于20000的轮廓

img = cv2.imread("shape.jpg")
gray = cv2.cvtColor(img,cv2.COLOR_BGR2GRAY)
#-----------#阈值处理
ret,binary = cv2.threshold(gray,200,255,0)

#-----------#查找轮廓
contours,hierarchy = cv2.findContours(binary,cv2.RETR_LIST,\
                                     cv2.CHAIN_APPROX_SIMPLE)

for i in range(len(contours)):
    area = cv2.contourArea(contours[i])
    if area<20000:
        img = cv2.drawContours(img,contours,i,(255
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值