ICode9

精准搜索请尝试: 精确搜索
首页 > 编程语言> 文章详细

python识别图片的圆形_详解利用python+opencv识别图片中的圆形

2021-08-05 02:31:40  阅读:212  来源: 互联网

标签:plt img python 累加器 cv2 圆形 检测 识别 255


在图片中识别足球

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

dp,用来检测圆心的累加器图像的分辨率于输入图像之比的倒数,且此参数允许创建一个比输入图像分辨率低的累加器。上述文字不好理解的话,来看例子吧。例如,如果dp= 1时,累加器和输入图像具有相同的分辨率。如果dp=2,累加器便有输入图像一半那么大的宽度和高度。

minDist,为霍夫变换检测到的圆的圆心之间的最小距离,即让我们的算法能明显区分的两个不同圆之间的最小距离。这个参数如果太小的话,多个相邻的圆可能被错误地检测成了一个重合的圆。反之,这个参数设置太大的话,某些圆就不能被检测出来了。

param1,有默认值100。它是method设置的检测方法的对应的参数。对当前唯一的方法霍夫梯度法,它表示传递给canny边缘检测算子的高阈值,而低阈值为高阈值的一半。

param2,也有默认值100。它是method设置的检测方法的对应的参数。对当前唯一的方法霍夫梯度法,它表示在检测阶段圆心的累加器阈值。它越小的话,就可以检测到更多根本不存在的圆,而它越大的话,能通过检测的圆就更加接近完美的圆形了。

minRadius,默认值0,表示圆半径的最小值。

maxRadius,也有默认值0,表示圆半径的最大值。

源代码:

# -*- coding: utf-8 -*-

"""

Created on Tue Sep 26 23:15:39 2017

@author: tina

"""

import cv2

import numpy as np

import matplotlib.pyplot as plt

img = cv2.imread('C:\\Users\\tina\\Pictures\\ahh\\ball.jpg')

gray = cv2.cvtColor(img,cv2.COLOR_BGR2GRAY)

plt.subplot(121),plt.imshow(gray,'gray')

plt.xticks([]),plt.yticks([])

circles1 = cv2.HoughCircles(gray,cv2.HOUGH_GRADIENT,1,

600,param1=100,param2=30,minRadius=80,maxRadius=97)

circles = circles1[0,:,:]

circles = np.uint16(np.around(circles))

for i in circles[:]:

cv2.circle(img,(i[0],i[1]),i[2],(255,0,0),5)

cv2.circle(img,(i[0],i[1]),2,(255,0,255),10)

cv2.rectangle(img,(i[0]-i[2],i[1]+i[2]),(i[0]+i[2],i[1]-i[2]),(255,255,0),5)

print("圆心坐标",i[0],i[1])

plt.subplot(122),plt.imshow(img)

plt.xticks([]),plt.yticks([])

标签:plt,img,python,累加器,cv2,圆形,检测,识别,255
来源: https://www.cnblogs.com/xushenghai19841013/p/15101496.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有