掌握ChangeSpeed类:让数学动画速度随心而动!

在制作数学动画时,我们常常希望动画的速度能够根据需要进行调整,以更好地展示数学概念的演变过程。

Manim框架中的ChangeSpeed类就是这样一个强大的工具,它能够帮助我们轻松地控制动画的速度变化,让动画更加生动和富有表现力。

1. 主要作用

ChangeSpeed类的主要作用是改变动画的播放速度

在数学动画中,有些部分可能需要快速展示,比如简单的平移或旋转;而有些部分则需要慢速展示,以便观众能够仔细观察其中的细节,比如复杂的函数变换或几何图形的构造。

通过使用ChangeSpeed类,我们可以对动画的速度进行精确的控制,让动画的节奏更加符合我们的需求。

一句话来说:动态控制动画的播放速度,实现加速/减速效果。

想象一辆小车:

  • 默认动画 → 小车匀速移动(枯燥?)
  • 使用ChangeSpeed → 小车起步慢 → 中途加速 → 终点前减速(生动!?)

它通过修改动画的时间流速实现变速,完美适配移动、旋转、变形等各类动画。

2. 参数详解

ChangeSpeed类的使用需要我们了解它的各个参数,其中最重要的参数就是speedinfo

这个参数是ChangeSpeed的灵魂!它是一个字典,定义不同时间点的速度倍率:

  • (Key):动画进度比例(0=开始,1=结束)
  • (Value):该时刻的速度倍数(1=原速,2=2倍速,0.5=半速)

设置speedinfo参数的示例如下:

# 先加速后减速(小车启动停止效果)
speedinfo = {
 0: 0.3, # 开始时0.3倍慢速
 0.7: 1.8, # 70%进度时1.8倍快速
 1: 0.2 # 结束时0.2倍慢速
}
# 匀速突然变慢(强调终点)
speedinfo = {
 0: 1.0, 
 0.8: 1.0, # 前80%保持原速
 1: 0.1 # 最后20%大幅减速
}

当然,除了speedinfo参数,ChangeSpeed类还有一些其他参数,比如动画的持续时间(duration)和动画的起始时间(start_time)。

这些参数比较简单,一看就明白它的含义。

3. 使用示例

下面通过两个示例来演示ChangeSpeed类的使用。

3.1. 模拟自由落体运动

小球下落逐渐加速,模拟重力加速。

class Example(Scene):
 def construct(self):
 ball = Circle(
 radius=0.2,
 color=RED,
 fill_color=YELLOW,
 fill_opacity=0.8,
 )
 path = Line(UP * 3, DOWN * 3) # 垂直路径
 # 重力加速度效果:下落越来越快
 speedinfo = {0: 0.1, 0.3: 0.5, 1: 2.0}
 self.play(
 ChangeSpeed(MoveAlongPath(ball, path), speedinfo=speedinfo),
 run_time=3,
 )
 self.wait()

3.2. 重点展示轨迹关键点

这个示例展示一个沿着抛物线运动的点,在几个关键位置放慢速度,引起注意。

class Example(Scene):
 # 求函数图像与坐标轴交点
 def construct(self):
 axes = Axes()
 graph = axes.plot(lambda x: x**2)
 dot = Dot(color=YELLOW)
 # 交点处减速强调
 speedinfo = {
 0: 1.2,
 0.4: 1.2, # 快速移动到第一个交点
 0.45: 0.1, # 在(0,0)减速
 0.55: 1.0,
 0.9: 1.0, # 快速移动到第二个交点
 0.95: 0.1, # 在(1,1)减速
 }
 self.play(
 ChangeSpeed(MoveAlongPath(dot, graph), speedinfo=speedinfo),
 run_time=5,
 )
 self.wait()

4. 总结

ChangeSpeed类是Manim框架中一个非常有用的工具,它为我们提供了对动画速度的灵活控制。

结合ChangeSpeed类来完成我们的动画,可以:

  1. 打破单调性 → 匀速动画易让观众走神,变速创造视觉节奏
  2. 符合现实规律 → 真实物理世界极少匀速运动(抛物线、摩擦力等)
  3. 突出关键信息 → 像电影慢镜头一样强调重点区域
  4. 提升专业感 → 细微的速度变化让动画媲美科教纪录片
作者:wang_yb原文地址:https://www.cnblogs.com/wang_yb/p/18929737

%s 个评论

要回复文章请先登录注册