要使用OpenCV检测图像中的圆形,可以使用Hough Circle Transform算法。以下是一个简单的例子,演示如何在图像中检测圆形:
import cv2 import numpy as np # 读取图像 image = cv2.imread('circle.jpg') gray = cv2.cvtColor(image, cv2.COLOR_BGR2GRAY) # 高斯滤波 gray_blurred = cv2.GaussianBlur(gray, (9, 9), 0) # 使用Hough Circle Transform检测圆形 circles = cv2.HoughCircles(gray_blurred, cv2.HOUGH_GRADIENT, dp=1, minDist=20, param1=50, param2=30, minRadius=0, maxRadius=0) if circles is not None: circles = np.uint16(np.around(circles)) for i in circles[0, :]: # 绘制圆形边界 cv2.circle(image, (i[0], i[1]), i[2], (0, 255, 0), 2) # 绘制圆心 cv2.circle(image, (i[0], i[1]), 2, (0, 0, 255), 3) # 显示结果 cv2.imshow('Detected Circles', image) cv2.waitKey(0) cv2.destroyAllWindows()
在上面的代码中,首先读取图像并将其转换为灰度图像。然后,对灰度图像进行高斯模糊处理。接下来,使用cv2.HoughCircles()
函数检测图像中的圆形。最后,遍历检测到的圆形,并用绿色圆圈绘制圆形的边界,用红色点绘制圆心。
注意:在使用Hough Circle Transform算法时,需要调整函数的参数以获得最佳效果,具体参数的意义可以参考OpenCV官方文档。