我想在远离源的给定距离处绘制同心圆。我试图做的第一件事就是在极坐标图上绘制弧线,因为这似乎是一个逻辑子步骤:
import numpy as np
import matplotlib.pyplot as plt
fig = plt.figure()
ax = fig.add_subplot(111, polar=True)
ax.plot([1.0,1.5], [5,5], color='r', linestyle='-')
plt.show()
我遇到的第一个问题是它画了一条直线而不是一条弧:
所以子问题可能是如何在极坐标图上的给定半径处绘制弧,在这种情况下是360度弧?。另一方面,可能有一个更好的解决方案,也许是一个不涉及极地情节的解决方案。最终,根据标题,我的目标是在中心源周围的一组半径上绘制同心圆。
答案 0 :(得分:5)
简单,用它来制作射击目标。:
ax.plot(np.linspace(0, 2*np.pi, 100), np.ones(100)*5, color='r', linestyle='-')
想想你如何在极轴上定义一个圆?需要两个方面,角度和半径。这些是np.linspace(0, 2*np.pi, 100)
和np.ones(100)*5
。如果您只需要一个弧,请将第一个参数更改为小于0到2pi的值。并相应地改变第二个参数。
还有其他方法可以做到这一点。如果您需要plot()
而不是Line2D,.lines.Line2D object
会创建.collections.PathCollection object
个对象:
ax.scatter(1, 0, s=100000, facecolors='none')
或者你想制作patch
es:
ax.bar(0, 5, 2*np.pi, bottom=0.0, facecolor='None') #need to modified the edge lines or won't look right