# 导入库并重命名
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数据:
x = np.linspace(0, 2 * np.pi, 100)
# Y数据:
y = np.sin(x)
# 2. 创建画布和坐标系
fig = plt.figure(tight_layout=True)
ax = fig.add_subplot(111)
# 3. 绘制正弦曲线
ax.plot(x, y)
# 4. 动画设计
# 更新点的位置
# 定义一个名为func的函数,num为参数。
def func(num):
#用if指定动画移动始终点
if x[num] == 6.283 and y[num] == 0:
point_ani.set_data(x[0], y[0])
else:
point_ani.set_data(x[num], y[num])
# 文本显示点的位置
text_pt.set_text("x=%.3f,y=%.3f" % (x[num], y[num]))
return point_ani, text_pt
point_ani, = plt.plot(x[0], y[0], "r*", markersize=16)
# 设置文本位置和大小
text_pt = plt.text(4, 0.9, "", fontsize=16)
# 动画设置:
ani = animation.FuncAnimation(fig, func, frames=100, interval=100, blit=True)
# 设置坐标轴
plt.xlabel('x轴', fontsize=14)
plt.ylabel('y轴', fontsize=14)
# 5.将动画保存为gif图片
#ani.save("pratice7.3.gif", writer='pillow')
# 6.绘制图表
plt.show()