這個項目碉堡了

新年第一天上班,沒想到就立春了,俗話說,一年之計在於春,全新的 17 年開始啦,來,收拾下心情,投入到工作中,擼起袖子,就是干!

就在前幾天,Airbnb 開源了一個項目叫做 Lottie,我個人覺得這個項目簡直碉堡了!

動畫相信大家都不陌生,在 App 開發過程中,適當的使用動畫可以提升用戶體驗,使我們的產品錦上添花,對於一些簡單的動畫,我們很容易就能實現,但是對於一些比較複雜的動畫,實現起來就比較麻煩了,比如下圖的一些動畫:

(渣乎不支持 Gif,具體 Gif 圖請移步這裡 這個項目碉堡了)

怎麼樣?這些可不是簡單的移動、縮放、旋轉就搞得定的,可能有些人思考了之後大概有以下實現思路:

  • 使用 Gif,這種方式當然可行,但是使用 Gif 佔用空間較大,而且需要為各種屏幕尺寸、解析度做適配,因為 Android 沒有提供原生 Gif 的 api 支持,所以這種方案還會遇到兼容性問題;

  • 使用幀動畫,這種方式還不如 Gif,一般來說使用幀動畫佔用空間比 Gif 還要大的多,而且一樣要做多屏幕解析度的適配,不過一般不會遇到兼容性問題;

  • 使用視頻,這種方式當然可以,但是一般來說宣傳片才用的上視頻,一般的動畫遠不需要用視頻才能實現的,未免有些大材小用了,而且佔用空間依然很大。

就沒有更好的實現方式了么?

當然有,Android 5.x 之後提供了對 SVG 的支持,通過 VectorDrawable、AnimatedVectorDrawable 的結合可以實現一些稍微複雜的動畫,但是兼容性是一個問題,當然這個可以通過一些第三方庫來解決,不過整個實現流程非常麻煩,每次全新實現一個動畫都得重頭來過,最最關鍵的是,如果一個公司下的 App,iOS 也要實現一套一樣的動畫,資源的佔用與開發成本就顯得過大了。

而 Airbnb 開源的這個項目完美的解決以上難題,我們來看下整個流程是什麼樣的。

假設我們要做一個引導頁面的歡迎動畫,這個一般設計師會用 Adobe 旗下的 After Effects (簡稱 AE)來做個動畫出來,設計師用 AE 做個動畫比工程師用代碼去實現一個動畫要快的多的多,調整起來也很方便,之後 AE 上有一款插件叫做 [Bodymovin](bodymovin/bodymovin),這個插件也比較屌,可以直接根據 AE 上的動畫文件導出 json 文件,這個 json 文件描述了該動畫的一些關鍵點的坐標以及運動軌跡,之後我們在項目中引用 Lottie 開源庫,在布局文件中簡單的加上這麼一句就完美的實現了。

或者代碼中這樣使用:

值得一提的是,我們的 hello-world.json 文件只需要放在 app/src/main/assets 目錄下就 ok 了。

當然,還有更多的用法,比如給動畫添加事件,比如描述動畫的 json 文件可以遠程更新下載到本地,這樣就可以不動聲色的定期更新你的動畫了。

有了這個庫,我們可以充分發揮我們的想像力,很簡單方便的就實現了一套很酷炫的動畫,最重要的是,這個庫是跨平台的,支持 Android、iOS 以及 ReactNative,共用一套 json 動畫描述文件,簡直了!

其實 Facebook 前段時間開源了一個類似的庫叫做 [Keyframes](facebookincubator/Keyframes),也是跨平台的,但是 Lottie 比 Keyframes 支持的特性更多,而且據 Airbnb 官方博客介紹,以後會讓這個庫支持更多的特性與功能,不得不說,真乃良心!

最後,這個庫的開源地址在這裡:

Android: airbnb/lottie-android

iOS: airbnb/lottie-ios

ReactNative: airbnb/lottie-react-native

最最後,Airbnb 還提供了一個 sample apk,考慮到部分人在 Google Play 上下載 apk 有些困難,我也貼心的把 sample apk 下載下來了,公眾號 AndroidDeveloper 後台回復「lottie」關鍵字獲取。

本文原創發佈於微信公眾號 「googdev」,轉載請註明出處。

推薦閱讀:

Google I/O 的規格和影響力比得上 WWDC 嗎?
小程序發布,你很方?

TAG:Android | iOS | 移动开发 |