当前位置: 首页 > news >正文

OpenCV几何图像变换(2)计算仿射变换矩阵的函数getAffineTransform()的使用

  • 操作系统:ubuntu22.04
  • OpenCV版本:OpenCV4.9
  • IDE:Visual Studio Code
  • 编程语言:C++11

算法描述

计算三对对应点之间的仿射变换。
该函数计算 2×3 的仿射变换矩阵,使得:
[ x i ′ y i ′ ] = map_matrix ⋅ [ x i y i 1 ] \begin{bmatrix} x'_i \\ y'_i \end{bmatrix} = \texttt{map\_matrix} \cdot \begin{bmatrix} x_i \\ y_i \\ 1 \end{bmatrix} [xiyi]=map_matrix xiyi1
其中,
d s t ( i ) = ( x i ′ , y i ′ ) , s r c ( i ) = ( x i , y i ) , i = 0 , 1 , 2 dst(i)=(x'_i,y'_i), src(i)=(x_i, y_i), i=0,1,2 dst(i)=(xi,yi),src(i)=(xi,yi),i=0,1,2

getAffineTransform() 函数是 OpenCV 中用于计算仿射变换矩阵的函数。仿射变换是一种几何变换,它可以包括缩放、旋转和平移等操作,但不包括透视变换。getAffineTransform() 主要用于计算从源图像到目标图像的仿射变换矩阵。

函数原型1

Mat cv::getAffineTransform	
(const Point2f 	src[],const Point2f 	dst[] 
)	

参数1

  • 参数src 源图像中三角形顶点的坐标。
  • 参数dst 目标图像中对应三角形顶点的坐标。

函数原型2


Mat cv::getAffineTransform
(InputArray 	src,InputArray 	dst 
)		

参数2

  • 参数src 源图像中三角形顶点的坐标。
  • 参数dst 目标图像中对应三角形顶点的坐标。

代码示例


#include <opencv2/opencv.hpp>
#include <iostream>using namespace cv;
using namespace std;int main()
{// 加载图像Mat src = imread("/media/dingxin/data/study/OpenCV/sources/images/hawk.jpg");if (src.empty()){cout << "Error: Image not found." << endl;return -1;}// 定义源图像中的三个点Point2f srcTri[] = {Point2f(0, 0), Point2f(src.cols - 1, 0), Point2f(0, src.rows - 1)};// 定义目标图像中的三个点Point2f dstTri[] = {Point2f(0, src.rows * 0.33), Point2f(src.cols * 0.85, src.rows * 0.25), Point2f(src.cols * 0.15, src.rows * 0.7)};// 获取仿射变换矩阵Mat warpMat = getAffineTransform(srcTri, dstTri);// 应用仿射变换Mat warpedImage;warpAffine(src, warpedImage, warpMat, src.size());// 显示原图像和变换后的图像namedWindow("Original Image", WINDOW_NORMAL);imshow("Original Image", src);namedWindow("Warped Image", WINDOW_NORMAL);imshow("Warped Image", warpedImage);// 等待按键并关闭窗口waitKey(0);destroyAllWindows();return 0;
}

运行结果

在这里插入图片描述


http://www.mrgr.cn/news/2522.html

相关文章:

  • 成为创作者的第1024天:成长与技术积累的旅程
  • 前端面试——js作用域
  • 高性能日志系统 代理模式构建全局日志器获取接口
  • windows hook之进程防杀(任务管理器)
  • 基于UE5和ROS2的激光雷达+深度RGBD相机小车的仿真指南(一)---UnrealCV获取深度+分割图像
  • linux下主机网络不通,如何进行排查?
  • Redis 作为 PHP 的会话存储
  • matlab rng函数的理解和使用
  • ip地址冲突的原因及其解决方法是什么
  • Flask SQLALchemy 的使用
  • 华为OD机试(C卷,100分)- 游戏分组
  • Java面试题———MySql篇②
  • 基于Hadoop的异构网络协同过滤推荐算法设计
  • 深度学习--包的弃用问题
  • 微服务:分布式事务
  • docker+ollama运行微软graphRAG实战流程1-安装运行模型
  • 一口气学完Python编程语言的基础内容
  • 华为LTC流程体系的内涵(附PPT分享)
  • 同态加密和SEAL库的介绍(十)CKKS 参数心得 2
  • [星瞳科技]OpenMV使用时有哪些常见错误和解决办法?