Lottie 動畫設(shè)計指南,阿里新出犸良就是Lottie

來源:
橘子
時間:
2019-07-16 13:37:19
閱讀:
13069


 

最近阿里新出的犸良在線制作動畫工具就是基于lottie制作技術(shù)原理,阿里犸良 : https://design.alipay.com/emotion

 

關(guān)于動效設(shè)計,是 UI 設(shè)計當中不可或缺的一環(huán)。大家對動效的認知也從最初認為動效只是為了美觀酷炫,到逐漸理解了動效對于提升用戶體驗和產(chǎn)品需求的重要作用。而導(dǎo)致這種認知的轉(zhuǎn)變,相當一部分原因是因為硬件性能的發(fā)展和動效輸出方式的優(yōu)化。使用原生代碼在各平臺實現(xiàn)復(fù)雜的動效是一件性價比較低的事,還要考慮到適配不同屏幕尺寸。無論對設(shè)計師還是開發(fā)人員都是比較繁瑣的。而使用了lottie之后,可以做到同一個文件能應(yīng)用到不同的平臺,還能極大地減少開發(fā)成本。

 

一、什么是lottie?

Lottie 是Airbnb開源的一個面向 iOS、Android、React Native 的動畫庫,能分析 Adobe After Effects 導(dǎo)出的動畫。不僅使用簡單,還能很好地實現(xiàn)動效設(shè)計師設(shè)計的動畫效果。而怎樣才能將設(shè)計師在AE里制作好的較為復(fù)雜的動畫轉(zhuǎn)換成lottie?這時候今天的主角Bodymovin就要出場啦~~就是這個叫Bodymovin的AE插件,是一個可以把動效設(shè)計師在AE里做好的動畫導(dǎo)出為json格式,然后以Android/iOS原生動畫的形式在移動設(shè)備上渲染播放。能幫助設(shè)計同學(xué)很容易的將AE動畫導(dǎo)出成代碼文件提供給開發(fā)同學(xué)使用。現(xiàn)在我用工作中使用到的案例給大家分享Bodymovin這個插件具體的應(yīng)用。

 

是不是聽起來很心動?其實 Lottie 已經(jīng)火了一兩年了,很多人應(yīng)該也看了一些介紹。希望工作項目中經(jīng)常涉及到動效設(shè)計,但是還在用老方法的同學(xué)??梢試L試使用 Lottie 幫助動效落地,提升團隊工作效率和個人影響力。

 

二、Lottie有什么用?

Lottie 可以應(yīng)用在 UI 設(shè)計的很多場景中。以下舉出幾個常用例子。

1. 動態(tài)啟動頁

 

2. 動態(tài)圖標/按鈕

 

3. 空頁面

 

4. 加載/下拉刷新

 

5. Banner/彈框

 

6. 表情/禮物/動態(tài)貼紙

以上僅列舉了部分常用案例,其實 Lottie 的應(yīng)用場景遠不止這些。在 APP 的多個模塊中都可以運用,那么我們要如何將 Lottie 運用在自己的工作項目中呢?那就要了解 Lottie 的原理了。

 

 

三、Lottie的工作流程

簡單講就是: 

1、使用AE  

2、使用Bodymovin 導(dǎo)出Json 數(shù)據(jù), 程序可直接使用~~ 

3、交付給開發(fā)使用 

 

Tips:在導(dǎo)出json文件時,可以點擊設(shè)置圖標,選擇其他幾種不同的方案

1、Split : 為動畫分解成多個文件

2、Glyphs: 將字體轉(zhuǎn)換成圖形形狀(建議勾選這個選項)

3、Hidden: 隱藏,檢查導(dǎo)出時需要隱藏的圖層

4、Guides: 向?qū)?,檢查導(dǎo)出時需要導(dǎo)出的向?qū)?/p>

5、Extra Comps: 額外補間,檢查表達式是否指向所有補間動畫

6、Assets: 資源,輸出項目圖片格式

 

每次導(dǎo)出時都需要進行設(shè)置。標紅區(qū)域為必選選項。字體圖形化可以將字體轉(zhuǎn)化為路徑,不勾選會因為應(yīng)用的平臺沒有相應(yīng)字體導(dǎo)致文字加載出錯;勾選演示模式后會生成 html 文件,打開該文件即可預(yù)覽動效。

