我用 python 编写了一个关于颜色检测的程序。但“Erode”句子周围总是存在错误。这是我的程序的一部分。谢谢。
# Convert the image to a Numpy array since most cv2 functions
# require Numpy arrays.
frame = np.array(frame, dtype=np.uint8)
threshold = 0.05
#blur the image
frame=cv2.blur(frame, (5,5))
#Convert from BGR to HSV
hsv = cv2.cvtColor(frame, cv2.COLOR_BGR2HSV)
#split into 3
h, s, v= cv2.split(hsv)
#red color
s = cv2.threshold(h, 15, 1, cv2.THRESH_BINARY_INV)#1-15,x>15 y=0
h = cv2.threshold(h, 245, 1, cv2.THRESH_BINARY)#245-255 x>245 y=1
h = h + s
kernel = cv2.getStructuringElement(cv2.MORPH_RECT,(3, 3))
h = cv2.erode(h, kernel)
v = cv2.sumElems(h)
Try:
_,h = cv2.threshold(h, 245, 1, cv2.THRESH_BINARY) #245-255 x>245 y=1
_,s = cv2.threshold(h, 15, 1, cv2.THRESH_BINARY_INV) #1-15,x>15 y=0
cv2.threshold
返回两个值:http://docs.opencv.org/modules/imgproc/doc/miscellaneous_transformations.html#cv2.threshold http://docs.opencv.org/modules/imgproc/doc/miscellaneous_transformations.html#cv2.threshold
cv2.threshold(src, thresh, maxval, type[ dst]) → retval, dst
你错过了第二个值dst
,在表达式中省略它,你只会得到retval
不是图像的值。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)