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

OpenCV 图形API(80)图像与通道拼接函数-----仿射变换函数warpAffine()

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

算法描述

对图像应用仿射变换。
函数 warpAffine 使用指定的矩阵对源图像进行变换:
dst ( x , y ) = src ( M 11 x + M 12 y + M 13 , M 21 x + M 22 y + M 23 ) \texttt{dst} (x,y) = \texttt{src} ( \texttt{M} _{11} x + \texttt{M} _{12} y + \texttt{M} _{13}, \texttt{M} _{21} x + \texttt{M} _{22} y + \texttt{M} _{23}) dst(x,y)=src(M11x+M12y+M13,M21x+M22y+M23)
当设置了标志 WARP_INVERSE_MAP 时,使用上述公式。

否则,变换矩阵会先通过 invertAffineTransform 被求逆,然后才代入上面的公式中代替 M。

该函数不能在原地(in-place)操作。

函数原型

GMat cv::gapi::warpAffine 	
(const GMat &  	src,const Mat &  	M,const Size &  	dsize,int  	flags = cv::INTER_LINEAR,int  	borderMode = cv::BORDER_CONSTANT,const Scalar &  	borderValue = Scalar() 
) 		

参数

  • 参数 src:输入图像。
  • 参数 M:2×3 的变换矩阵。
  • 参数 dsize:输出图像的尺寸(宽度,高度)。
  • 参数 flags:
    插值方法的组合(参见 InterpolationFlags);
    可选标志 WARP_INVERSE_MAP,表示矩阵 M 是一个“逆变换”(即从目标图像映射到源图像,dst → src)。
  • 参数 borderMode:像素外推方法(参见 BorderTypes);
    不支持 BORDER_TRANSPARENT 模式。
  • 参数 borderValue:当边界模式为常量填充时所使用的像素值;
    默认值为 0(黑色)。

代码示例

#include <opencv2/opencv.hpp>
#include <opencv2/gapi.hpp>
#include <opencv2/gapi/core.hpp>
#include <opencv2/gapi/imgproc.hpp>using namespace cv;
using namespace cv::gapi;int main() {// 加载输入图像Mat src = imread("/media/dingxin/data/study/OpenCV/sources/images/Lenna.png");if (src.empty()) {std::cerr << "无法加载图像!" << std::endl;return -1;}// 定义仿射变换矩阵 M// 示例:将图像旋转 45 度,并平移 (50, 50)double angle = 45; // 旋转角度double scale = 1;  // 缩放比例Point2f center(src.cols / 2.0, src.rows / 2.0); // 旋转中心Mat M = getRotationMatrix2D(center, angle, scale);// 添加平移M.at<double>(0, 2) += 50;M.at<double>(1, 2) += 50;// 定义输出图像尺寸Size new_size(src.cols, src.rows);// 定义 G-API 图像处理图(graph)GMat in;  // 输入节点// 应用仿射变换GMat out = gapi::warpAffine(in, M, new_size, INTER_LINEAR, BORDER_CONSTANT, Scalar(0, 0, 0));// 构建 GComputationGComputation computation(in, out);// 执行计算Mat dst;computation.apply(src, dst);// 显示结果imshow("原始图像", src);imshow("仿射变换后的图像", dst);waitKey();return 0;
}

运行结果

在这里插入图片描述

http://www.xdnf.cn/news/308773.html

相关文章:

  • SAP修改数据库表
  • 大疆三方云平台部署
  • 网页截图指南
  • PDF内容搜索--支持跨文件夹多文件、组合词搜索
  • debian中笔记本的省电选择auto-cpufreq
  • 解决windows重启后分辨率问题
  • 2025最新出版 Microsoft Project由入门到精通
  • 雅思阅读--重点短语/句式39个
  • 小红书怎么看自己ip地址?小红书更改ip地址教学
  • UE5 脚部贴地不穿过地板方案
  • 含锡废水回收率提升技术方案
  • 37-算法打卡-栈与队列-滑动窗口最大值-leetcode(239)-第三十七天
  • ==和equals的区别 hashCode和equals的联系
  • 文章记单词 | 第65篇(六级)
  • 【JavaScript】将字符串转为base64
  • C/C++ 扩展智能提示太慢或无法解析项目
  • 使用VMware Workstation pro 17.5.1在Windows上安装Ubuntu 24.04.2的 详细步骤
  • 第一章-语言基础\3.STL
  • RHCSA Linux系统 网络管理
  • Grafana-新增用户
  • 104二叉树的最大深度
  • 标签语句分析
  • 第11次:用户注册(简要版)
  • 【大模型面试】大模型(LLMs)高频面题全面整理(★2025年5月最新版★)
  • 13前端项目----购物车修改
  • 结合Hutool 突增突降检测的算法
  • Linuxweb服务的部署及优化
  • 网站主机控制面板深度解析:cPanel、Plesk 及其他主流选择
  • AIDC智算中心建设:存储核心技术解析
  • suna直接从agent启动时,死循环问题