iOS Lottie動畫的小嘗試

起因: 最近閑下來之后, 覺得公司項目里有些地方可以優(yōu)化一下過度效果, 所以開啟了逛開發(fā)者論壇的模式, 搜到了好多做動畫的技術框架, 這些框架寫的都很好, 不過都不太符合我心中的預期, 直到看到愛彼迎的Lottie動畫,眼前一亮
先來說說以前用到的動畫的缺點(純屬個人經(jīng)驗)

1: 編碼, 因為好多自定制效果需要我們開發(fā)人員自己去思考的,耗費腦細胞不說, 在工期上也不好把握,特別是在敏捷式開發(fā)為主流的今天......

2: 性能, 一些非常酷炫的動畫需要靠美工小姐姐給我們gif圖片, 當gif圖片量很大的時候,性能就成了一個問題, 就算是用原生自己寫, 也要考慮繪制性能的問題

3: 不能跨平臺, 在實際開發(fā)當中為了追求各端的一致性, 通常都會要美工給gif圖......不然就是所有開發(fā)們 一起耗費腦細胞

4: 時效性, 如果產(chǎn)品給的需求是 動畫需要產(chǎn)品在后臺手動控制, 那前端就很窩火兒了, 我以前的做法是, 用做換膚的那套方案, 讓產(chǎn)品把各種資源文件打包上傳,但gif過大的話,也是個問題......

什么是Lottie
“Lottie is a library for Android, iOS, Web, and Windows that parse Adobe After Effects animations exported as json with bodymovin and renders them natively on mobile and on the web!” - 自官網(wǎng):http://airbnb.io/lottie/#/
翻譯:
Lottie可以播放 使用bodymovin從Adobe After Effects中導出的json文件, 并且可以在 iOS胯努、Android逢防、macOS、React Native 和 Windows 中進行解析使用的開源庫

針對于上面做動畫的一些缺點, 來比對一下Lottie的優(yōu)勢
1:編碼: 代碼量很少(下文例子會出現(xiàn))

2:性能: 性能很高,我播放了好幾個動畫, 內(nèi)存幾乎沒怎么變化

3:能跨平臺: 這在很大程度上解決了多端效果不一致的問題

4:所占的空間比較小: 無論是下載還是被當成資源文件集成到項目中來, 一個json文件充其量就是幾十到幾百kb, 和動不動就好幾M的gif比,那可省多了,對App瘦身是一個很大的幫助

5:節(jié)省開發(fā)時間, 不管美工設計出了什么復雜動畫,只要能給我們開發(fā)這份json文件, 我們就可以完全可以節(jié)約做動畫所帶來的開發(fā)成本,而且設計師可以大膽的進行UE設計

舉個例子吧

import UIKit
import Lottie
class ViewController: UIViewController {
    
    override func viewDidLoad() {
        super.viewDidLoad()
        self.view.backgroundColor = .white
        let animationView = AnimationView(name: "159-animation")
        let width = self.view.frame.size.width

        animationView.frame = CGRect(x: 10, y: 50, width: width - 20, height: width - 20);
        animationView.center = self.view.center
        
        animationView.loopMode = .loop
        animationView.contentMode = .scaleAspectFill
        animationView.animationSpeed = 0.5
        view.addSubview(animationView)
        
        animationView.play()
    }

}

效果



很簡單吧!!!
遷移:
從代碼里可以看出 Lottie的的載體是一個view, 根據(jù)這一點 我們能有好多騷操作, 只要我們能找到這個view, 比如自定義帶動畫的tabbar, 比如自定義上拉加載, 下拉刷新的動畫, 路由跳轉的動畫, 總之一切基于view能實現(xiàn)的動畫, 我想都可以用Lottie實現(xiàn)
,可以粗略的理解為 view是個播放器, 播放json文件動畫

最后編輯于
?著作權歸作者所有,轉載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市溉箕,隨后出現(xiàn)的幾起案子晦墙,更是在濱河造成了極大的恐慌肴茄,老刑警劉巖,帶你破解...
    沈念sama閱讀 206,968評論 6 482
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件抗楔,死亡現(xiàn)場離奇詭異拦坠,居然都是意外死亡,警方通過查閱死者的電腦和手機贪婉,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,601評論 2 382
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來才顿,“玉大人,你說我怎么就攤上這事郑气。” “怎么了尾组?”我有些...
    開封第一講書人閱讀 153,220評論 0 344
  • 文/不壞的土叔 我叫張陵示弓,是天一觀的道長。 經(jīng)常有香客問我奏属,道長,這世上最難降的妖魔是什么勇婴? 我笑而不...
    開封第一講書人閱讀 55,416評論 1 279
  • 正文 為了忘掉前任嘱腥,我火速辦了婚禮,結果婚禮上齿兔,老公的妹妹穿的比我還像新娘窄做。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 64,425評論 5 374
  • 文/花漫 我一把揭開白布吻商。 她就那樣靜靜地躺著,像睡著了一般艾帐。 火紅的嫁衣襯著肌膚如雪盆偿。 梳的紋絲不亂的頭發(fā)上柒爸,一...
    開封第一講書人閱讀 49,144評論 1 285
  • 那天捎稚,我揣著相機與錄音,去河邊找鬼今野。 笑死罐农,一個胖子當著我的面吹牛条霜,可吹牛的內(nèi)容都是我干的涵亏。 我是一名探鬼主播,決...
    沈念sama閱讀 38,432評論 3 401
  • 文/蒼蘭香墨 我猛地睜開眼拆内,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了矛纹?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 37,088評論 0 261
  • 序言:老撾萬榮一對情侶失蹤或南,失蹤者是張志新(化名)和其女友劉穎艾君,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體冰垄,經(jīng)...
    沈念sama閱讀 43,586評論 1 300
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,028評論 2 325
  • 正文 我和宋清朗相戀三年逝薪,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片董济。...
    茶點故事閱讀 38,137評論 1 334
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖虏肾,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情封豪,我是刑警寧澤,帶...
    沈念sama閱讀 33,783評論 4 324
  • 正文 年R本政府宣布第步,位于F島的核電站,受9級特大地震影響雌续,放射性物質發(fā)生泄漏。R本人自食惡果不足惜驯杜,卻給世界環(huán)境...
    茶點故事閱讀 39,343評論 3 307
  • 文/蒙蒙 一做个、第九天 我趴在偏房一處隱蔽的房頂上張望鸽心。 院中可真熱鬧居暖,春花似錦、人聲如沸太闺。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,333評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至怠惶,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間策治,已是汗流浹背脓魏。 一陣腳步聲響...
    開封第一講書人閱讀 31,559評論 1 262
  • 我被黑心中介騙來泰國打工通惫, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人履腋。 一個月前我還...
    沈念sama閱讀 45,595評論 2 355
  • 正文 我出身青樓府树,卻偏偏與公主長得像,于是被迫代替她去往敵國和親奄侠。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 42,901評論 2 345