Merge pull request #6812 from aleksandaratanasov:master

This commit is contained in:
Vadim Pisarevsky 2016-07-19 17:21:09 +00:00
commit abbc988fb5
2 changed files with 21 additions and 16 deletions

View File

@ -29,11 +29,14 @@ if __name__ == '__main__':
cimg = src.copy() # numpy function cimg = src.copy() # numpy function
circles = cv2.HoughCircles(img, cv2.HOUGH_GRADIENT, 1, 10, np.array([]), 100, 30, 1, 30) circles = cv2.HoughCircles(img, cv2.HOUGH_GRADIENT, 1, 10, np.array([]), 100, 30, 1, 30)
a, b, c = circles.shape
for i in range(b): if circles != None: # Check if circles have been found and only then iterate over these and add them to the image
cv2.circle(cimg, (circles[0][i][0], circles[0][i][1]), circles[0][i][2], (0, 0, 255), 3, cv2.LINE_AA) a, b, c = circles.shape
cv2.circle(cimg, (circles[0][i][0], circles[0][i][1]), 2, (0, 255, 0), 3, cv2.LINE_AA) # draw center of circle for i in range(b):
cv2.circle(cimg, (circles[0][i][0], circles[0][i][1]), circles[0][i][2], (0, 0, 255), 3, cv2.LINE_AA)
cv2.circle(cimg, (circles[0][i][0], circles[0][i][1]), 2, (0, 255, 0), 3, cv2.LINE_AA) # draw center of circle
cv2.imshow("detected circles", cimg)
cv2.imshow("source", src) cv2.imshow("source", src)
cv2.imshow("detected circles", cimg)
cv2.waitKey(0) cv2.waitKey(0)

View File

@ -36,17 +36,19 @@ if __name__ == '__main__':
else: # HoughLines else: # HoughLines
lines = cv2.HoughLines(dst, 1, math.pi/180.0, 50, np.array([]), 0, 0) lines = cv2.HoughLines(dst, 1, math.pi/180.0, 50, np.array([]), 0, 0)
a,b,c = lines.shape if lines != None:
for i in range(a): a,b,c = lines.shape
rho = lines[i][0][0] for i in range(a):
theta = lines[i][0][1] rho = lines[i][0][0]
a = math.cos(theta) theta = lines[i][0][1]
b = math.sin(theta) a = math.cos(theta)
x0, y0 = a*rho, b*rho b = math.sin(theta)
pt1 = ( int(x0+1000*(-b)), int(y0+1000*(a)) ) x0, y0 = a*rho, b*rho
pt2 = ( int(x0-1000*(-b)), int(y0-1000*(a)) ) pt1 = ( int(x0+1000*(-b)), int(y0+1000*(a)) )
cv2.line(cdst, pt1, pt2, (0, 0, 255), 3, cv2.LINE_AA) pt2 = ( int(x0-1000*(-b)), int(y0-1000*(a)) )
cv2.line(cdst, pt1, pt2, (0, 0, 255), 3, cv2.LINE_AA)
cv2.imshow("detected lines", cdst)
cv2.imshow("source", src) cv2.imshow("source", src)
cv2.imshow("detected lines", cdst)
cv2.waitKey(0) cv2.waitKey(0)