動畫庫 Lottie的基本使用

版本是 3.2.2砚哆。
GitHub:https://github.com/airbnb/lottie-android
官方文檔:http://airbnb.io/lottie/

配置

  1. 在 app/build.gradle 中添加如下:(版本號以官網(wǎng)最新版為準(zhǔn))
implementation 'com.airbnb.android:lottie:3.2.2'

使用

  1. 在 main/assets下添加動畫資源躁锁,data.json.

    image
  2. 在布局文件中添加 LottieAnimationView 控件

<com.airbnb.lottie.LottieAnimationView
        android:id="@+id/animation_view"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        app:lottie_fileName="data.json"
        app:lottie_loop="true"
        app:lottie_autoPlay="true"/>

  1. 效果圖

    image

動畫資源

如果你因為各種原因战转,沒有辦法專門由一個設(shè)計師來為你的 App 定制動畫效果以躯,你也可以嘗試找找線上公開的一些 Lottie 的動畫效果忧设,這里推薦使用 LottieFiles 這個網(wǎng)站。
LottieFiles: https://www.lottiefiles.com/

進階

  1. 本地 json 動畫使用膀懈。
        mLottieAnimationView= (LottieAnimationView) findViewById(R.id.animation_view); //實例化
        //設(shè)置是否循環(huán)播放:true為循環(huán).false為播放一次
        mLottieAnimationView.loop(true);
//        //暫停
//        mLottieAnimationView.pauseAnimation();
//        //開始播放
//        mLottieAnimationView.playAnimation();
        mLottieAnimationView.addAnimatorListener(new Animator.AnimatorListener() {
            @Override
            public void onAnimationStart(Animator animation) {
                //動畫開始監(jiān)聽
            }

            @Override
            public void onAnimationEnd(Animator animation) {
                //動畫結(jié)束
            }

            @Override
            public void onAnimationCancel(Animator animation) {
                //動畫取消
            }

            @Override
            public void onAnimationRepeat(Animator animation) {
                //動畫重復(fù)
            }
        });

  1. 網(wǎng)絡(luò) json 動畫使用谨垃。
    private RelativeLayout mLayout;
    private LottieAnimationView mLottieAnimationView;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_network);
        mLayout = (RelativeLayout) findViewById(R.id.layout_content);
        initView();

    }

    private void initView() {
        mLottieAnimationView = new LottieAnimationView(NetworkActivity.this);
        String response = "你從網(wǎng)絡(luò)獲取的json";
        try {
            JSONObject jsonObject = new JSONObject(response);
            LottieComposition.Factory.fromJson(getResources(), jsonObject, new OnCompositionLoadedListener() {
                @Override
                public void onCompositionLoaded(LottieComposition lottieComposition) {
                    setComposition(lottieComposition);
                }
            });

        } catch (JSONException e) {
            e.printStackTrace();
        }
        mLayout.addView(mLottieAnimationView);
    }

    private void setComposition(LottieComposition lottieComposition) {
        mLottieAnimationView.setProgress(0);
        mLottieAnimationView.loop(true);
        mLottieAnimationView.setComposition(lottieComposition);
        mLottieAnimationView.playAnimation();
    }

工具

集成流程
UI 使用 AE → 安裝 bodymovin 插件 → 將 AE 中的動畫工程文件通過 bodymovin 轉(zhuǎn)換為 .json 文件→ 發(fā)給開發(fā)-開發(fā)集成Lottie框架-直接在項目中使用
是不是很簡潔狐血,這樣我們壓根就不需要一幀一幀的png或者.gif文件了易核,不僅讓gif的加載速度變快而且節(jié)約了我們app的內(nèi)部空間。

AE安裝插件教程(這里的安裝教程讓UI去看就好)
MAC
windows
懶得寫了 介紹兩個別人的文章 :
文章2
文章3

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市碰逸,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌满钟,老刑警劉巖,帶你破解...
    沈念sama閱讀 217,185評論 6 503
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件夭织,死亡現(xiàn)場離奇詭異吠撮,居然都是意外死亡泥兰,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,652評論 3 393
  • 文/潘曉璐 我一進店門膀捷,熙熙樓的掌柜王于貴愁眉苦臉地迎上來削彬,“玉大人,你說我怎么就攤上這事糕篇∽眯模” “怎么了?”我有些...
    開封第一講書人閱讀 163,524評論 0 353
  • 文/不壞的土叔 我叫張陵墩崩,是天一觀的道長侯勉。 經(jīng)常有香客問我址貌,道長,這世上最難降的妖魔是什么练对? 我笑而不...
    開封第一講書人閱讀 58,339評論 1 293
  • 正文 為了忘掉前任螟凭,我火速辦了婚禮,結(jié)果婚禮上棒厘,老公的妹妹穿的比我還像新娘。我一直安慰自己谓媒,他們只是感情好达传,可當(dāng)我...
    茶點故事閱讀 67,387評論 6 391
  • 文/花漫 我一把揭開白布迫筑。 她就那樣靜靜地躺著脯燃,像睡著了一般。 火紅的嫁衣襯著肌膚如雪辕棚。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,287評論 1 301
  • 那天,我揣著相機與錄音补君,去河邊找鬼。 笑死伟桅,一個胖子當(dāng)著我的面吹牛叽掘,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播盖腕,決...
    沈念sama閱讀 40,130評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼浓镜,長吁一口氣:“原來是場噩夢啊……” “哼竖哩!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起相叁,我...
    開封第一講書人閱讀 38,985評論 0 275
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎乌企,沒想到半個月后成玫,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,420評論 1 313
  • 正文 獨居荒郊野嶺守林人離奇死亡猪腕,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,617評論 3 334
  • 正文 我和宋清朗相戀三年陋葡,在試婚紗的時候發(fā)現(xiàn)自己被綠了彻采。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 39,779評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡岭粤,死狀恐怖特笋,靈堂內(nèi)的尸體忽然破棺而出雹有,到底是詐尸還是另有隱情,我是刑警寧澤霸奕,帶...
    沈念sama閱讀 35,477評論 5 345
  • 正文 年R本政府宣布质帅,位于F島的核電站,受9級特大地震影響嫉嘀,放射性物質(zhì)發(fā)生泄漏魄揉。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,088評論 3 328
  • 文/蒙蒙 一瓣俯、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧腔剂,春花似錦驼仪、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,716評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽粘优。三九已至,卻和暖如春雹顺,著一層夾襖步出監(jiān)牢的瞬間嬉愧,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,857評論 1 269
  • 我被黑心中介騙來泰國打工王财, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留裕便,地道東北人。 一個月前我還...
    沈念sama閱讀 47,876評論 2 370
  • 正文 我出身青樓挂疆,卻偏偏與公主長得像下翎,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子胆萧,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 44,700評論 2 354

推薦閱讀更多精彩內(nèi)容