Python3+OpenCV2实现图像的几何变换(平移、镜像、缩放、旋转、仿射)


Posted in Python onMay 13, 2019

前言

总结一下最近看的关于opencv图像几何变换的一些笔记.

这是原图:

Python3+OpenCV2实现图像的几何变换(平移、镜像、缩放、旋转、仿射)

1.平移

import cv2
import numpy as np

img = cv2.imread("image0.jpg", 1)
imgInfo = img.shape
height = imgInfo[0]
width = imgInfo[1]
mode = imgInfo[2]

dst = np.zeros(imgInfo, np.uint8)

for i in range( height ):
  for j in range( width - 100 ):
    dst[i, j + 100] = img[i, j]

cv2.imshow('image', dst)
cv2.waitKey(0)

demo很简单,就是将图像向右平移了100个像素.如图:

Python3+OpenCV2实现图像的几何变换(平移、镜像、缩放、旋转、仿射)

2.镜像

import cv2
import numpy as np


img = cv2.imread('image0.jpg', 1)
cv2.imshow('src', img)
imgInfo = img.shape
height= imgInfo[0]
width = imgInfo[1]
deep = imgInfo[2]

dst = np.zeros([height*2, width, deep], np.uint8)

for i in range( height ):
  for j in range( width ):
    dst[i,j] = img[i,j]
    dst[height*2-i-1,j] = img[i,j]

for i in range(width):
  dst[height, i] = (0, 0, 255)
cv2.imshow('image', dst)
cv2.waitKey(0)

demo生成一个如下效果:

Python3+OpenCV2实现图像的几何变换(平移、镜像、缩放、旋转、仿射)

3.缩放

import cv2
img = cv2.imread("image0.jpg", 1)
imgInfo = img.shape
print( imgInfo )
height = imgInfo[0]
width = imgInfo[1]
mode = imgInfo[2]

# 1 放大 缩小 2 等比例 非等比例
dstHeight = int(height * 0.5)
dstWeight = int(width * 0.5)

# 最近邻域插值 双线性插值 像素关系重采样 立方插值
dst = cv2.resize(img, (dstWeight,dstHeight))
print(dst.shape)
cv2.imshow('image', dst)
cv2.waitKey(0)

使用resize直接进行缩放操作,同时还可以使用邻域插值法进行缩放,代码如下:

# 1 info 2 空白模板 3 重新计算x, y
import cv2
import numpy as np
img = cv2.imread('image0.jpg', 1)
imgInfo = img.shape # 先高度,后宽度
height = imgInfo[0]
width = imgInfo[1]
dstHeight = int(height/2)
dstWidth = int(width/2)

dstImage = np.zeros([dstHeight, dstWidth, 3], np.uint8)
for i in range( dstHeight ):
  for j in range(dstWidth):
    iNew = i * ( height * 1.0 / dstHeight )
    jNew = j * ( width * 1.0 / dstWidth )

    dstImage[i,j] = img[int(iNew),int(jNew)]

cv2.imshow('image', dstImage)
cv2.waitKey(0)

4.旋转

import cv2

img = cv2.imread('image0.jpg', 1)
cv2.imshow('src', img)
imgInfo = img.shape
height= imgInfo[0]
width = imgInfo[1]
deep = imgInfo[2]

# 定义一个旋转矩阵
matRotate = cv2.getRotationMatrix2D((height*0.5, width*0.5), 45, 0.7) # mat rotate 1 center 2 angle 3 缩放系数

dst = cv2.warpAffine(img, matRotate, (height, width))

cv2.imshow('image',dst)
cv2.waitKey(0)

旋转需要先定义一个旋转矩阵,cv2.getRotationMatrix2D(),参数1:需要旋转的中心点.参数2:需要旋转的角度.参数三:需要缩放的比例.效果如下图:

Python3+OpenCV2实现图像的几何变换(平移、镜像、缩放、旋转、仿射)

5.仿射

import cv2
import numpy as np

img = cv2.imread('image0.jpg', 1)
cv2.imshow('src', img)
imgInfo = img.shape
height= imgInfo[0]
width = imgInfo[1]
deep = imgInfo[2]
# src 3 -> dst 3 (左上角, 左下角,右上角)
matSrc = np.float32([[0,0],[0,height-1],[width-1, 0]]) # 需要注意的是 行列 和 坐标 是不一致的
matDst = np.float32([[50,50],[100, height-50],[width-200,100]])

matAffine = cv2.getAffineTransform(matSrc,matDst) #mat 1 src 2 dst 形成组合矩阵
dst = cv2.warpAffine(img, matAffine,(height, width))
cv2.imshow('image',dst)
cv2.waitKey(0)

