Python3与OpenCV3.3 图像处理(二十)--圆检测

 

这节同样是代码,代码比较简单,基本上都能看懂

 

 

import cv2 as cv
import numpy as np

def detect_circles(img):
    dst=cv.pyrMeanShiftFiltering(img,10,100)
    cimg=cv.cvtColor(dst,cv.COLOR_BGR2GRAY)
    circles=cv.HoughCircles(cimg,cv.HOUGH_GRADIENT,1,20,param1=50,param2=30,minRadius=0,maxRadius=0)
    circles=np.uint16(np.around(circles))
    for i in circles[0,:]:
        cv.circle(img,(i[0],i[1]),i[2],(0,0,255),2)
        cv.circle(img, (i[0], i[1]), 2, (255,0,0), 2)
    cv.imshow("c",img)

src=cv.imread('yx.jpg')
cv.imshow('def',src)
detect_circles(src)
cv.waitKey(0)
cv.destroyAllWindows()
觉得不错打赏一下
posted @ 2017-12-20 22:46  ProgramerCat  阅读(182)  评论(0编辑  收藏  举报