Lottie--前端动画效果--UI输出json格式--lottie动画在JavaScript中使用

这篇具有很好参考价值的文章主要介绍了Lottie--前端动画效果--UI输出json格式--lottie动画在JavaScript中使用。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

Lottie一个适用于Web、Android、iOS、React Native和Window的移动库,它可以使用Bodymovin解析以json格式导出的Adobe After Effects动画,并再移动设备上进行本地渲染。

1.需要引入JavaScript文件,我使用的是cdn中的链接。这里直接上链接,按需取用。点这里
2.json格式的文件

我不是UI啊,我也不知道怎么做出来的,我只知道使用AE做的动画再通过bodymovin导出的。到我手里就是两个文件:一个.html文件和一个.json文件。

html后缀的文件可以直接使用,但是对于项目来说会存在冗余,所以我是用的json后缀文件。

3.引入json文件

在HTML里引入json文件我是这样做的:
1.需要给json文件声明变量接收
拿到的json文件:{" ":" "," ":" "}
处理后json文件:var one={" ":" "," ":" "}
(文件太长了,复制过来占地方,就这样看吧,也不影响[狗头])

备注:这里直接修改json文件会使文件出现小红叉,虽然不影响静态页面的显示,但为了更专业,这里可以把文件修改为js文件。
方法:将json文件修改为js文件,处理文件部分改为:window.one={" ":" "," ":" "},正常引入js文件即可,除了文件格式不一样,其他都是一样的,不需要做修改。

2.在文件中使用<script></script>标签引入js文件或者json文件

4.使用lottie

接下来就是本篇文的主角–lottie

<body>
	<div id="lottie"></div>
	
	<!--引入lottie的js文件地址-->
	<script type="text/javascript" src="https://cdnjs.cloudflare.com/ajax/libs/bodymovin/5.9.1/lottie.min.js"></script>
	<!--引入的js格式文件-->
	<script type="text/javascript" src="js/json/animation.js"></script>
	<script type="text/javascript">
		//使用lottie
		const anim = lottie.loadAnimation({
			container: document.getElementById('lottie'),
			renderer: 'svg',//渲染方式:svg:支持交互、不会失帧;canvas、html:支持3D,支持交互
			loop: false,//循环播放:默认为true
			autoplay: false,//自动播放:默认为true
			//assetsPath:'images/',//图片文件夹的路径(这里可以设置图片地址,如果设置了最终是在这个路径下找图片)
			animationData: one //变量名(还记得上面声明变量接收的json文件或者js文件吧,跟那个接收的名字要一样)
		})

		//然后就是把这段代码放在你想要运行的时候,比如想要在加载之后就执行,那就放在以下代码里
		window.onload=function(){anim.play()}
	</script>
</body>
5.常用方法

anim.play():播放,从当前帧开始播放
anim.stop():停止,并回到第0帧
anim.pause():暂停,并保持当前帧
anim.goToAndStop(value,isFrame):跳到某个时刻/帧并停止
anim.goToAndPaly(value,isFrame):跳到某个时刻/帧并播放

//isFrame:指明value的单位是毫秒(false 默认的)还是帧(true),可以省略。
animation.goToAndStop(30, true)     // 跳转到第30帧并停止
animation.goToAndPlay(300)          // 跳转到第300毫秒并播放

anim.playSegments(arr,forceFlag):以帧为单位,播放指定片段

//arr:可以包含两个数字或者两个数字组成的数组
//forceFlag:表示是否立即强制播放该片段
animation.playSegments([10,20], false)          // 播放完之前的片段,播放10-20帧
animation.playSegments([[0,5],[10,18]], true)   // 直接播放0-5帧和10-18帧

anim.setSpeed(speed):设置播放速度,speed为1表示正常速度
anim.setDirection(direction):设置播放方向,1表示正向播放,-1表示反向播放
anim.destroy():删除该动画,移除相应的元素标签等

6.常用事件
//监听方法 给需要的动画添加监听
//加载完动画json文件时的data_ready事件
anim.addEventListener('data_ready', () => { console.log('animation data has loaded'); })

//播放完成(循环播放下不会触发)
anim.addEventListener('complete', () => {});

//当前循环下播放(循环播放/非循环播放)结束时触发
anim.addEventListener('loopComplete', () => {});

//每进入一帧就会触发,播放时每一帧都会触发一次,stop方法也会触发
anim.addEventListener('enterFrame', () => {});

//播放指定片段时触发,playSegments、resetSegments等方法刚开始播放指定片段时会触发,如果playSegments播放多个片段,多个片段最开始都会触发
anim.addEventListener('segmentStart', () => {});

//将在动画删除时触发
anim.addEventListener('destroy', () => {});
7.部分高阶用法(来源网络)

在制作AE动画时,将图层命名为#svgId格式,前端加载该动画后,相应的图层的id会被设置为svgId,可以通过dom⽅法获取该元素并做相应的操作;

