matplotlib绘制动画代码示例


Posted in Python onJanuary 02, 2018

matplotlib从1.1.0版本以后就开始支持绘制动画

下面是几个的示例:

第一个例子使用generator,每隔两秒,就运行函数data_gen:

# -*- coding: utf-8 -*-  
 
import numpy as np 
import matplotlib.pyplot as plt 
import matplotlib.animation as animation 
 
fig = plt.figure() 
axes1 = fig.add_subplot(111) 
line, = axes1.plot(np.random.rand(10)) 
 
#因为update的参数是调用函数data_gen,所以第一个默认参数不能是framenum 
def update(data): 
  line.set_ydata(data) 
  return line, 
# 每次生成10个随机数据 
def data_gen(): 
  while True: 
    yield np.random.rand(10) 
 
ani = animation.FuncAnimation(fig, update, data_gen, interval=2*1000) 
plt.show()

第二个例子使用list(metric),每次从metric中取一行数据作为参数送入update中:

import numpy as np 
import matplotlib.pyplot as plt 
import matplotlib.animation as animation 
 
start = [1, 0.18, 0.63, 0.29, 0.03, 0.24, 0.86, 0.07, 0.58, 0] 
 
metric =[[0.03, 0.86, 0.65, 0.34, 0.34, 0.02, 0.22, 0.74, 0.66, 0.65], 
     [0.43, 0.18, 0.63, 0.29, 0.03, 0.24, 0.86, 0.07, 0.58, 0.55], 
     [0.66, 0.75, 0.01, 0.94, 0.72, 0.77, 0.20, 0.66, 0.81, 0.52] 
    ] 
 
fig = plt.figure() 
window = fig.add_subplot(111) 
line, = window.plot(start) 
#如果是参数是list,则默认每次取list中的一个元素,即metric[0],metric[1],... 
def update(data): 
  line.set_ydata(data) 
  return line, 
 
ani = animation.FuncAnimation(fig, update, metric, interval=2*1000) 
plt.show()

第三个例子:

import numpy as np 
from matplotlib import pyplot as plt 
from matplotlib import animation 
 
# First set up the figure, the axis, and the plot element we want to animate 
fig = plt.figure() 
ax = plt.axes(xlim=(0, 2), ylim=(-2, 2)) 
line, = ax.plot([], [], lw=2) 
 
# initialization function: plot the background of each frame 
def init(): 
  line.set_data([], []) 
  return line, 
 
# animation function. This is called sequentially 
# note: i is framenumber 
def animate(i): 
  x = np.linspace(0, 2, 1000) 
  y = np.sin(2 * np.pi * (x - 0.01 * i)) 
  line.set_data(x, y) 
  return line, 
 
# call the animator. blit=True means only re-draw the parts that have changed. 
anim = animation.FuncAnimation(fig, animate, init_func=init, 
                frames=200, interval=20, blit=True) 
 
#anim.save('basic_animation.mp4', fps=30, extra_args=['-vcodec', 'libx264']) 
 
plt.show()

第四个例子:

# -*- coding: utf-8 -*- 
  
import numpy as np 
import matplotlib.pyplot as plt 
import matplotlib.animation as animation 
 
# 每次产生一个新的坐标点 
def data_gen(): 
  t = data_gen.t 
  cnt = 0 
  while cnt < 1000: 
    cnt+=1 
    t += 0.05 
    yield t, np.sin(2*np.pi*t) * np.exp(-t/10.) 
data_gen.t = 0 
 
# 绘图 
fig, ax = plt.subplots() 
line, = ax.plot([], [], lw=2) 
ax.set_ylim(-1.1, 1.1) 
ax.set_xlim(0, 5) 
ax.grid() 
xdata, ydata = [], [] 
 
# 因为run的参数是调用函数data_gen,所以第一个参数可以不是framenum:设置line的数据,返回line 
def run(data): 
  # update the data 
  t,y = data 
  xdata.append(t) 
  ydata.append(y) 
  xmin, xmax = ax.get_xlim() 
 
  if t >= xmax: 
    ax.set_xlim(xmin, 2*xmax) 
    ax.figure.canvas.draw() 
  line.set_data(xdata, ydata) 
 
  return line, 
   
# 每隔10秒调用函数run,run的参数为函数data_gen, 
# 表示图形只更新需要绘制的元素 
ani = animation.FuncAnimation(fig, run, data_gen, blit=True, interval=10, 
  repeat=False) 
plt.show()

再看下面的例子:

# -*- coding: utf-8 -*- 
import numpy as np 
import matplotlib.pyplot as plt 
import matplotlib.animation as animation 
 
#第一个参数必须为framenum 
def update_line(num, data, line): 
  line.set_data(data[...,:num]) 
  return line, 
 
fig1 = plt.figure() 
 
data = np.random.rand(2, 15) 
l, = plt.plot([], [], 'r-') 
plt.xlim(0, 1) 
plt.ylim(0, 1) 
plt.xlabel('x') 
plt.title('test') 
 
