我在X轴上有点,我想做从每个点到另一个点(X2,Y2)的直线。
这段代码是用于从Y=35到X点(P
)的蓝线,它可以工作
pos_fixed = np.array([0, TR])
lines = np.array([[[pos, 0], pos_fixed] for pos in P])
line_coll = LineCollection(lines)
fig, ax = plt.subplots()
ax.add_collection(line_coll)
plt.xlim([0, lines[:,:,0].max()])
plt.ylim([0, lines[:,:,1].max()])
plt.xlabel('Oś')
plt.ylabel('Promień')
plt.show()
下面是代码,它应该完成我在开始描述的内容:
for s in range(len(P)-1):
position = np.array([P[s], 0])
lines = np.array([[position, [x2[s], y2[s]]]])
line_coll = LineCollection(lines)
fig, ax = plt.subplots()
ax.add_collection(line_coll)
plt.xlim([0, lines[:,:,0].max()])
plt.ylim([0, lines[:,:,1].max()])
plt.show()
我的期望在附图上(我有红色和紫色的点,我不知道如何做绿色线条)。
这段代码(第二段)显示了几十个图表(每条绿色的线都是单独的),并且不包括(我希望)前面的代码/前面的图表。
发布于 2019-04-15 04:04:24
您将在每个循环上创建一个图形。您可以首先设置图形,然后在for
循环中添加行。重新排列代码,如下所示:
# create the figure
fig, ax = plt.subplots()
plt.xlim([0, lines[:,:,0].max()])
plt.ylim([0, lines[:,:,1].max()])
# lines from the first part of the question
pos_fixed = np.array([0, TR])
lines = np.array([[[pos, 0], pos_fixed] for pos in P])
line_coll = LineCollection(lines,colors='blue')
ax.add_collection(line_coll)
plt.xlabel('Oś')
plt.ylabel('Promień')
# lines for the second part
for s in range(len(P)-1):
position = np.array([P[s], 0])
lines = np.array([[position, [x2[s], y2[s]]]])
line_coll = LineCollection(lines,colors='green')
ax.add_collection(line_coll)
plt.show()
https://stackoverflow.com/questions/55678968
复制相似问题