cv2.findContours获取最大轮廓
时间: 2023-11-23 11:56:29 浏览: 87
以下是使用cv2.findContours获取最大轮廓的Python代码示例:
```python
import cv2
# 读取图像并转换为灰度图像
img = cv2.imread('test.jpg')
gray = cv2.cvtColor(img, 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)
# 找到最大轮廓
max_contour = max(contours, key=cv2.contourArea)
# 绘制最大轮廓
cv2.drawContours(img, [max_contour], -1, (0, 0, 255), 2)
# 显示结果
cv2.imshow('image', img)
cv2.waitKey(0)
cv2.destroyAllWindows()
```
其中,cv2.findContours函数用于查找轮廓,第一个参数是二值化后的图像,第二个参数是轮廓检索模式,第三个参数是轮廓近似方法。在这个例子中,我们使用cv2.RETR_EXTERNAL模式查找外部轮廓,使用cv2.CHAIN_APPROX_SIMPLE方法压缩水平、垂直和对角线方向的轮廓,并只保留端点。然后,我们使用max函数找到最大轮廓,使用cv2.drawContours函数绘制最大轮廓。
阅读全文