Matplotlib 极坐标图的反向径向轴
Reverse radial axes of Matplotlib polar plot
我正在尝试创建一个天文极坐标图,其径向轴从外线的 -45° 开始,并在图的中心增加到 90°。但是我没有找到任何方法来反转 PolarAxes 实例的径向轴。 invert_yaxis()
方法根本不起作用。此外,还有一些隐藏方法,例如ax.set_rlim()
,没有任何文档。
这是我当前的代码:
fig = plt.figure()
ax = fig.add_axes([0.1,0.1,0.8,0.8], polar=True)
# ax.invert_yaxis()
ax.set_theta_zero_location('N')
ax.set_ylim(-45, 90)
ax.set_yticks(np.arange(-45, 90, 15))
ax.plot(ras, decs, linestyle='', marker='.')
还有我的情节
有点"hacky",但如果您知道界限(这看起来像是您所做的,因为它对应于赤纬),您可以这样做:
import matplotlib.pyplot as plt
import numpy as np
fig = plt.figure()
ax = fig.add_axes([0.1,0.1,0.8,0.8], polar=True)
# ax.invert_yaxis()
ax.set_theta_zero_location('N')
ax.set_rlim(90, -45, 1)
# Note: you must set the end of arange to be slightly larger than 90 or it won't include 90
ax.set_yticks(np.arange(-45, 91, 15))
ax.set_yticklabels(ax.get_yticks()[::-1])
ax.plot([0,10,20], 90-np.array([12,13,14]), linestyle='', marker='.')
fig.show()
老问题,但我终于找到了一个简单的答案。使用 ax.set_rlim(bottom=90, top=-45)
。请注意,您必须在调用 ax.plot()
之前设置它,否则它不会相应地转换绘制点。
我正在尝试创建一个天文极坐标图,其径向轴从外线的 -45° 开始,并在图的中心增加到 90°。但是我没有找到任何方法来反转 PolarAxes 实例的径向轴。 invert_yaxis()
方法根本不起作用。此外,还有一些隐藏方法,例如ax.set_rlim()
,没有任何文档。
这是我当前的代码:
fig = plt.figure()
ax = fig.add_axes([0.1,0.1,0.8,0.8], polar=True)
# ax.invert_yaxis()
ax.set_theta_zero_location('N')
ax.set_ylim(-45, 90)
ax.set_yticks(np.arange(-45, 90, 15))
ax.plot(ras, decs, linestyle='', marker='.')
还有我的情节
有点"hacky",但如果您知道界限(这看起来像是您所做的,因为它对应于赤纬),您可以这样做:
import matplotlib.pyplot as plt
import numpy as np
fig = plt.figure()
ax = fig.add_axes([0.1,0.1,0.8,0.8], polar=True)
# ax.invert_yaxis()
ax.set_theta_zero_location('N')
ax.set_rlim(90, -45, 1)
# Note: you must set the end of arange to be slightly larger than 90 or it won't include 90
ax.set_yticks(np.arange(-45, 91, 15))
ax.set_yticklabels(ax.get_yticks()[::-1])
ax.plot([0,10,20], 90-np.array([12,13,14]), linestyle='', marker='.')
fig.show()
老问题,但我终于找到了一个简单的答案。使用 ax.set_rlim(bottom=90, top=-45)
。请注意,您必须在调用 ax.plot()
之前设置它,否则它不会相应地转换绘制点。