在制作AE动画时,将图层命名为.svgClass格式,前端加载该动画后,相应的图层的class会被设置为svgClass,可以通过dom⽅法获取这些元素并做相应的操作;

8.补充对json文件的解析

注:来源于网络的图片,见水印
动画总的运行时间=(结束关键帧-起始关键帧)/帧率
Lottie--前端动画效果--UI输出json格式--lottie动画在JavaScript中使用文章来源地址https://www.toymoban.com/news/detail-408498.html

到了这里,关于Lottie--前端动画效果--UI输出json格式--lottie动画在JavaScript中使用的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • Android 动画 Lottie 如何使用

    一、简介 Lottie 是Airbnb开源的一个面向 iOS、Android、React Native 的动画库,能分析 Adobe After Effects 导出的动画,并且能让原生 App 像使用静态素材一样使用这些动画,完美实现动画效果。 1.让设计师使用Adobe 的 After Effects(简称 AE)工具(美工一般都会这个)制作这个动画。 2.在AE中安

    2024年04月26日
    浏览(29)
  • Lottie动画的优劣及原理

    Lottie是目前应用十分广泛的动画框架。在周会汇报的时候,老板问能不能对Lottie进行优化,于是就有了下文对Lottie原理的研究。毕竟要进行优化,首先要深入了解原理嘛。 Lottie通过读取json文件信息实现动画效果。 json信息包括json整体结构、图片资源、图层信息等,这些属性

    2024年02月05日
    浏览(27)
  • Android Lottie加载gson文件动画

    一:Lottie的使用 在你工程的build.gradle文件里添加如下配置 二:布局文件直接引入LottieAnimationView 例如:文件放置目录 如此,动画就能跑起来了: 1.lottie_fileName:在app/src/main/assets目录下的动画json文件名。 2.lottie_loop:动画是否循环播放,默认不循环播放。 3.lottie_autoPlay:动画

    2024年02月11日
    浏览(34)
  • android studio启动页面动画Lottie

    1.在build.gradle(app)中加入依赖 implementation\\\'com.airbnb.android:lottie:3.7.0\\\'  2.在Java包下新建活动  3.在res下创建raw包  

    2023年04月08日
    浏览(33)
  • vue3+vite中使用Lottie动画

    Lottie通过读取json文件信息实现动画效果   官方文档 Lottie官网 lottie库有众多动画 选择下载Lottie JSON到项目中 安装Lottie包 pnpm add lottie-web 模板创建  引入lottie-web以及动画json文件 import lottie from \\\'lottie-web\\\'; import transformJson from \\\"@/assets/json/playLottie.json\\\" js   动画生成!!! 

    2024年02月07日
    浏览(25)
  • 微信小程序使用lottie动图插件

    1、通过npm安装Lottie库 npm install --save lottie-miniprogram 2、npm 构建 1)npm init 2)微信开发者工具中 点击  工具一构建npm 3、js文件里引用 4、wxml文件使用canvas 5、js方法调用      注:json路径为小程序合法域名下服务器上的文件,可将文件夹整体扔到服务器上 6、效果展示

    2024年02月04日
    浏览(29)
  • Python(21)json.dumps()使用indent参数 格式化输出json数据格式

    json.dumps() 方法 将一个Python数据结构转换为JSON字符串 输出为 这样的格式一般都不优美,当数据很多的时候,看得就不是很直观方便。 可以使用 indent=4 参数来对json进行数据格式化输出,会根据数据格式缩进显示,读起来更加清晰 用法如下 输出为 json.dumps()方法,参数解释

    2024年02月08日
    浏览(32)
  • Python 中的 JSON 模块详解及 JSON 数组的输出格式示例

    正文: 在 Python 中,JSON(JavaScript Object Notation)是一种常用的数据交换格式。Python 提供了一个内置模块 json 来处理 JSON 数据。本文将详细介绍 Python 中的 json 模块,包括 JSON 对象的序列化和反序列化,以及如何处理 JSON 数组。 1. 导入 json 模块 在使用 json 模块之前,我们需要

    2024年02月07日
    浏览(34)
  • 前端开发攻略---Vue通过自定义指令实现元素平滑上升的动画效果(可以自定义动画时间、动画效果、动画速度等等)。

    这个指令不是原生自带的,需要手动去书写,但是这辈子只需要编写这一次就好了,后边可以反复利用。 IntersectionObserver 是一个用于监测元素是否进入或离开视口(viewport)的 API。它可以帮助你在页面滚动时或者元素位置改变时进行回调操作,这样你就可以根据元素是否可见

    2024年04月11日
    浏览(38)
  • 这里推荐几个前端动画效果网站

    1. AnimistaAnimista 是一个 CSS 动画/转场库和在线工具。它有许多现成的 CSS 动画片段可以直接使用,也可以在线定制动画。 网站地址:Animista - On-Demand CSS Animations Library   2. Animate.cssAnimate.css 是一个免费的 CSS 动画库,里面有 Attention Seekers 、 Bouncing Entrances 、 Fading Entrances、Rotating En

    2024年02月13日
    浏览(30)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包