依星源码资源网,依星资源网

 找回密码
 立即注册

QQ登录

只需一步,快速开始

【好消息,好消息,好消息】VIP会员可以发表文章赚积分啦 !
查看: 17|回复: 0

OpenCV图像平移

[复制链接] 主动推送

1万

主题

1万

帖子

1万

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
15517
发表于 昨天 11:27 | 显示全部楼层 |阅读模式
OpenCV图像平移
图像平移是将图像的所有像素坐标进行水平或垂直方向移动,也就是所有像素按照给定的偏移量在水平方向上沿x轴、垂直方向上沿y轴移动。这种操作分为两种,一种是图像大小不改变,这样最后原图像中会有一部分不在图像中。还有一种就是图像大小改变。这样可以保全原图像的内容。其公式如下:

OpenCV图像平移

OpenCV图像平移


从实现角度讲,其实就是拷贝原图像中的一部分到新图像中,用OpenCV实现代码如下:
  1. Mat imgTranslate(Mat &matSrc, int xOffset, int yOffset, bool bScale)
  2. {
  3.         // 判断是否改变图像大小,并设定被复制ROI
  4.         int nRows = matSrc.rows;
  5.         int nCols = matSrc.cols;
  6.         int nRowsRet = 0;
  7.         int nColsRet = 0;
  8.         Rect rectSrc;
  9.         Rect rectRet;
  10.         if (bScale)
  11.         {
  12.                 nRowsRet = nRows + abs(yOffset);
  13.                 nColsRet = nCols + abs(xOffset);
  14.                 rectSrc.x = 0;
  15.                 rectSrc.y = 0;
  16.                 rectSrc.width = nCols;
  17.                 rectSrc.height = nRows;
  18.         }
  19.         else
  20.         {
  21.                 nRowsRet = matSrc.rows;
  22.                 nColsRet = matSrc.cols;
  23.                 if (xOffset >= 0)
  24.                 {
  25.                         rectSrc.x = 0;
  26.                 }
  27.                 else
  28.                 {
  29.                         rectSrc.x = abs(xOffset);
  30.                 }
  31.                 if (yOffset >= 0)
  32.                 {
  33.                         rectSrc.y = 0;
  34.                 }
  35.                 else
  36.                 {
  37.                         rectSrc.y = abs(yOffset);
  38.                 }
  39.                 rectSrc.width = nCols - abs(xOffset);
  40.                 rectSrc.height = nRows - abs(yOffset);
  41.         }
  42.         // 修正输出的ROI
  43.         if (xOffset >= 0)
  44.         {
  45.                 rectRet.x = xOffset;
  46.         }
  47.         else
  48.         {
  49.                 rectRet.x = 0;
  50.         }
  51.         if (yOffset >= 0)
  52.         {
  53.                 rectRet.y = yOffset;
  54.         }
  55.         else
  56.         {
  57.                 rectRet.y = 0;
  58.         }
  59.         rectRet.width = rectSrc.width;
  60.         rectRet.height = rectSrc.height;
  61.         // 复制图像
  62.         Mat matRet(nRowsRet, nColsRet, matSrc.type(), Scalar(0));
  63.         matSrc(rectSrc).copyTo(matRet(rectRet));
  64.         return matRet;
  65. }
  66. ... prompt'''
复制代码
调用代码如下:
  1. #include "opencv2/core/core.hpp"
  2. #include "opencv2/imgproc/imgproc.hpp"
  3. #include "opencv2/highgui/highgui.hpp"
  4. #include <iostream>
  5. #include <string>

  6. using namespace cv;

  7. int main()
  8. {
  9.         std::string strPath = "D:\\我的文档\\My Pictures\\OpenCV\";
  10.         Mat matSrc = imread(strPath + "熊猫.jpg");
  11.         // 判断是否真确读取数据
  12.         if (matSrc.empty())
  13.                 return 1;
  14.         // 平移图像
  15.         Mat matScale_0 = imgTranslate(matSrc, 50, 50, false);
  16.         Mat matScale_1 = imgTranslate(matSrc, -50, -50, false);
  17.         Mat matScale_2= imgTranslate(matSrc, 50, 50, true);
  18.         Mat matScale_3 = imgTranslate(matSrc, -50, -50, true);
  19.         
  20.         // 保存图像
  21.         imwrite(strPath + "0.jpg", matScale_0);
  22.         imwrite(strPath + "1.jpg", matScale_1);
  23.         imwrite(strPath + "2.jpg", matScale_2);
  24.         imwrite(strPath + "3.jpg", matScale_3);

  25.         // 显示图像
  26.         imshow("src", matSrc);
  27.         imshow("ret_0", matScale_0);
  28.         imshow("ret_1", matScale_1);
  29.         imshow("ret_2", matScale_2);
  30.         imshow("ret_3", matScale_3);

  31.         waitKey();
  32.         return 0;
  33. }
复制代码
运行效果如下:
不改变图像大小

OpenCV图像平移

OpenCV图像平移

OpenCV图像平移

OpenCV图像平移
改变图像大小

OpenCV图像平移

OpenCV图像平移

OpenCV图像平移

OpenCV图像平移


相关帖子

扫码关注微信公众号,及时获取最新资源信息!下载附件优惠VIP会员6折;永久VIP4折
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

免责声明:
1、本站提供的所有资源仅供参考学习使用,版权归原著所有,禁止下载本站资源参与商业和非法行为,请在24小时之内自行删除!
2、本站所有内容均由互联网收集整理、网友上传,并且以计算机技术研究交流为目的,仅供大家参考、学习,请勿任何商业目的与商业用途。
3、若您需要商业运营或用于其他商业活动,请您购买正版授权并合法使用。
4、论坛的所有内容都不保证其准确性,完整性,有效性,由于源码具有复制性,一经售出,概不退换。阅读本站内容因误导等因素而造成的损失本站不承担连带责任。
5、用户使用本网站必须遵守适用的法律法规,对于用户违法使用本站非法运营而引起的一切责任,由用户自行承担
6、本站所有资源来自互联网转载,版权归原著所有,用户访问和使用本站的条件是必须接受本站“免责声明”,如果不遵守,请勿访问或使用本网站
7、本站使用者因为违反本声明的规定而触犯中华人民共和国法律的,一切后果自己负责,本站不承担任何责任。
8、凡以任何方式登陆本网站或直接、间接使用本网站资料者,视为自愿接受本网站声明的约束。
9、本站以《2013 中华人民共和国计算机软件保护条例》第二章 “软件著作权” 第十七条为原则:为了学习和研究软件内含的设计思想和原理,通过安装、显示、传输或者存储软件等方式使用软件的,可以不经软件著作权人许可,不向其支付报酬。若有学员需要商用本站资源,请务必联系版权方购买正版授权!
10、本网站如无意中侵犯了某个企业或个人的知识产权,请来信【站长信箱312337667@qq.com】告之,本站将立即删除。
郑重声明:
本站所有资源仅供用户本地电脑学习源代码的内含设计思想和原理,禁止任何其他用途!
本站所有资源、教程来自互联网转载,仅供学习交流,不得商业运营资源,不确保资源完整性,图片和资源仅供参考,不提供任何技术服务。
本站资源仅供本地编辑研究学习参考,禁止未经资源商正版授权参与任何商业行为,违法行为!如需商业请购买各资源商正版授权
本站仅收集资源,提供用户自学研究使用,本站不存在私自接受协助用户架设游戏或资源,非法运营资源行为。
 
在线客服
点击这里给我发消息 点击这里给我发消息 点击这里给我发消息
售前咨询热线
312337667

微信扫一扫,私享最新原创实用干货

QQ|免责声明|小黑屋|依星资源网 ( 鲁ICP备2021043233号-3 )|网站地图

GMT+8, 2025-4-16 16:18

Powered by Net188.com X3.4

邮箱:312337667@qq.com 客服QQ:312337667(工作时间:9:00~21:00)

快速回复 返回顶部 返回列表