OpenCV轮廓拟合与凸包的讲解与实战应用(附Python源码)

简介: OpenCV轮廓拟合与凸包的讲解与实战应用(附Python源码)

需要源码和图片请点赞关注收藏后评论区留言私信~~~

一、轮廓拟合

拟合是指将平面上的一系列点,用一条光滑的曲线连接起来,轮廓的拟合就是将凹凸不平的轮廓用平整的几何图形体现出来

1:矩形包围框

矩形包围框是指图像轮廓的最小矩形边界,opencv提供的boundingRect方法可以自动计算轮廓最小矩形边界的坐标、宽和高,语法如下

retval=cv2.boundingRect(array)

array 轮廓数组

retval 元组类型 包含四个整数值 分别是最小矩形包围框的 左上角顶点的横坐标,左上角顶点的纵坐标,矩形的宽和高

下面为爆炸图形绘制矩形包围框

部分代码如下

import cv2
img = cv2.imread("shape2.png")  # 读取原图
graycv2.cvtColor(img, cv2.COLOR_BGR2GRAY)  # 从彩色图像变成单通道灰度图像
# 将灰度图像进行二值化阈值处理
t, biry = cv2.threshold(gray, 127, 255, cv2.THRESH_BINARY)
# 获取二值化图像中的轮廓极轮廓层次数据
contours, hierarchy = cv2.findContours(binary, cv2.RETR_LIST, cv2.CHAIN_APPROX_SIMPLE)
x, y, w, h = cv2.boundingRect(contours[0])  # 获取第一个轮廓的最小矩形边框,记录坐标和宽高
cv2.rectangle(img, (x, y), (x + w, y + h), (0, 0, 255), 2)  # 绘制红色矩形
cv2.how("img", img)  # 显示绘制结果
cv2.waitKey()  # 按下任何键盘按键后
cv2.destroyAllWindows()  # 释放所有窗体

2:圆形包围框

圆形包围框与矩形包围框一样,是图像轮廓的最小圆形边界,opencv提供的minEnclosingCircle方法可以自动计算轮廓最小圆形边界的圆心和半径 语法如下

center,radius=cv2.minEnclosingCircle(points)

points 轮廓数组

center 元组类型 包含两个浮点值 是最小圆形包围框圆心的横纵坐标

radius 浮点类型 最小圆形包围框的半径

下面为爆炸图形绘制圆形包围框

二、凸包

如果能找出图形最外层的端点,将这些端点连接起来,就可以围出一个包围图形的最小包围框,这种包围框叫凸包

凸包是最逼近轮廓的多边形,凸包的每一处都是凸出来的,也就是任意三个点组成的内角均小于180度

opencv提供的convexHull方法可以自动找出轮廓的凸包 语法如下

hull=cv2.convexHull(points,clockwise,returnPoints)

points 轮廓数组

clockwise 可选参数 布尔类型 为true时凸包中的点顺时针排列

returnpoints 可选参数 布尔类型 ture时返回点坐标

hull 凸包的点阵数组

下面为爆炸图形绘制凸包

首先要判断图形的轮廓,然后用convexhull方法找到轮廓的凸包,最后通过polylines方法将凸包中各点连接起来

部分代码如下

import cv2
img = cv2.imread("shape2.png")  # 读取原始图像
gray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)  # 转为灰度图像
ret, birycv2.threshold(gray, 127, 225, cv2.THRESH_BINARY)  # 二值化阈值处理
# 检测图像中出现的所有轮廓
contours, hiera = cv2.findContours(binary, cv2.RETR_LIST, cv2.CHAIN_APPROX_SIMPLE)
hull = cv2.vexHull(contours[0])  # 获取轮廓的凸包
cv2.polylines(img, [hull], True, (0, 0, 255), 2)  # 绘制凸包
cv2.imshow("img", img)  # 显示图像
cv2.waitKey()  # 按下任何键盘按键后
cv2.destroyAllWindows()  # 释放所有窗体

创作不易 觉得有帮助请点赞关注收藏~~~

相关文章
|
5月前
|
监控 数据可视化 数据挖掘
Python Rich库使用指南:打造更美观的命令行应用
Rich库是Python的终端美化利器,支持彩色文本、智能表格、动态进度条和语法高亮,大幅提升命令行应用的可视化效果与用户体验。
446 0
|
6月前
|
数据采集 监控 Java
Python 函数式编程的执行效率:实际应用中的权衡
Python 函数式编程的执行效率:实际应用中的权衡
319 102
|
5月前
|
机器学习/深度学习 算法 安全
【强化学习应用(八)】基于Q-learning的无人机物流路径规划研究(Python代码实现)
【强化学习应用(八)】基于Q-learning的无人机物流路径规划研究(Python代码实现)
399 6
|
5月前
|
设计模式 缓存 运维
Python装饰器实战场景解析:从原理到应用的10个经典案例
Python装饰器是函数式编程的精华,通过10个实战场景,从日志记录、权限验证到插件系统,全面解析其应用。掌握装饰器,让代码更优雅、灵活,提升开发效率。
397 0
|
6月前
|
数据采集 存储 数据可视化
Python网络爬虫在环境保护中的应用:污染源监测数据抓取与分析
在环保领域,数据是决策基础,但分散在多个平台,获取困难。Python网络爬虫技术灵活高效,可自动化抓取空气质量、水质、污染源等数据,实现多平台整合、实时更新、结构化存储与异常预警。本文详解爬虫实战应用,涵盖技术选型、代码实现、反爬策略与数据分析,助力环保数据高效利用。
379 0
|
6月前
|
存储 程序员 数据处理
Python列表基础操作全解析:从创建到灵活应用
本文深入浅出地讲解了Python列表的各类操作,从创建、增删改查到遍历与性能优化,内容详实且贴近实战,适合初学者快速掌握这一核心数据结构。
619 0
|
6月前
|
中间件 机器人 API
Python多态实战:从基础到高阶的“魔法”应用指南
Python多态机制通过“鸭子类型”实现灵活接口,使不同对象统一调用同一方法,自动执行各自行为。它简化代码逻辑、提升扩展性,适用于数据处理、策略切换、接口适配等场景。掌握多态思维,能有效减少冗余判断,使程序更优雅、易维护。
322 0
|
Python
实战!用 Python 给母亲送祝福!
今天是母亲节,小阿酱在这里祝天下所有的母亲节日快乐,作为女儿的我除了买礼物送惊喜外还要用 Python 送上特殊的祝福! 母亲节(Mother’s Day),是一个感谢母亲的节日。妈妈曾经也是一个女孩子,怕黑怕虫子,也会掉眼泪,笨手笨脚怕扎针,但她温柔了我,温柔了岁月。 借此祝全天下妈妈母亲节快乐!
727 0
实战!用 Python 给母亲送祝福!
|
5月前
|
数据采集 机器学习/深度学习 人工智能
Python:现代编程的首选语言
Python:现代编程的首选语言
503 102
|
5月前
|
数据采集 机器学习/深度学习 算法框架/工具
Python:现代编程的瑞士军刀
Python:现代编程的瑞士军刀
398 104

推荐镜像

更多