需要确定图像矩阵的三个点坐标,及(左上角, 左下角,右上角).定义两个矩阵,matSrc 为原图的三个点坐标,matDst为进行仿射的三个点坐标,通过cv2.getAffineTransform()形成组合矩阵.效果如下:

Python3+OpenCV2实现图像的几何变换(平移、镜像、缩放、旋转、仿射)

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Python 相关文章推荐
pyqt和pyside开发图形化界面
Jan 22 Python
Python中用Decorator来简化元编程的教程
Apr 13 Python
用PyQt进行Python图形界面的程序的开发的入门指引
Apr 14 Python
详解Python中open()函数指定文件打开方式的用法
Jun 04 Python
Python的Django框架中消息通知的计数器实现教程
Jun 13 Python
Python实现螺旋矩阵的填充算法示例
Dec 28 Python
对numpy的array和python中自带的list之间相互转化详解
Apr 13 Python
python清除字符串前后空格函数的方法
Oct 21 Python
Python多线程thread及模块使用实例
Apr 28 Python
浅谈Python协程
Jun 17 Python
PyQT5 实现快捷键复制表格数据的方法示例
Jun 19 Python
python中编写函数并调用的知识点总结
Jan 13 Python
Python 通过打码平台实现验证码的实现
May 13 #Python
利用python和百度地图API实现数据地图标注的方法
May 13 #Python
一篇文章彻底搞懂Python中可迭代(Iterable)、迭代器(Iterator)与生成器(Generator)的概念
May 13 #Python
为什么你还不懂得怎么使用Python协程
May 13 #Python
Python玩转加密的技巧【推荐】
May 13 #Python
11个Python3字典内置方法大全与示例汇总
May 13 #Python
python中的数据结构比较
May 13 #Python
You might like
hessian 在PHP中的使用介绍
2010/12/13 PHP
解析php中curl_multi的应用
2013/07/17 PHP
PHP中关键字interface和implements详解
2017/06/14 PHP
基于laravel Request的所有方法详解
2019/09/29 PHP
Laravel登录失败次数限制的实现方法
2020/08/26 PHP
JSON 入门指南 想了解json的朋友可以看下
2009/08/26 Javascript
jsTree树控件(基于jQuery, 超强悍)[推荐]
2009/09/01 Javascript
json 实例详细说明教程
2009/10/31 Javascript
关闭浏览器时提示onbeforeunload事件
2013/12/25 Javascript
Winform客户端向web地址传参接收参数的方法
2016/05/17 Javascript
js实现浏览器倒计时跳转页面效果
2016/08/12 Javascript
JQuery学习总结【一】
2016/12/01 Javascript
浅谈JavaScript的闭包函数
2016/12/08 Javascript
微信小程序 在线支付功能的实现
2017/03/14 Javascript
jQuery动态产生select option下拉列表
2017/03/15 Javascript
js对象实例详解(JavaScript对象深度剖析,深度理解js对象)
2017/09/21 Javascript
让Vue也可以使用Redux的方法
2018/05/23 Javascript
vue.js内置组件之keep-alive组件使用
2018/07/10 Javascript
React Native开发封装Toast与加载Loading组件示例
2018/09/08 Javascript
JavaScript动态添加数据到表单并提交的几种方式
2019/06/26 Javascript
Python入门篇之面向对象
2014/10/20 Python
Python中使用MELIAE分析程序内存占用实例
2015/02/18 Python
Python下的Softmax回归函数的实现方法(推荐)
2017/01/26 Python
利用Python中的pandas库对cdn日志进行分析详解
2017/03/07 Python
python 递归遍历文件夹,并打印满足条件的文件路径实例
2017/08/30 Python
便捷提取python导入包的属性方法
2018/10/15 Python
浅谈python 读excel数值为浮点型的问题
2018/12/25 Python
在python3中实现查找数组中最接近与某值的元素操作
2020/02/29 Python
Python3之乱码\xe6\x97\xa0\xe6\xb3\x95处理方式
2020/05/11 Python
python中spy++的使用超详细教程
2021/01/29 Python
HTML5 在canvas中绘制矩形附效果图
2014/06/23 HTML / CSS
学校节能减排倡议书
2014/05/16 职场文书
汽车运用工程专业求职信
2014/06/18 职场文书
管理工程专业求职信
2014/08/10 职场文书
2015年宣传工作总结
2015/04/08 职场文书
运动会广播稿100字
2015/08/19 职场文书