當含有圖片資源時可以根據(jù)需要選擇勾選對應(yīng)的選項。

 

保存好設(shè)置后,點擊渲染即可生成動效文件給開發(fā)。當只有矢量圖層時,開發(fā)只需要使用 json 文件即可。當含有圖片文件時需要將 json 文件和圖片文件夾一并給到開發(fā)人員使用。需要注意的是不能隨意修改文件夾名稱和內(nèi)部文件名。如果需要修改圖片名稱,應(yīng)該同步修改 json 內(nèi)部代碼。相關(guān)修改方法,后續(xù)文章將會詳解。

 

 

四、Lottie可控制幀數(shù)

前面已經(jīng)提過 Lottie 是 Airbnb 開源的一個動畫渲染庫。我們可以理解為它是一個多功能的視頻播放器,開發(fā)人員需要將這個播放器部署到相應(yīng)的環(huán)境中。然后設(shè)計人員提供視頻(動效文件)給開發(fā)人員,讓開發(fā)人員按照要求播放視頻文件,即可完成動效的應(yīng)用。

Lottie 動畫的播放控制,除了常規(guī)的控制,還支持進度播放、幀播放。以一個動態(tài)按鈕的切換為例,方便大家理解。

上圖所示為一個菜單/關(guān)閉按鈕的動態(tài)切換。

假設(shè)該按鈕動效一共10幀,整個按鈕切換分為兩部分,第一部分:從菜單切換到關(guān)閉(1-10幀);第二部分:從關(guān)閉切換到菜單(10-1)。我們可以讓開發(fā)通過以下控制方式,完成我們想要的效果。

按鈕動效默認顯示第1幀(菜單狀態(tài)),點擊按鈕以后開始播放動效,動效播放到第10幀的時候停止,并停在第10幀(關(guān)閉狀態(tài))。

當按鈕為關(guān)閉狀態(tài)(第10幀)時,點擊按鈕以后動效從第10幀倒放到第1幀(關(guān)閉狀態(tài)),并停在第1幀(菜單狀態(tài))。

通過以上方式就完成了對一個動效按鈕的控制。而日常工作中我們可以靈活地運用多種控制方式。

首先動效的觸發(fā),可以是一次交互事件,比如點擊、滑動;也可以是監(jiān)聽到了廣播,比如網(wǎng)絡(luò)異常等。

而觸發(fā)以后的動效控制也多種多樣,可以從開始播放到結(jié)束,也可以進行倒放;可以循環(huán)播放某一段動效;也可以從某一幀播放到另一幀,或者某一個時間點播放到另一個時間點;更多的控制方式需要大家在工作中慢慢挖掘。

 

 

五、Lottie支持的AE屬性

Lottie雖然能夠滿足多種場景需要,但是并非支持所有的 AE 效果。設(shè)計制作時,需要考慮該效果是否支持。否則,會導(dǎo)致出錯或者所用效果無法生效。

 

上圖為 Lottie 支持的主要 AE 屬性,此處有刪減掉部分不常用的屬性。可以打開以下鏈接查看完整版http://airbnb.io/lottie/#/supported-features

需要注意的是文檔中雖然說支持漸變,但是會出錯,所以大家在使用矢量圖形時,請勿使用漸變效果。關(guān)于漸變效果的修復(fù)后續(xù)文章會提到,官網(wǎng)以后也會修復(fù)相關(guān)問題,但是沒有確切時間。

通過上圖我們可以了解到,Lottie 支持的 AE 屬性基本包含以下幾類:

1、基礎(chǔ)的形狀比如圓形、矩形、星形等,也可以支持鋼筆工具繪制的矢量形狀和從 AI 中導(dǎo)入的矢量圖形。

2、支持位移、大小縮放、透明度、旋轉(zhuǎn)、修剪路徑、蒙版、遮罩這些基礎(chǔ)動畫屬性。

3、支持圖層間建立父子級關(guān)系(只支持圖層與圖層之間建立,當圖層的屬性之間建立父子關(guān)系會失效,比如 A 圖層可以和 B 圖層建立父子關(guān)系,但是 A 圖層的位移屬性和 B 圖層的位移屬性單獨建立父子關(guān)系則不生效)。

