本篇介绍Manim中的渐变生长类的动画。

这类动画的特点是可以清晰地展示图形的生成过程、物体的运动变化,帮助我们更好地理解抽象概念和复杂结构。

渐变生长类的动画的主要有:

  1. GrowArrow:让箭头从起始点按设定路径(如直线或弧线)和速度动态生长
  2. GrowFromCenter:使对象以自身中心为起点,向四周按指定比例和速度均匀扩展生长
  3. GrowFromEdge:让对象从指定边缘开始,按照设定的速度和程度向内部或外部生长
  4. GrowFromPoint:从一个点开始,按照自定义的生长函数和速度来使对象生长
  5. SpinInFromNothing:结合旋转和渐显效果,使对象从无到有并伴随着旋转而出现

1. 动画概述

1.1. GrowArrow

GrowArrow主要用于箭头(Arrow)对象的动画效果,能够让箭头从无到有地生长出来,给人一种动态的引导视觉效果。

它的动画过程比较平滑,能够很好地控制箭头生长的速度和方向,主要用于展示矢量相关内容的动画。

它的主要参数有:

参数名称 类型 说明
arrow Arrow类型 进行动画的箭头对象
point_color Color 箭头在生长到完整大小之前的初始颜色

主要方法有:

名称 说明
create_starting_mobject 用于创建动画起始时的对象状态

1.2. GrowFromCenter

GrowFromCenter以对象的中心为起点,向四周扩展生长。

这种生长方式给人一种对称、均匀的视觉感受,使得对象的出现更加自然和美观。

对于具有中心对称性的对象,能够很好地突出其对称性,它适合用于展现图形从中心构建过程的动画。

它的主要参数有:

参数名称 类型 说明
mobject Mobject 要进行动画的对象
point_color Color 对象在生长到完整大小之前的初始颜色

1.3. GrowFromEdge

GrowFromEdge以对象的边缘为起始点进行生长,能够很好地体现图形的边界扩展过程。

这种方式与GrowFromCenter形成对比,更侧重于展示图形是如何从边界开始构建的。

它可以根据需要选择不同的边缘作为生长起始边,常用于突出图形边界扩展的效果。

它的主要参数有:

参数名称 类型 说明
mobject Mobject 要进行动画的对象
edge np.ndarray 指定生长的起始边缘方向
point_color Color 对象在生长到完整大小之前的初始颜色

edge参数可以使用预定义的方向常量(如DOWNRIGHTUR等)来指定对象的边界框边缘方向,

从而确定从哪个边缘开始生长。

1.4. GrowFromPoint

GrowFromPoint从指定的一个点开始生长,这个点可以是对象内部或外部的任意一点。

这种方式提供了高度的定制性,能够聚焦于对象在某个特定位置的生长过程。

它可以用于创建一些具有创意的动画效果,比如让多个对象从不同的点同时生长,形成一个复杂的场景。

它的主要参数有:

参数名称 类型 说明
mobject Mobject 要进行动画的对象
point np.ndarray 指定对象生长的起始点
point_color Color 对象在生长到完整大小之前的初始颜色

主要方法有:

名称 说明
create_starting_mobject 创建动画起始时的对象状态
create_target 创建动画的目标对象状态

1.5. SpinInFromNothing

SpinInFromNothing结合了旋转和从无到有的出现效果。

对象在旋转的同时逐渐显现,给人一种从虚无中旋转诞生的感觉

可以控制旋转的角度、方向和速度,以及对象出现的速度,从而实现各种不同的入场效果。

它的主要参数有:

参数名称 类型 说明
mobject Mobject 要进行动画的对象
angle float 指定对象在生长到完整大小之前旋转的角度
point_color Color 对象在生长到完整大小之前的初始颜色

angle参数设置2 * PI表示对象将完整旋转一周(360 度)后完全出现。

2. 使用示例

下面通过示例来演示各个生长类动画的使用。

2.1. GrowArrow 示例

在这个示例中,创建了三个不同方向的箭头。

对于每个箭头,使用GrowArrow动画并设置不同的初始颜色(point_color),为了能看出初始颜色,设置了箭头的最终颜色和初始颜色不一样。

# 创建不同方向的箭头
a1 = Arrow(LEFT * 2, RIGHT * 2, color=RED)
a2 = Arrow(UP * 2, DOWN * 2, color=BLUE)
a3 = Arrow(UR * 2, DL * 2, color=GREEN) # 以不同颜色和路径弧度展示GrowArrow动画
self.play(
GrowArrow(a1, point_color=BLUE),
)
self.play(
GrowArrow(a2, point_color=GREEN),
)
self.play(
GrowArrow(a3, point_color=RED),
)

2.2. GrowFromCenter 示例

此示例创建了圆形、正方形和三角形。在GrowFromCenter动画中,为每个图形设置不同的初始颜色(point_color)。

