检测物体并获得平均像素值(BGR)

时间:2016-12-29 10:25:39

标签: python opencv image-processing

我有一张白纸作为背景的叶子图片,我需要去除噪点(黄点)并获得叶子的像素值(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()

1 个答案:

答案 0 :(得分:0)

所以基本上你有一张带有叶子和黑色背景的蒙面图像。现在的问题是,它将颜色之和除以所有像素的数量,而不是仅将其除以具有叶子的像素数量。解决此问题的一种简单快捷方法是将mean = cv2.mean(mask_upstate)的结果乘以Total pixels / Non-black pixels,其结果如下:

# Get the BGR value
mean = cv2.mean(mask_upstate)
multiplier = float(mask.size)/cv2.countNonZero(mask)
mean = tuple([multiplier * x for x in mean])

因此,你只有非黑色像素的平均值,没有黑色背景的叶子。

希望这有帮助!