我想在远离源的给定距离处绘制同心圆.我试图做的第一件事就是在极坐标图上绘制弧线,因为这似乎是一个逻辑子步骤:
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()
Run Code Online (Sandbox Code Playgroud)
我遇到的第一个问题是,它绘制的是直线而不是弧形:
因此,子问题可能是如何在极坐标图上的给定半径处绘制弧,在这种情况下是360度弧?.另一方面,可能有一个更好的解决方案,也许是一个不涉及极地情节的解决方案.最终,根据标题,我的目标是在中心源周围的一组半径上绘制同心圆.
容易,用它来制作射击目标:
ax.plot(np.linspace(0, 2*np.pi, 100), np.ones(100)*5, color='r', linestyle='-')
Run Code Online (Sandbox Code Playgroud)
想想你如何在极轴上定义一个圆?需要两个方面,角度和半径.这些都是np.linspace(0, 2*np.pi, 100)
和np.ones(100)*5
这里.如果您只需要一个弧,请将第一个参数更改为小于0到2pi的值.并相应地改变第二个参数.
还有其他方法可以做到这一点.如果你想要而不是Line2D
plot()
创建.lines.Line2D object
对象.collections.PathCollection object
:
ax.scatter(1, 0, s=100000, facecolors='none')
Run Code Online (Sandbox Code Playgroud)
或者你想制作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
Run Code Online (Sandbox Code Playgroud)