cv2.findContours的例子
时间: 2023-07-22 15:59:45 浏览: 82
当使用OpenCV中的cv2.findContours函数时,可以通过以下代码示例来查找图像中的轮廓:
```python
import cv2
# 读取图像
image = cv2.imread('image.jpg')
# 将图像转换为灰度
gray = cv2.cvtColor(image, cv2.COLOR_BGR2GRAY)
# 对图像进行阈值处理
_, threshold = cv2.threshold(gray, 127, 255, cv2.THRESH_BINARY)
# 查找轮廓
contours, _ = cv2.findContours(threshold, cv2.RETR_EXTERNAL, cv2.CHAIN_APPROX_SIMPLE)
# 在原始图像上绘制轮廓
cv2.drawContours(image, contours, -1, (0, 255, 0), 2)
# 显示结果
cv2.imshow('Contours', image)
cv2.waitKey(0)
cv2.destroyAllWindows()
```
在这个例子中,我们首先读取了一张图像,并将其转换为灰度图像。然后,我们对灰度图像进行阈值处理,将其转换为二值图像。接下来,使用cv2.findContours函数查找二值图像中的轮廓。函数的第一个参数是二值图像,第二个参数指定轮廓的检索模式,第三个参数指定轮廓的近似方法。函数返回轮廓集合和层次结构。最后,我们使用cv2.drawContours函数在原始图像上绘制轮廓,并显示结果。
请注意,这只是一个简单的示例,假设你已经在同一目录下有一张名为"image.jpg"的图像文件。你可以根据自己的需求修改代码来适应不同的图像和轮廓处理任务。
阅读全文