0、设置了使用中文黑体字体显示,并解决了matplotlib绘图时负号显示为方块的问题:
1、生成了一个包含100个点的正弦曲线数据,x轴范围为0到2π:
5、将动画保存为GIF图片,文件名为"pratice7.3.1.gif",使用了Pillow库作为动画写入器:
题目:
绘制一个具有动画效果的图表,具体要求如下: (1) 绘制一条正弦曲线; (2) 绘制一个红色圆点,该圆点最初位于正弦曲线的左端; (3) 制作一个圆点沿曲线运动的动画,并时刻显示圆点的坐标位置。
实现过程:
导入模块 :
import numpy as np
import matplotlib.pyplot as plt
import matplotlib.animation as animation
0、设置了使用中文黑体字体显示,并解决了matplotlib绘图时负号显示为方块的问题:
plt.rcParams["font.sans-serif"] = ["SimHei"]
plt.rcParams["axes.unicode_minus"] = False
1、生成了一个包含100个点的正弦曲线数据,x轴范围为0到2π:
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、在坐标系上绘制了正弦曲线:
ax.plot(x, y)
4、创建了一个红色圆点对象,并将其初始化在曲线左端:
point, = ax.plot(x[0], y[0], "ro")
4.1、定义了一个更新函数update
在每一帧更新时,更新圆点的位置以及文本框内显示的内容为当前的坐标位置。然后返回更新后的圆点和文本对象:
效果一:
point, = ax.plot(x[0], y[0], "ro") # 创建圆点对象,并初始化在曲线左端
coord_text = ax.text(1.58*np.pi, 1, "", fontsize=16, bbox=dict(facecolor='white', alpha=0.5, edgecolor='white')) # 创建文本对象用于显示坐标位置
def update(frame):
point.set_data(x[frame], y[frame]) # 更新圆点位置
coord_text.set_text(f"({x[frame]:.2f}, {y[frame]:.2f})") # 更新文本内容为当前坐标位置
return point, coord_text
效果二:
point, = ax.plot(x[0], y[0], "ro") # 创建圆点对象,并初始化在曲线左端
coord_text = ax.text(0, 0, "") # 创建文本对象用于显示坐标位置
def update(frame):
point.set_data(x[frame], y[frame]) # 更新圆点位置
coord_text.set_text(f"({x[frame]:.2f}, {y[frame]:.2f})") # 更新文本内容为当前坐标位置
coord_text.set_position((x[frame], y[frame])) # 更新文本位置为当前坐标位置
return point, coord_text
ani = animation.FuncAnimation(fig, update, frames=len(x), interval=100, blit=True) # 创建动画
5、将动画保存为GIF图片,文件名为"pratice7.3.1.gif",使用了Pillow库作为动画写入器:
ani.save("pratice7.3.gif", writer='pillow')
6、显示绘制的图表:
plt.show()
效果一总代码如下:
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. 绘制正弦曲线
ax.plot(x, y)
# 4. 动画设计
point, = ax.plot(x[0], y[0], "ro") # 创建圆点对象,并初始化在曲线左端
coord_text = ax.text(1.58*np.pi, 1, "", fontsize=16, bbox=dict(facecolor='white', alpha=0.5, edgecolor='white')) # 创建文本对象用于显示坐标位置
def update(frame):
point.set_data(x[frame], y[frame]) # 更新圆点位置
coord_text.set_text(f"({x[frame]:.2f}, {y[frame]:.2f})") # 更新文本内容为当前坐标位置
return point, coord_text
ani = animation.FuncAnimation(fig, update, frames=len(x), interval=100, blit=True) # 创建动画
# 5.将动画保存为gif图片
ani.save("pratice7.3.1.gif", writer='pillow')
# 6.展示图表
plt.show()
效果一输出结果如下:
效果二总代码如下:
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. 绘制正弦曲线
ax.plot(x, y)
# 4. 动画设计
point, = ax.plot(x[0], y[0], "ro") # 创建圆点对象,并初始化在曲线左端
coord_text = ax.text(0, 0, "") # 创建文本对象用于显示坐标位置
def update(frame):
point.set_data(x[frame], y[frame]) # 更新圆点位置
coord_text.set_text(f"({x[frame]:.2f}, {y[frame]:.2f})") # 更新文本内容为当前坐标位置
coord_text.set_position((x[frame], y[frame])) # 更新文本位置为当前坐标位置
return point, coord_text
ani = animation.FuncAnimation(fig, update, frames=len(x), interval=100, blit=True) # 创建动画
# 5.将动画保存为gif图片
ani.save("pratice7.3.gif", writer='pillow')
# 5.展示图表
plt.show()
# 5.将动画保存为gif图片
ani.save("pratice7.3.2.gif", writer='pillow')
# 6.展示图表
plt.show()