import cv2
import numpy as np
cap = cv2.VideoCapture(0)
while(True):
ret, frame=cap.read()
gray_img = cv2.cvtColor(frame, cv2.COLOR_BGR2GRAY)
img = cv2.medianBlur(gray_img, 5)
circles = cv2.HoughCircles(img,cv2.cv.CV_HOUGH_GRADIENT,
1,410,param1=100,param2=30,minRadius=15,maxRadius=25)
circles = np.uint16(np.around(circles))
for i in circles[0,:]:
cv2.circle(frame,(i[0],i[1]),i[2],(0,255,0),2)
cv2.circle(frame,(i[0],i[1]),2,(0,0,255),3)
cv2.imshow("HoughCirlces", frame)
if cv2.waitKey(97) == ord('a'):
break
cv2.destroyAllWindows()
cap.release()
으아아아
minRadius 및 maxRadius 제한은 너무 가혹합니다. 원이 캡처되지 않으면 원은 비어 있게 되며 후속 작업으로 인해 오류가 발생합니다.
minRadius=0, maxRadius=0으로 변경