为了账号安全,请及时绑定邮箱和手机立即绑定

如何使用opencv实现居中剪切图像

如何使用opencv实现居中剪切图像

一只斗牛犬 2022-05-24 10:51:14
当我使用 warpAffine 剪切图像时:M2 = np.float32([[1, 0, 0], [0.2, 1, 0]])aff2 = cv2.warpAffine(im, M2, (W, H))我获得了在图像中心周围没有剪切的图像。我可以在图像的一侧看到黑色三角形区域,而另一侧没有黑色区域。我怎样才能让图像被对称剪切?
查看完整描述

1 回答

?
RISEBY

TA贡献1856条经验 获得超5个赞

您必须调整翻译参数(第 3 列)以使图像居中。即你必须翻译一半的宽度和高度乘以一个因子。


例如


M2 = np.float32([[1, 0, 0], [0.2, 1, 0]])

M2[0,2] = -M2[0,1] * W/2

M2[1,2] = -M2[1,0] * H/2

aff2 = cv2.warpAffine(im, M2, (W, H))

//img1.sycdn.imooc.com//628c483c00018aeb02500248.jpg

//img1.sycdn.imooc.com//628c484600011fef02460244.jpg

完整代码

import cv2

import numpy as np

import matplotlib.pyplot as plt


im = np.ones((100,100))

H, W = im.shape


M2 = np.float32([[1, 0, 0], [0.2, 1, 0]])

M2[0,2] = -M2[0,1] * W/2

M2[1,2] = -M2[1,0] * H/2

aff2 = cv2.warpAffine(im, M2, (W, H))


plt.imshow(aff2, cmap="gray")


查看完整回答
反对 回复 2022-05-24
  • 1 回答
  • 0 关注
  • 125 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
微信客服

购课补贴
联系客服咨询优惠详情

帮助反馈 APP下载

慕课网APP
您的移动学习伙伴

公众号

扫描二维码
关注慕课网微信公众号