1
我有一张白纸作为背景的图片,我需要去除噪点(黄点)并获得像素值(bgr)叶。检测一个物体并得到平均像素值(BGR)
我用绿色阈值来检测叶子并用原始图像掩盖它。我使用cv2.mean来获取像素值,但它计算所有像素包括黑色区域/背景。
如何获得只为叶的像素值? 这里是我使用的代码:
import cv2
import numpy as np
img=cv2.imread('crop21.jpg')
blur=cv2.GaussianBlur(img,(5,5),0)
hsv=cv2.cvtColor(blur,cv2.COLOR_BGR2HSV)
#threshold green
low_g=np.array([35,100,60],np.uint8)
up_g=np.array([85,255,190],np.uint8)
mask=cv2.inRange(hsv,low_g,up_g)
mask_upstate=cv2.bitwise_and(blur, blur, mask=mask)
#get the bgr value
mean=cv2.mean(mask_upstate)
print (mean)
cv2.imshow('image',mask_upstate)
cv2.waitKey(0)
cv2.destroyAllWindows()
我在函数cv :: countNonZero中遇到错误cn == 1。如何解决它? – gygem
使用te mask,而不是mask_upstate,因为mask是一个二进制图像,并且乘法器计算给出了相同的结果。刚刚编辑! – ebeneditos
哦,它的工作....非常感谢 – gygem