轻松掌握Manim的.animate语法:让动画编程更简单
在Manim中,.animate语法是一个非常实用的功能,它能让你的动画代码变得更加简洁和直观。
本文将详细介绍.animate语法,看看它是如何让动画制作变得更加简单又有趣,即使是编程新手也能轻松上手。
1. .animate是什么?
在Manim中,.animate是一个特殊的语法糖,它允许你将对象的属性修改操作直接转换为动画效果。
简单来说,当你对一个动画对象(Mobject)使用.animate前缀时,原本立即生效的属性修改会变成一个平滑的动画过渡过程。
举个简单的例子,如果你想让一个正方形旋转 45 度,传统的做法可能需要使用Rotate动画类,而使用.animate语法,你只需要在旋转方法前加上.animate即可:
# 传统方法
self.play(Rotate(square, angle=PI/4))
# 使用.animate语法
self.play(square.animate.rotate(PI/4))
2. 为什么需要 .animate?
使用Manim中提供的各类动画类,也能实现各类动画效果,.animate语法并不是提供新的动画效果,而是:
2.1. 让代码更加简洁
想象一下,如果你需要对一个对象进行多次属性修改,并且希望每次修改都产生动画效果,传统的方法需要为每一次修改都创建一个动画对象,这会让代码变得冗长繁琐。
而.animate语法允许你以链式调用的方式完成多个动画效果,让代码更加简洁直观。
2.2. 更符合自然编程思维
.animate语法的设计理念是** "所见即所得"**,你可以像平时修改对象属性一样编写代码,而 Manim 会自动将这些修改转换为流畅的动画效果。
这种方式更符合我们日常的编程思维,降低了动画编程的学习成本。
2.3. 增强动画控制能力
通过.animate语法,你可以更精细地控制动画的各个方面,比如动画持续时间、缓动效果等。你
可以将多个动画效果组合在一起,创建出复杂而流畅的动画序列。
3. 常用场景是和使用示例
下面我们通过示例来演示.animate语法在一些常用场景的使用。
3.1. 基本属性动画
最常见的.animate用法就是对对象的基本属性进行动画化,比如位置、旋转角度、颜色、大小等。
下面的示例展示了如何使用.animate语法创建一个动态变化的正方形:
class AnimatedSquare(Scene):
def construct(self):
# 创建一个蓝色正方形
square = Square(color=BLUE, fill_opacity=0.7)
# 显示正方形
self.play(Create(square))
# 使用.animate语法创建一系列动画
self.play(
square.animate.set_fill(RED), # 改变填充颜色
)
self.play(
square.animate.rotate(PI / 6), # 旋转45度
)
self.play(
square.animate.shift(UP), # 向上移动
)
self.play(
square.animate.scale(1.5), # 放大1.5倍
)
# 等待一段时间查看效果
self.wait()

在这个示例中,我们使用.animate语法对正方形的填充颜色、旋转角度、位置和大小进行了动画化处理。
所有这些动画效果形成一个流畅的动画序列。
3.2. 场景变换动画
除了基本属性的动画,.animate语法还可以用于对象的变换效果。
下面的示例展示了如何将一个正方形变换为圆形,并在变换过程中使用.animate语法添加颜色变化:
from manim import *
class AnimatedSquare(Scene):
def construct(self):
# 创建一个蓝色正方形
square = Square(color=BLUE, fill_opacity=0.7).shift(DOWN).scale(0.5)
# 显示正方形
self.play(Create(square))
# 使用.animate语法创建一系列动画
self.play(
square.animate.set_fill(RED), # 改变填充颜色
)
self.play(
square.animate.rotate(PI / 6), # 旋转45度
)
self.play(
square.animate.shift(UP), # 向上移动
)
self.play(
square.animate.scale(1.5), # 放大1.5倍
)
# 等待一段时间查看效果
self.wait()

