利用python+opencv识别图片中的圆形(霍夫变换)

在图片中识别足球

先补充下霍夫圆变换的几个参数知识:

  • dp,用来检测圆心的累加器图像的分辨率于输入图像之比的倒数,且此参数允许创建一个比输入图像分辨率低的累加器。上述文字不好理解的话,来看例子吧。例如,如果dp= 1时,累加器和输入图像具有相同的分辨率。如果dp=2,累加器便有输入图像一半那么大的宽度和高度。
  • minDist,为霍夫变换检测到的圆的圆心之间的最小距离,即让我们的算法能明显区分的两个不同圆之间的最小距离。这个参数如果太小的话,多个相邻的圆可能被错误地检测成了一个重合的圆。反之,这个参数设置太大的话,某些圆就不能被检测出来了。
  • param1,有默认值100。它是method设置的检测方法的对应的参数。对当前唯一的方法霍夫梯度法,它表示传递给canny边缘检测算子的高阈值,而低阈值为高阈值的一半。
  • param2,也有默认值100。它是method设置的检测方法的对应的参数。对当前唯一的方法霍夫梯度法,它表示在检测阶段圆心的累加器阈值。它越小的话,就可以检测到更多根本不存在的圆,而它越大的话,能通过检测的圆就更加接近完美的圆形了。
  • minRadius,默认值0,表示圆半径的最小值。
  • maxRadius,也有默认值0,表示圆半径的最大值。


源代码:

[python] view plain copy
  1. # -*- coding: utf-8 -*-  
  2. """ 
  3. Created on Tue Sep 26 23:15:39 2017 
  4.  
  5. @author: tina 
  6. """  
  7. import cv2  
  8. import numpy as np  
  9. import matplotlib.pyplot as plt  
  10.   
  11. img = cv2.imread('C:\\Users\\tina\\Pictures\\ahh\\ball.jpg')  
  12. gray = cv2.cvtColor(img,cv2.COLOR_BGR2GRAY)  
  13.   
  14. plt.subplot(121),plt.imshow(gray,'gray')  
  15. plt.xticks([]),plt.yticks([])  
  16.   
  17. circles1 = cv2.HoughCircles(gray,cv2.HOUGH_GRADIENT,1,  
  18. 600,param1=100,param2=30,minRadius=80,maxRadius=97)  
  19. circles = circles1[0,:,:]  
  20. circles = np.uint16(np.around(circles))  
  21. for i in circles[:]:   
  22.     cv2.circle(img,(i[0],i[1]),i[2],(255,0,0),5)  
  23.     cv2.circle(img,(i[0],i[1]),2,(255,0,255),10)  
  24.     cv2.rectangle(img,(i[0]-i[2],i[1]+i[2]),(i[0]+i[2],i[1]-i[2]),(255,255,0),5)  
  25.       
  26. print("圆心坐标",i[0],i[1])  
  27. plt.subplot(122),plt.imshow(img)  
  28. plt.xticks([]),plt.yticks([])  
原图:


识别后效果:
  • 3
    点赞
  • 49
    收藏
    觉得还不错? 一键收藏
  • 8
    评论
好的,我了解了你的问题。关于利用 Python + OpenCV 识别图片圆形霍夫变换),我可以给你一些详细的解释和代码示例。 首先,我们需要导入 OpenCV 库和 NumPy 库。这里需要注意的是,需要安装正确的 OpenCV 版本,否则可能会出现一些问题。 ```python import cv2 import numpy as np ``` 接下来,我们需要读取图片并将其转换为灰度图像。然后,我们可以对灰度图像进行高斯模糊处理,以减少噪声。这里的高斯核大小可以根据实际情况进行调整。 ```python img = cv2.imread('image.jpg') gray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY) gray = cv2.GaussianBlur(gray, (5, 5), 0) ``` 接着,我们可以使用霍夫变换检测圆形。这里需要注意的是,需要设置最小半径和最大半径的范围,以及检测圆形的参数阈值。这些参数的设置也需要根据实际情况进行调整。 ```python circles = cv2.HoughCircles(gray, cv2.HOUGH_GRADIENT, 1, 100, param1=100, param2=30, minRadius=0, maxRadius=0) ``` 最后,我们可以将检测到的圆形标记出来,并显示图片。 ```python if circles is not None: circles = np.round(circles[0, :]).astype("int") for (x, y, r) in circles: cv2.circle(img, (x, y), r, (0, 255, 0), 2) cv2.imshow("Image", img) cv2.waitKey(0) ``` 完整代码如下: ```python import cv2 import numpy as np img = cv2.imread('image.jpg') gray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY) gray = cv2.GaussianBlur(gray, (5, 5), 0) circles = cv2.HoughCircles(gray, cv2.HOUGH_GRADIENT, 1, 100, param1=100, param2=30, minRadius=0, maxRadius=0) if circles is not None: circles = np.round(circles[0, :]).astype("int") for (x, y, r) in circles: cv2.circle(img, (x, y), r, (0, 255, 0), 2) cv2.imshow("Image", img) cv2.waitKey(0) ``` 希望这个代码示例能对你有所帮助!
评论 8
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值