【100天精通Python】Day67:Python可视化_Matplotlib 绘动画,2D、3D 动画 示例+代码

news2025/1/13 2:56:25

1 绘制2D动画(animation)

        Matplotlib是一个Python绘图库,它提供了丰富的绘图功能,包括绘制动画。要绘制动画,Matplotlib提供了FuncAnimation类,允许您创建基于函数的动画。下面是一个详细的Matplotlib动画示例,演示了如何创建一个简单的动画。

示例1:Matplotlib绘制一个简单的正弦波动画 :

import numpy as np
import matplotlib.pyplot as plt
from matplotlib.animation import FuncAnimation

# 创建一个空白图形
fig, ax = plt.subplots()

# 创建一个空白线条,稍后将在动画中更新
line, = ax.plot([], [], lw=2)

# 设置坐标轴范围
ax.set_xlim(0, 2*np.pi)
ax.set_ylim(-1, 1)

# 初始化函数,用于创建空白图形
def init():
    line.set_data([], [])
    return line,

# 动画更新函数,在每一帧中更新线条数据
def update(frame):
    x = np.linspace(0, 2*np.pi, 1000)
    y = np.sin(2*np.pi * (x - 0.01 * frame))
    line.set_data(x, y)
    return line,

# 创建动画对象,传递初始化函数和更新函数
ani = FuncAnimation(fig, update, frames=200, init_func=init, blit=True)

# 保存动画为gif文件(可选)
ani.save('sine_wave_animation.gif', writer='pillow', fps=30)

# 显示动画
plt.show()

这个示例演示了如何创建一个简单的正弦波动画。让我们分析一下代码: 

  1. 我们首先导入必要的库,包括NumPy和Matplotlib中的FuncAnimation类。

  2. 创建一个图形对象(fig)和一个坐标轴对象(ax),然后创建一个空白的线条对象(line)。

  3. 设置坐标轴范围。

  4. 编写init函数,它用于初始化图形,此处是清空线条。

  5. 编写update函数,它在每一帧中更新线条的数据。在这个示例中,我们绘制了一个在x轴上以不同速度移动的正弦波。

  6. 创建FuncAnimation对象,传递初始化函数、更新函数、帧数等参数。

  7. 最后,您可以选择将动画保存为GIF文件(使用ani.save)或直接在窗口中显示(使用plt.show())。

 示例2:绘制散点图动画

​​​​import matplotlib.pyplot as plt
import matplotlib.animation as animation
import numpy as np

fig, ax = plt.subplots()

x = np.random.rand(100)
y = np.random.rand(100)
scatter = ax.scatter(x, y)

def update(frame):
    scatter.set_offsets(np.column_stack((x+frame/100, y)))
    return scatter,

ani = animation.FuncAnimation(fig, update, frames=100, interval=50)
ani.save('animation.gif', writer='pillow')
plt.show()

 

2 matplotlib 绘制3D动画(animation) 

Matplotlib允许您创建3D动画,通过使用FuncAnimation类,您可以在3D场景中制作动画。

示例:Matplotlib 绘制旋转的魔方动画

import numpy as np
import matplotlib.pyplot as plt
from mpl_toolkits.mplot3d import Axes3D
from matplotlib.animation import FuncAnimation
from mpl_toolkits.mplot3d.art3d import Poly3DCollection

# 创建一个3D图形对象
fig = plt.figure()
ax = fig.add_subplot(111, projection='3d')

# 定义立方体的顶点坐标和连接顺序
vertices = np.array([[1, 1, 1], [1, 1, -1], [1, -1, -1], [1, -1, 1],
                     [-1, 1, 1], [-1, 1, -1], [-1, -1, -1], [-1, -1, 1]])

faces = [[vertices[0], vertices[1], vertices[2], vertices[3]],
         [vertices[4], vertices[5], vertices[6], vertices[7]],
         [vertices[0], vertices[1], vertices[5], vertices[4]],
         [vertices[2], vertices[3], vertices[7], vertices[6]],
         [vertices[0], vertices[3], vertices[7], vertices[4]],
         [vertices[1], vertices[2], vertices[6], vertices[5]]]

