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

作者:阿策小和尚 时间:2023-06-19 12:41:17 

目录
  • 前言

  • Lottie

    • 案例尝试

      • 1. 集成依赖

      • 2. 添加 LottieAnimationView 加载网络资源

      • 3. 加载本地资源

      • 4. 循环播放 & 动画监听

      • 5. 暂停 & 继续 & 取消

    • 小扩展

      • 1. 硬件加速器

      • 2. json 文件解析

  • 总结

    前言

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

    Lottie

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

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

    案例尝试

    1. 集成依赖

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


    api 'com.airbnb.android:lottie:4.1.0'

    2. 添加 LottieAnimationView 加载网络资源

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


    <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();

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

    3. 加载本地资源

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


    mView2 = (LottieAnimationView) this.findViewById(R.id.lottie_view2);
    mView2.setAnimation("mooncake.json");
    mView2.playAnimation();

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

    4. 循环播放 & 动画监听

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


    mView2.loop(true);

    mView1.setRepeatCount(5);

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


    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()");
       }
    });

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

    5. 暂停 & 继续 & 取消

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

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


    @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;
       }
    }

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

    小扩展

    1. 硬件加速器

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


    android:hardwareAccelerated="true"

    2. json 文件解析

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

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

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

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

    asstes 中 w / h 为资源宽高;u / p 非别对应资源露肩和名称;其中的 layers 也为图层信息;layers 中的 ks 为动画的主要信息;

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

    来源:https://juejin.cn/post/7005369808204070926

    标签:android,lottie,动画
    0
    投稿

    猜你喜欢

  • java实现滑动验证解锁

    2023-06-02 12:16:36
  • Android底部菜单简单应用

    2022-03-25 18:09:58
  • C#实体类转换的两种方式小结

    2023-08-01 21:06:45
  • JavaCV实现读取视频信息及自动截取封面图详解

    2022-05-20 14:43:05
  • Android studio实现简单的计算器

    2022-09-07 23:23:28
  • c# 如何实现不同进程之间的通信

    2022-08-26 10:25:06
  • 浅谈React Native打包apk的坑

    2022-07-26 05:44:28
  • Android三种GSM手机定位技术分析

    2023-04-10 10:09:22
  • Android实现网易新闻客户端侧滑菜单(1)

    2023-09-12 00:54:05
  • Mybatis使用@Select注解sql中使用in问题

    2023-01-06 20:52:48
  • C#实现顺序表(线性表)完整实例

    2022-06-04 15:42:31
  • Android 开发随手笔记之使用摄像头拍照

    2023-01-31 05:17:22
  • Spring Boot项目如何同时支持HTTP和HTTPS协议的实现

    2023-11-19 19:57:05
  • intellij idea使用git stash暂存一次提交的操作

    2023-03-08 08:30:11
  • Java中实现多线程关键词整理(总结)

    2023-09-08 16:08:49
  • RestTemplate使用不当引发的问题及解决

    2023-01-21 11:27:19
  • Android Studio 3.x版本 的输入法遇到的坑及解决方案

    2023-03-19 03:13:40
  • Android基于HttpUrlConnection类的文件下载实例代码

    2022-08-28 02:18:49
  • Mybatis联合查询的实现方法

    2021-11-27 23:26:44
  • Spring Data JPA调用存储过程实例代码

    2023-11-25 00:13:15
  • asp之家 软件编程 m.aspxhome.com