gpt4 book ai didi

python - OpenCV python3无法正确旋转图像

转载 作者:行者123 更新时间:2023-12-02 17:08:32 26 4
gpt4 key购买 nike

我想将python3与OpenCV软件包一起使用,以15度旋转图像并将其旋转回去。但是,下面的代码似乎不起作用,但是我认为代码中没有逻辑错误。在“NEAREST”窗口中,图像已正确旋转,但在“NEAREST-OK-RESTORE”窗口中,图像未旋转回到其原始位置(显示在“原始”窗口中)。

enter image description here

#! /usr/bin/env python3
#! -*- coding:utf-8 -*-

import cv2
import numpy as np

imgmat = cv2.imread('./lena.jpg',255)
print(hex(id(imgmat)))

cv2.imshow('original',imgmat)

rows,cols = imgmat.shape

M = cv2.getRotationMatrix2D((cols/2,rows/2),-15,1)
dst = cv2.warpAffine(src=imgmat,M=M,dsize=(cols,rows),flags=cv2.INTER_NEAREST)
print(hex(id(dst)))
cv2.imshow('NEAREST',dst)


OKMM = cv2.invertAffineTransform(M)
dst = cv2.warpAffine(dst,OKMM,(cols,rows),flags = cv2.INTER_NEAREST)
print(hex(id(dst)))
cv2.imshow('NEAREST-OK-RESTORE',dst)

cv2.waitKey(0)

测试图像在这里:
enter image description here

最佳答案

发生这种情况的原因是,当您执行旋转时,这是在原始图像尺寸的范围内进行的,因此,如果您旋转图像,则会导致图像剪裁,并且产生的角点会超出原始图像尺寸。

您需要做的是对图像进行零填充,以便将旋转后的图像完全包含在其中,然后旋转该图像,然后向后旋转时,您将不得不裁剪结果。

要确定对图像进行零填充的方式,请注意,当图像旋转45度时,图像的最大可能尺寸为。这意味着图像的对角线现在将是图像中的行数。因此,对图像进行零填充,以便我们至少可以在进行45度旋转时存储图像,旋转该图像,然后向后旋转,则必须裁剪结果。

您可以使用 numpy.pad 为您完成此操作,完成后,您可以简单地裁剪结果:

我对您的代码进行了以下更改以实现此目的:

import cv2
import numpy as np

imgmat = cv2.imread('./lena.jpg',255)
print(hex(id(imgmat)))

cv2.imshow('original',imgmat)

rows,cols = imgmat.shape

# NEW - Determine the diagonal length of the image
diagonal = int(np.ceil(np.sqrt(rows**2.0 + cols**2.0)))

# NEW - Determine how many pixels we need to pad to the top/bottom and left/right
pp_r, pp_c = (diagonal - rows) // 2, (diagonal - cols) // 2

# NEW - Pad the image
imgmat_copy = np.pad(imgmat, ((pp_r, pp_r), (pp_c, pp_c)), 'constant', constant_values=(0,0))

### Your code as before - note we are rotating the zero padded image
rows,cols = imgmat_copy.shape
M = cv2.getRotationMatrix2D((cols/2,rows/2),-15,1)
dst = cv2.warpAffine(src=imgmat_copy,M=M,dsize=imgmat_copy.shape,flags=cv2.INTER_NEAREST)
print(hex(id(dst)))
cv2.imshow('NEAREST',dst)


OKMM = cv2.invertAffineTransform(M)
dst = cv2.warpAffine(dst,OKMM,(cols,rows),flags = cv2.INTER_NEAREST)
print(hex(id(dst)))

# NEW - Crop the image
dst = dst[pp_r:-pp_r+1,pp_c:-pp_c+1]
cv2.imshow('NEAREST-OK-RESTORE',dst)
cv2.waitKey(0)
cv2.destroyAllWindows()

我现在得到:

enter image description here

关于python - OpenCV python3无法正确旋转图像,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49516630/

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