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

相关推荐
DisonTangor1 小时前
PaddleOCR-VL: 通过0.9B超紧凑视觉语言模型增强多语言文档解析
人工智能·计算机视觉·语言模型·自然语言处理·开源·aigc
AndrewHZ2 小时前
【图像处理基石】通过立体视觉重建建筑高度:原理、实操与代码实现
图像处理·人工智能·计算机视觉·智慧城市·三维重建·立体视觉·1024程序员节
Theodore_10222 小时前
深度学习(3)神经网络
人工智能·深度学习·神经网络·算法·机器学习·计算机视觉
算家云8 小时前
DeepSeek-OCR本地部署教程:DeepSeek突破性开创上下文光学压缩,10倍效率重构文本处理范式
人工智能·计算机视觉·算家云·模型部署教程·镜像社区·deepseek-ocr
I'm a winner11 小时前
基于YOLO算法的医疗应用专题:第一章 计算机视觉与深度学习概述
算法·yolo·计算机视觉
这张生成的图像能检测吗13 小时前
(论文速读)开放词汇3D场景理解的掩蔽点-实体对比
人工智能·计算机视觉·图像生成·1024程序员节·开放词汇·3d重建
Antonio91514 小时前
【图像处理】灰度图像与二值化
图像处理·opencv
tangchen。15 小时前
YOLOv4 :兼顾速度与精度!
人工智能·计算机视觉·目标跟踪
学术头条15 小时前
用视觉压缩文本!清华、智谱推出Glyph框架:通过视觉-文本压缩扩展上下文窗口
人工智能·深度学习·计算机视觉
Mrliu__15 小时前
Opencv(一): 用Opencv了解图像
人工智能·opencv·计算机视觉