#framenum从1增加大25后,返回再次从1增加到25,再返回... 
line_ani = animation.FuncAnimation(fig1, update_line, 25,fargs=(data, l),interval=50, blit=True) 
 
#等同于 
#line_ani = animation.FuncAnimation(fig1, update_line, frames=25,fargs=(data, l), 
#  interval=50, blit=True) 
 
#忽略frames参数,framenum会从1一直增加下去知道无穷 
#由于frame达到25以后,数据不再改变,所以你会发现到达25以后图形不再变化了 
#line_ani = animation.FuncAnimation(fig1, update_line, fargs=(data, l), 
#  interval=50, blit=True) 
 
plt.show()

总结

以上就是本文关于matplotlib绘制动画代码示例的全部内容,希望对大家有所帮助。感兴趣的朋友可以继续参阅本站其他相关专题,如有不足之处,欢迎留言指出。感谢朋友们对本站的支持!

Python 相关文章推荐
Python自定义线程池实现方法分析
Feb 07 Python
Pandas:DataFrame对象的基础操作方法
Jun 07 Python
Python实现朴素贝叶斯分类器的方法详解
Jul 04 Python
Python 单元测试(unittest)的使用小结
Nov 14 Python
python+pyqt5实现图片批量缩放工具
Mar 18 Python
windows下安装Python虚拟环境virtualenvwrapper-win
Jun 14 Python
PyQt5固定窗口大小的方法
Jun 18 Python
Python爬虫库BeautifulSoup的介绍与简单使用实例
Jan 25 Python
keras实现多种分类网络的方式
Jun 11 Python
浅析python 字典嵌套
Sep 29 Python
python对输出的奇数偶数排序实例代码
Dec 04 Python
python中pymysql包操作数据库方法
Apr 19 Python
Python+matplotlib+numpy实现在不同平面的二维条形图
Jan 02 #Python
Python 实现淘宝秒杀的示例代码
Jan 02 #Python
python基于twisted框架编写简单聊天室
Jan 02 #Python
python http接口自动化脚本详解
Jan 02 #Python
详解用python实现简单的遗传算法
Jan 02 #Python
一个Python最简单的接口自动化框架
Jan 02 #Python
利用Hyperic调用Python实现进程守护
Jan 02 #Python
You might like
mysql数据库差异比较的PHP代码
2012/02/05 PHP
比较简单的百度网盘文件直链PHP代码
2013/03/24 PHP
coreseek 搜索英文的问题详解
2013/06/08 PHP
PHP反向代理类代码
2014/08/15 PHP
PHP比较运算符的详细介绍
2015/09/29 PHP
php ucwords() 函数将字符串中每个单词的首字符转换为大写(实现代码)
2016/05/12 PHP
php删除数组指定元素实现代码
2017/05/03 PHP
php处理多图上传压缩代码功能
2018/06/13 PHP
基于jQuery的为attr添加id title等效果的实现代码
2011/04/20 Javascript
深入理解JavaScript系列(22):S.O.L.I.D五大原则之依赖倒置原则DIP详解
2015/03/05 Javascript
jQuery代码实现表格中点击相应行变色功能
2016/05/09 Javascript
BootStrap实现树形目录组件代码详解
2016/06/21 Javascript
JS仿QQ好友列表展开、收缩功能(第一篇)
2017/07/07 Javascript
老生常谈JavaScript面向对象基础与this指向问题
2017/10/16 Javascript
vue 引入公共css文件的简单方法(推荐)
2018/01/20 Javascript
JavaScript事件冒泡与事件捕获实例分析
2018/08/01 Javascript
详解小程序如何动态绑定点击的执行方法
2019/11/26 Javascript
vue使用nprogress实现进度条
2019/12/09 Javascript
JS+DIV实现拖动效果
2020/02/11 Javascript
Node.js API详解之 vm模块用法实例分析
2020/05/27 Javascript
jQuery实现滑动开关效果
2020/08/02 jQuery
python通过百度地图API获取某地址的经纬度详解
2018/01/28 Python
python实现聚类算法原理
2018/02/12 Python
pycharm 取消默认的右击运行unittest的方法
2018/11/29 Python
使用Python-OpenCV向图片添加噪声的实现(高斯噪声、椒盐噪声)
2019/05/28 Python
Python学习笔记之lambda表达式用法详解
2019/08/08 Python
python使用matplotlib绘制雷达图
2019/10/18 Python
Python3 使用selenium插件爬取苏宁商家联系电话
2019/12/23 Python
个人函授自我鉴定
2014/03/25 职场文书
运动会拉拉队口号
2014/06/09 职场文书
会计岗位说明书
2014/07/29 职场文书
励志演讲稿200字
2014/08/21 职场文书
党的群众路线领导班子整改方案
2014/09/27 职场文书
关于迟到的检讨书
2015/05/06 职场文书
spring注解 @PropertySource配置数据源全流程
2022/03/25 Java/Android
Mybatis-Plus 使用 @TableField 自动填充日期
2022/04/26 Java/Android