【发布时间】:2018-10-28 13:55:37
【问题描述】:
我偶然发现了this question,并正在尝试使用 Python Pillow 执行透视变换。
这就是我正在尝试做的事情以及结果的样子:
这是我曾经尝试过的代码:
from PIL import Image
import numpy
# function copy-pasted from https://stackoverflow.com/a/14178717/744230
def find_coeffs(pa, pb):
matrix = []
for p1, p2 in zip(pa, pb):
matrix.append([p1[0], p1[1], 1, 0, 0, 0, -p2[0]*p1[0], -p2[0]*p1[1]])
matrix.append([0, 0, 0, p1[0], p1[1], 1, -p2[1]*p1[0], -p2[1]*p1[1]])
A = numpy.matrix(matrix, dtype=numpy.float)
B = numpy.array(pb).reshape(8)
res = numpy.dot(numpy.linalg.inv(A.T * A) * A.T, B)
return numpy.array(res).reshape(8)
# test.png is a 256x256 white square
img = Image.open("./images/test.png")
coeffs = find_coeffs(
[(0, 0), (256, 0), (256, 256), (0, 256)],
[(15, 115), (140, 20), (140, 340), (15, 250)])
img.transform((300, 400), Image.PERSPECTIVE, coeffs,
Image.BICUBIC).show()
我不确定转换是如何工作的,但似乎这些点向相反的方向移动(例如,我需要做 (-15, 115) 以使 A 点向右移动。但是,它也赢了'不是移动 15 个像素,而是 5)。
如何确定目标点的确切坐标以正确倾斜图像?
【问题讨论】:
标签: python image-processing python-imaging-library coordinate-transformation