我有两个点并将它们绘制成一条线,如下图所示。
fig=plt.figure(figsize=(7,6))
plt.plot(lont[-2:],latt[-2:],'b')
plt.show()
现在我想将这条线旋转45度(以两点之一为原点)我该怎么办?
我有两个点并将它们绘制成一条线,如下图所示。
fig=plt.figure(figsize=(7,6))
plt.plot(lont[-2:],latt[-2:],'b')
plt.show()
现在我想将这条线旋转45度(以两点之一为原点)我该怎么办?
旋转如下所示:
newx = (x1 - xorigin)*cos(45 * pi / 180)
newy = (y1 - yorigin)*sin(45 * pi / 180)
如果您的一个点是原点,您只需将其应用于另一点
import matplotlib.pyplot as plt
import numpy as np
import pandas as pd
angle = np.deg2rad(45)
lont = pd.Series([1, 2, 4, 6])
latt = pd.Series([4, 6, 3, 2])
R = (lont.diff()**2 + latt.diff()**2)**0.5
theta = np.arctan(latt.diff()/lont.diff())
Xnew = lont.shift(1)+ R*np.cos(angle + theta)
Ynew = latt.shift(1) + R*np.sin(angle+ theta)
fig=plt.figure()
plt.plot(lont, latt,'-ob')
plt.plot([lont.iloc[-n-2], Xnew.iloc[-n-1]], [latt.iloc[-n-2], Ynew.iloc[-n-1]], ":*r")
plt.show()