Python OpenCV中cv2.minAreaRect实例解析
作者:求则得之,舍则失之 发布时间:2022-09-02 19:36:58
在这个文章中,我们将学习如何在感兴趣区域周围画最小面积矩形框。
1.最小面积矩形框
下图显示了两个矩形框,绿色的是普通矩形框,红色的是最小面积矩形框。可以发现,红色的是旋转矩形。
OpenCV提供了一个函数cv2.minAreaRect来寻找最小面积的旋转矩形。将2D点集作为输入,并返回一个Box2D结构,其中包括以下详细信息–(中心(x,y),(宽度、高度)、旋转角度)。
(center(x,y), (width, height), angle of rotation) = cv2.minAreaRect(points)
但是要绘制一个矩形,我们需要矩形的四个角,因此为了将Box2D结构转换为4个角点,OpenCV提供了另一个函数cv2.boxPoints(),这将Box2D结构作为输入并返回4个角点。4个角点从y最高的点开始按顺时针顺序排列。语法如下:
points = cv2.boxPoints(box)
在绘制矩形之前,需要将4个角点转换为整数类型。可以使用np.int32或者np.int64(不要使用np.int8,因为它允许最大值127并截断)。有时,你可能会看到使用了np.int0,不要混淆,这相当于np.int32或者np.int64,具体取决于你的系统结构。完整的代码如下:
rect = CV2.minAreaRect(cnt)
box = cv2.boxPoints(rect)
box = np.int0(box)
得到四个坐标后,就可以轻松绘制图形了。现在,让我们讨论一下旋转角度。
2.旋转角度
获得四个角点以后,这四个角点从具有最高y的点开始按顺时针顺序排列,如下所示。如果2个点具有相同的最高y,则最右的点是起点。这些点被编号为0,1,2,3(0开始,3结束)。
因此,OpenCV的cv2.minAreaRect()给出的旋转角度实际上是直线(连接起点和终点)与水平线之间的角度,如下所示。
因此角度值始终位于[-90, 0)之间。为什么?因为如果对象旋转超过90°,则使用下一条边来计算与水平面的角度。因此计算出的角度始终位于[-90,0)之间。
实际角度是对象旋转的角度,计算出的角度是cv.minAreaRect()返回的角度。
补充:cv2.minAreaRect输出旋转角度测试
函数使用方法
min_rect = cv2.minAreaRect(cnt)
# 输入参数cnt是通过findContours识别出来的轮廓信息
# 输出min_rect是一个元组,其中的结构是最小外接矩形的(中心(x,y),(边1长度,边2长度),旋转角度)
简单测试一下对几个角度的矩形和平行四边形的识别效果
图片可能较小,建议放大观看
可以看到,输出的旋转角度和矩形边2的选择有关,具体函数是按照什么规则来确定边1和边2,我还不清楚,但是根据上面的实验结论,大致可以推测出以下规律:
规定水平矩阵为上图第一个矩形形状,即长边平行于x轴,短边垂直于x轴,
按住水平矩形的左上角,逆时针旋转矩形不超过90度 形成的矩形,长边作为边2;
按住水平矩形的左上角,顺时针旋转矩形小于90度 形成的矩形,短边作为边2。
参考目录
https://theailearner.com/tag/cv2-minarearect/
来源:https://blog.csdn.net/weixin_43229348/article/details/125986969
猜你喜欢
- 如下所示:#!/usr/bin/env pythonimport serialimport timeimport threadclass M
- 我们知道为了提高代码的运行速度,我们需要对书写的python代码进行性能测试,而代码性能的高低的直接反馈是电脑运行代码所需要的时间。这里将介
- 前言python内置了一些非常巧妙而且强大的内置函数,对初学者来说,一般不怎么用到,我也是用了一段时间python之后才发现,哇还有这么好的
- 近日在月影的blog上找到一段代码。看了老半天没明白什么意思,倍受打击!不死心,于是仔细分析思考了好几次,才明白过来这段函数的意义。js果然
- 如何取回已忘记的密码?forget.asp' 申请<html><head><title>闪亮日子
- django框架默认将session保存到数据库中,在高并发访问无疑会影响服务器性能,因此最好将session保存到redis中避免直接从数
- 创建类Python 类使用 class 关键字来创建。简单的类的声明可以是关键字后紧跟类名:class ClassName(bases):&
- 主要使用IE各个阶段实现的一些方法,从中也可以看出IE的发展史。暂时提供到IE4的判定。var isIE = window.ActiveXO
- 前言综合应用已经学习过的知识点:变量流程控制函数模块系统需求1.程序启动,显示名片管理系统欢迎界面,并显示功能菜单*************
- 前言本文将使用pytorch框架的目标识别技术实现滑块验证码的破解。我们这里选择了yolov5算法例:输入图像输出图像可以看到经过检测之后,
- 以前写过一个标签效果,外观虽然好看,但代码不太规范,实现的方法比较繁冗。需要注意的是标签的背景图,两种状态,激活的标签背景为蓝色,反之为灰色
- 代码如下:--销售冠军 --问题:在公司中,老板走进来,要一张每个地区销量前3名的销售额与销售员的报表 --- create t
- 先用最简单的三层全连接神经网络,然后添加激活层查看实验结果,最后加上批标准化验证是否有效首先根据已有的模板定义网络结构SimpleNet,命
- 这年头,信息和获得信息的渠道越来越多。随着信息量的增大,先有了分类,又有了导航,再有了搜索,后面的发展还不得而知。在此只是根据平日的所看所想
- 1. 背景在软件需求、开发、测试过程中,有时候需要使用一些测试数据,针对这种情况,我们一般要么使用已有的系统数据,要么需要手动制造一些数据。
- 本文研究的主要是Python进程间通信Queue的相关实例,具体如下。1.Queue使用方法:Queue.qsize():返回当前队列包含的
- 本文使用案例是基于 python2.7 实现以下内容均为个人使用 peewee 的经验和遇到的坑,不会涉及过多的基本操作。所以,没有使用过
- 本文介绍了asp编程中使用数组的各种方法,并给出了详细的asp实例代码方便大家理解。asp中数组的定义Dim MyArray My
- 此次遇到的问题是在import pycurl 时报错pycurl:libcurl link-time version is older th
- 张同学 10.4号开始发视频,视频的点赞量一直很高,11.17 号的视频达到了顶峰,收获 250w 个赞,之后关注量也开启了暴涨。所以挖掘