在这个示例中,我们首先使用.animate.rotate对正方形进行旋转动画,然后使用Transform将正方形变换为圆形,最后再使用.animate.set_fill对圆形的颜色进行动画化处理。
通过.animate语法,我们可以轻松地在不同的动画效果之间创建平滑的过渡。
3.3. 多对象动画控制
.animate语法还可以用于同时控制多个对象的动画效果,下面是一个示例,展示了如何同时对两个正方形进行不同的动画处理:
from manim import *
class MultipleObjectsAnimated(Scene):
def construct(self):
# 创建两个正方形
left_square = Square(color=BLUE, fill_opacity=0.7).shift(1.5 * LEFT)
right_square = Square(color=GREEN, fill_opacity=0.7).shift(1.5 * RIGHT)
# 同时显示两个正方形
self.play(Create(left_square), Create(right_square))
# 使用.animate语法对左边正方形进行旋转动画
# 同时使用传统方法对右边正方形进行旋转
self.play(
left_square.animate.rotate(PI), # 使用.animate语法
Rotate(right_square, angle=PI), # 传统方法
run_time=2, # 动画持续时间
)
# 等待一段时间查看效果
self.wait()

这个示例展示了.animate语法和传统动画方法的区别。
左边的正方形使用.animate.rotate进行旋转,而右边的正方形使用传统的Rotate类进行旋转。
由于旋转 180 度后对象的起始状态和结束状态相同,.animate语法会尝试在两个相同的状态之间进行插值,这可能会产生一些意想不到的效果(比如上面左边正方形显示的是缩放效果,而不是旋转效果),而传统的Rotate类则会直接执行旋转动作。
4. 总结
.animate语法是 Manim 中一个非常实用的功能,它让动画编程变得更加简单和直观。
通过.animate语法,你可以像修改普通对象属性一样编写动画代码,而 Manim 会自动将这些修改转换为流畅的动画效果。
无论是基本属性的动画、对象变换还是多对象控制,.animate语法都能让你的代码更加简洁和易读。
不过,.animate语法并不是为了取代传统动画方法,它们各有应用场景,使用.animate语法时也要注意:
.animate语法的本质:当你使用.animate语法时,Manim实际上是在对象的当前状态和目标状态之间进行插值计算,从而生成平滑的动画效果。这意味着如果你的起始状态和结束状态相同,可能不会看到任何动画效果。- 与传统动画方法相比:在大多数情况下,
.animate语法已经足够满足你的动画需求,但在某些特殊情况下,比如需要精确控制动画的插值方式或处理复杂的对象变换时,传统的动画方法可能更加合适。 - 动画持续时间和缓动效果:你可以通过
self.play方法的参数来控制.animate动画的持续时间和缓动效果,例如run_time=2设置动画持续 2 秒,easing=smooth设置平滑的缓动效果。
轻松掌握Manim的.animate语法:让动画编程更简单的更多相关文章
- Jquery小例子:全选按钮、加事件、挂事件;parent()语法;slideToggle()语法;animate()语法;元素的淡入淡出效果:fadeIn() 、fadeOut()、fadeToggle() 、fadeTo();function(e):e包括事件源和时间数据;append() 方法
function(e): 事件包括事件源和事件数据,事件源是指是谁触发的这个事件,谁就是事件源(div,按钮,span都可以是事件源),时间数据是指比如点击鼠标的事件中,事件数据就是指点击鼠标的左建或 ...
- Adobe Edge Animate –地球自转动画的实现,类似flash遮罩层的效果
Adobe Edge Animate –地球自转动画的实现,类似flash遮罩层的效果 版权声明: 本文版权属于 北京联友天下科技发展有限公司. 转载的时候请注明版权和原文地址. 目前Edge的功能尚 ...
- vue中使用第三方插件animate.css实现动画效果
vue中使用第三方插件animate.css实现动画效果1.首先先引入第三方类animated.css2.将你所需要动画的标签用包裹起来3.在transition元素中添加enter-active-c ...
- 转一篇简洁的UIView动画编程方法
iOS 中的 UIView 动画编程其实还是很简单的,像 CSS3 一样,在给定的时间内完成状态连续性的变化呈现.比如背景色,Frame 大小,位移.翻转,特明度等. 以前我使用的编程方式都是用下面 ...
- 冒泡动画按钮的简单实现(使用CSS3)
冒泡动画按钮的简单实现(使用CSS3) 原始的参考文章是 http://tutorialzine.com/2010/10/css3-animated-bubble-buttons/ ,基本原理是利用了 ...
- Cats(3)- freeK-Free编程更轻松,Free programming with freeK
在上一节我们讨论了通过Coproduct来实现DSL组合:用一些功能简单的基础DSL组合成符合大型多复杂功能应用的DSL.但是我们发现:cats在处理多层递归Coproduct结构时会出现编译问题.再 ...
- Swift动画编程指南-01 简介
大家好,我是老镇,这段时间家里和工作上发生了很多的事情,所以很长一段时间都没有出来搞什么小动作了.在接下来的一段时间内我会制作一些列关于使用Swift进行动画编程的视频,希望和大家胃口. 在iOS的世 ...
- iOS开发之动画编程的几种方法
iOS开发之动画编程的几种方法 IOS中的动画总结来说有五种:UIView<block>,CAAnimation<CABasicAnimation,CATransition,CAKe ...
- iOS开发CoreAnimation解读之一——初识CoreAnimation核心动画编程
iOS开发CoreAnimation解读之一——初识CoreAnimation核心动画编程 一.引言 二.初识CoreAnimation 三.锚点对几何属性的影响 四.Layer与View之间的关系 ...
- “AS3.0高级动画编程”学习:第一章高级碰撞检测
AdvancED ActionScript 3.0 Animation 是Keith Peters大师继"Make Things Move"之后的又一力作,网上已经有中文翻译版本了 ...
随机推荐
- Polar困难模式部分题解
choose from pwn import *from LibcSearcher import *context.terminal = ["tmux","splitw& ...
- Qt个人项目总结 —— MySQL数据库查询与断言
3.Qt项目总结--数据库查询断言问题 问题: 当我使用MySQL数据库的查询操作时, 如果查询的数据在数据库中不存在,那么Qt会直接被干崩溃 但是?为什么呢?不应该是返回if语句中的结果吗,为什么会 ...
- 终于写完轮子一部分:tcp代理 了,记录一下
24年终自己立了flag: 25年做些轮子玩(用于浪费生命,赚不了钱) 所以25年就准备用c#写一个网络代理NZOrz(nginx知道吧,就那玩意儿干的事),包含 udp/tcp/http1 2 3, ...
- 一款基于.NET开源、强大的网络管理和网络问题排查工具!
前言 今天大姚给大家分享一款基于.NET开源.免费.功能强大的网络管理和网络问题排查工具:NETworkManager. 项目介绍 NETworkManager 是一个基于.NET开源(GPL-3.0 ...
- 扩展知识:vscode配置easyx
扩展知识:vscode配置easyx 前言 因为个人用习惯了vscode,对于visual studio的操作只能说相当程度上很不适应,因此,我打算经历一番配置,让vscode可以配置上easyx ...
- Java List和Array之间的转换
import java.util.Arrays; import java.util.List; class Test { //Object数组向List的转换 public static List&l ...
- MongoDB 简单介绍
MongoDB介绍 疑问 解答 什么是 MongoDB 一个以 JSON 为数据模型的文档数据库 为什么叫文档数据库? 文档来自于 "JSON Document",并非我们一般理解 ...
- 【Java】枚举类和注解
一.枚举类的使用 1. 枚举类的说明: 枚举类的理解:类的对象只有有限个,确定的.我们称此类为枚举类 当需要定义一组常量时,强烈建议使用枚举类 枚举类的实现: JDK 5.0以前需要自定义 JDK 5 ...
- dxSpreadSheet的报表demo-关于设计报表模板的Datagroup问题
看随机的报表DEMO,主从表也好,数据分组也好.呈现的非常到位. 问题:可是自己在实现数据分组时,一旦设定分组字段就出现了混乱的数据记录. 问题的原因: 看一下一个报表页面设计时需要理清的概念. 页头 ...
- vue3第二次传递数据方法无法获取到最新的值
使用reactive父组件第二次传递给子组件的数据:方法中可以获取到最新数据 <template> <div> <div> <h1>子组件</h1 ...