# 创建不同形状的对象
circle = Circle()
square = Square(color=BLUE)
triangle = Triangle(color=YELLOW) # 以不同缩放比例和中心点展示GrowFromCenter动画
self.play(
GrowFromCenter(circle, point_color=BLUE),
)
self.play(
GrowFromCenter(square, point_color=YELLOW),
)
self.play(
GrowFromCenter(triangle, point_color=RED),
)

2.3. GrowFromEdge 示例

在这个例子中,创建三个矩形。针对每个矩形的GrowFromEdge动画,指定了不同的起始边缘(edge)和不同的初始颜色(point_color)。

通过不同的边缘生长,可以看到矩形从边缘开始生长的多样化效果。

# 创建多个矩形
r1 = Rectangle(color=BLUE).shift(UP)
r2 = Rectangle(color=RED)
r3 = Rectangle(color=YELLOW).shift(DOWN) # 从不同边缘和以不同速度展示GrowFromEdge动画
self.play(
GrowFromEdge(r1, DOWN, point_color=BLUE),
)
self.play(
GrowFromEdge(r2, RIGHT, point_color=RED),
)
self.play(
GrowFromEdge(r3, UP, point_color=YELLOW),
)

2.4. GrowFromPoint 示例

该示例先创建了三个点,然后在通过不同的起始点和自定义生长函数,展示了GrowFromPoint动画在灵活指定生长起始点和控制生长方式方面的强大功能。

# 创建一个点和多个正方形
p1 = Dot(point=LEFT * 2, color=BLUE)
p2 = Dot(point=UP * 2, color=RED)
p3 = Dot(point=RIGHT * 2 + DOWN * 2, color=YELLOW)
s1 = Square(color=BLUE).shift(LEFT * 2)
s2 = Square(color=RED)
s3 = Square(color=YELLOW).shift(RIGHT * 2) self.add(p1, p2, p3)
self.play(
GrowFromPoint(s1, p1.get_center()),
)
self.play(
GrowFromPoint(s2, p2.get_center(),
grow_function=lambda t: t**2,
),
)
self.play(
GrowFromPoint(s3, p3.get_center()),
)

2.5. SpinInFromNothing 示例

这里创建了三个不同边数的多边形。

SpinInFromNothing动画中,为每个多边形设置了不同的旋转角度(angle)和初始颜色(point_color)。

通过不同的旋转角度和颜色设置,可以看到多边形从无到有并伴随着旋转和颜色变化的生长效果。

# 创建多个多边形
p1 = RegularPolygon(5).shift(LEFT * 2)
p2 = RegularPolygon(6, color=RED)
p3 = RegularPolygon(8, color=YELLOW).shift(RIGHT * 2) # 以不同旋转角度和颜色展示SpinInFromNothing动画
self.play(
SpinInFromNothing(p1),
)
self.play(
SpinInFromNothing(p2, angle=np.pi),
)
self.play(
SpinInFromNothing(p3, angle=3 * np.pi / 2, point_color=PINK),
)

3. 附件

文中的代码只是关键部分的截取,完整的代码共享在网盘中(grow.py),

下载地址: 完整代码 (访问密码: 6872)

