前言:
当前姐妹们对“opencv canny边缘检测”大概比较讲究,各位老铁们都想要了解一些“opencv canny边缘检测”的相关知识。那么小编在网摘上收集了一些关于“opencv canny边缘检测””的相关内容,希望你们能喜欢,咱们一起来了解一下吧!导读
在上篇文章中,我们介绍了仿射变换,我们只需要通过一个两行三列的变换矩阵M就能够对图像实现平移、缩放、翻转、旋转操作。这些变换其实都属于平面变换,如果我们想要进行空间变换呢?
将上图的扑克牌单独提取出来,如下图所示
这时候我们应该如何来实现这个功能呢?这个其实就涉及到了图像的一个空间变换,就需要用到我们所说的透视变换了。
透视变换
透视变换(Perspective Transformation)是指利用透视中心、像点、目标点三点共线的条件,按透视旋转定律使承影面(透视面)绕迹线(透视轴)旋转某一角度,破坏原有的投影光线束,仍能保持承影面上投影几何图形不变的变换。简而言之,就是将一个平面通过一个投影矩阵投影到指定平面上。
原理解析
透视变换通用的变换公式:
u和v是原始图片,参数ω等于1,通过透视变换后得到的图片坐标x,y,其中
上式中的变换矩阵,可以将其拆成四个部分,第一部分表示线性变换:
这部分矩阵主要用于图像的缩放、旋转操作,在仿射变换中我们也介绍过。第二部分用来进行平移操作[a31a32],第三部分用来产生透视变换[a13a23],第四部分参数a33等于1。
在上篇文章中我们介绍的仿射变换矩阵一共有6个参数,所以我们只需要3个坐标对(6个方程)就能求解,而透视变换矩阵一共有8个参数,所以需要4个坐标对(8个方程)才能求解,其实仿射变换也是透视变换的一种特殊形式。
所以变换后x和y的表达式为
接下来我们看一个例子,原始图像的四个点的坐标分别为(0,0)、(1,0)、(1,1)、(0,1)与之对应变换后的四个点坐标分别为(x1,y1)、(x2,y2)、(x3,y3)、(x4,y4),根据上面的公式和对应的四个点坐标可得下面的方程式
通过上面的8个方程,我们可以解出8个参数求出透视变换矩阵,最后我们通过opencv的warpPerspective方法利用透视变换矩阵来实现透视变换,接下来我们通过结合一个实例来具体运用一下。
透视变换实例讲解
这里我们主要通过opencv来实现上面介绍的那个功能
读取图像Canny边缘检测
Canny函数参数解析:
image:输入图像数组threshold1:最低的阈值threshold2:最高的阈值edges:输出的边缘图像,单通道8位图像apertureSize:Sobel算子的大小L2gradient:表示一个布尔值,如果为真,则使用更精确的L2范数进行计算,否则使用L1范数
霍夫直线检测
HoughLinesP函数参数解析:
image:经过Canny边缘检测后的输出图像rho:极坐标的半径r以像素值为单位的分辨率,一般使用1像素theta:极坐标的极角θ\thetaθ以弧度为单位的分辨率,一般使用1度threshold:检测一条直线所需最少的曲线交点lines:存储检测到的直线,包含直线的起点和终点坐标minLineLength:组成一条直线的最少点的数量,点数量不足的直线将被抛弃maxLineGap:在一条直线上的点的最大距离
计算顶点坐标
通过直线两个端点的坐标来计算直线的交点坐标,找出扑克牌的四个顶点位置
对顶点坐标进行排序
在计算透视变换矩阵之前我们需要对元素图像的坐标与变换后图像的坐标一一对应,按照左->上->右->下的顺序
计算变换矩阵进行透视变换