# 定义每个面的颜色
colors = ['r', 'g', 'b', 'y', 'm', 'c']


# 初始化函数,创建空白图形
def init():
    return ax


# 动画更新函数,用于旋转立方体
def update(frame):
    ax.cla()  # 清除当前图形
    ax.set_xlim(-2, 2)
    ax.set_ylim(-2, 2)
    ax.set_zlim(-2, 2)
    ax.set_title(f'Frame {frame}')

    # 旋转立方体
    angle = frame * (360 / frames)
    for i, face in enumerate(faces):
        rotated_face = []
        for vertex in face:
            x, y, z = vertex
            x_rotated = x * np.cos(np.radians(angle)) - z * np.sin(np.radians(angle))
            z_rotated = x * np.sin(np.radians(angle)) + z * np.cos(np.radians(angle))
            rotated_face.append([x_rotated, y, z_rotated])
        rotated_face = np.array(rotated_face)
        ax.add_collection3d(Poly3DCollection([rotated_face], facecolors=colors[i], alpha=0.8))

    return ax


frames = 100  # 动画帧数
ani = FuncAnimation(fig, update, frames=frames, init_func=init, blit=False)

# 在创建FuncAnimation对象之后,添加以下代码保存动画为GIF文件
ani.save('rotating_colored_cube_animation.gif', writer='pillow', fps=30)

# 显示动画
plt.show()

        上述代码演示了如何使用Matplotlib创建一个旋转的彩色3D立方体动画,并将其保存为GIF文件。以下是代码的主要部分和功能分析: 

  1. 首先,导入必要的Python库:

    • numpy:用于处理数学运算和数组操作。
    • matplotlib.pyplot:Matplotlib的绘图模块,用于创建和显示图形。
    • mpl_toolkits.mplot3d.Axes3D:Matplotlib的3D绘图工具。
    • matplotlib.animation.FuncAnimation:用于创建动画的Matplotlib类。
  2. 创建一个3D图形对象(fig)和一个3D坐标轴对象(ax)。

  3. 定义立方体的顶点坐标(vertices)和连接顺序(faces)。vertices包含了立方体的八个角点的坐标,而faces包含了连接这些点的面。

  4. 定义每个面的颜色(colors),这里使用了六种不同的颜色。

  5. 编写初始化函数init,它返回一个空白的3D图形。

  6. 编写动画更新函数update,它在每一帧中清除当前图形,然后重新绘制旋转后的立方体。动画中的旋转通过逐渐改变角度(angle)来实现。每个面的顶点坐标都根据旋转角度计算出旋转后的坐标,然后使用Poly3DCollection来绘制立方体的面,每个面使用不同的颜色。

  7. 定义动画帧数(frames),表示动画的总帧数。

  8. 使用FuncAnimation类创建动画对象(ani),传递初始化函数、更新函数、帧数等参数。

  9. 使用ani.save方法将动画保存为GIF文件,指定文件名('rotating_colored_cube_animation.gif')、GIF编写器('pillow',使用Pillow库)和帧速率(fps=30)。

  10. 最后,通过plt.show()显示动画。

这段代码实现了一个具有旋转动画效果的3D立方体,每个面都有不同的颜色,生成的动画保存为GIF文件。您可以根据需要修改颜色、帧数、文件名等参数来自定义动画。

3 总结:绘制动画的通用流程

(1)导入必要的库:首先,你需要导入Matplotlib库及其子模块,例如pyplot和animation。通常使用以下语句导入这些库:

import matplotlib.pyplot as plt
from matplotlib.animation import FuncAnimation

(2) 创建画布和子图:使用Matplotlib创建一个画布并添加子图(axes)。可以使用`plt.subplots()`函数来完成这个步骤:

fig, ax = plt.subplots()

(3)定义初始化函数:创建一个函数来初始化动画。这个函数会设置图形的初始状态,例如绘制图形的背景、坐标轴的范围等,确保动画的每一帧都从相同的初始状态开始。

def init():
    # 设置图形的初始状态
    return ax

