运用animation绘制一个具有动画效果的图表

目录

实训:

1.导入模块并设置中文黑体

 2.准备正弦曲线数据

3.创建画布和坐标系

 4.绘制正弦曲线并定义一个圆点

5.动画设计

PS: 

6.将动画保存为gif图片 

 7.展示图表

 PS:


实训:

   要求:绘制一个具有动画效果的图表,具体要求如下:

  1. 绘制一条正弦曲线;
  2. 绘制一个红色圆点,该圆点最初位于正弦曲线的左端;
  3. 制作一个圆点沿曲线运动的动画,并时刻显示圆点的坐标位

       (具体效果参考运行结果gif图) 

1.导入模块并设置中文黑体

代码如下:

#导入模块
%matplotlib notebook
import numpy as np
import matplotlib.pyplot as plt
from matplotlib.animation import FuncAnimation
#设置中文黑体
plt.rcParams["font.sans-serif"] = ["SimHei"]
plt.rcParams["axes.unicode_minus"] = False

 2.准备正弦曲线数据

代码如下:

#准备正弦曲线数据
x = np.linspace(0, 2*np.pi, 100,)
y = np.sin(x)

3.创建画布和坐标系

代码如下:

#创建画布和坐标系
fig = plt.figure(tight_layout=True)
ax = fig.add_subplot(111)

 4.绘制正弦曲线并定义一个圆点

代码如下:

#绘制正弦曲线
line, = ax.plot(x, y)
#定义一个圆点
point, = ax.plot([], [], "ro")

5.动画设计

代码如下:

#添加注释文本(坐标值x,y)
text = ax.text(x=4.2, y=0.8, s='', fontdict={'fontsize': 15}) #x,y(注释文本的坐标位置)s(注释文本的内容)fontdict(控制字体的字典) 
#定义每帧动画调用的函数 
def animate(i):
    text_x = format(x[i], '1.3f')   #x坐标数据保留三位小数
    text_y = format(y[i], '1.3f')   #y坐标数据保留三位小数
    point.set_data([x[i]], [y[i]])  #使圆点在正弦曲线移动
    text.set_text(f'x={text_x},y={text_y}')  #显示圆点的坐标数据于右上角
 
    
    return point,text 
#定义初始化帧的函数
def init():
    line.set_ydata(np.sin(x))
    return line,
 
 
ani = FuncAnimation(fig=fig, func=animate, frames=len(x), init_func=init, interval=30, blit=False

PS: 

  • fig:表示动画所在的画布
  • func:表示每帧动画调用的函数
  • frames:表示动画的长度(一次动画包含的帧数)
  • init_func:表示用于开始绘制帧的函数
  • interval:表示更新动画的频率,以毫秒为单位,默认为200
  • blit:表示是否更新所有的点,默认为False

6.将动画保存为gif图片 

代码如下:

#将动画保存为gif图片
ani.save("pratice7.3.gif", writer='pillow')

 7.展示图表

代码如下:

#展示图表
plt.show()

 PS:

#将动画保存为GIF图片
ani.save('sin_wave.gif', writer='pillow')

图表效果如下:

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值