Opencv几何变换

1 图像缩放

缩放是对图像的大小进行调整,即使图像放大或缩小。

API

cv2.resize(src,dsize,fx=0,fy=0,interpolation=cv2.INTER_LINEAR)

参数:

src : 输入图

dsize: 绝对尺寸,直接指定调整后图像的大小

fx,fy: 相对尺寸,将dsize设置为None,然后将fx和fy设置为比例因子即可

interpolation:插值方法,

示例:

 

 

2 图像平移

图像平移将图像按照指定方向和距离,移动到相应的位置。

API

cv.warpAffine(img,M,dsize)

参数:

img: 输入图像

M: 2*∗3移动矩阵

 

注意:将M设置为np.float32类型的Numpy数组。

dsize: 输出图像的大小

注意:输出图像的大小,它应该是(宽度,高度)的形式。请记住,width=列数,height=行数。

示例

需求是将图像的像素点移动(50,100)的距离:

import numpy as np

import cv2 as cv

import matplotlib.pyplot as plt

# 1. 读取图像

img1 = cv.imread("./image/image2.jpg")



# 2. 图像平移

rows,cols = img1.shape[:2]

M = M = np.float32([[1,0,100],[0,1,50]])# 平移矩阵

dst = cv.warpAffine(img1,M,(cols,rows))

# 3. 图像显示

fig,axes=plt.subplots(nrows=1,ncols=2,figsize=(10,8),dpi=100)

axes[0].imshow(img1[:,:,::-1])

axes[0].set_title("原图")

axes[1].imshow(dst[:,:,::-1])

axes[1].set_title("平移后结果")

plt.show()

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

ZSup{A}

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值