前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >OpenCV 入门教程:寻找和绘制轮廓

OpenCV 入门教程:寻找和绘制轮廓

作者头像
小蓝枣
发布2023-07-10 16:10:34
5550
发布2023-07-10 16:10:34
举报
文章被收录于专栏:CSDN博客专家-小蓝枣的博客

OpenCV 入门教程:寻找和绘制轮廓

导语

寻找和绘制轮廓是图像处理中常用的技术之一,用于识别、定位和分析图像中的目标区域。在 OpenCV 中,寻找和绘制轮廓可以通过边缘检测和形态学操作实现。本文将以寻找和绘制轮廓为中心,为你介绍使用 OpenCV 进行轮廓处理的基本步骤和实例。

😃😄 ❤️ ❤️ ❤️

一、寻找轮廓

寻找轮廓是通过边缘检测和形态学操作,将图像中的目标区域边界提取出来。以下是一个使用寻找轮廓的示例代码:

代码语言:javascript
复制
import cv2

# 读取图像文件
image = cv2.imread('image.jpg')

# 将图像转换为灰度图像
gray_image = cv2.cvtColor(image, cv2.COLOR_BGR2GRAY)

# 进行边缘检测
edges = cv2.Canny(gray_image, 100, 200)

# 寻找轮廓
contours, _ = cv2.findContours(edges, cv2.RETR_EXTERNAL, cv2.CHAIN_APPROX_SIMPLE)

在上述示例中,我们首先将彩色图像转换为灰度图像,然后使用 Canny 函数进行边缘检测。接下来,使用 findContours 函数寻找图像中的轮廓。 RETR_EXTERNAL 参数表示只检测外部轮廓, CHAIN_APPROX_SIMPLE 参数表示简化轮廓的表示方式。

二、绘制轮廓

绘制轮廓是通过将寻找到的轮廓绘制在图像上,用于可视化和分析。以下是一个使用绘制轮廓的示例代码:

代码语言:javascript
复制
import cv2

# 读取图像文件
image = cv2.imread('image.jpg')

# 将图像转换为灰度图像
gray_image = cv2.cvtColor(image, cv2.COLOR_BGR2GRAY)

# 进行边缘检测
edges = cv2.Canny(gray_image, 100, 200)

# 寻找轮廓
contours, _ = cv2.findContours(edges, cv2.RETR_EXTERNAL, cv2.CHAIN_APPROX_SIMPLE)

# 绘制轮廓
cv2.drawContours(image, contours, -1, (0, 255, 0), 2)

在上述示例中,我们在原始图像上使用 drawContours 函数绘制寻找到的轮廓。 contours 参数是轮廓列表, -1 参数表示绘制所有轮廓, (0, 255, 0) 参数表示绘制轮廓的颜色, 2 参数表示绘制轮廓的线宽。

三、示例应用

现在,我们来看一些常见的示例应用,演示寻找和绘制轮廓的操作:

3.1 目标检测和定位

使用寻找和绘制轮廓可以实现目标检测和定位。以下是一个示例代码:

代码语言:javascript
复制
import cv2

# 读取图像文件
image = cv2.imread('image.jpg')

# 将图像转换为灰度图像
gray_image = cv2.cvtColor(image, cv2.COLOR_BGR2GRAY)

# 进行边缘检测
edges = cv2.Canny(gray_image, 100, 200)

# 寻找轮廓
contours, _ = cv2.findContours(edges, cv2.RETR_EXTERNAL, cv2.CHAIN_APPROX_SIMPLE)

# 绘制轮廓
cv2.drawContours(image, contours, -1, (0, 255, 0), 2)

这个示例将加载名为" image.jpg "的图像文件,并通过边缘检测和轮廓绘制实现目标检测和定位。

展示:

3.2 图像分割

寻找和绘制轮廓还可以用于图像分割,将图像中的目标区域提取出来。以下是一个示例代码:

代码语言:javascript
复制
import cv2

# 读取图像文件
image = cv2.imread('image.jpg')

# 将图像转换为灰度图像
gray_image = cv2.cvtColor(image, cv2.COLOR_BGR2GRAY)

# 进行边缘检测
edges = cv2.Canny(gray_image, 100, 200)

# 寻找轮廓
contours, _ = cv2.findContours(edges, cv2.RETR_EXTERNAL, cv2.CHAIN_APPROX_SIMPLE)

# 绘制轮廓
cv2.drawContours(image, contours, -1, (0, 255, 0), 2)

# 提取目标区域
segmented_image = cv2.bitwise_and(image, image, mask=edges)

这个示例将加载名为" image.jpg "的图像文件,并通过边缘检测和轮廓绘制提取出目标区域。

展示:

总结

通过本文的介绍,你已经了解了使用 OpenCV 进行寻找和绘制轮廓的基本步骤。你学会了使用边缘检测和 findContours 函数寻找图像中的轮廓,并使用 drawContours 函数绘制轮廓。

寻找和绘制轮廓是图像处理中常用的技术,可以用于目标检测、定位、图像分割等多个领域。通过调整边缘检测和轮廓绘制的参数,你可以根据实际需求得到所需的轮廓处理效果。

祝你在使用 OpenCV 进行寻找和绘制轮廓的过程中取得成功!

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2023-07-09,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • OpenCV 入门教程:寻找和绘制轮廓
  • 一、寻找轮廓
  • 二、绘制轮廓
  • 三、示例应用
    • 3.1 目标检测和定位
      • 3.2 图像分割
      • 总结
      相关产品与服务
      图像处理
      图像处理基于腾讯云深度学习等人工智能技术,提供综合性的图像优化处理服务,包括图像质量评估、图像清晰度增强、图像智能裁剪等。
      领券
      问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档