计算机视觉之opencv: 剪切,移位,镜像,旋转,仿射

#剪切
import numpy as np
import cv2
img=cv2.imread('1.jpg')
img_new=img[1:200,200:400]
cv2.imshow('window',img_new)
cv2.waitKey(0)
#移位
import numpy as np
import cv2
img=cv2.imread('1.jpg')
img_new=np.zeros(img.shape,np.uint8)
for i in range(img.shape[0]-100):
    for j in range(img.shape[1]-100):
        img_new[i+100][j+100]=img[i][j]
cv2.imshow('window',img_new)
cv2.waitKey(0)
#镜像
import numpy as np
import cv2
img=cv2.imread('1.jpg')
rnum=img.shape[0]
cnum=img.shape[1]
img_new=np.zeros([rnum,cnum*2,3],np.uint8)

for i in range(rnum):
    for j in range(cnum):
        img_new[i][j]=img[i][j]
        img_new[i][2*cnum-1-j]=img[i][j]
cv2.imshow('window',img_new)
cv2.waitKey(0)
#旋转
import numpy as np
import cv2
img=cv2.imread('1.jpg',1)
cv2.imshow('src',img)
rnum=img.shape[0]
cnum=img.shape[1]

matrotate=cv2.getRotationMatrix2D((rnum*0.5,cnum*0.5),45,0.5)
dst=cv2.warpAffine(img,matrotate,(rnum,cnum))
cv2.imshow('dst',dst)
cv2.waitKey(0)

#仿射
import cv2
import numpy as np
img=cv2.imread('1.jpg')
cv2.imshow('src',img)
rnum=img.shape[0]
cnum=img.shape[1]
matsrc=np.float32([[0,0],
                   [0,rnum-1],
                   [cnum-1,0]])
matdst=np.float32([[50,50],
                   [300,rnum-200],
                   [cnum-300,100]])
mataffine=cv2.getAffineTransform(matsrc,matdst)
dst=cv2.warpAffine(img,mataffine,(cnum,rnum))
cv2.imshow('dst',dst)
cv2.waitKey(0)
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值