前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >专栏 >Android Lottie 中秋月饼变明月动画特效

Android Lottie 中秋月饼变明月动画特效

作者头像
阿策小和尚
发布于 2021-09-17 02:12:46
发布于 2021-09-17 02:12:46
1.2K00
代码可运行
举报
文章被收录于专栏:阿策小和尚阿策小和尚
运行总次数:0
代码可运行

和尚在 Android 端进行动画处理时主要用的是 Android 自带的三种动画形式,今天和尚简单尝试通过 Airbnb Lottie 展示一个中秋月饼变明月的小动画;

Lottie

Lottie 动画是 Airbnb 开源的一套多平台兼容的动画形式,和尚之前简单尝试过 Flutter 版本,使用非常便捷,今天和尚简单了解一下 Android 版本;

案例尝试

1. 集成依赖

build.gradle 中集成最新版本的 Lottie 依赖并同步;

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
api 'com.airbnb.android:lottie:4.1.0'
2. 添加 LottieAnimationView 加载网络资源

首先在 xml 文件中添加 LottieAnimationView,之后通过 setAnimationFromUrl() 加载网络资源;其中加载网络图片时有两个重载方法,其中 cacheKey 为缓存策略;加载完网络资源之后还需要 playAnimation( 启动动画;

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
<com.airbnb.lottie.LottieAnimationView
    android:id="@+id/lottie_view"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    />

mView = (LottieAnimationView) this.findViewById(R.id.lottie_view);
mView.setAnimationFromUrl("https://assets6.lottiefiles.com/packages/lf20_Tprkoc.json");
mView.playAnimation();
3. 加载本地资源

LottieAnimationView 加载本地资源时,需要先下载生成的 json 文件,并添加到工程中,通过 setAnimation() 引入本地资源;其中 setAnimation() 也有多个重载方法,可以灵活应用;

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
mView2 = (LottieAnimationView) this.findViewById(R.id.lottie_view2);
mView2.setAnimation("mooncake.json");
mView2.playAnimation();
4. 循环播放 & 动画监听

前两步设置完 setAnimation() 之后,播放完成就停止动画,若需要重复播放,可以通过 loop(true) 方式进行循环播放,但该方法在新的 API 中不建议使用,可以通过 setRepeatCount() 设置播放次数,或通过动画监听在动画结束时再次播放等;

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
mView2.loop(true);

mView1.setRepeatCount(5);

可以通过 addAnimatorListener() 进行动画监听;其中当设置 **** 播放次数后,每次播放均会调用 *onAnimationRepeat()* 回调,播放结束之后才会调用 onAnimationEnd();而如果不设置播放次数时,不会进入 onAnimationRepeat() 回调;

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
mView2.addAnimatorListener(new Animator.AnimatorListener() {
    @Override
    public void onAnimationStart(Animator animator) {
        Log.e(TAG, "-> onAnimationStart()");
    }

    @Override
    public void onAnimationEnd(Animator animator) {
        Log.e(TAG, "-> onAnimationEnd()");
    }

    @Override
    public void onAnimationCancel(Animator animator) {
        Log.e(TAG, "-> onAnimationCancel()");
    }

    @Override
    public void onAnimationRepeat(Animator animator) {
        Log.e(TAG, "-> onAnimationRepeat()");
    }
});
5. 暂停 & 继续 & 取消

和尚通过 playAnimation() 使动画进行播放;而 Lottie 也提供了 pauseAnimation() 暂停动画;resumeAnimation() 暂停后继续播放以及 cancelAnimation() 取消动画等方法;

其中调用 playAnimation() 时会从动画起始位置播放,而 resumeAnimation() 会从暂停或取消动画停止位置播放;pauseAnimation()cancelAnimation() 均会停止动画,但 cancelAnimation() 停止后会 lottieDrawable.cancelAnimation() 清空动画 Drawable,且会在 onAnimationCancel() 监听中进行回调;

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
@Override
public void onClick(View view) {
    switch (view.getId()){
        case R.id.main_btn1:
            mView2.playAnimation();
            break;
        case R.id.main_btn2:
            mView2.pauseAnimation();
            break;
        case R.id.main_btn3:
            mView2.resumeAnimation();
            break;
        case R.id.main_btn4:
            mView2.cancelAnimation();
            break;
    }
}

小扩展

1. 硬件加速器

和尚在使用 Lottie 时建议开启硬件加速器,降低动画帧率,避免卡顿;

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
android:hardwareAccelerated="true"
2. json 文件解析

和尚之前觉得 Lottiejson 文件是一个很神奇很复杂的天书,今天和尚简单介绍一下其中属性对应关系;

整体结构包括如下几个部分:v 为对应 bodymovin 动画版本;fr 为帧率;ip / op 分别对应起始/结束关键帧;w / h 为动画宽高;assets 为资源信息,包括 Drawable 等;layers 为图层信息;

asstesw / h 为资源宽高;u / p 分别对应资源路径和名称;其中的 layers 也为图层信息;layers 中的 ks 为动画的主要信息;

和尚理解 Lottie 整体是利用属性动画控制进度,通过进度变更更改 layers 中触发 LottieAnimationView 重绘各个资源信息;


和尚的中秋月饼变明月的 Lottie 动画尝试到此为止,主要是熟悉了一下 Android Lottie 的应用;如有错误,请多多指导!

来源:阿策小和尚

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2021-09-12,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 阿策小和尚 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
Lottie 超酷炫动画效果,了解下?
说到动画效果,一般都会感到很高端,感觉很酷炫;而和尚技术有限,稍复杂的动画效果也需要很多时间处理,但是遇到时间紧任务重的情况该怎么办呢?那就尝试一下 Lottie 吧,酷炫的动画集成却相当简单,还支持跨平台。
阿策小和尚
2019/08/12
1.8K0
Lottie 超酷炫动画效果,了解下?
【源码分析】Lottie 实现炫酷动画背后的原理
自我在内网发布了一篇关于 Lottie 的重点原理分析的文章之后,就不断有同事来找我询问关于 Lottie 的各种东西,最近又有同事来问,就想着可能对大家也会有所帮助,就稍作处理后分享出来。
程序亦非猿
2019/08/16
2K0
【源码分析】Lottie 实现炫酷动画背后的原理
UWP 创建动画的极简方式 — LottieUWP
提到 UWP 中创建动画,第一个想到的大多都是 StoryBoard。因为 UWP 和 WPF 的界面都是基于 XAML 语言的,所以实现 StoryBoard 会非常方便。 来看一个简单的 StoryBoard 例子: <Page...> <Grid x:Name="grid"> <Grid.Resources> <Storyboard x:Key="demoStoryBoard" AutoReverse="True" RepeatBehavior="For
Shao Meng
2018/04/28
1.6K0
UWP 创建动画的极简方式 — LottieUWP
D10-Android自定义控件之动画篇2-动画监听
本篇接上一篇: AnimatorSet的使用,将多个Animator组合进行动画 动画的监听 ---- 一、AnimatorSet的使用 在此之前先看一下AnimatorSet、Animat
张风捷特烈
2018/09/29
4850
D10-Android自定义控件之动画篇2-动画监听
Android优化之Hardware Layer
项目中越来越多的动画,越来越多的效果导致了应用性能越来越低。该如何提升。 ###简介 在View播放动画的过程中每一帧都需要被重绘。如果使用view layers,就不用每帧都去重绘,因为View渲染一旦离开屏幕缓冲区就可以被重用。 而且,hardware layers会在GPU上缓存,这样就会让一些动画过程中的操作变得更快。通过hardware layers可以快速的渲染一些简单的转变(位移、选中、缩放、颜色渐变)。由于很多动画都是这些动作的结合,所以hardware layers可以显著的提高动
xiangzhihong
2018/01/26
7270
Android开发笔记(九十六)集合动画与属性动画
补间动画有四大类:透明度动画AlphaAnimation、旋转动画RotateAnimation、缩放动画ScaleAnimation、平移动画TranslateAnimation,而集合动画AnimationSet便是用来将几个补间动画组装起来。即在同一时刻,让某视图呈现出多种动画效果,如一边缩放一边旋转。 下面是AnimationSet的常用方法: addAnimation : 添加动画。 setFillAfter : 设置是否维持结束画面。true表示动画结束后停留在结束画面,false表示动画结束后恢复到开始画面。 setRepeatMode : 设置重播模式。RESTART表示从头开始,REVERSE表示倒过来开始。 setDuration : 设置动画的持续时间。 setStartTime : 设置动画的开始时间。Animation.START_ON_FIRST_FRAME表示当前时间,其他值表示转换为整型数的时间。一般无需调用该方法,默认就是立即开始播放。 setInterpolator : 设置动画的插值器。
aqi00
2019/01/18
9730
Android十八章:属性动画Android属性动画(第一话)
Android动画能给界面带来很炫的效果,如果我们要实现这些效果,在android3.0版本前实现动画主要有2种方式,帧动画和补间动画。
ppjun
2018/09/05
1.1K0
android代码实现ScaleAnimation[通俗易懂]
import android.app.Activity; import android.os.Bundle; import android.view.View; import android.view.View.OnClickListener; import android.view.animation.Animation; import android.view.animation.Animation.AnimationListener; import android.view.animation.ScaleAnimation; import android.widget.ImageView;
全栈程序员站长
2022/11/03
4770
Lottie : 让动画如此简单
本文介绍了在Android开发中,使用Lottie动画库实现更高效、更简洁的动画效果,同时避免了XML布局的繁琐和冗余。通过实例展示了如何在Android应用中使用Lottie动画,并总结了一些关于Lottie动画在实际应用中的使用经验和技巧。
QQ音乐技术团队
2017/09/11
29.7K4
Lottie : 让动画如此简单
从零开始学Android自定义View之动画系列——属性动画(2)
独立的动画能够实现的视觉效果毕竟是相当有限的,因此将多个动画组合到一起播放就显得尤为重要。幸运的是,Android团队在设计属性动画的时候也充分考虑到了组合动画的功能,因此提供了一套非常丰富的API来让我们将多个动画组合到一起。 实现组合动画功能主要需要借助AnimatorSet这个类,这个类提供了一个play()方法,如果我们向这个方法中传入一个Animator对象(ValueAnimator或ObjectAnimator)将会返回一个AnimatorSet.Builder的实例,AnimatorSet.Builder中包括以下四个方法:
老马的编程之旅
2022/06/22
5290
从零开始学Android自定义View之动画系列——属性动画(2)
揭露动画实现时的注意事项(附上bug-logcat)
昨天晚上开始学一下这个揭露动画,准备用在项目中做一个转场,啃完了API之后开始写个小demo,距离跑成功一步之遥的当儿,出了个bug,就怎么点击按钮都没用。
凌川江雪
2018/12/07
7140
Android动画基础详析 | 属性动画基础及ValueAnimator
在上篇博客Android动画基础详析 | 概述、逐帧动画、视图动画(附诸多实际运行效果动图)的基础上我们新建一个property包和一个PropertyActivity:
凌川江雪
2019/09/30
1.5K0
Android动画基础详析 | 属性动画基础及ValueAnimator
自定义View(三)-动画-属性动画ValueAnimator
之前我们把视图动画(也就是View动画)分析的差不多了,当然帧动画我们没有讲解,其实帧动画比较简单,就是通过顺序播放一系列的图像从而产生动画效果,可以简单理解为图片的切换。和我们小时候玩的翻书让物体动起来是一个道理。它使用起来也比较简单。所以我们就不单独拿出来讲解。到后面我们会用到时再去简单讲解。这篇我们继续来学习动画之属性动画(Property Animator)。
g小志
2018/09/11
1.4K0
自定义View(三)-动画-属性动画ValueAnimator
Lottie内存泄漏问题的定位与分析
Lottie是Airbnb开源的跨平台动画库,支持iOS、Android、React Native 和 Web 等平台。它可以解析使用 Bodymovin 导出为 json 的 Adobe After Effects 动画,允许应用程序像使用静态图像一样轻松使用动画。
用户5521279
2020/07/07
7.1K0
Lottie内存泄漏问题的定位与分析
自定义View实战--实现一个清新美观的加载按钮
当时在心里问自己能不能做,答案肯定是能做的,不过我比较懒,觉得中间那个伸缩变化要编写很多代码,所以懒得理。后来,为了不让自己那么浮躁,也为了锻炼自己的耐心程度,还是坚持实现它了。这个过程,觉得自己还是有所收获,把握了一些想当然的细节,输理了对于自定义 View 的流程。
Frank909
2019/01/14
6070
Android自定义View-SVG动画
SVG是可缩放矢量图形,全称Scalable Vector Graphics。经过数学计算利用直线和曲线绘制而成,无论怎么放大,都不会出现马赛克现象。可以使用Illustrator矢量图绘图软件来进行绘图。
音视频开发进阶
2020/08/27
2.9K0
Android自定义View-SVG动画
相关推荐
Lottie 超酷炫动画效果,了解下?
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
本文部分代码块支持一键运行,欢迎体验
本文部分代码块支持一键运行,欢迎体验