0


cv2.contourArea函数详解

问题:cv2.findContours找到所有的轮廓之后,想取出包含面积最大的轮廓,用cv2.contourArea算一下,但是得到的结果跟实际差别相当大,最大轮廓面积的计算成很小的一个值,而其中一个不太起眼的区域被计算得倒最大的面积。

findContours() 提取轮廓, contourArea() 计算轮廓面积。

ContourArea计算轮廓的面积使用格林公式。格林公式是什么?这不重要。ContourArea()求得得面积居然比真实面积还要小。这又是怎么回事呢?

重点

原来ContourArea()是取连通域边界像素中心点,连接起来,成为一个轮廓,导致一周得边界像素点丢失,即求得得面积比真实得面积少了一圈。

比如下图,真实面积44=16,而ContourArea()则只是算红线内得面积,只有33=9。

因此,countArea() 函数也会 ”有中去无“,视而不见,算出来的轮廓面积会出现0。

有轮廓,但是面积为0。

比如有的轮廓厚度只有两像素,都是边缘线,那计算出来的面积就等于0。

参考:AI大道理

整理不易,欢迎一键三连!!!


本文转载自: https://blog.csdn.net/qq_38308388/article/details/129280461
版权归原作者 zy_destiny 所有, 如有侵权,请联系我们删除。

“cv2.contourArea函数详解”的评论:

还没有评论