manim边学边做--渐变生长的更多相关文章

  1. 学EE做硬件找工作不如学CS做软件,为什么会这样?

    学EE做硬件找工作不如学CS做软件,为什么会这样? 电子工程(EE)就业最好的方向居然是转计算机,也许让有的人觉得很不公平,EE也是很重要的学科,我们学习也很努力,为什么就业会不如CS?也有的人好奇, ...

  2. 牛腩学Kotlin做Android应用

    牛腩学Kotlin做Android应用,蹭热度视频,边学边做, 01-kotlin插件安装及hello world 02-kotlin基础语法速览 哔哩哔哩观看地址:http://www.bilibi ...

  3. php实现记忆化递归--以斐波那契数列为例(还是以边学边做为主,注重练习)

    php实现记忆化递归--以斐波那契数列为例(还是以边学边做为主,注重练习) 一.总结 1.递归不优化的话,30层开外就有点吃力了 2.php因为定义变量的时候不用定义变量类型,所以数组里面的类型也是p ...

  4. html5-3 html5标签(热点地图如何实现)(边学边做)

    html5-3 html5标签(热点地图如何实现)(边学边做) 一.总结 一句话总结:热点地图用绝对定位实现. 1.自定义列表怎么弄? dl  自定义列表dt  自定义标题dd  自定义列表内容 2. ...

  5. 第一份开发工作,边学边做android

    我刚刚毕业,在培训学校学的Java web开发,虽然学的没有大学生那么丰富细致,没有他们理论基础扎实,但是这是我学习软件开发的唯一方式了. 从小学我学习就是倒数2.3等,所有人都认为我是个没法学习的孩 ...

  6. 边学边做,简单的 GraphQL 实例

    项目中有功能要调用 API,对方 API 用的是 GraphQL 实现,就简单学了下,感叹技术进步真快,Facebook 发明的这玩意儿咋这么牛逼,使前端开发人员变得主动起来,想要什么接口.返回什么结 ...

  7. LabVIEW Actor Framwork (2)________ 边学边做server&client

    回顾下初始需求: 现在要做一个类似聊天的demo,一个server端,若干个client端:首先是server启动,通过server可以打开若干个client端,然后每个client可以独立给serv ...

  8. 牛腩学ASP.NET CORE做博客(视频)

    牛腩学习ASP.NET CORE做的项目,边学边做. 目录: 01-dotnetcore网站部署到centos7系统上(时长 2:03:16) 02-前期准备及项目搭建 (时长:0:23:35) 03 ...

  9. 牛腩学用MUI做手机APP

    斗鱼直播间直播学习撸码,最终目标是用MUI做一个手机APP(暂定android平台,攒钱买IPHONE 7SE!!!),直播内容含整个软件APP的制作过程(含后台接口的制作,放到自己买的阿里云服务器, ...

  10. 技术的止境(客户价值第一,快速实现第二,边做边学,迅速成为牛人。紧贴客户的需求去做技术,立于不败之地。追求的目标:把一项产品去做好,用产品去养活自己和家人)good

    作为一个依靠技术来谋生的程序员,我最近一直在思考一个问题,有限的生命里,面对无限的技术更新,我要研究到什么程度才能算是完成我的成为技术大牛的目标呢?换而言之,那就是技术的止境在哪儿呢?深入的思考下去, ...

随机推荐

  1. 邀请参与 2022 第三季度 Flutter 开发者调查

    自 Flutter 3 发布之后,我们在以移动端为中心到多平台框架的路线上稳步前行,用 Dart 2.17 的新语言特性帮助大家提升工作效率,并对核心工具进行了改进,让您在跨平台打造优秀体验时更加得心 ...

  2. 墨天轮最受DBA欢迎的数据库技术文档-SQL优化篇

    [墨天轮最受欢迎的技术文档]系列文章得到了很多朋友的支持,大家也告诉了我们期待看到的主题这不!大家想看的优化系列-SQL优化篇来啦~原文文末送墨值中,欢迎大家参与! 数据库的调优被分成多个阶段,每个阶 ...

  3. js中,什么是数组 , 数组有几种创建方式?

    1. 什么是数组? 数组是可以把一组相关的数据一起存放,并提供方便的访问(存取) 数组是指一组数据的集合,其中每个数据被称作元素(数组单元),数组单元可以是任意类型的数据,数组是一种将一组数据存储在单 ...

  4. 全局和局部混入 mixins

    使用 mixins 混入 的目的 :复用代码,维护代码 : 局部混入: 全局混入 + 按钮权限控制 : ps:定义一个方法 ,checkPermission (str) str 是按钮的权限标识 , ...

  5. Linux中ln 链接命令的用法

    ln的语法 Usage: ln [OPTION]... [-T] TARGET LINK_NAME (1st form) or: ln [OPTION]... TARGET (2nd form) or ...

  6. 洛谷P1381单词背诵

    单词背诵 题目描述 灵梦有 \(n\) 个单词想要背,但她想通过一篇文章中的一段来记住这些单词. 文章由 \(m\) 个单词构成,她想在文章中找出连续的一段,其中包含最多的她想要背的单词(重复的只算一 ...

  7. KubeSphere 迈向新的里程碑 —— 10000 颗星星!

    喜大普奔,开源项目 KubeSphere 于近期在 "云原生分布式操作系统" 的征程中迈入新的里程碑 -- GitHub Star 数量突破 10,000! 真心感谢每一位贡献者. ...

  8. Uniswap V2 核心 合约代码

    Uniswap V2 核心 UniswapV2Factory UniswapV2Pair UniswapV2ERC20 IUniswapV2Router02 1. UniswapV2Factory 合 ...

  9. 模拟器运行环境及Lua代码——使用遗传进化算法(neat算法)玩超级玛丽游戏

    SuperMario_GeneticEvolution_Neat 项目介绍: 模拟器运行环境及Lua代码--使用遗传进化算法(neat算法)玩超级玛丽游戏 代码地址: https://openi.pc ...

  10. 基于CTFshow的文件上传二次渲染绕过与CTF实战

    1. 二次渲染简介 二次渲染指的是上传的文件(如图片),为了显示的更加规范(尺寸.像素),网站会对文件进行二次处理,经过解码或转换可能导致其中的恶意代码失效.例如,后门程序在图像渲染过程中可能被清除或 ...