作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我需要计算不对称形状的面积,如下图所示
此代码读取图像并将其转换为灰色并找到形状
我需要找出不对称形状的区域
import numpy as np
import cv2
# load the image, convert it to grayscale, and blur it slightly
image = cv2.imread("download.jpg")
gray = cv2.cvtColor(image, cv2.COLOR_BGR2GRAY)
gray = cv2.GaussianBlur(gray, (7, 7), 0)
# find contours in the edge map
cnts = cv2.findContours(gray.copy(), cv2.RETR_EXTERNAL,
cv2.CHAIN_APPROX_SIMPLE)
cv2.drawContours(image,cnts, 0, (255, 0, 0), 8)
cv2.imshow("Image", image)
cv2.waitKey(0)
最佳答案
我已经测试了您的代码,发现没有找到形状的轮廓。这是因为您在灰色图像中做了cv2.findContours
。该图像应该是二进制图像,因此我使用了cv2.threshold
。然后可以使用cv2.contourArea
计算面积。
下面是代码和结果。
import numpy as np
import cv2
image = cv2.imread("1.jpg")
gray = cv2.cvtColor(image, cv2.COLOR_BGR2GRAY)
gray = cv2.GaussianBlur(gray, (7, 7), 0)
_,thresh = cv2.threshold(gray,128,255,cv2.THRESH_BINARY_INV)
im, cnts, hier = cv2.findContours(thresh.copy(), cv2.RETR_EXTERNAL,cv2.CHAIN_APPROX_SIMPLE)
for cnt in cnts:
cv2.drawContours(image,cnts, -1, (0, 0, 255), 1)
print(cv2.contourArea(cnt))
cv2.imshow("thresh", thresh)
cv2.imshow("Image", image)
cv2.waitKey(0)
>> 8656.0
>> 3824.5
关于python - 如何使用opencv在python中计算不对称形状区域,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53985548/
我是一名优秀的程序员,十分优秀!