def detect_circles():
img = cv2.imread('img.JPG', 0)
#img = cv2.medianBlur(img, 3)
#cim= cv2.GaussianBlur(img, (15, 15), 0)
cimg = cv2.cvtColor(img, cv2.COLOR_GRAY2BGR)
circles = cv2.HoughCircles(img, cv2.cv.CV_HOUGH_GRADIENT, 1, 30,param1=100,param2=39,minRadius=25,maxRadius=70)
circles = np.uint16(np.around(circles))
count = 0
for i in circles[0, :]:
count = count + 1
# draw the outer circle
cv2.circle(cimg, (i[0], i[1]), i[2], (0, 255, 0), 2)
# draw the center of the circle
cv2.circle(cimg, (i[0], i[1]), 2, (0, 0, 255), 3)
cv2.imwrite('circles_detected.JPG', cimg)
print(count)
此函数用于检测图像中的圆。
它工作正常,但我需要区分颜色。
所以我写了一个函数,将每个像素的G和R值设置为0。在
^{pr2}$
当我尝试用蓝色像素图像检测圆圈时,我收到以下错误消息:Traceback