目标:在OpenCV中找到球
问题:我有一个用hsv边界获得的口罩,但是我的口罩有些渗入背景。如何从不需要的背景中分割出想要的圆? 我怀疑问题是我正在使用minEnclosingCircle,但我不知道该用什么
我尝试腐蚀面具以分隔圆圈,但这对我没有多大帮助
面具
结果圈子
def draw_circle(orig,mask,name):
cnts=cv2.findContours(mask.copy(),cv2.RETR_EXTERNAL,cv2.CHAIN_APPROX_SIMPLE)
cnts=imutils.grab_contours(cnts)
center=None
if len(cnts)>0:
c=max(cnts,key=cv2.contourArea)
((x,y),radius)=cv2.minEnclosingCircle(c)
M=cv2.moments(c)
center = (int(M["m10"] / M["m00"]), int(M["m01"] / M["m00"]))
if radius > 10:
cv2.circle(orig, (int(x), int(y)), int(radius),
(0, 255, 255), 2)
cv2.circle(orig, center, 5, (0, 0, 255), -1)
#d=int(name.split(".JPG")[0])
#expected_R=(231*1.6)/(2*d)
#error=1.0-(radius/expected_R)
#print "error is "+str(error)
else:
print "oops"
cv2.imshow(str(name)+" circled",orig)
cv2.imshow(str(name)+" mask",mask)
cv2.waitKey(0)