gpt4 book ai didi

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

转载 作者:行者123 更新时间:2023-12-02 16:48:19 24 4
gpt4 key购买 nike

当我使用warpAffine剪切图像时:

M2 = np.float32([[1, 0, 0], [0.2, 1, 0]])
aff2 = cv2.warpAffine(im, M2, (W, H))

我获得的图像在图像中心周围没有被剪切。我可以在图像的一侧看到黑色三角形区域,而另一侧没有黑色区域。

如何让图像对称地剪切?

最佳答案

您必须调整翻译参数(第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))

之前

enter image description here



enter image description here

完整代码
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")

关于python - 我如何使用opencv实现居中剪切图像,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57881430/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com