(4) 定义更新函数:创建一个函数来更新动画的每一帧。通常,这个函数根据时间或数据的变化更新图形。例如,你可以使用以下语句在每一帧中更新线条的位置:

```python
def update(frame):
    # 更新图形的每一帧
    # 更新线条的位置或其他图形元素
    return ax
```

(5)创建动画对象:使用`FuncAnimation`类创建一个动画对象。这个类接受以下参数:绘制图形的画布、更新函数、帧数、帧之间的延迟以及初始化函数。可以使用以下语句创建动画对象:

anim = FuncAnimation(fig, update, frames=num_frames, init_func=init, interval=interval, blit=True)

其中,`fig`是创建的画布对象,通常为第2步中创建的对象;`update`是在第4步中定义的更新函数;`num_frames`是动画的总帧数;`init`是在第3步中定义的初始化函数;`interval`是帧之间的延迟(以毫秒为单位);`blit`是一个布尔值,表示是否只绘制变化的部分(默认值为False)。

(6)显示动画:使用`plt.show()`函数来显示动画。

 ​​​​​​​

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1032181.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

服务器时间正常,docker容器日志显示时间少了8小时

问题: 项目中docker部署的项目容器日志时间少了8小时。解决: 在Dockerfile添加下面语句: # 设置时区 ENV TZ"Asia/Shanghai"

数字人惯性动作捕捉技术服务,激发吉祥物IP创新活力

近日,2023年成都市全国科普日主场活动启动仪式中,全球首发全国首个科普数字人形象大使“科普熊猫”,在大会活动现场,数字人“科普熊猫”结合惯性动作捕捉技术,与现场主持人、观众进行实时互动交流,以虚实结…

华为云云耀云服务器L实例评测|2核2G跑mysql性能测试

前言 上一次我们介绍了华为云云耀云服务器L实例的基本信息,从购买到特色都做了简要介绍。但是 很多人看到这个配置又产生了迟疑,主要是因为云耀现在提供的全系是2核,性能吃得消吗?今天我们就来做一个性能测试 环境准备 因为我们…

Unity fbx动画压缩自动化

