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。

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

你可能感兴趣的:(android)