EmguCV学习笔记 VB.Net 5.3 透视变换

news2024/9/20 13:17:53

  版权声明:本文为博主原创文章,转载请在显著位置标明本文出处以及作者网名,未经作者允许不得用于商业目的。

EmguCV是一个基于OpenCV的开源免费的跨平台计算机视觉库,它向C#和VB.NET开发者提供了OpenCV库的大部分功能。

教程VB.net版本请访问:EmguCV学习笔记 VB.Net 目录-CSDN博客

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

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

教程配套文件及相关说明以及如何获得pdf教程和代码,请移步:EmguCV学习笔记

学习VB.Net知识,请移步: vb.net 教程 目录_vb中如何用datagridview-CSDN博客

 学习C#知识,请移步:C# 教程 目录_c#教程目录-CSDN博客

 

5.3 透视变换

透视变换是一种将图像从一种视角转换到另一种视角的技术,它可以用来对图像进行旋转、倾斜、缩放、裁剪等操作。

在Emgu.CV中,透视变换主要通过CvInvoke的WarpPerspective方法来实现。该方法接受源图像、变换矩阵(3×3的矩阵,可以由源图像和目标图像对应的四个点来获得)和目标图像的大小作为参数,可以将源图像根据变换矩阵进行透视变换,并将结果存储在目标图像中。

透视变换的步骤如下:

1. 提取源图像中的四个关键点,这四个点应该形成一个四边形,表示源图像中需要进行透视变换的区域。

2. 计算变换矩阵,可以使用CvInvoke的GetPerspectiveTransform方法来获得变换矩阵。该方法接受源图像中的四个关键点和目标图像中的四个关键点作为参数,返回一个3x3的变换矩阵。

3. 使用CvInvoke的WarpPerspective方法进行透视变换。该方法接受源图像、变换矩阵和目标图像的大小作为参数,可以将源图像根据变换矩阵进行透视变换,并将结果存储在目标图像中。

通过透视变换,可以将图像中的任意四边形区域变换为矩形区域,从而方便后续的处理和分析。例如纠正图像的透视畸变、拍摄图像中的文档扫描、图像的校正等。

5.3.1 GetPerspectiveTransform

GetPerspectiveTransform方法用于计算透视变换矩阵,它将一个四边形区域映射到另一个四边形区域,从而实现图像的透视变换。该方法声明如下:

Public Shared Function GetPerspectiveTransform(src As System.Drawing.PointF(), dest As System.Drawing.PointF()) As Emgu.CV.Mat

参数说明:

src:源四边形的四个顶点坐标,类型为PointF()。

dst:目标四边形的四个顶点坐标,类型为PointF()。

返回值:

透视变换矩阵(Mat类型)。

具体操作类似GetAffineTransform方法,这里不再累述。需要注意的是:源和目标四边形的四个顶点坐标同GetAffineTransform方法中的点数组一样需要按照对应顺序传入。

5.3.2 WarpPerspective

使用CvInvoke的WarpPerspective方法实现透视变换,该方法将输入图像根据给定的透视变换矩阵进行变换,并返回变换后的图像。该方法声明如下:

Public Shared Sub WarpPerspective(src As Emgu.CV.IInputArray, dst As Emgu.CV.IOutputArray, mapMatrix As Emgu.CV.IInputArray, dsize As System.Drawing.Size, Optional interpolationType As Emgu.CV.CvEnum.Inter = 1, Optional warpType As Emgu.CV.CvEnum.Warp = 0, Optional borderMode As Emgu.CV.CvEnum.BorderType = 0, Optional borderValue As Emgu.CV.Structure.MCvScalar = Nothing)

参数可以参看5.2.1【warpAffine】:

