動(dòng)效設(shè)計(jì),是 UI 設(shè)計(jì)當(dāng)中不可或缺的一環(huán)。大家對(duì)動(dòng)效的認(rèn)知也從最初認(rèn)為動(dòng)效只是為了美觀酷炫,到逐漸理解了動(dòng)效對(duì)于提升用戶體驗(yàn)和產(chǎn)品需求的重要作用。而導(dǎo)致這種認(rèn)知的轉(zhuǎn)變,相當(dāng)一部分原因是因?yàn)橛布阅艿陌l(fā)展和動(dòng)效輸出方式的優(yōu)化。
因?yàn)閯?dòng)效實(shí)現(xiàn)的過程就是設(shè)計(jì)師和開發(fā)之間互相博弈的過程。設(shè)計(jì)師可能通過 AE 或者其他工具做出炫酷的效果,和開發(fā)對(duì)接就懵了。要么無法實(shí)現(xiàn),要么極其復(fù)雜。畢竟開發(fā)工程師要通過代碼把動(dòng)效實(shí)現(xiàn)出來,設(shè)計(jì)師得用開發(fā)所能理解的語言來描述。就如同你能完美地解出一道數(shù)學(xué)題一樣,讓你把解題思路教給別人,你可能就沒那么順暢了。一方面取決于你的表述能力,而更重要的是對(duì)方的理解能力。過去所廣泛采用的通過動(dòng)效標(biāo)注輸出給開發(fā)的方式,都存在還原度的問題。很多時(shí)候還原度達(dá)到 80% 可能都算比較好的了。
而今天要說到的 Lottie 不僅可以 100% 還原動(dòng)效,而且無需動(dòng)效標(biāo)注。直接通過 AE 輸出動(dòng)效文件給開發(fā)。開發(fā)人員直接調(diào)用,然后完美還原。
Lottie 是 Airbnb 開源的一個(gè)動(dòng)畫渲染庫,同時(shí)支持 Android、iOS、React Native 平臺(tái)。Lottie 支持渲染播放 AE 動(dòng)畫。通過 AE 插件 bodymovie 導(dǎo)出 json 文件作為動(dòng)畫數(shù)據(jù),其工作流程如下:
是不是聽起來很心動(dòng)?其實(shí) Lottie 已經(jīng)火了一兩年了,很多人應(yīng)該也看了一些介紹。希望工作項(xiàng)目中經(jīng)常涉及到動(dòng)效設(shè)計(jì),但是還在用老方法的同學(xué)。可以嘗試使用 Lottie 幫助動(dòng)效落地,提升團(tuán)隊(duì)工作效率和個(gè)人影響力。
Lottie 可以應(yīng)用在 UI 設(shè)計(jì)的很多場(chǎng)景中。以下舉出幾個(gè)常用例子。
1. 動(dòng)態(tài)啟動(dòng)頁
2. 動(dòng)態(tài)圖標(biāo)/按鈕
3. 空頁面
4. 加載/下拉刷新
5. Banner/彈框
6. 表情/禮物/動(dòng)態(tài)貼紙
以上僅列舉了部分常用案例,其實(shí) Lottie 的應(yīng)用場(chǎng)景遠(yuǎn)不止這些。在 APP 的多個(gè)模塊中都可以運(yùn)用,那么我們要如何將 Lottie 運(yùn)用在自己的工作項(xiàng)目中呢?那就要了解 Lottie 的原理了。
前面已經(jīng)提過 Lottie 是 Airbnb 開源的一個(gè)動(dòng)畫渲染庫。我們可以理解為它是一個(gè)多功能的視頻播放器,開發(fā)人員需要將這個(gè)播放器部署到相應(yīng)的環(huán)境中。然后設(shè)計(jì)人員提供視頻(動(dòng)效文件)給開發(fā)人員,讓開發(fā)人員按照要求播放視頻文件,即可完成動(dòng)效的應(yīng)用。
Lottie 動(dòng)畫的播放控制,除了常規(guī)的控制,還支持進(jìn)度播放、幀播放。以一個(gè)動(dòng)態(tài)按鈕的切換為例,方便大家理解。
△ 用 Swift 制作一個(gè)漂亮的漢堡按鈕過渡動(dòng)畫
上圖所示為一個(gè)菜單/關(guān)閉按鈕的動(dòng)態(tài)切換。
假設(shè)該按鈕動(dòng)效一共10幀,整個(gè)按鈕切換分為兩部分,第一部分:從菜單切換到關(guān)閉(1-10幀);第二部分:從關(guān)閉切換到菜單(10-1)。我們可以讓開發(fā)通過以下控制方式,完成我們想要的效果。
按鈕動(dòng)效默認(rèn)顯示第1幀(菜單狀態(tài)),點(diǎn)擊按鈕以后開始播放動(dòng)效,動(dòng)效播放到第10幀的時(shí)候停止,并停在第10幀(關(guān)閉狀態(tài))。
當(dāng)按鈕為關(guān)閉狀態(tài)(第10幀)時(shí),點(diǎn)擊按鈕以后動(dòng)效從第10幀倒放到第1幀(關(guān)閉狀態(tài)),并停在第1幀(菜單狀態(tài))。
通過以上方式就完成了對(duì)一個(gè)動(dòng)效按鈕的控制。而日常工作中我們可以靈活地運(yùn)用多種控制方式。
首先動(dòng)效的觸發(fā),可以是一次交互事件,比如點(diǎn)擊、滑動(dòng);也可以是監(jiān)聽到了廣播,比如網(wǎng)絡(luò)異常等。
而觸發(fā)以后的動(dòng)效控制也多種多樣,可以從開始播放到結(jié)束,也可以進(jìn)行倒放;可以循環(huán)播放某一段動(dòng)效;也可以從某一幀播放到另一幀,或者某一個(gè)時(shí)間點(diǎn)播放到另一個(gè)時(shí)間點(diǎn);更多的控制方式需要大家在工作中慢慢挖掘。
Lottie雖然能夠滿足多種場(chǎng)景需要,但是并非支持所有的 AE 效果。設(shè)計(jì)制作時(shí),需要考慮該效果是否支持。否則,會(huì)導(dǎo)致出錯(cuò)或者所用效果無法生效。
上圖為 Lottie 支持的主要 AE 屬性,此處有刪減掉部分不常用的屬性。可以打開以下鏈接查看完整版http://airbnb.io/lottie/#/supported-features
需要注意的是文檔中雖然說支持漸變,但是會(huì)出錯(cuò),所以大家在使用矢量圖形時(shí),請(qǐng)勿使用漸變效果。關(guān)于漸變效果的修復(fù)后續(xù)文章會(huì)提到,官網(wǎng)以后也會(huì)修復(fù)相關(guān)問題,但是沒有確切時(shí)間。
通過上圖我們可以了解到,Lottie 支持的 AE 屬性基本包含以下幾類:
- 基礎(chǔ)的形狀比如圓形、矩形、星形等,也可以支持鋼筆工具繪制的矢量形狀和從 AI 中導(dǎo)入的矢量圖形。
- 支持位移、大小縮放、透明度、旋轉(zhuǎn)、修剪路徑、蒙版、遮罩這些基礎(chǔ)動(dòng)畫屬性。
- 支持圖層間建立父子級(jí)關(guān)系(只支持圖層與圖層之間建立,當(dāng)圖層的屬性之間建立父子關(guān)系會(huì)失效,比如 A 圖層可以和 B 圖層建立父子關(guān)系,但是 A 圖層的位移屬性和 B 圖層的位移屬性單獨(dú)建立父子關(guān)系則不生效)。
- 支持速度貝塞爾插值,可以搭配 Flow 插件生成各種緩動(dòng)效果。
- 支持導(dǎo)入圖片。
- 支持時(shí)間拉伸和時(shí)間重映射來通知時(shí)間和速度。
前面已經(jīng)提到 Lottie 是通過 AE 插件 bodymovie 導(dǎo)出 json 文件作為動(dòng)畫數(shù)據(jù)。接下來就為大家講解插件的安裝與使用方法。
1. 下載bodymovie插件
官方英文插件地址:https://aescripts.com/bodymovin/(文末提供中文漢化版下載地址和詳細(xì)安裝教程)
2. 自動(dòng)安裝方法
下載zxp格式安裝器,下載地址:https://aescripts.com/learn/zxp-installer/,安裝成功后,雙擊步驟 1 中下載的插件即可完成安裝。
3. 手動(dòng)安裝方法
如果自動(dòng)安裝失敗,可嘗試手動(dòng)安裝。首先修改 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)到編輯>首選項(xiàng)>常規(guī)>并選中「允許腳本寫入文件和訪問網(wǎng)絡(luò)」。
Mac:轉(zhuǎn)到Adobe After Effects>首選項(xiàng)>常規(guī)>并選中「允許腳本寫入文件和訪問網(wǎng)絡(luò)」。
安裝完成后即可在窗口>擴(kuò)展>bodymovin(Window> Extensions> bodymovin)中找到 bodymovin 插件。
插件主界面如圖所示。在主界面可以選擇需要導(dǎo)出的合成、導(dǎo)出設(shè)置、導(dǎo)出文件夾,并且可以預(yù)覽動(dòng)效。
每次導(dǎo)出時(shí)都需要進(jìn)行設(shè)置。標(biāo)紅區(qū)域?yàn)楸剡x選項(xiàng)。字體圖形化可以將字體轉(zhuǎn)化為路徑,不勾選會(huì)因?yàn)閼?yīng)用的平臺(tái)沒有相應(yīng)字體導(dǎo)致文字加載出錯(cuò);勾選演示模式后會(huì)生成 html 文件,打開該文件即可預(yù)覽動(dòng)效。
當(dāng)含有圖片資源時(shí)可以根據(jù)需要選擇勾選對(duì)應(yīng)的選項(xiàng)。
保存好設(shè)置后,點(diǎn)擊渲染即可生成動(dòng)效文件給開發(fā)。當(dāng)只有矢量圖層時(shí),開發(fā)只需要使用 json 文件即可。當(dāng)含有圖片文件時(shí)需要將 json 文件和圖片文件夾一并給到開發(fā)人員使用。需要注意的是不能隨意修改文件夾名稱和內(nèi)部文件名。如果需要修改圖片名稱,應(yīng)該同步修改 json 內(nèi)部代碼。相關(guān)修改方法,后續(xù)文章將會(huì)詳解。
為了測(cè)試 json 文件是否能在對(duì)應(yīng)平臺(tái)顯示正常,Lottie 提供了預(yù)覽平臺(tái)。將導(dǎo)出的 json 文件上傳到網(wǎng)站即可預(yù)覽效果,也可以下載相應(yīng) APP 掃碼或者導(dǎo)入 json 文件預(yù)覽。
官方社區(qū),可以預(yù)覽動(dòng)效和查看其他設(shè)計(jì)師公開的動(dòng)效案例(自己上傳的預(yù)覽動(dòng)效不會(huì)被公開):https://lottiefiles.com/
iOS 在 app store 搜索 Lottie 即可下載預(yù)覽軟件,安卓需要在 google play 下載安裝。考慮到部分朋友無法使用 google play, 文末提供下載。
相信大家看完都有躍躍欲試的想法。但是要實(shí)際應(yīng)用在工作項(xiàng)目中就需要各位設(shè)計(jì)師去推動(dòng)了。其中可能會(huì)面臨一些阻力,比如開發(fā)人員的能力水平以及個(gè)人的溝通方式等等問題。但是對(duì)于正確的事,只要我們堅(jiān)持去做就會(huì)有結(jié)果的。首先對(duì)于 gif 動(dòng)畫而言,Lottie 更加輕量,且性能更好,并且不易失真;對(duì)于開發(fā)人員自己寫動(dòng)效來說,一方面 Lottie 減少了大量動(dòng)效標(biāo)注的時(shí)間,并且可以 100% 還原動(dòng)效,對(duì)于開發(fā)人員來說無需再手動(dòng)寫動(dòng)效了。一次部署,終身輕松。相信相關(guān)人員了解以后都會(huì)去支持的。
為了方便開發(fā)人員使用,下面列出幾個(gè)使用網(wǎng)站,如果開發(fā)人員不知道如何部署和控制動(dòng)效,直接把鏈接扔給他們就行了。
- Lottie官方介紹和開發(fā)文檔:http://airbnb.io/lottie/#/README
- York_魚的lottie介紹和動(dòng)效控制方法詳解:https://www.jianshu.com/p/01f6bb509d54
文件下載鏈接:https://share.weiyun.com/5DpXrKm 密碼:iuaruk
備用下載鏈接:https://share.weiyun.com/5m2Dinf
關(guān)于 Lottie 的介紹就到這里,后續(xù)將會(huì)持續(xù)更新 Lottie 動(dòng)效設(shè)計(jì)過程中涉及的各種問題和方法技巧。
歡迎關(guān)注作者的微信公眾號(hào):「懿凡設(shè)計(jì)」
復(fù)制本文鏈接 文章為作者獨(dú)立觀點(diǎn)不代表優(yōu)設(shè)網(wǎng)立場(chǎng),未經(jīng)允許不得轉(zhuǎn)載。
發(fā)評(píng)論!每天贏獎(jiǎng)品
點(diǎn)擊 登錄 后,在評(píng)論區(qū)留言,系統(tǒng)會(huì)隨機(jī)派送獎(jiǎng)品
2012年成立至今,是國內(nèi)備受歡迎的設(shè)計(jì)師平臺(tái),提供獎(jiǎng)品贊助 聯(lián)系我們
AI輔助海報(bào)設(shè)計(jì)101例
已累計(jì)誕生 737 位幸運(yùn)星
發(fā)表評(píng)論 為下方 36 條評(píng)論點(diǎn)贊,解鎖好運(yùn)彩蛋
↓ 下方為您推薦了一些精彩有趣的文章熱評(píng) ↓