30分钟上手manim:零基础制作数学动画教程
2026-02-04 05:01:22作者:滑思眉Philip
你还在为数学概念难以可视化而烦恼?想制作专业的数学教学动画却被复杂软件劝退?本文将带你30分钟入门manim(数学动画引擎),从安装到输出第一个动画,全程无需编程经验,让抽象公式动起来!
读完本文你将学会:
- 快速搭建manim开发环境
- 创建基础几何图形与数学公式
- 添加平滑动画过渡效果
- 导出高清视频与GIF动图
- 掌握5个实用场景模板
环境准备:3步完成安装
manim支持Windows、macOS和Linux系统,推荐使用Python 3.8+环境。以下是最简安装流程:
核心依赖安装
首先安装FFmpeg(视频处理)和LaTeX(公式渲染):
# Ubuntu/Debian
sudo apt update && sudo apt install ffmpeg texlive-full
# Windows (使用Chocolatey)
choco install ffmpeg
完整安装指南参见官方文档:docs/source/getting_started/installation.rst
源码获取与依赖安装
git clone https://gitcode.com/GitHub_Trending/ma/manim
cd manim
pip install -e .
验证安装
运行示例场景验证环境是否配置成功:
manimgl example_scenes.py OpeningManimExample
若看到坐标系变换动画窗口,说明安装成功!
核心概念:5分钟了解manim架构
manim动画由三个核心组件构成:
graph TD
A[Scene 场景] --> B[Mobject 可动对象]
A --> C[Animation 动画效果]
B --> D[几何图形/公式/文本]
C --> E[变换/移动/颜色变化]
- Scene(场景):动画的舞台,所有元素都在场景中展示
- Mobject(可动对象):可展示的基本元素,如圆形(Circle)、方形(Square)、公式(Tex)
- Animation(动画):对象的动作效果,如创建(ShowCreation)、变换(Transform)
官方核心文档:docs/source/documentation/mobject/index.rst
实战教程:从方形到圆形的华丽变身
1. 基础场景框架
创建start.py文件,写入最基础的场景结构:
from manimlib import *
class SquareToCircle(Scene):
def construct(self):
# 你的动画代码将写在这里
square = Square() # 创建方形
self.play(ShowCreation(square)) # 展示创建过程
self.wait(1) # 暂停1秒
执行命令渲染:
manimgl start.py SquareToCircle
2. 添加形状变换
修改代码,让方形平滑变换为圆形:
from manimlib import *
class SquareToCircle(Scene):
def construct(self):
circle = Circle() # 创建圆形
circle.set_fill(BLUE, opacity=0.5) # 填充蓝色,半透明
circle.set_stroke(BLUE_E, width=4) # 深蓝色边框,宽度4
square = Square() # 创建方形
self.play(ShowCreation(square)) # 绘制方形
self.wait()
self.play(ReplacementTransform(square, circle)) # 方形变换为圆形
self.wait()
完整示例代码:docs/example.py
3. 导出与分享
- 导出图片:
manimgl start.py SquareToCircle -s(保存至images/目录) - 导出视频:
manimgl start.py SquareToCircle -o(保存至videos/目录)
进阶技巧:让动画更专业
交互式开发模式
在代码末尾添加self.embed()进入交互模式:
def construct(self):
# ... 原有代码 ...
self.embed() # 动画结束后进入交互终端
在交互终端中可实时测试代码:
>>> play(circle.animate.stretch(4, dim=0)) # 横向拉伸4倍
>>> play(Rotate(circle, 90 * DEG)) # 旋转90度
数学公式渲染
使用Tex类添加LaTeX公式:
equation = Tex("E = mc^2") # 创建公式
equation.scale(2) # 放大2倍
self.play(Write(equation)) # 书写效果展示
更多公式示例:example_scenes.py
坐标系与函数图像
快速创建坐标系并绘制函数图像:
axes = Axes(x_range=(-3, 3), y_range=(-1, 5)) # 创建坐标系
graph = axes.get_graph(lambda x: x**2, color=RED) # 二次函数图像
self.play(ShowCreation(axes), ShowCreation(graph))
场景模板:5个实用案例
| 应用场景 | 代码路径 | 关键类/方法 |
|---|---|---|
| 矩阵变换 | example_scenes.py#L24-42 | apply_matrix |
| 复数函数可视化 | example_scenes.py#L44-68 | ComplexPlane |
| 几何证明动画 | example_scenes.py#L156-210 | TransformMatchingStrings |
| 3D曲面展示 | example_scenes.py#L566-648 | Surface |
| 数据可视化 | example_scenes.py#L420-495 | Axes.get_graph |
常见问题与解决方案
中文显示异常
- 安装中文字体(如SimHei或WenQuanYi Micro Hei)
- 在
custom_config.yml中配置字体路径:
text_config:
font: "SimHei"
配置文件路径:manimlib/default_config.yml
渲染速度慢
- 降低分辨率:
manimgl -r 800,600 - 减少采样率:
manimgl --quality low
学习资源与社区
- 官方文档:docs/source/index.rst
- 贡献指南:docs/source/development/contributing.rst
- 示例场景:docs/source/getting_started/example_scenes.rst
收藏本文,关注项目更新,下一篇我们将深入讲解3D数学动画制作!如有疑问,欢迎在项目仓库提交issue交流。
登录后查看全文
热门项目推荐
相关项目推荐
Kimi-K2.5Kimi K2.5 是一款开源的原生多模态智能体模型,它在 Kimi-K2-Base 的基础上,通过对约 15 万亿混合视觉和文本 tokens 进行持续预训练构建而成。该模型将视觉与语言理解、高级智能体能力、即时模式与思考模式,以及对话式与智能体范式无缝融合。Python00- QQwen3-Coder-Next2026年2月4日,正式发布的Qwen3-Coder-Next,一款专为编码智能体和本地开发场景设计的开源语言模型。Python00
xw-cli实现国产算力大模型零门槛部署,一键跑通 Qwen、GLM-4.7、Minimax-2.1、DeepSeek-OCR 等模型Go06
PaddleOCR-VL-1.5PaddleOCR-VL-1.5 是 PaddleOCR-VL 的新一代进阶模型,在 OmniDocBench v1.5 上实现了 94.5% 的全新 state-of-the-art 准确率。 为了严格评估模型在真实物理畸变下的鲁棒性——包括扫描伪影、倾斜、扭曲、屏幕拍摄和光照变化——我们提出了 Real5-OmniDocBench 基准测试集。实验结果表明,该增强模型在新构建的基准测试集上达到了 SOTA 性能。此外,我们通过整合印章识别和文本检测识别(text spotting)任务扩展了模型的能力,同时保持 0.9B 的超紧凑 VLM 规模,具备高效率特性。Python00
KuiklyUI基于KMP技术的高性能、全平台开发框架,具备统一代码库、极致易用性和动态灵活性。 Provide a high-performance, full-platform development framework with unified codebase, ultimate ease of use, and dynamic flexibility. 注意:本仓库为Github仓库镜像,PR或Issue请移步至Github发起,感谢支持!Kotlin07
VLOOKVLOOK™ 是优雅好用的 Typora/Markdown 主题包和增强插件。 VLOOK™ is an elegant and practical THEME PACKAGE × ENHANCEMENT PLUGIN for Typora/Markdown.Less00
项目优选
收起
deepin linux kernel
C
27
11
OpenHarmony documentation | OpenHarmony开发者文档
Dockerfile
525
3.72 K
Ascend Extension for PyTorch
Python
331
395
本项目是CANN提供的数学类基础计算算子库,实现网络在NPU上加速计算。
C++
878
586
openEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。
C
336
165
暂无简介
Dart
766
189
Nop Platform 2.0是基于可逆计算理论实现的采用面向语言编程范式的新一代低代码开发平台,包含基于全新原理从零开始研发的GraphQL引擎、ORM引擎、工作流引擎、报表引擎、规则引擎、批处理引引擎等完整设计。nop-entropy是它的后端部分,采用java语言实现,可选择集成Spring框架或者Quarkus框架。中小企业可以免费商用
Java
12
1
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
1.33 K
747
🔥LeetCode solutions in any programming language | 多种编程语言实现 LeetCode、《剑指 Offer(第 2 版)》、《程序员面试金典(第 6 版)》题解
Java
67
20
React Native鸿蒙化仓库
JavaScript
302
352