cv2.contourArea函数详解
时间:2024-04-09 20:50:45 来源:网络cs 作者:利杜鹃 栏目:卖家故事 阅读:
问题:cv2.findContours找到所有的轮廓之后,想取出包含面积最大的轮廓,用cv2.contourArea算一下,但是得到的结果跟实际差别相当大,最大轮廓面积的计算成很小的一个值,而其中一个不太起眼的区域被计算得倒最大的面积。
findContours() 提取轮廓, contourArea() 计算轮廓面积。
ContourArea计算轮廓的面积使用格林公式。格林公式是什么?这不重要。ContourArea()求得得面积居然比真实面积还要小。这又是怎么回事呢?
重点
原来ContourArea()是取连通域边界像素中心点,连接起来,成为一个轮廓,导致一周得边界像素点丢失,即求得得面积比真实得面积少了一圈。
比如下图,真实面积4*4=16,而ContourArea()则只是算红线内得面积,只有3*3=9。
因此,countArea() 函数也会 ”有中去无“,视而不见,算出来的轮廓面积会出现0。
有轮廓,但是面积为0。
比如有的轮廓厚度只有两像素,都是边缘线,那计算出来的面积就等于0。
参考:AI大道理
整理不易,欢迎一键三连!!!
阅读本书更多章节>>>>本文链接:https://www.kjpai.cn/gushi/2024-04-09/156261.html,文章来源:网络cs,作者:利杜鹃,版权归作者所有,如需转载请注明来源和作者,否则将追究法律责任!
上一篇:SCUM私人服务器搭建部署教程
下一篇:返回列表