我想在远离源的给定距离处绘制同心圆.我试图做的第一件事就是在极坐标图上绘制弧线,因为这似乎是一个逻辑子步骤:
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度弧.另一方面,可能有一个更好的解决方案,也许是一个不涉及极地情节的解决方案.最终,根据标题,我的目标是在中心源周围的一组半径上绘制同心圆.
解决方法:
容易,用它来制作射击目标:
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对象对象,如果你想要.collections.PathCollection对象而不是Line2D:
ax.scatter(1, 0, s=100000, facecolors='none')
或者你想制作补丁:
ax.bar(0, 5, 2*np.pi, bottom=0.0, facecolor='None') #need to modified the edge lines or won't look right
标签:python,matplotlib
来源: https://codeday.me/bug/20190831/1775992.html