当前位置: 首页 > news >正文

Python OpenCV 影像处理:影像轮廓

► 前言

上篇介绍使用OpenCV Python对于图像上的二值化操作,二值化主要用途包括图像分割、物体侦测、文字识别等。这种转换可以帮助检测图像中的物体或特定特征,并提取有用的信息,本篇基于二值化操作进行近一步的操作,透过影像梯度区分影像前景、后景,框选所需目标物件。透过程式码的说明,让各位了解OpenCV Python于图像处理上的基本操作。

►轮廓(Contour)定义

轮廓是由多个点组成的连续曲线或多边形,这些点会包围物体或形状的边界。轮廓描述了物体在影像中的外形和轮廓的形状。这些轮廓提供了对物体形状和结构的描述,可以识别和理解影像中的物体。

►轮廓检测与绘制

OpenCV提供findContours()函数用于在二值化影像中寻找轮廓。

  1. image: 输入的二值化图像,通常是经过灰度转换和二值化处理后的图像。
  2. mode: 轮廓检测模式。它指定轮廓的检索模式,可以使用以下值之一:
    • RETR_EXTERNAL:只检测最外层的轮廓。
    • RETR_LIST:检测所有的轮廓,但不建构轮廓的层次结构。
    • RETR_CCOMP:检测所有的轮廓,并将其组织为两级层次结构。
    • RETR_TREE:检测所有的轮廓,并将其组织为完整的层次结构。
  3. method: 轮廓的逼近方法。它指定轮廓的逼近方法,可以使用以下值之一:
    • CHAIN_APPROX_NONE:储存所有的轮廓点,不进行逼近。
    • CHAIN_APPROX_SIMPLE:仅储存水平、垂直和对角线端点,压缩水平、垂直和对角线节点,只保留该方向上的终点。
  4. contours(可选): 轮廓的输出列表,每个轮廓是一个由点构成的 numpy 数组。
  5. hierarchy(可选): 输出的层次结构,描述了轮廓之间的嵌套关系。
  6. offset(可选): 输入图像的可选偏移参数。

并透过drawContours()函数将轮廓叠加于原始图像上。

  1. image: 用于绘制轮廓的图像。
  2. contours: 要绘制的轮廓,是一个包含轮廓的列表,每个轮廓是一个由点构成的 numpy 数组。
  3. contourIdx: 指定要绘制的轮廓的索引。如果为负值(例如 -1),则绘制所有轮廓。
  4. color: 绘制轮廓的颜色。它是一个包含三个整数的元组,分别表示蓝色、绿色和红色通道的值。
  5. thickness(可选): 绘制轮廓的线条宽度。如果 thickness 为正值,表示线条的粗细;如果 thickness 为负值或者等于 0,则轮廓内部被填充。
  6. lineType(可选): 绘制轮廓的线条类型。预设为 LINE_8,表示 8 连通线条。你也可以使用 cv2.LINE_AA 以获得抗锯齿效果。
  7. hierarchy(可选): 描述轮廓层次结构的 numpy 数组。在 findContours 中获取,通常不需要手动指定。
  8. maxLevel(可选): 绘制轮廓的最大层级。如果不指定,则绘制所有层级的轮廓。
  9. offset(可选): 输入图像的可选偏移参数。

在轮廓检测与绘制分为以下四个步骤:

  • 读取图像并转为灰度图
  • 灰度图像二值化
  • 检测轮廓
  • 绘制轮廓


 

►轮廓周长与面积计算

在 OpenCV 中,可以使用 cv2.arcLength 函数来计算轮廓的周长,使用 cv2.contourArea 函数来计算轮廓的面积。

  • contour:要计算周长的轮廓。
  • closed:一个布尔值,表示轮廓是否是封闭的。如果是封闭的,则 closed 设为 True;如果不是封闭的,则设为 False。

  • contour:要计算面积的轮廓。 

►小结

透过以上讲解,搭配程式码进行范例讲解,相信各位对于图像上的轮廓检测能有更深刻的理解,期待下一篇博文吧!

►Q&A

 问题一:图像不是二值化的,如何进行轮廓检测?

在进行轮廓检测之前,必须将图像转换为二值化形式。可以使用灰度转换和阈值处理来实现。确保你的图像经过适当的预处理。

问题二:找不到预期的轮廓,检测效果不好。

调整二值化的阈值或使用自适应阈值处理。有时候,图像的光线和对比度变化可能导致检测效果不佳,可以先进行适当的图像增强。

