时间:2021-05-22
本文实例为大家分享了opencv实现图像几何变换的具体代码,供大家参考,具体内容如下
图像的扩大与缩小有专门的一个函数,cv2.resize(),那么关于伸缩需要确定的就是缩放比例,可以是x与y方向相同倍数,也可以单独设置x与y的缩放比例。另外一个就是在缩放以后图像必然就会变化,这就又涉及到一个插值问题。那么这个函数中,缩放有几种不同的插值(interpolation)方法,在缩小时推荐cv2.INTER_ARER,扩大是推荐cv2.INTER_CUBIC和cv2.INTER_LINEAR。默认都是cv2.INTER_LINEAR,比如:
import cv2import matplotlib.pyplot as pltimg = cv2.imread('d:/1.jpg')# 插值:interpolation# None本应该是放图像大小的位置的,后面设置了缩放比例,#所有就不要了res1 = cv2.resize(img,None,fx=2,fy=2,interpolation=cv2.INTER_CUBIC)#直接规定缩放大小,这个时候就不需要缩放因子height,width = img.shape[:2]res2 = cv2.resize(img,(2*width,2*height),interpolation=cv2.INTER_CUBIC)plt.subplot(131)plt.imshow(img)plt.subplot(132)plt.imshow(res1)plt.subplot(133)plt.imshow(res2)plt.show()为了构造这个矩阵,opencv提供了一个函数:
cv2.getRotationMatrix2D(),这个函数需要三个参数,旋转中心,旋转角度,旋转后图像的缩放比例,比如下例:
import cv2 import matplotlib.pyplot as plt img = cv2.imread('d:/1.jpg') rows, cols = img.shape[:2] # 第一个参数旋转中心,第二个参数旋转角度,第三个参数:缩放比例 M = cv2.getRotationMatrix2D((cols / 2, rows / 2), 45, 1) # 第三个参数:变换后的图像大小 res = cv2.warpAffine(img, M, (rows, cols)) plt.subplot(121) plt.imshow(img) plt.subplot(122) plt.imshow(res) plt.show()以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
前言总结一下最近看的关于opencv图像几何变换的一些笔记.这是原图:1.平移importcv2importnumpyasnpimg=cv2.imread("i
本文实例为大家分享了Opencv实现图像灰度线性变换的具体代码,供大家参考,具体内容如下通过图像灰度线性变换提高图像对比度和亮度,原图像为src,目标图像为ds
本文实例讲述了Python实现图像几何变换的方法。分享给大家供大家参考。具体实现方法如下:importImagetry:im=Image.open('test.
本文实例讲述了Python实现PS滤镜Fishlens图像扭曲效果。分享给大家供大家参考,具体如下:这里实现PS滤镜中的一种几何变换–Fishlens,对图像做
本文实例讲述了Python图像处理之图像的缩放、旋转与翻转实现方法。分享给大家供大家参考,具体如下:图像的几何变换,如缩放、旋转和翻转等,在图像处理中扮演着重要