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方法。

相关推荐
西部秋虫8 小时前
迷你视频会议系统(FlashMeeting)
opencv·ffmpeg·视频会议·回声抑制
智驱力人工智能18 小时前
小区高空抛物AI实时预警方案 筑牢社区头顶安全的实践 高空抛物检测 高空抛物监控安装教程 高空抛物误报率优化方案 高空抛物监控案例分享
人工智能·深度学习·opencv·算法·安全·yolo·边缘计算
光泽雨19 小时前
检测阈值 匹配阈值分析 金字塔
图像处理·人工智能·计算机视觉·机器视觉·smart3
sali-tec19 小时前
C# 基于OpenCv的视觉工作流-章22-Harris角点
图像处理·人工智能·opencv·算法·计算机视觉
学电子她就能回来吗20 小时前
深度学习速成:损失函数与反向传播
人工智能·深度学习·学习·计算机视觉·github
光羽隹衡21 小时前
计算机视觉——Opencv(图像拼接)
人工智能·opencv·计算机视觉
爱打代码的小林1 天前
基于 MediaPipe 实现实时面部关键点检测
python·opencv·计算机视觉
深蓝电商API1 天前
图片验证码识别:pytesseract+opencv入门
人工智能·opencv·计算机视觉·pytesseract
Sagittarius_A*1 天前
特征检测:SIFT 与 SURF(尺度不变 / 加速稳健特征)【计算机视觉】
图像处理·人工智能·python·opencv·计算机视觉·surf·sift
nLsUCWFJR1 天前
(Matlab)基于贝叶斯优化卷积双向长短期记忆网络(CNN-BiLSTM)回归预测
opencv