Python OpenCV 图像平移的实现示例


Posted in Python onJune 04, 2021

每次学习新东西的时候,橡皮擦都是去海量检索,然后找到适合自己理解的部分。

再将其拼凑成一个小的系统,争取对该内容有初步理解。

今天这 1 个小时,核心要学习的是图像的平移,在电脑上随便打开一张图片,实现移动都非常简单,但是在代码中,出现了一些新的概念。

检索 OpenCV 图像平移相关资料时,碰到的第一个新概念是就是 仿射变换

每次看到这样子的数学名字,必然心中一凉,做为一个数学小白,又要瑟瑟发抖了。

百度一下,看看百科中是如何介绍的。

Python OpenCV 图像平移的实现示例

看过上图中的一些相关简介之后,对于这个概念也并没有太深刻的理解,本着先用起来,在补充理论的学习观点,我们先实现图像平移。

学习过程中,碰到一些概念性的东西,可以先应用起来,然后在后续的深入学习过程中,逐步去完善它们。

cv2.warpAffine() 仿射变换

基于该方法去寻找相关资料,得到仿射变换的基本概念,从二维坐标到二维坐标之间的线性变换,并且要保持二维图形的“平直性” 和 “平行性”。

仿射变换中,包含平移,缩放,翻转,旋转,剪切。

该方法的语法结构如下:

dst = cv2.warpAffine(src, M, dsize[, dst[, flags[, borderMode[, borderValue]]]])

参数说明:

  • src:输入图像
  • M:2*3 transformation matrix (转变矩阵)
  • dsize:输出图像的大小,格式为(cols,rows),width 对应 cols,height 对应 rows
  • flags: 可选参数,插值方法的组合(int 类型),默认值 INTER_LINEAR
  • borderMode:可选参数,边界像素模式(int 类型),默认值 BORDER_CONSTANT
  • borderValue:可选参数,边界填充值; 默认情况下,默认值 Scalar()即 0

官方可查阅的英文资料如下:

Python OpenCV 图像平移的实现示例

插值方式(flags)有如下类型:

  • INTER_LINEAR 线性插值
  • INTER_NEAREST 最近邻插值
  • INTER_AREA 区域插值
  • INTER_CUBIC 三次样条插值
  • INTER_LANCZOS4 Lanczos 插值

一般情况下,使用 wrapAffine 前三个参数,即 warpAffine(img,M,(rows,cols)) 实现基本的仿射变换效果,但是这种情况会出现 黑边 现象。

最后一个参数为 borderValue,边界填充的颜色,默认为黑色,可以自行设置为其它颜色。

具体代码

图像平移是图像位置的移动。在平移前,需要先转换矩阵 M,,其中 txty 表示在(x,y)方向上的位移,如下所示:

Python OpenCV 图像平移的实现示例

测试代码如下,重要部分在注释中进行说明。

import numpy as np
import cv2 as cv

img = cv.imread('10.jpg', 1)
rows, cols, channels = img.shape
# [1,0,100] 右移 100, [0,1,50] 下移 50
M = np.float32([[1, 0, 100], [0, 1, 50]])
res = cv.warpAffine(img, M, (cols, rows))
cv.imshow("img", res)
cv.waitKey()

特别说明:
cv.warpAffine 方法的第三个参数是输出图像的大小,其形式应为(width,height)。记住 width =列数(cols),height =行数(rows)。

以下为代码运行结果。

Python OpenCV 图像平移的实现示例

关于 borderMode 参数值的说明:

该部分内容涉及边缘处理,翻阅手册过程找到的说明指向 BorderTypes。翻阅了一下,依旧是有些超纲,可以先记录下相关内容,日后在进行回顾,参考地址

所有值罗列如下:

  • BORDER_CONSTANT = 0
  • BORDER_REPLICATE = 1
  • BORDER_REFLECT = 2
  • BORDER_WRAP = 3
  • BORDER_REFLECT_101 = 4
  • BORDER_TRANSPARENT = 5
  • BORDER_REFLECT101 = BORDER_REFLECT_101
  • BORDER_DEFAULT = BORDER_REFLECT_101
  • BORDER_ISOLATED = 16

Python OpenCV 图像平移的实现示例

borderValue:当图像边界处理方式为 BORDER_CONSTANT 时的填充值。

测试代码如下:

import numpy as np
import cv2 as cv

