【manim动画教程】–高级动画效果

在常用的动画效果中,介绍了一些元素的创建,销毁,移动和变换的方法,这些方法都是针对单个动画的。
如果需要多个动画互相关联,或者元素需要有更复杂的运动方式,那么,仅仅依靠常用的动画效果可能就无法满足要求了。

本篇的高级动画效果主要介绍一些更加灵活的元素运动方式,如何组合多个动画,以及如何联动多个动画的方式。
掌握了这些方法,就能够表达出更加复杂的数学几何动画。

1. 沿着路径运动

常用的动画一般都是直线运动或者圆弧运动,而 MoveAlongPath 可以让元素沿着任意的函数轨迹来运动。
下面的示例是一个点沿着一个较为复杂的三角函数形成的路径运动。

cos_func = FunctionGraph(
    lambda t: np.cos(t) + 0.5 * np.cos(7 * t) + (1 / 7) * np.cos(14 * t),
    color=RED,
)
sc.add(cos_func)
d1 = dot(cos_func.get_start())
sc.play(MoveAlongPath(d1, cos_func), rate_func=linear, run_time=3)

运行效果:
沿着路径运动.gif

2. 保留运动路径

保留动画的轨迹,可以更好的追踪元素的变化规律。
通过 TracedPath可以设置保留运动轨迹的效果。
下面的示例是一个点以一定的弧度运行,并将其运行的轨迹绘制出来。

d = dot(RIGHT * 2)
b = TracedPath(d.get_center)
sc.add(d, b)

sc.play(d.animate(path_arc=PI / 4).shift(LEFT * 2))
sc.play(d.animate(path_arc=-PI / 4).shift(LEFT * 2))

运行效果:
保留运动路径.gif

3. 动画组合

在常用的动画效果中,一般都是逐个显示各个动画效果,manim中提供了几个控制动画组合的方式。
用的较多的两个分别是:

  1. 多个动画组合时,设置每个动画的延迟启动时间
  2. 多个动画组合时,前一个动画成功执行后再执行下一个动画

3.1 延迟启动

通过 LaggedStart控制组合的多个动画之间的启动时间间隔。
下面的示例是一个点先启动,但是要运行1秒才到达终点,
另一个点延迟0.5秒启动,但是运行0.5秒就到达终点,所以两个点最终应该同时到达

d1 = dot(LEFT * 2 + UP, color=RED)
d2 = dot(LEFT * 2 + DOWN)
dl = DashedLine(
    RIGHT * 2 + UP * 3,
    RIGHT * 2 + DOWN * 3,
    dash_length=0.1,
    dashed_ratio=0.8,
    stroke_width=2,
    color=GREEN,
)
sc.add(d1, d2, dl)
sc.wait(0.5)

ani1 = d1.animate(run_time=1).shift(RIGHT * 4)
ani2 = d2.animate(run_time=0.5).shift(RIGHT * 4)

sc.play(LaggedStart(ani1, ani2, lag_ratio=0.5))

运行效果:
动画组合-延迟启动.gif

3.2 顺序启动

通过 Succession控制多个动画顺序执行,它能够保证上一个执行成功后才执行下一个。
下面的示例是4个不同颜色的点,每个点移动成功之后,移动下一个点。

dot1 = Dot(point=LEFT * 2 + UP * 2, radius=0.16, color=BLUE)
dot2 = Dot(point=LEFT * 2 + DOWN * 2, radius=0.16, color=MAROON)
dot3 = Dot(point=RIGHT * 2 + DOWN * 2, radius=0.16, color=GREEN)
dot4 = Dot(point=RIGHT * 2 + UP * 2, radius=0.16, color=YELLOW)
sc.add(dot1, dot2, dot3, dot4)

sc.play(
    Succession(
        dot1.animate.move_to(dot2),
        dot2.animate.move_to(dot3),
        dot3.animate.move_to(dot4),
        dot4.animate.move_to(dot1),
    )
)

运行效果:
动画组合-顺序启动.gif

4. 动画联动

动画联动是比动画组合更复杂的一种模式,动画组合时,每个动画其实是固定的,只是启动的时机不一样。
而在动画联动中,一个动画如何运行是完全基于另一个动画的,而不是实现预设的。

下面的示例是一个角度的联动效果,
初始元素有:

  1. 两条线line1line_moving组成的角度
  2. 标识角度的一段弧线a
  3. 标识角度的字母 tex
  4. 显示角度数值的文字 theta_tex

初始角度 110°,然后可以看到随着 line_moving的移动(先变成 90°,再增加 140°),
atextheta_tex的联动效果。

rotation_center = LEFT

theta_tracker = ValueTracker(110)
line1 = Line(LEFT, RIGHT)
line_moving = Line(LEFT, RIGHT)
line_ref = line_moving.copy()
line_moving.rotate(theta_tracker.get_value() * DEGREES, about_point=rotation_center)
a = Angle(line1, line_moving, radius=0.5, other_angle=False)
tex = MathTex(r"\theta").move_to(
    Angle(
        line1, line_moving, radius=0.5 + 3 * SMALL_BUFF, other_angle=False
    ).point_from_proportion(0.5)
)

theta_tex = Tex(
    r"$\theta = $",
    str(int(theta_tracker.get_value())),
    r"$^\circ$",
    font_size=50,
    color=RED,
).shift(UP * 2)

sc.add(line1, line_moving, a, tex, theta_tex)
sc.wait()

