租用问题

质量为本、客户为根、勇于拼搏、务实创新

< 返回租用问题列表

如何使用OpenCV检测图像中的圆形,opencv chm

发布时间:2024-05-22 16:21:15

如何使用OpenCV检测图象中的圆形

要使用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官方文档。