OpenCV中的最小面积矩形拟合
OpenCV在轮廓拟合中支持两个轮廓外接矩形求取函数,它们分别是:boundingRect与minAreaRect,对同一个轮廓,它们运行结果显示如下:
图-1
其中绿色是运行boundingRect函数返回得到矩形框,红色是运行minAreaRect返回得到矩形框。白色区域是二值图像的轮廓。这两个函数的详细解释如下:
Rect cv::boundingRect(
InputArray array // 轮廓点
)
返回的矩形Rect对象;
RotatedRect cv::minAreaRect(
InputArray points // 轮廓点
)
返回稍微复杂点是一个RotatedRect对象,它包含下面几个方面的信息:
- 中心位置
- 宽与高
- 旋转角度
其中中心位置像素坐标信息、宽与高也是基于像素的,选择角度值在-90~0之间,而且永远是这个,这个是最令人迷惑的地方,很多人第一次知道minAreaRect可以返回角度,很开心以为可以知道旋转了,最后发现角度跟想象的返回值差异很大,原因在于minAreaRect返回的角度永远都是以最低的一个点为支撑来计算,所以无论怎么旋转,它返回永远是0~-90之间的值。一个动态图解如下:
演示展示
输入原图:
求取轮廓,然后求外接矩形、关键点、十字交叉线 图示如下:
求取轮廓,然后求最小外接矩形、关键点、十字交叉线 图示如下:
求取外接矩形与最小外接矩形的代码演示如下:
# 外接矩形
x, y, w, h = cv.boundingRect(contours[cnt])
cv.rectangle(result, (x, y), (x+w, y+h), (0, 0, 255), 2, 8, 0)
# 最小外接矩形
min_box = cv.minAreaRect(contours[cnt])
pts = np.int0(cv.boxPoints(min_box))
cv.drawContours(result, [pts], 0, (0, 0, 255), 2)
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