line_moving.add_updater(
    lambda x: x.become(line_ref.copy()).rotate(
        theta_tracker.get_value() * DEGREES, about_point=rotation_center
    )
)
a.add_updater(
    lambda x: x.become(Angle(line1, line_moving, radius=0.5, other_angle=False))
)
tex.add_updater(
    lambda x: x.move_to(
        Angle(
            line1, line_moving, radius=0.5 + 3 * SMALL_BUFF, other_angle=False
        ).point_from_proportion(0.5)
    )
)
theta_tex.add_updater(
    lambda x: x.become(
        Tex(
            r"$\theta = $",
            str(int(theta_tracker.get_value())),
            r"$^\circ$",
            font_size=50,
            color=RED,
        ).shift(UP * 2)
    )
)

sc.play(theta_tracker.animate.set_value(90))
sc.play(theta_tracker.animate.increment_value(140), run_time=3)

运行效果:
动画联动.gif

5. 总结回顾

本篇介绍的高级动画效果,其实是一些更加灵活的制作动画的方法。
利用这些方法,可以更加方便的定制自己的动画效果。

本篇介绍的高级动画效果和上一篇的常用动画效果可以理解成软件的VIP功能和免费功能,
如果免费功能够用,尽量使用免费功能,免费功能满足不了要求的时候,再考虑VIP功能。

本文关联的微信视频号短视频:
manim-高级动画效果-视频号.png

原文链接:https://www.cnblogs.com/wang_yb/p/17317576.html

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:【manim动画教程】–高级动画效果 - Python技术站

(0)
上一篇 2023年4月17日
下一篇 2023年4月17日

相关文章

  • python Pygame的具体使用讲解

    Python Pygame的具体使用讲解 Pygame是一个基于Python的游戏开发库,它可以让开发者方便地开发2D游戏。本文将详细讲解如何使用Pygame进行游戏开发。 安装Pygame 使用Pygame前,需要安装Pygame。可使用pip命令进行安装。 pip install pygame 创建游戏窗口 使用Pygame创建游戏窗口非常简单,只需要导…

    python 2023年5月14日
    00
  • python读取xml文件方法解析

    在Python中,可以使用xml模块解析XML文件。以下是Python读取XML文件方法解析的详细攻略: 使用ElementTree模块解析XML文件 ElementTree是Python标准库中的一个模块,可以解析XML文件。以下是使用ElementTree模块解析XML文件的示例: import xml.etree.ElementTree as ET t…

    python 2023年5月14日
    00
  • pandas读取excel,txt,csv,pkl文件等命令的操作

    下面是“pandas读取excel,txt,csv,pkl文件”的完整实例教程。 准备工作 在使用pandas读取文件之前,首先需要导入pandas库。通常我们使用以下命令导入pandas: import pandas as pd 接下来我们需要准备几个数据文件来做示例: 示例1:sales.xlsx,一个包含销售数据的Excel文件 示例2:iris.cs…

    python 2023年5月14日
    00
  • Python使用Beautiful Soup包编写爬虫时的一些关键点

    在本攻略中,我们将介绍如何使用Python的BeautifulSoup包编写爬虫时的一些关键点。BeautifulSoup是一个Python库,用于从HTML和XML文件中提取数据。它提供了一种简单的方式来遍历HTML和XML文档,查找和提取数据。 以下是一个完整攻略包括两个示例。 步骤1:安装BeautifulSoup 首先,需要安装BeautifulSo…

    python 2023年5月15日
    00
  • python编程羊车门问题代码示例

    让我们来详细讲解一下“python编程羊车门问题代码示例”的完整攻略。 什么是羊车门问题 羊车门问题也叫蒙提霍尔问题(Monty Hall problem),源自一个电视游戏节目:参赛者选中某门,此时节目主持人会开启另外两扇门中的一扇,露出其中的一只山羊,之后参赛者是否改变选择。一些人对于这道问题有不同的答案,促使学校以及教科书认为只是一个影响统计学理论的小…

    python 2023年5月20日
    00
  • 一篇文章带你了解python字典基础

    一篇文章带你了解Python字典基础 什么是字典 Python 字典是一种无序的、可变的、有键的集合数据类型,其基本数据结构为键值对(key-value)。在字典中,每个键(key)都对应着一个值(value),键和值之间用冒号(:)隔开,键值对之间用逗号(,)分隔。 定义字典 可以通过花括号直接定义一个字典,也可以通过 dict() 函数来创建一个字典。其…

    python 2023年5月13日
    00
  • Python正则表达式匹配HTML页面编码

    以下是“Python正则表达式匹配HTML页面编码”的完整攻略: 一、问题描述 在Python中,我们可以使用正则表达式来匹配HTML页面编码。本文将详细讲解Python正则表达式匹配HTML页面编码的方法,以及如何在实际开发中应用。 二、解决方案 2.1 匹配HTML页面编码的方法 在Python中,匹配HTML页面编码的方法可以使用正则表达式来实现。我们…

    python 2023年5月14日
    00
  • pandas读取CSV文件时查看修改各列的数据类型格式

    当我们使用pandas读取CSV文件时,默认会根据每列数据的内容自动判断数据类型。如果数据量较大,或者数据类型较为复杂,那么自动判断可能就存在偏差。在这种情况下,我们可以手动指定每列的数据类型。 下面是如何指定数据类型的具体步骤及示例说明: 步骤1:使用pandas的read_csv函数读取CSV文件,同时指定参数dtype,为每列指定数据类型。 impor…

    python 2023年6月3日
    00
合作推广
合作推广
分享本页
返回顶部