Lottie - Lottie 中渐变填充的实现研究

本文详细介绍如何通过修改源码使Lottie动画支持渐变效果,包括使用Bodymovin插件生成JSON文件,并在VSCode中调整渐变位置及RGB百分比,实现复杂渐变填充。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Lottie动画以制作简单,对接方便被越来越多的开发团队所接受并使用。但json文件格式也有自身的一些问题,其中比较严重的是不支持渐变效果。以下文字将为您详细说明,如何通过简单源码的修改,让你的Lottie动画支持渐变。

Lottie官网介绍

关于Lottie基础,这里不详细赘述了,请大家自行查阅。

准备工具

必备的AE和Bodymovin插件,编码器推荐VS Code(因为逻辑层级有颜色标注...),实在不行系统自带的文本编辑也可以。

在AE中制作一个渐变填充的矢量小球

为了方便讲解,这里就不加任何动效了。

使用Bodymovin生成Json文件

将.json文件拖到 Preview & Test Lottie Animations on Web, iOS and Android 官网预览效果,你会得到以下的样式。

Bodymovin默认生成的json文件会将所有渐变的填充,编成黑白渐变。

重点从这里开始

使用VS Code(Sublime或者文本编辑也可以)打开刚刚生成的Data.json文件。

见到代码不要慌我们慢慢来。

你将见到这样的界面。其实,Bodymovin插件是将设计师制作好的AE动画翻译成程序可以直接读取的语言(其实本质上所有的图形工具都是这样工作的),到程序那里就直接调取json再读取,由于没有产生位图所以在体积上会小很多。

查找名为“椭圆路径 1”的字段(这里可通过更改AE中路径命名作为标记,来快速找到想要修改的路径)

到这里,其他的我们都不管,直接看“椭圆路径 1”后面的出现的 [0,1,1,1,1,0,0,0] 数组。这就是我们的渐变为啥变成黑白的原因了。经过我的假设和尝试,证明了这八位数是渐变的位置+RGB的百分数(这太为难人了,居然是百分数而不用整数表示)。

修改好了,保存一下。将.json文件拖到 Preview & Test Lottie Animations on Web, iOS and Android 官网预览效果。

您还可以试试通过修改"p"值,多加几组渐变来增强记忆。

做了两个稍微复杂一点的渐变,证明AE上的参数全可控。感兴趣的可以自己研究一下。

https://lottiefiles.com/4574-gradient

https://lottiefiles.com/4579-gradual

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

陆克和他的代码

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值