本篇介绍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. form data 与request payload的区别以及php接收这些数据的方法

    form data 与request payload的区别以及php接收这些数据的方法 以前与前端交互一直都是POST.GET的,PHP端就直接$_POST,$_GET来接收,从来没有出现过以外. 最 ...

  2. 【Simpleperf】Android的CPU分析,性能优化利器

    很多时候,写代码是一件很爽的事情,但最后需要对APP进行瘦身.性能分析却是一件很棘手的事情.当需要对APP的性能进行分析时,Simpleperf是一个简单快捷的选择. 正文开始前,先奉上官方的资料: ...

  3. docker安装过程 - 下载mysql

    1. 下载必要的包 sudo yum install -y yum-utils device-mapper-persistent-data lvm2 2. 指定虚拟机去哪里安装 docker sudo ...

  4. 05 Transformer 中的前馈神经网络(FFN)的实现

    2:20:理论链接 博客配套视频链接: https://space.bilibili.com/383551518?spm_id_from=333.1007.0.0 b 站直接看 配套 github 链 ...

  5. 一图为你揭秘云数据库GaussDB管理平台亮点

    云数据库GaussDB管理平台(TPOPS)是一款即开即用.稳定可靠.管理便捷的数据库运维管理平台.通过该平台,用户可以快速部署安装GauSSDB,实现智能化运维,大幅度提升运维和管理效率.一图带你揭 ...

  6. 在Ubuntu小设备上使用VSCode+SSH开发部署nicegui的Web应用,并设置系统开机自动启动应用

    在一些小的设备上跑Ubuntu系统,需要快速的开发和调整项目的时候,往往使用SSH进行远程的开发测试,这样可以避免传统的打包更新处理,能够快速的在实际环境上测试具体的内容.另外由于系统设备往往需要重启 ...

  7. 做PPT知识积累

    很多技术人员鄙视PPT,他们觉得做PPT的人不干具体工作,只会把别人的劳动成果用PPT的形式变成自己的成果.这种想法有些酸,根源在于没有真正理解PPT的价值.工作中PPT的作用及其重要,也可以理解为梳 ...

  8. FFmpeg 视频转 GIF

    Filtergraph 在 ffmpeg 命令中,可以使用 -filter.-vf.-af 或 -filter_complex 选项指定 filter graph Filtergraph 由 filt ...

  9. Uniswap V2 核心 合约代码

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

  10. C240817D. 模拟赛:树上dp(以i为起点)+set操作

    C240817D. 模拟赛 比较显然的树上dp, 但是维护set比较烦 考场上其实自己是定义 \(f[i]\) 是以 \(i\) 结尾, 然后这样的话单次更新根本做不到 \(O(logN)\). 反应 ...