【代码位置:frmChapter5】Button10_Click

   '透视变换--四点变换

    Private Sub Button10_Click(sender As Object, e As EventArgs) Handles Button10.Click

        Dim m As New Mat("C:\learnEmgucv\rect.png", CvEnum.ImreadModes.Color)

        ImageBox1.Image = m

        '根据4点得到透视变换矩阵

        Dim srcpoint1(3) As PointF

        srcpoint1(0) = New PointF(0, 0)

        srcpoint1(1) = New PointF(m.Width, 0)

        srcpoint1(2) = New PointF(0, m.Height)

        srcpoint1(3) = New PointF(m.Width, m.Height)

        Dim dstpoint1(3) As PointF

        dstpoint1(0) = New PointF(m.Width / 3, 0)

        dstpoint1(1) = New PointF(m.Width * 2 / 3, 0)

        dstpoint1(2) = New PointF(0, m.Height)

        dstpoint1(3) = New PointF(m.Width, m.Height)

        '获得透视变换矩阵

        Dim pm1 As New Mat

        pm1 = CvInvoke.GetPerspectiveTransform(srcpoint1, dstpoint1)

        '透视变换

        Dim dst1 As New Mat

        CvInvoke.WarpPerspective(m, dst1, pm1, m.Size)

        ImageBox2.Image = dst1

        '根据4点得到透视变换矩阵

        Dim srcpoint2(3) As PointF

        srcpoint2(0) = New PointF(0, 0)

        srcpoint2(1) = New PointF(m.Width, 0)

        srcpoint2(2) = New PointF(0, m.Height)

        srcpoint2(3) = New PointF(m.Width, m.Height)

        Dim dstpoint2(3) As PointF

        dstpoint2(0) = New PointF(0 - m.Width / 3, 0)

        dstpoint2(1) = New PointF(m.Width * 4 / 3, 0)

        dstpoint2(2) = New PointF(0, m.Height)

        dstpoint2(3) = New PointF(m.Width, m.Height)

        '获得透视变换矩阵

        Dim pm2 As New Mat

        pm2 = CvInvoke.GetPerspectiveTransform(srcpoint2, dstpoint2)

        '透视变换

        Dim dst2 As New Mat

        CvInvoke.WarpPerspective(m, dst2, pm2, m.Size)

        ImageBox3.Image = dst2

End Sub

运行后如下图所示:

图5-11 透视变换后的图像

5.3.3 PerspectiveTransform

CvInvoke类的PerspectiveTransform方法可以用于实现透视变换。该方法的声明如下:

Public Shared Function PerspectiveTransform(src As System.Drawing.PointF(), mat As Emgu.CV.IInputArray) As System.Drawing.PointF()

参数说明:

  1. src:是一个Point类型的数组,其中包含了原图像中的四个点坐标。这四个点的坐标必须按照顺序排列,
  2. mat:透视变换矩阵, Mat类型。透视变换矩阵是一个3x3的矩阵,用于将原图像中的四个点映射到变换后图像中的四个点。

返回值:

返回包含了变换后图像中的四个点坐标。这四个点的坐标必须按照顺序排列,与原图像中的四个点一一对应。

【代码位置:frmChapter5】Button11_Click、PointFToPoint

    Private Sub Button11_Click(sender As Object, e As EventArgs) Handles Button11.Click

        Dim m As New Mat("C:\learnEmgucv\rect.png", CvEnum.ImreadModes.Color)

        ImageBox1.Image = m

        '根据4点得到透视变换矩阵

        Dim srcpoint1(3) As PointF

        srcpoint1(0) = New PointF(0, 0)

        srcpoint1(1) = New PointF(m.Width, 0)

        srcpoint1(2) = New PointF(0, m.Height)

        srcpoint1(3) = New PointF(m.Width, m.Height)

        Dim dstpoint1(3) As PointF

        dstpoint1(0) = New PointF(m.Width / 3, 0)

        dstpoint1(1) = New PointF(m.Width * 2 / 3, 0)

        dstpoint1(2) = New PointF(0, m.Height)

        dstpoint1(3) = New PointF(m.Width, m.Height)

        '获得透视变换矩阵

        Dim pm1 As New Mat

        pm1 = CvInvoke.GetPerspectiveTransform(srcpoint1, dstpoint1)

        '透视变换

        Dim dst1 As New Mat

        CvInvoke.WarpPerspective(m, dst1, pm1, m.Size)

        ImageBox2.Image = dst1

        '图像矩形区域的四个顶点

        Dim pts(3) As PointF

        pts(0) = New PointF(0, m.Height)

        pts(1) = New PointF(m.Width, m.Height)

        pts(2) = New PointF(m.Width, 0)

        pts(3) = New PointF(0, 0)

        '透视变换后的四个坐标点

        pts = CvInvoke.PerspectiveTransform(pts, pm1)

        'PointF() to Point()

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

        '绘制透视变换后的坐标

        Dim vp As New VectorOfPoint(points)

        Dim m2 As Mat = m.Clone

        For i As Integer = 0 To vp.Size - 1

            CvInvoke.Polylines(m2, vp, True, New MCvScalar(255, 0, 0), 1)

        Next

        ImageBox3.Image = m2

