news 2026/7/2 3:48:55

MANIM零基础入门:30分钟创建第一个数学动画

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
MANIM零基础入门:30分钟创建第一个数学动画

快速体验

  1. 打开 InsCode(快马)平台 https://www.inscode.net
  2. 输入框内输入如下内容:
生成一个面向初学者的MANIM学习项目,包含:1) 安装配置指导 2) 基础图形绘制教程 3) 简单动画制作示例 4) 常见问题解答。要求每个步骤都有可视化示例和可运行的代码片段,使用最简语法并添加详细注释。
  1. 点击'项目生成'按钮,等待项目生成完整后预览效果

MANIM零基础入门:30分钟创建第一个数学动画

最近想给数学课件加点动态效果,偶然发现了MANIM这个强大的数学动画引擎。作为Python库,它能把抽象的数学概念变成直观的动画。虽然官方文档有点硬核,但经过几天摸索,我总结出了最适合新手的入门路径。

环境准备比想象中简单

  1. 安装Python:推荐Python 3.8+版本,官网下载安装包勾选"Add to PATH"选项。安装后命令行输入python --version验证是否成功。

  2. 创建虚拟环境:在项目文件夹里执行python -m venv venv,然后激活环境(Windows用venv\Scripts\activate,Mac/Linux用source venv/bin/activate)。

  3. 安装MANIM:激活环境后运行pip install manim,这个命令会安装基础版。如果需要视频导出功能,建议用pip install manim[full]安装完整版。

第一个图形:画个圆试试

MANIM的核心是Scene类,所有动画都在这个舞台上演。创建一个.py文件,导入manim库后:

  1. 基础结构:每个动画文件都需要继承Scene类,并实现construct方法。这里我们画个红色圆圈:
from manim import * class FirstCircle(Scene): def construct(self): circle = Circle(color=RED) self.play(Create(circle)) self.wait(2)
  1. 运行命令:保存为first_scene.py后,在终端执行manim -pql first_scene.py FirstCircle-pql参数表示预览低画质,运行后会弹出视频窗口。

  2. 参数调整:尝试修改color=BLUEradius=2等属性,重新运行看效果变化。

让图形动起来

静态图形不够过瘾?给圆环添加移动动画:

  1. 位移动画:在self.wait(2)前添加:
self.play(circle.animate.shift(RIGHT*3))
  1. 组合动画:MANIM支持同时播放多个动画,用AnimationGroup包装:
self.play(AnimationGroup( circle.animate.shift(UP), circle.animate.scale(2), lag_ratio=0.5 ))
  1. 路径动画:沿预定路径移动:
path = ArcBetweenPoints(LEFT*3, RIGHT*3) self.play(MoveAlongPath(circle, path))

数学公式与文本

MANIM最强大的功能是渲染LaTeX公式:

  1. 基础公式
equation = MathTex(r"\frac{d}{dx}f(x) = \lim_{h\to 0}\frac{f(x+h)-f(x)}{h}") self.play(Write(equation))
  1. 公式变换
eq1 = MathTex("a^2 + b^2 = c^2") eq2 = MathTex("c = \\sqrt{a^2 + b^2}") self.play(Transform(eq1, eq2))
  1. 文字说明
text = Text("勾股定理", font_size=24).next_to(eq1, DOWN) self.play(AddTextLetterByLetter(text))

避坑指南

  1. 视频不显示:检查是否安装了ffmpeg,完整版MANIM自带,基础版需要单独安装。

  2. LaTeX报错:确保系统安装了TeX发行版(如MiKTeX或TeX Live)。

  3. 动画卡顿:复杂场景先用-pql低画质预览,完成后再用-pqh导出高清。

  4. 导入错误:检查Python版本和MANIM版本是否兼容,推荐使用virtualenv隔离环境。

  5. 路径问题:Windows用户注意反斜杠转义,建议使用原始字符串r"path\to\file"

进阶方向

掌握基础后可以尝试: - 使用ValueTracker实现交互式动画 - 通过自定义CSS美化文本样式 - 利用ThreeDScene创建3D数学图形 - 组合多个场景制作完整教学视频

整个学习过程中,我发现在InsCode(快马)平台上实践特别方便。不需要配置本地环境,打开网页就能直接编写和运行MANIM代码,还能一键分享动画成果。对于想快速验证效果的新手来说,这种即开即用的体验确实省去了很多麻烦。特别是他们的实时预览功能,改完代码立即能看到变化,比本地反复渲染测试效率高多了。

快速体验

  1. 打开 InsCode(快马)平台 https://www.inscode.net
  2. 输入框内输入如下内容:
生成一个面向初学者的MANIM学习项目,包含:1) 安装配置指导 2) 基础图形绘制教程 3) 简单动画制作示例 4) 常见问题解答。要求每个步骤都有可视化示例和可运行的代码片段,使用最简语法并添加详细注释。
  1. 点击'项目生成'按钮,等待项目生成完整后预览效果
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/29 17:23:02

Kafka面试小白指南:从基础概念到常见问题

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容: 开发一个面向Kafka初学者的交互式学习应用,包含:1. 动画图解Kafka核心概念(生产者、消费者、Broker等);2. 渐进式难度设…

作者头像 李华
网站建设 2026/6/26 15:17:41

零基础Neo4j入门:从安装到第一个图查询

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容: 开发一个交互式Neo4j学习沙盒环境,包含:1) 内置的Neo4j实例;2) 分步互动教程;3) 实时查询编辑器;4) 可视化结果展示。使…

作者头像 李华
网站建设 2026/7/1 13:16:52

JDK1.8入门指南:从安装到第一个Lambda程序

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容: 生成一个面向Java初学者的JDK1.8学习项目。要求:1. 包含JDK1.8安装配置指南;2. 10个循序渐进的示例代码(从Hello World到Lambda表达式&#xff…

作者头像 李华
网站建设 2026/7/1 0:39:29

现代C++特性深度探索:模板扩展、类增强、STL更新与Lambda表达式

可变参数模版4.4 emplace系列接口通过前面的学习,我们知道emplace_back和push_back的区别其实不是很大,真正的区别就是:emplace_bakc是一个可变参数模版,而push_back只是一个普通的函数emplace_back可以传参数包进行构造&#xff…

作者头像 李华
网站建设 2026/6/28 20:47:07

AI如何革新电路设计?在线仿真新体验

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容: 开发一个基于AI的电路在线仿真平台,支持用户上传电路图或输入电路描述,自动生成仿真结果。平台应包含以下功能:1. 支持常见电子元件库&#xff…

作者头像 李华
网站建设 2026/6/25 18:05:41

5分钟创建Maven原型项目:快速验证你的技术方案

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容: 开发一个Maven原型项目生成器,功能:1.主流框架(Spring/MyBatis等)模板库 2.可视化依赖选择器 3.自动生成可执行demo代码 4.一键部署测试环境 5.原型评估报告…

作者头像 李华