3

我想在远离源的给定距离处绘制同心圆。我尝试做的第一件事是在极坐标图上画一条弧线,因为这似乎是一个合乎逻辑的子步骤:

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 度弧?. 另一方面,可能有一个更好的解决方案,也许是一个不涉及极地情节的解决方案。最终,根据标题,我的目标是在围绕中心源的一组半径处绘制同心圆。

4

1 回答 1

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()创建.lines.Line2D object对象,如果你想.collections.PathCollection object而不是 Line2D:

ax.scatter(1, 0, s=100000, facecolors='none')

或者你想制作patches:

ax.bar(0, 5, 2*np.pi, bottom=0.0, facecolor='None') #need to modified the edge lines or won't look right
于 2013-10-02T06:31:06.427 回答