应用场景:Unity WebGl项目,原先的动画压缩后也有20到30M,导致用户进入网页加载太慢。需求是在不对动画精确度造成影响的前提下,影响尽可能地压缩动画。(使用的是Maya导出的人体骨骼动画,在动画压缩方式选择…

2023华为杯数学建模研赛思路分享——最全版本F题深度解析

题目回顾: 强对流降水临近预报 我国地域辽阔,自然条件复杂,因此灾害性天气种类繁多,地区差异大。其中,雷雨大风、冰雹、龙卷、短时强降水等强对流天气是造成经济损失、危害生命安全最严重的一类灾害性天气[1]。以202…

计算机毕业设计 基于SpringBoot的“漫画之家”系统的设计与实现 Java实战项目 附源码+文档+视频讲解

博主介绍:✌从事软件开发10年之余,专注于Java技术领域、Python人工智能及数据挖掘、小程序项目开发和Android项目开发等。CSDN、掘金、华为云、InfoQ、阿里云等平台优质作者✌ 🍅文末获取源码联系🍅 👇🏻 精…

SmartCode ViewerX VNC 3.11 Crack

SmartCode ViewerX VNC 查看器 ActiveX 轻松地将 VNC 查看器功能添加到您的应用程序中 SmartCode ViewerX VNC Viewer ActiveX 使开发人员可以使用一组直观的 ActiveX 属性和方法完全访问 VNC 查看器功能。借助ViewerX控件,开发人员可以轻松地为其应用程序提供屏幕共…

如何判断IP地址的合法性

判断IP地址的合法性是网络管理和安全领域中非常重要的任务之一。IP地址(Internet Protocol Address)是计算机网络中用于标识和定位设备的一种数字地址。合法的IP地址必须符合特定的格式和规范。在这篇文章中,我们将讨论如何判断IP地址的合法性…

算法通关村-----一图理解递归

递归的本质 递归的本质是方法调用,自己调用自己,系统为我们维护了不同调用之间的保存和返回功能。 递归的特征 执行范围不断缩小,这样才能触底反弹 终止判断在递归调用之前 如何写递归 以n的阶乘为例 第一步 从小到大递推 n1 f(1)1 …

C++标准模板库——vector的使用及其模拟实现

目录 一. vector的介绍 1.vector的介绍 二.vector的使用 vector中常见接口的介绍vector的构造和析构函数vector的三种遍历方式 三.vector的模拟实现 vector的增删查改vector容器的容量变化和大小增减vector迭代器失效问题vector的小框架 构造函数和析构函数迭代器和operat…

基于AR增强现实模拟离心泵结构拆装与运行

通过AR模拟,学生可以虚拟地观察离心泵的结构和部件,进行拆装、安装和调试的操作,而无需实际接触物理设备。这极大地降低了学生操作过程中的风险。 AR模拟离心泵的拆装过程可以分为几个步骤。首先,学生选择相应的模拟程序&#xff…

如何利用kakaoTalk进行营销?

kakaoTalk是一款韩国即时通讯软件,用户渗透率达95%,使用程度类似于国内的微信。而除了普通的聊天功能外,他还包含叫车服务、食品外送、餐厅预订、支付和游戏等多种功能,几乎每个韩国人都在使用KakaoTalk。 因此,对于要…

Java中swing的5种布局方式浅析

在一个传统的java项目中,遇到一个需要调整布局的需求,下面将学习网上大佬的文章,并将过程记录下来。 1、Java swing5种布局方式 1、 边界布局(BorderLayout)2、流式布局(FlowLayout)3、网格布局…

Quartz 建表语句SQL文件

SQL文件在jar里面,github下载 https://github.com/quartz-scheduler/quartz/releases/tag/v2.3.2 解压,sql文件路径:quartz-core\src\main\resources\org\quartz\impl\jdbcjobstore tables_mysql_innodb.sql # # In your Quartz propertie…

yo!这里是c++中的多态

前言 在学完继承之后,紧接着我们来认识多态,建议继承不太熟的先把继承部分的知识点搞熟,再来学习多态,否则会走火入魔,会混乱。因为多态是建立在继承的基础之上,而且多态中还存在与继承类似的概念&#xff…

大数据学习1.3-xShell配置jdk

1.创建java文件 mkdir /usr/local/java 2.切换到java中 cd /user/local/java/ 3.将jdk直接拖到xShell中 4.解压jdk tar -zxvf jdk-8u221-linux-x64.tar.gz 5.配置环境变量-进入环境变量文件 vi /etc/profile 6.添加如下内容 JAVA_HOME/usr/local/java/jdk1.8.0_221 CLASSP…

【方案】浅析利用AI智能识别与视频监控技术打造智慧水产养殖监管系统

一、方案背景 针对目前水产养殖集约、高产、高效、生态、安全的发展需求,基于智能传感、智慧物联网、人工智能、视频监控等技术打造智慧水产系统,成为当前行业的发展趋势。传统的人工观察水产养殖方式较为单一,难以及时发现人员非法入侵、偷…

树莓派提示不认识GPIO

有的板子可能不会安装wiringpi库,在运行下面指令式 gpio readall 会报如下错 即使运行版本查看指令也是这个错误 gpio -v 目前最新版是2.52版 先更新软件源 ,再安装wiringpi库 sudo apt-get update sudo apt-get upgrade sudo apt-get install wi…

Flink的部署模式:Local模式、Standalone模式、Flink On Yarn模式

Flink常见的部署模式 Flink部署、执行模式Flink的部署模式Flink的执行模式 Local本地模式下载安装启动、停止Flink提交测试任务停止作业 Standalone独立模式会话模式单作业模式应用模式 YARN运行模式会话模式启动Hadoop集群申请一个YARN会话查看Yarn、Flink提交作业查看、测试作…

Centos7安装mysql详细过程

官网 https://dev.mysql.com/downloads/repo/yum/1、下载安装包 cd /optwget http://dev.mysql.com/get/mysql57-community-release-el7-11.noarch.rpm2、安装MYSQL源 yum -y install mysql57-community-release-el7-11.noarch.rpm3、查看安装结果 yum repolist enabled | …