使用mplot3d绘制3d图表

使用animation制作动图

1.1 animtaion概述

   matplotlib 在 1.1 版本的标准库中加人了动画模块——animation,使用该模块的Animtion 类可以实现一些基本的动画效果。Animtion 类是一个动画基类,它针对不同的行为分别派生了不同的子类,主要包括 FuncAnimation 类和 AritistAnimation 类。其中,Funcanimation类表示基于重复调用一个函数的动画;AritistAnimation 类表示基下一组固定Amrtis(标准的绘画元素,比如文本、线条、知形等)对象的动画。具体说明加下

1.2.FuncAnimation类

   FuncAnimation 是基于函数的动画类,它通过重复调用同一函数来制作动画。FuncAnimation 类的构造方法的语法格式如下所示:

FuncAnimation (fig, func, framese=None, init_ func=None, fargs=None,
save_count=None,*,cache_frame_data=True,**kwargs)


该方法常用参数的含义如下:
fig:表示动画所在的画布
func:表示每帧动画调用的函数
frames :表示动画的长度(一次动画包舍的倾数)
init_func:表示用于开始绘制懒的函数,它会在第一帧动画之前调用一次。若未设置该参数,则程序将使用 fames 序列中第一项的绘图结果
·fargs : 表示传递给 func 函数的其他参数。
·interval:表示更新动画的频率,以毫秒为单位,默认为 200。
·blit : 表示是否更新所有的点,默认为 Fale。官方推荐将 blit 参数设为True,但建议macOS的用户将 blit 参数设为 False,否则将无法显示动画。
 

1.3AritistAnimation类

     ArtistAnimation是基于一组 Atist 对象的动画类,它通过一帧一帧的数据制作动画ArtislAnimation类的构造方法的语法格式如下所示:

ArtistAnimation(fig,artists,interval,repeat_delay,repeat,
blit,*args,**kwargs)


该方法常用参数的含义如下:
·fig:表示动画所在的画布。
·artists :表示一组Artist 对象的列表。
·interval: 表示更新动画的频率,以毫秒为单位,默认为 200。
·repeat_delay : 表示再次播放动画之前延迟的时长。
·repeat : 表示是否重复播放动画。

#若希望将动画存储为视频文件,则可以借助ffmpeg或mencoder,之后使用Animation类的save()方法将每一帧动画存储为视频文件,具体代码如下:

ani.save('basic_animation.mp4',fps=30,extra_args=['-vcodec','libx264'])

而后我们利用这个来做一个动画图表:


 绘制一个具有动画效果的图表,具体要求如下:
(1)    绘制一条正弦曲线;
(2)    绘制一个红色圆点,该圆点最初位于正弦曲线的左端;
(3)    制作一个圆点沿曲线运动的动画,并时刻显示圆点的坐标位置。

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

%matplotlib notebook 
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. 动画设计

def update_points(num):
    point_ani.set_data(x[num], y[num])    # num代表当前动画第几帧
    text_pt.set_text("x=%.3f, y=%.3f"%(x[num], y[num]))
    return point_ani,text_pt,
 
x = np.linspace(0, 2*np.pi, 100)
y = np.sin(x)
 
plt.plot(x,y)
point_ani,= plt.plot(x[0], y[0], "ro")
text_pt = plt.text(4, 0.8, '', fontsize=16)
 
# 开始制作动画
ani = animation.FuncAnimation(fig, update_points, np.arange(0, 100), interval=100, blit=True)

# 5.将动画保存为gif图片(用于上传博客)
ani.save("pratice7.3.gif", writer='pillow')

# 6.展示图表
plt.show()

运行的gif动图:

  • 7
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值