End Sub

    'PointFPoint方法

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

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

    End Function

运行后如下图所示:

 

图5-12 透视变换后的坐标点

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2058217.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

微分方程(Blanchard Differential Equations 4th)中文版Section2.2

动力系统的几何分析 捕食者-猎物系统的向量场 在第2.1节中,我们展示了两个不同捕食者-猎物系统的 R ( t ) R(t) R(t) 和 F ( t ) F(t) F(t) 图形,但没有描述我们是如何生成这些图形的。我们将在第2.5节中解决这个问题,采用欧拉方法推广到…

Java | Leetcode Java题解之第355题设计推特

题目&#xff1a; 题解&#xff1a; class Twitter {private class Node {// 哈希表存储关注人的 IdSet<Integer> followee;// 用链表存储 tweetIdLinkedList<Integer> tweet;Node() {followee new HashSet<Integer>();tweet new LinkedList<Integer&g…

《深入浅出WPF》读书笔记.6binding系统(上)

《深入浅出WPF》读书笔记.6binding系统(上) 背景 这一章是核心内容。databinding可以理解为实现逻辑层和展示层的桥梁。 binding基础 如何理解binding <Window x:Class"BindingSysDemo.BindingSysDemo1"xmlns"http://schemas.microsoft.com/winfx/2006/…

【pyqt5】QLineEdit中的文本输入限制方式,输入校验规则的应用详解

✨✨ 欢迎大家来到景天科技苑✨✨ &#x1f388;&#x1f388; 养成好习惯&#xff0c;先赞后看哦~&#x1f388;&#x1f388; &#x1f3c6; 作者简介&#xff1a;景天科技苑 &#x1f3c6;《头衔》&#xff1a;大厂架构师&#xff0c;华为云开发者社区专家博主&#xff0c;…

从0到1学会nginx分布式框架

nginx 项目地址晓智科技晓智科技晓智文档晓智文档源码地址源码地址文档源码文档源码 yum 安装 nginx 安装 yum-utils sudo yum install -y yum-utils添加 yum 源文件 # 新建文件 vim /etc/yum.repos.d/nginx.repo # 添加文件源 [nginx-stable] namenginx stable repo ba…

点击展开详细说明网站html引导页源码

点击展开详细说明网站html引导页源码,源码由HTMLCSSJS组成&#xff0c;记事本打开源码文件可以进行内容文字之类的修改&#xff0c;双击html文件可以本地运行效果&#xff0c;也可以上传到服务器里面&#xff0c;重定向这个界面 https://download.csdn.net/download/huayula/89…

开箱即用,使用极空间搭建小清新的自托管个人仪表板『honey』

开箱即用&#xff0c;使用极空间搭建小清新的自托管个人仪表板『honey』 哈喽小伙伴们好&#xff0c;我是Stark-C~ 说到可以在NAS部署的自托管仪表板呀&#xff0c;导航栏呀简直不要太多&#xff0c;光是我之前分享的譬如Sun-Panel &#xff0c;Dashy&#xff0c;HomePage&am…

【Linux】1.Linux环境搭建

文章目录 1.Linux环境安装2.云服务器选择2.1 3个云服务器平台2.2阿里云平台租借云服务器教程 3.Xshell安装4.Xshell配置连接云服务器5.如何多人共享一台Linux云服务器&#xff1f;6.如何更改他人访问云服务器的密码呢&#xff1f;7.如何阻止你共享的人访问云服务器呢&#xff1…

<数据集>RSOD数据集<目标检测>

数据集格式&#xff1a;VOCYOLO格式 图片数量&#xff1a;936张 标注数量(xml文件个数)&#xff1a;936 标注数量(txt文件个数)&#xff1a;936 标注类别数&#xff1a;4 标注类别名称&#xff1a;[aircraft, oiltank, overpass, playground] 序号类别名称图片数框数1air…

【轨物推荐】数字化时代的企业技术创新方法论

原创 郭朝晖 蝈蝈创新随笔 2024年08月03日 18:29 上海 数字化转型的一个重要特点&#xff0c;是用数字化技术手段解决企业的技术、运营和管理问题。于是我发现&#xff1a;数字化项目往往既有技术项目的特点、又有工程项目管理的特点&#xff0e;还有创新项目的特点。但换个角…

