opencv(33) 图像轮廓之二:轮廓的面积和长度

1 cv2.contourArea() 轮廓面积

函数原型:

retval = contourArea (contour, oriented)

参数:

  1. contour 轮廓。
  2. oriented 布尔值,当为True时,表示顺时针或逆时针计算。

2 cv2.arcLength() 轮廓长度

函数原型:

retval = cv2.arcLength (contour, closed)

参数:

  1. contour 轮廓。
  2. closed 布尔值,当为True时,表示闭合。

3 示例

import cv2
import numpy as np


img = cv2.imread('C:\\Users\\xxx\\Downloads\\contourImg.png')    #读取图像
gray = cv2.cvtColor(img,cv2.COLOR_BGR2GRAY) #转为灰度值图
ret, binary = cv2.threshold(gray,220,255,cv2.THRESH_BINARY) #转为二值图
contours, hierarchy = cv2.findContours(binary,cv2.RETR_TREE,\
                                       cv2.CHAIN_APPROX_NONE) #寻找轮廓
n=len(contours)       #轮廓个数
contoursImg=[]
cv2.imshow("original",img)  #显示原图

#### 逐一在全黑背景上绘制并显示轮廓
for i in range(n):
    area = cv2.contourArea(contours[i])      # 计算轮廓面积
    length = cv2.arcLength(contours[i],True) # 计算轮廓长度
    temp = np.zeros(img.shape, np.uint8)  # 生成黑背景
    contoursImg.append(temp)
    contoursImg[i] = cv2.drawContours(contoursImg[i], contours, i, (0, 255, 0), 3)  # 绘制轮廓
    cv2.imshow("contours[" + str(i) + "]", contoursImg[i])#显示轮廓
    print(f"轮廓{i}的面积:{area}, 长度:{length};")
cv2.waitKey()
cv2.destroyAllWindows()

轮廓0的面积:47722.5, 长度:826.080295920372;
轮廓1的面积:12979.5, 长度:583.2619735002518;
轮廓2的面积:37884.0, 长度:790.0;

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
根据提供的引用内容,我可以告诉您关于OpenCV图像轮廓的一些信息。 在OpenCV中,图像轮廓是指图像中所有连续的边界点的集合。通过分析图像中的边缘,可以获取到物体的形状和边界信息。您可以使用不同的函数和方法来处理和计算图像轮廓轮廓近似是指根据指定的精度,将轮廓的形状近似为顶点数量较少的其他形状。可以使用函数cv.approxPolyDP()来进行轮廓近似操作。该函数的参数包括输入轮廓、精度和是否闭合等参数。通过调整精度来控制近似的程度。 轮廓面积是指轮廓所包围区域的面积大小。在OpenCV中,可以使用函数cv.contourArea()或者通过轮廓的矩moments计算得到。前者直接计算轮廓面积,后者通过计算轮廓的矩来获取面积轮廓的周长是指轮廓的边界上所有的像素点的总长度。可以使用函数cv.arcLength()来计算轮廓的周长。 如果想要在图像上绘制轮廓,可以使用函数cv.drawContours()。该函数的参数包括图像、轮廓轮廓的索引、颜色和厚度等。通过设置轮廓的索引为-1,可以绘制所有的轮廓。 希望以上信息对您有所帮助。如果您还有其他问题,请随时提问。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [Opencv轮廓](https://blog.csdn.net/weixin_44575152/article/details/115332445)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值