问题三:图像中有噪音或小的斑点,影响轮廓检测。

在进行轮廓检测之前,进行图像平滑处理,例如使用高斯滤波器或中值滤波器,以减少噪音的影响。

问题四:轮廓太多或太少,难以准确识别目标。

调整二值化的阈值,以控制检测到的轮廓数量。另外,可以使用形态学运算进行轮廓的调整和修复。

问题五:轮廓检测后如何进一步处理找到的轮廓?

根据应用需求,可以使用轮廓的特性进行进一步的筛选、过滤或分析。例如,可以根据轮廓的面积、长宽比等进行筛选,以排除不需要的轮廓。

►参考资料 

OpenCV - Open Computer Vision Library

欢迎登录大大通,了解更多原厂技术方案、学习教程吧!

相关文章:

  • 北京网站建设多少钱?
  • 辽宁网页制作哪家好_网站建设
  • 高端品牌网站建设_汉中网站制作
  • 详细阐述Android中的四种启动模式
  • 项目问题 | CentOS 7停止维护导致yum失效的解决办法
  • 前端数据存在什么地方,刷新页面之后依旧存在
  • 【数学建模备赛】Ep05:斯皮尔曼spearman相关系数
  • 尚硅谷Java面试题第四季-MySQL面试题
  • 关于武汉芯景科技有限公司的多协议收发芯片XJ526(第二篇RS422模式)开发指南(兼容SP526)
  • Java:循环练习
  • 开发指南054-选择人员
  • day35
  • LUOGU P2048 [NOI2010] 超级钢琴(贪心+堆)
  • vue elementPlus中使用dayjs
  • 《Docker:实现开发环境一致性与高效部署的利器》
  • ArcGIS如何将投影坐标系转回为地理坐标系
  • SpringBoot集成kafka-生产者发送消息
  • 【前端面试】浏览器原理解读
  • ES6简单总结(搭配简单的讲解和小案例)
  • Git的一些常用操作
  • IP路由与转发
  • Java 实战开发之spring、logback配置及chrome开发神器(六)
  • JavaScript新鲜事·第5期
  • jquery cookie
  • MySQL数据库运维之数据恢复
  • python大佬养成计划----difflib模块
  • 基于游标的分页接口实现
  • 来,膜拜下android roadmap,强大的执行力
  • 一起来学SpringBoot | 第十篇:使用Spring Cache集成Redis
  • 由插件封装引出的一丢丢思考
  • 2017年360最后一道编程题
  • #vue3 实现前端下载excel文件模板功能
  • (1)Hilt的基本概念和使用
  • (2)(2.4) TerraRanger Tower/Tower EVO(360度)
  • (Mac上)使用Python进行matplotlib 画图时,中文显示不出来
  • (不用互三)AI绘画:科技赋能艺术的崭新时代
  • (附源码)ssm高校志愿者服务系统 毕业设计 011648
  • (论文阅读32/100)Flowing convnets for human pose estimation in videos
  • (免费分享)基于springboot,vue疗养中心管理系统
  • (三分钟了解debug)SLAM研究方向-Debug总结
  • (十一)JAVA springboot ssm b2b2c多用户商城系统源码:服务网关Zuul高级篇
  • (原創) 人會胖會瘦,都是自我要求的結果 (日記)
  • (转)详解PHP处理密码的几种方式
  • (转)一些感悟
  • *** 2003
  • ***测试-HTTP方法
  • *++p:p先自+,然后*p,最终为3 ++*p:先*p,即arr[0]=1,然后再++,最终为2 *p++:值为arr[0],即1,该语句执行完毕后,p指向arr[1]
  • .net core webapi Startup 注入ConfigurePrimaryHttpMessageHandler
  • .NET MVC第五章、模型绑定获取表单数据
  • .NET 漏洞分析 | 某ERP系统存在SQL注入
  • .NET/C# 使用 #if 和 Conditional 特性来按条件编译代码的不同原理和适用场景
  • .net开发日常笔记(持续更新)
  • .net开发时的诡异问题,button的onclick事件无效
  • .net开源工作流引擎ccflow表单数据返回值Pop分组模式和表格模式对比
  • .NET中的Event与Delegates,从Publisher到Subscriber的衔接!
  • @angular/cli项目构建--Dynamic.Form
  • @vue/cli 3.x+引入jQuery
  • [ C++ ] STL---string类的模拟实现