鲲鹏服务器安装Kafka

由于项目需求&#xff0c;需要在鲲鹏云主机上安装Kafka&#xff0c;并且要求安装的版本为2.3.X。下面主要从以下几个步骤说明如何安装&#xff1a; 1、下载kafka的安装文件 2、上传到服务器 3、修改配置 4、启动 5、使用工具测试 服务器信息 CPU信息 [rootecs02 ~]# lscpu A…

[数据集][目标检测]瞳孔虹膜检测数据集VOC+YOLO格式8768张2类别

数据集格式&#xff1a;Pascal VOC格式YOLO格式(不包含分割路径的txt文件&#xff0c;仅仅包含jpg图片以及对应的VOC格式xml文件和yolo格式txt文件) 图片数量(jpg文件个数)&#xff1a;8768 标注数量(xml文件个数)&#xff1a;8768 标注数量(txt文件个数)&#xff1a;8768 标注…

24款保时捷帕拉梅拉升级原厂360全景影像案例

24款保时捷帕拉梅拉升级原厂360全景影像后&#xff0c;车辆的前后左右都能被清晰地拍摄下来&#xff0c;并通过车载屏幕实时显示。这可以帮助驾驶员更好地了解车辆周围的环境&#xff0c;从而提高驾驶安全性和便利性。以下是一些可能的效果展示&#xff1a; • 全景视图&#…

wincc报警如何通过短信发送给手机

单位使用WINCC上位机监控现场&#xff0c;需要把报警信息发送到指定手机上&#xff0c;能否实现&#xff1f;通过巨控GRMOPC系列远程智能控制终端&#xff0c;简单配置即可实现wincc报警短信传送到手机。配置过程无需任何通讯程序&#xff0c;也不要写任何触发脚本。 GRMOPC模…

Vue的遍历(列表、对象、字符串、数字)、key的原理

目录 1 遍历(列表、对象、字符串、数字)2. key的原理2.1 key使用index2.1 key使用数据的唯一id2.3 key的原理 3. 列表过滤4. 列表排序 1 遍历(列表、对象、字符串、数字) key可以使用数据的唯一字段(最好)&#xff0c;也可以使用index(默认) 使用示例: <!DOCTYPE html>…

数据科学已死?

既然有了人工智能&#xff0c;训练自己的机器学习模型是否还值得&#xff1f; 既然有了人工智能&#xff0c;学习 Python 是否还值得&#xff1f; 既然有了人工智能&#xff0c;KNIME 还在营业吗&#xff1f; 既然有了人工智能&#xff0c;数据科学是否仍然需要&#xff1f;…

【深度学习与NLP】——Transformer架构解析

目录 第一章:Transformer背景介绍 1.1 Transformer的诞生 1.2 Transformer的优势 1.3 Transformer的市场 第二章:Transformer架构解析 2.1 认识Transformer架构 2.1.1 Transformer模型的作用 2.1.2 Transformer总体架构图 2.2 输入部分实现 2.2.1 文本嵌入层的作用 …

维护和升级LabVIEW程序

在维护和升级LabVIEW程序时&#xff0c;需要全面考虑代码的现状和未来的需求。以下是各个方面的详细注意事项&#xff0c;以确保程序能够在稳定性和性能方面得到提升。 1. 理解现有代码: 深入代码分析: 仔细阅读现有的代码&#xff0c;了解其逻辑结构、数据流、和控制流程。关注…

众善慈善机构:帮助贫困地区的人们提高自身的就业能力和创业能力

众善慈善机构是一家致力于帮扶和脱贫的慈善机构&#xff0c;主要致力于帮助贫困地区的人们改善生活条件&#xff0c;提高生活质量。 众善慈善机构的主要帮扶对象是贫困地区的儿童、老人和残疾人。他们通过开展各种救助项目&#xff0c;为这些人群提供生活物资、教育、医疗等方面…

【附源码】Python :PYQT界面点击按钮随机变色

系列文章目录 Python 界面学习&#xff1a;PYQT界面点击按钮随机变色 文章目录 系列文章目录一、项目需求二、源代码三、代码分析3.1 导入模块&#xff1a;3.2 定义App类&#xff1a;3.3 构造函数&#xff1a;3.4 初始化用户界面&#xff1a;3.5 设置窗口属性&#xff1a;3.6 …