• Android Lottie动画


    1.Lottie动画

    Lottie是Airbnb开源的动画框架,是基于CALayer的动画,所有的路径预先在AE中计算好,转换为Json文件, 然后自动转换为Layer的动画。

    Lottie有各种不同的版本, 安卓、iOS、前端都可以使用, 理论上动画做一套就可以共用, 大大的减少了工作量。如果实现复杂的动画,可以直接让设计出相关的动画json文件,大大减轻了代码的工作量。现在有了 Lottie,只需要简单的代码就可以实现复杂动画效果的库。很好的解决了动态改变动画的能力,只需要动态加载相应的json文件就能实现动画的改变。

     

    2.Lottie动画的用法

    ①添加依赖

    dependencies {

      implementation 'com.airbnb.android:lottie:4.2.2'

    }

    ②在XML中使用LottieAnimationView控件

        android:id="@+id/lt_gift"

        android:layout_width="200dp"

        android:layout_height="200dp"

        app:lottie_autoPlay="false"

        app:lottie_fileName="lottie/gift.json"

        app:lottie_loop="true"

        app:lottie_repeatMode="restart"/>

    属性说明:

    lottie_autoPlay:自动播放动画(默认false)

    lottie_fileName:app/src/main/assets目录下的json文件名(json文件可以直接放到assets目录下,比如“gift.json”,也可新建子目录,比如"lottie/gift.json")

    lottie_loop:循环播放(默认false)

    lottie_repeatMode:循环模式(默认restart)

    ③使用java代码调用playAnimation播放动画

    LottieAnimationView ltGift = findViewById(R.id.lt_gift);

    ltGift.setAnimation("lottie/gift.json");// 代码设置动画文件

    ltGift.playAnimation(); // 开始播放动画,首次播放会有短暂延迟,因为加载动画文件需要时间

    ④监听动画播放进度addAnimatorUpdateListener

    ltGift.addAnimatorUpdateListener(new ValueAnimator.AnimatorUpdateListener() {

        @Override

        public void onAnimationUpdate(ValueAnimator animation) {

            float progress = animation.getAnimatedFraction();//播放进度

            // TODO:

        }

    });

    addAnimatorListener可以监听动画开始、结束、取消、重复等事件。

    ⑤设置动画进度setProgress

    LottieAnimationView ltGift = findViewById(R.id.lt_gift);

    ltGift.setAnimation("lottie/gift.json");

    ltGift.setProgress(0.5f); //不需要调用playAnimation,可直接展示该进度的动画效果

    ⑥监听json文件加载完成addLottieOnCompositionLoadedListener

    ltGift.addLottieOnCompositionLoadedListener(new LottieOnCompositionLoadedListener() {

        @Override

        public void onCompositionLoaded( LottieComposition composition) {

            //此时渲染了动画第一帧

        }

    });

    所有lottie动画最终都会生成一个LottieComposition对象,该对象包含了动画的所有信息,包括动画时长、宽高、起始帧、图层列表等。

    ⑦缓存机制LottieCompositionCache

    运行时缓存,内部使用LruCache实现,缓存大小为10MB。

    自测200KB以内的动画文件,首次加载需要600ms左右,缓存加载只需要100ms。

    自动缓存,不需要手动控制。

  • 相关阅读:
    基于SSM的校园快递一站式服务系统设计与实现
    将excel表中的英文自动翻译成中文
    opencv-python图像处理:Canny边缘检测算法,模板匹配,直方图均衡化,傅里叶变换
    人类与机器:如何让身体与植入物长期共存?少突胶质细胞也许是答案
    一次违法网站的渗透经历
    【鸟哥杂谈】十分钟搭建自己的本地 Node-Red可拖拽图形化物联网
    18. 机器学习——集成学习
    关于MYSQL增量备份介绍
    1.思科模拟器下载教程(Packet Tracer 8.2.2)
    HTML静态网页成品作业(HTML+CSS)——VIVO介绍网页(1个页面)
  • 原文地址:https://blog.csdn.net/zenmela2011/article/details/127640539