img = cv.imread('10.jpg', 1)
rows, cols, channels = img.shape
M = np.float32([[1, 0, 100], [0, 1, 50]])
res = cv.warpAffine(img, M, (cols, rows),
                    borderMode=cv.BORDER_CONSTANT, borderValue=(200, 66, 66))
cv.imshow("img", res)
cv.waitKey()

OpenCV 尾声

到此这篇关于Python OpenCV 图像平移的实现示例的文章就介绍到这了,更多相关OpenCV 图像平移内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Python 相关文章推荐
Python实现的简单文件传输服务器和客户端
Apr 08 Python
Python实现压缩与解压gzip大文件的方法
Sep 18 Python
Python 正则表达式入门(中级篇)
Dec 07 Python
Python随机数用法实例详解【基于random模块】
Apr 18 Python
Python复数属性和方法运算操作示例
Jul 21 Python
关于反爬虫的一些简单总结
Dec 13 Python
浅谈python中对于json写入txt文件的编码问题
Jun 07 Python
Python多进程写入同一文件的方法
Jan 14 Python
python使用requests模块实现爬取电影天堂最新电影信息
Apr 03 Python
深入解析神经网络从原理到实现
Jul 26 Python
python orm 框架中sqlalchemy用法实例详解
Feb 02 Python
python json.dumps中文乱码问题解决
Apr 01 Python
Python包argparse模块常用方法
Jun 04 #Python
opencv读取视频并保存图像的方法
Python还能这么玩之用Python做个小游戏的外挂
Jun 04 #Python
python opencv旋转图片的使用方法
Python还能这么玩之用Python修改了班花的开机密码
Anaconda安装pytorch及配置PyCharm 2021环境
python如何利用cv2模块读取显示保存图片
Jun 04 #Python
You might like
PHP_MySQL教程-第一天
2007/03/18 PHP
学习php设计模式 php实现桥梁模式(bridge)
2015/12/07 PHP
php实现根据身份证获取精准年龄
2020/02/26 PHP
PHP如何防止用户重复提交表单
2020/12/09 PHP
javascript 禁止复制网页
2009/06/11 Javascript
JavaScript 闭包在封装函数时的简单分析
2009/11/28 Javascript
Jquery AutoComplete自动完成 的使用方法实例
2010/03/19 Javascript
jQuery实现可收缩展开的级联菜单实例代码
2013/11/27 Javascript
浅析webapp框架AngularUI的demo
2014/12/21 Javascript
浅谈Javascript线程及定时机制
2015/07/02 Javascript
javascript中的五种基本数据类型
2015/08/26 Javascript
BootStrap文件上传样式超好看【持续更新】
2016/05/10 Javascript
原生js封装二级城市下拉列表的实现代码
2016/06/16 Javascript
AngularJS中的API(接口)简单实现
2016/07/28 Javascript
nodejs multer实现文件上传与下载
2017/05/10 NodeJs
使用mint-ui开发项目的一些心得(分享)
2017/09/07 Javascript
Vue 中使用vue2-highcharts实现top功能的示例
2018/03/05 Javascript
深入koa-bodyparser原理解析
2019/01/16 Javascript
基于iview-admin实现动态路由的示例代码
2019/10/02 Javascript
js+canvas实现简单扫雷小游戏
2021/01/22 Javascript
浅谈Python中列表生成式和生成器的区别
2015/08/03 Python
Python实现二叉搜索树
2016/02/03 Python
python对list中的每个元素进行某种操作的方法
2018/06/29 Python
python实现自动登录后台管理系统
2018/10/18 Python
Python OpenCV读取显示视频的方法示例
2020/02/20 Python
Python内建序列通用操作6种实现方法
2020/03/26 Python
用python查找统一局域网下ip对应的mac地址
2021/01/13 Python
RentCars.com巴西:汽车租赁网站
2016/08/22 全球购物
美国摄影爱好者购物网站:Focus Camera
2016/10/21 全球购物
Saucony澳大利亚官网:美国跑鞋品牌,运动鞋中的劳斯莱斯
2018/05/05 全球购物
酒店总经理工作职责
2013/12/13 职场文书
电视购物广告词
2014/03/19 职场文书
党的群众路线教育实践活动个人对照检查材料(企业)
2014/11/05 职场文书
预防艾滋病宣传活动总结
2015/05/09 职场文书
预备党员入党感言
2015/08/01 职场文书
运动会口号霸气押韵
2015/12/24 职场文书