我需要对获得圆心颜色的代码进行第二次观察。由于某些不为人知的原因,它为每个离正确的中心返回接近相同的值。圈子的结果:
中心颜色:[126 126 126] 点 x:502 y:440
中心颜色 [124 124 124] 点 x:502 y:516
中心颜色 [133 133 133] 点 x:502 y:596
中心颜色 [116 116 116] 点 x:504 y:306
中心颜色 [119 119 119] 点 x:504 y:366
输入图像如下所示。显然应该有非常不同的值,因为黑色圆圈的平均 RBG 应该远低于 100 范围。
下图显示代码正在正确找到圆圈和圆圈的中心(标记为绿色)它只是没有找到正确的中心颜色值
下面的代码:
import cv2
import numpy as np
from math import sqrt
# Open
img = cv2.imread('test1.jpg',0)
# Process
img = cv2.medianBlur(img,5)
cimg = cv2.cvtColor(img,cv2.COLOR_GRAY2BGR)
# Find Interest
circles = cv2.HoughCircles(img,cv2.cv.CV_HOUGH_GRADIENT,1,20,
param1=50,param2=30,minRadius=1,maxRadius=20)
circles = np.uint16(np.around(circles))
# Post Process
for i in circles[0,:]:
# 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)
print "Center Colour"
print cimg[i[0], i[1]]
print "Point"
print "x: "+str(i[0]) + " y: " + str(i[1])
cv2.imwrite('output.png',cimg)