从cv2.findContours得出的所有轮廓中找出圆形轮廓
时间: 2024-04-26 17:19:20 浏览: 116
opencv 找图像的轮廓
4星 · 用户满意度95%
从cv2.findContours得出的所有轮廓中找出圆形轮廓的方法如下:
1. 首先,使用cv2.findContours函数找到图像中的所有轮廓。该函数返回一个包含所有轮廓的列表。
2. 遍历轮廓列表,对于每个轮廓,可以使用cv2.approxPolyDP函数对其进行多边形逼近,以减少轮廓的点数。
3. 对于逼近后的轮廓,可以使用cv2.minEnclosingCircle函数找到其外接圆。该函数返回圆心坐标和半径。
4. 判断外接圆的半径是否在一定范围内,以确定是否为圆形轮廓。可以根据应用需求设置合适的半径范围。
以下是示例代码:
```
import cv2
# 读取图像
image = cv2.imread('image.jpg')
# 转换为灰度图像
gray = cv2.cvtColor(image, cv2.COLOR_BGR2GRAY)
# 二值化处理
ret, thresh = cv2.threshold(gray, 127, 255, cv2.THRESH_BINARY)
# 寻找轮廓
contours, hierarchy = cv2.findContours(thresh, cv2.RETR_EXTERNAL, cv2.CHAIN_APPROX_SIMPLE)
# 遍历轮廓
for contour in contours:
# 多边形逼近
approx = cv2.approxPolyDP(contour, 0.01 * cv2.arcLength(contour, True), True)
# 外接圆
(x, y), radius = cv2.minEnclosingCircle(approx)
# 判断是否为圆形轮廓
if radius > 10 and radius < 100:
cv2.circle(image, (int(x), int(y)), int(radius), (0, 255, 0), 2)
# 显示结果
cv2.imshow('Circle Contours', image)
cv2.waitKey(0)
cv2.destroyAllWindows()
```
阅读全文