# 导入模块
import numpy as np
import matplotlib.pyplot as plt
import matplotlib.animation as animation
# 0. 设置中文黑体
plt.rcParams["font.sans-serif"] = ["SimHei"]
plt.rcParams["axes.unicode_minus"] = False
# 1. 准备正弦曲线数据
x = np.linspace(0, 2*np.pi, 100)
y = np.sin(x)
# 2. 创建画布和坐标系
fig = plt.figure(tight_layout=True)
ax = fig.add_subplot(111)
# 3. 绘制正弦曲线
# x[0],y[0]表示折线图坐标(0,0)
# "ro":表示颜色为红色,样式为圆点
ax.plot(x, y)
#在坐标(0,0)处绘制红点
point,=ax.plot(x[0],y[0],"ro")
#在坐标(4,0.8)显示文本
text_ts=ax.text(4,0.8,"")
# 4. 动画设计
#################################################
def animate(i):
point.set_data(x[i], y[i]) #更新红点所在的位置
text_ts.set_text(f"x={x[i]:.3f}, y={y[i]:.3f}") #文本显示每次更新红点经过折线图的坐标位置
return point , text_ts,
ani = animation.FuncAnimation(fig, func=animate, interval=100, blit=True)
# 5.将动画保存为gif图片
ani.save("pratice7.3.gif", writer='pillow')
# 6.展示图表
plt.show()
运行结果