EmguCV学习笔记 VB.Net 3.6 旋转矩形

版权声明:本文为博主原创文章,转载请在显著位置标明本文出处以及作者网名,未经作者允许不得用于商业目的。
教程VB.net版本请访问:
EmguCV学习笔记 VB.Net 目录-CSDN博客

教程C#版本请访问: EmguCV学习笔记 C# 目录-CSDN博客

笔者的博客网址:https://blog.csdn.net/uruseibest

教程配套文件及相关说明以及如何获得pdf教程和代码(博客上的教程内容会和pdf教程一致,教程中也会包含所有代码),请移步:************************************************************EmguCV学习笔记****************************************************************

3.6 旋转矩形

RotatedRect结构表示一个旋转矩形,它由中心坐标、大小(长轴长度和短轴长度)和旋转角度三个属性组成。

以下是RotatedRect结构的定义:

Public Structure RotatedRect

Public Center As PointF

Public Size As SizeF

Public Angle As Single

End Structure

其中,各属性的含义如下:

  1. Center:旋转矩形的中心坐标,PointF类型。
  2. Size:旋转矩形的长轴长度和短轴长度,SizeF类型。
  3. Angle:旋转矩形的旋转角度,单位为度,Single类型。

RotatedRect结构还提供了一些方法,如GetVertices、GetBoundingRect等,可以方便地获取旋转矩形的顶点坐标、外接矩形等信息。

如果要绘制出旋转矩形,比较遗憾的是Cvinvoke没有提供直接的方法,但是可以通过RotatedRect的GetVertices先获得顶点坐标,再通过Polylines和FillPoly来绘制和填充。

【代码位置:frmChapter3】Button6_Click、PointFToPoint

'旋转矩形

Private Sub Button6_Click(sender As Object, e As EventArgs) Handles Button6.Click

Dim mcs1 As New MCvScalar(0, 0, 255)

Dim mcs2 As New MCvScalar(0, 255, 0)

'旋转20度的旋转矩形

Dim rrec As New RotatedRect(New PointF(100, 200), New SizeF(80, 100), 20)

'获得4个顶点坐标

Dim pf() As PointF = rrec.GetVertices

'将PointF()转Point()

Dim p() As Point = Array.ConvertAll(pf, New Converter(Of PointF, Point)(AddressOf PointFToPoint))

'将Point()元素推入VectorOfPoint

Dim vp As New VectorOfPoint

vp.Push(p)

'绘制旋转矩形

CvInvoke.Polylines(mBg, vp, True, mcs1, 3)

'填充旋转矩形

CvInvoke.FillPoly(mBg, vp, mcs2)

ImageBox1.Image = mBg

End Sub

'将PointF转Point方法

Public Shared Function PointFToPoint(ByVal pf As PointF) As Point

Return New Point(CInt(pf.X), CInt(pf.Y))

End Function

运行后如下图所示:

图3-6 绘制、填充旋转矩形

大多数时候,我们获得的是PointF,也就是浮点坐标的Point。当遇到PointF需要转为Point的时候,可以使用以下代码:

Public Shared Function PointFToPoint(ByVal pf As PointF) As Point

Return New Point(CInt(pf.X), CInt(pf.Y))

End Function

如果是PointF数组转为Point数组,可以使用以下代码:

Dim p() As Point = Array.ConvertAll(pf, New Converter(Of PointF, Point)(AddressOf PointFToPoint))

这里使用了Array类的ConvertAll方法。

相关推荐
兵慌码乱5 天前
基于 MediaPipe 与 PySide2 的手势交互音乐控制系统实现:轻量化视觉交互全流程解析
python·opencv·计算机视觉·人机交互·手势识别·mediapipe·pyside2
小小杨树8 天前
读懂色彩:拍照调色不再难
算法·计算机视觉·配色
H__Rick9 天前
自动对焦学习-3
人工智能·学习·计算机视觉
计算机科研狗@OUC9 天前
(cvpr26) AIMDepth: Asymmetric Image-Event Mamba for Monocular Depth Estimation
人工智能·深度学习·计算机视觉
qq_366566509 天前
2026最新:5款AI视频口型同步工具实测横评,视频翻译后嘴型对不上的终极解决方案
人工智能·计算机视觉·新媒体运营
梦想三三10 天前
OpenCV银行卡数字识别项目(图像预处理与字符分割)
人工智能·opencv·计算机视觉
kaikaile199510 天前
图像稀疏化分解 + 压缩感知(CS)重建 MATLAB
开发语言·计算机视觉·matlab
武子康10 天前
调查研究-180 roboflow/supervision:计算机视觉工程里的“胶水层“,为什么值得关注?
人工智能·opencv·计算机视觉·chatgpt·llm·向量化
YOLO数据集集合10 天前
无人机风电设备智能巡检 风机叶片缺陷目标检测数据集实战 | 表面腐蚀漏油识别 工业视觉质检 深度学习模型训练落地10337期
人工智能·深度学习·目标检测·计算机视觉·无人机