群友:这个你能写出来不

简介: Lottie 是 Airbnb 开发的一款能够为几乎所有的客户端添加动画效果的开源工具,目前我已经在 iOS、Android、RN、小程序、web 上都使用过 Lottie 来添加我的动画。只需要花两分钟时间,我们就可以知道如何实现这种比较炫酷的动画效果。

昨天在群里闲聊的时候,有个朋友突然录了这样一个视频,然后问了一句:


微信图片_20220511144135.png


当然可以,有一种高逼格的解决方案不用我们前端写多少代码就能快速实现。

他就是大名鼎鼎的 Lottie。俗称「老铁」


五分钟后,我就给这位同学写了一个 动画 demo。


微信图片_20220511144104.gif


Lottie 是 Airbnb 开发的一款能够为几乎所有的客户端添加动画效果的开源工具,目前我已经在 iOS、Android、RN、小程序、web 上都使用过 Lottie 来添加我的动画。


只需要花两分钟时间,我们就可以知道如何实现这种比较炫酷的动画效果。


第一步,获取动画源文件


Lottie 原理是播放一个动画文件,我们可以通过该动画内容支持的开始、结束、暂停、是否循环等方式来选择合适的操作方式。因此,动画源文件的来源就变得非常重要。


最理想的方式是选择一个适合你当前项目的 UI 风格,因此设计该动画的职责就需要你们项目团队的 UI 设计师来完成。UI 设计师可以通过 Adobe After Effects 来设计充满想象力的动画效果,然后使用 Lottie 提供的 Bodymovin 插件将设计好的动画导出为一个 JSON 文件。


拿到这个 JSON 文件之后,就开始在页面上开始快速实现该动画了。


如果你们团队没有厉害的 UI 设计师,需要我们前端自己去寻找风格相近的动画,我们也可以在下面这个网站上去寻找,这里有大量的已经做好的 Lottie 动画。


微信图片_20220511144107.png

微信图片_20220511144111.png



该网站提供了部分免费的 Lottie 动画,还有许多你满意的动画源文件是收费的,我们可以通过开发者工具,找到对应动画的DOM节点,直接获取 JSON 内容。



微信图片_20220511144114.png


除此之外,蚂蚁设计团队还给我们提供了一个 Lottie 动画在线设计工具:犸良动画平台


微信图片_20220511144117.png

微信图片_20220511144121.png


这里提供了大量的插图、金币红包、人物、按钮、氛围、图标等动画效果,我们可以自由组合设计,最后导出生成我们需要的 JSON 文件。


微信图片_20220511144124.png

第二步:找到对应的 npm 包


此处以 React 为例,我们在 npm 上找到一个名为 react-lottie 的包,引入到你的项目中,结合刚才得到的 JSON 动画源文件,就可以快速实现了。


demo 代码如下:


import React, { useState } from 'react';
import Lottie from 'react-lottie'
import * as animateData from './01.json'
import * as data2 from './02.json'
export default function LittieDemo() {
  const [play, setPlay] = useState(false)
  const [paused, setPaused] = useState(false)
  const option = {
    loop: true,
    autoplay: true,
    animationData: animateData,
    renderSettings: {
      preserveAspectRatio: 'xxx'
    }
  }
  const option2 = {
    loop: true,
    autoplay: true,
    animationData: data2,
    renderSettings: {
      preserveAspectRatio: 'xxx'
    }
  }
  return (
    <div>
      <Lottie options={option} height={200} width={200} isPaused={paused} />
      <Lottie options={option2} height={200} width={200} isPaused={paused} />
    </div>
  )
}


OK,我好了。

相关文章
|
消息中间件 Kubernetes NoSQL
Debian11系统boost库安装
Debian11系统boost库安装
|
小程序 JavaScript
【微信小程序】之轮播图、swiper、swiper-item、banner组件使用
【微信小程序】之轮播图、swiper、swiper-item、banner组件使用
【微信小程序】之轮播图、swiper、swiper-item、banner组件使用
|
JavaScript 算法 编译器
Vue3的新特性
Vue3的新特性
404 0
|
JavaScript
Rspack 创建 vue2/3 项目接入 antdv(rspack.config.js 配置 less 主题)
Rspack 创建 vue2/3 项目接入 antdv(rspack.config.js 配置 less 主题)
613 0
|
安全 调度 C++
C++ std::chrono库使用指南 (实现C++ 获取日期,时间戳,计时等功能)(二)
C++ std::chrono库使用指南 (实现C++ 获取日期,时间戳,计时等功能)
1489 0
|
11月前
|
监控 安全 网络协议
Hyper V上网实战:多虚拟机网络环境配置
在Hyper-V环境中配置多虚拟机网络以实现上网功能,需完成以下步骤:1. 确认Hyper-V安装与物理网络连接正常;2. 配置虚拟交换机(外部、内部或专用)以支持不同网络需求;3. 设置虚拟机网络适配器并关联对应虚拟交换机;4. 验证虚拟机网络连接状态;5. 根据场景需求优化多虚拟机网络环境。此外,还需注意网络隔离、性能监控及数据备份等事项,确保网络安全稳定运行。
|
机器学习/深度学习 资源调度 自然语言处理
长短时记忆网络(LSTM)完整实战:从理论到PyTorch实战演示
长短时记忆网络(LSTM)完整实战:从理论到PyTorch实战演示
19324 0
|
小程序
Galacean Effects 2.0 带来了哪些新功能?
各位特效魔法师、创意小能手们,我们近期解锁了一系列超能力,或许会让你的创作如虎添翼,酷炫到飞起!✨🎉🎉
1408 1
|
缓存 前端开发 应用服务中间件
看看高手是怎么部署前端代码的
【8月更文挑战第8天】从简单的前端项目部署开始,构建dist文件夹并通过Nginx代理接口请求,以解决跨域问题。为进一步优化大型系统的性能及稳定性,需采用高级部署策略。例如,利用CDN分发静态资源并采用缓存控制减少带宽消耗,通过文件哈希值更新URL确保资源按需刷新。面对大规模部署挑战,采用非覆盖式发布方法避免样式错乱风险,并通过灰度部署逐步验证新版功能,确保服务平稳过渡。借助Nginx实现流量切分,可灵活调整新旧版本流量比例,有效降低上线风险。
359 3

热门文章

最新文章