4、支持速度貝塞爾插值,可以搭配 Flow 插件生成各種緩動效果。

5、支持導(dǎo)入圖片。

6、支持時間拉伸和時間重映射來通知時間和速度。

 

 

六、AE插件安裝與使用

前面已經(jīng)提到 Lottie 是通過 AE 插件 bodymovie 導(dǎo)出 json 文件作為動畫數(shù)據(jù)。接下來就為大家講解插件的安裝與使用方法。

 

1. 下載bodymovie插件

官方英文插件地址:https://aescripts.com/bodymovin/(文末提供中文漢化版下載地址和詳細安裝教程)

 

2. 自動安裝方法(推薦,簡單)

下載zxp格式安裝器,下載地址:https://aescripts.com/learn/zxp-installer/,安裝成功后,雙擊步驟 1 中下載的插件即可完成安裝。

 

3. 手動安裝方法

如果自動安裝失敗,可嘗試手動安裝。首先修改 ZXP 文件后綴名為 ZIP,然后解壓縮文件,得到文件夾,將文件夾復(fù)制到以下目錄。

WINDOWS:

C:\Program Files (x86)\Common Files\Adobe\CEP\extensions or

C:\AppData\Roaming\Adobe\CEP\extensions

MAC:

/Library/Application\ Support/Adobe/CEP/extensions/bodymovin

您可以打開終端并鍵入:

  • $ cp -R YOURUNZIPEDFOLDERPATH/extension /Library/Application\ Support/Adobe/CEP/extensions/bodymovin

然后鍵入:

  • $ ls /Library/Application\ Support/Adobe/CEP/extensions/bodymovin

以確保它被正確復(fù)制類型。

 

4. 安裝后

Windows:轉(zhuǎn)到編輯>首選項>常規(guī)>并選中「允許腳本寫入文件和訪問網(wǎng)絡(luò)」。

Mac:轉(zhuǎn)到Adobe After Effects>首選項>常規(guī)>并選中「允許腳本寫入文件和訪問網(wǎng)絡(luò)」。

 

 

七、動效預(yù)覽

為了測試 json 文件是否能在對應(yīng)平臺顯示正常,Lottie 提供了預(yù)覽平臺。將導(dǎo)出的 json 文件上傳到網(wǎng)站即可預(yù)覽效果,也可以下載相應(yīng) APP 掃碼或者導(dǎo)入 json 文件預(yù)覽。

官方社區(qū),可以預(yù)覽動效和查看其他設(shè)計師公開的動效案例(自己上傳的預(yù)覽動效不會被公開):https://lottiefiles.com/

支持在線預(yù)覽json文件的 json test: https://nicolasjengler.github.io/bodymovins-json-tester/dist/

iOS 在 app store 搜索 Lottie 即可下載預(yù)覽軟件,安卓需要在 google play 下載安裝??紤]到部分朋友無法使用 google play, 文末提供下載。

 

 

 

 

八、推動落地

相信大家看完都有躍躍欲試的想法。但是要實際應(yīng)用在工作項目中就需要各位設(shè)計師去推動了。其中可能會面臨一些阻力,比如開發(fā)人員的能力水平以及個人的溝通方式等等問題。但是對于正確的事,只要我們堅持去做就會有結(jié)果的。首先對于 gif 動畫而言,Lottie 更加輕量,且性能更好,并且不易失真;對于開發(fā)人員自己寫動效來說,一方面 Lottie 減少了大量動效標注的時間,并且可以 100% 還原動效,對于開發(fā)人員來說無需再手動寫動效了。一次部署,終身輕松。相信相關(guān)人員了解以后都會去支持的。

為了方便開發(fā)人員使用,下面列出幾個使用網(wǎng)站,如果開發(fā)人員不知道如何部署和控制動效,直接把鏈接扔給他們就行了。

 

 

九、打包下載鏈接

 

百度網(wǎng)盤下載:https://pan.baidu.com/s/1gGYmRqaQrZkWtDVcvnRj0A

 

 



轉(zhuǎn)載請注明:優(yōu)波設(shè)計


掃描二維碼可分享給好友