VenusDrawable-以描述文件的方式繪制Bitmap動畫

前言

參考矢量動畫實現(xiàn),幀動畫瘪校。發(fā)現(xiàn)幀動畫中l(wèi)oad一系列的資源圖片,創(chuàng)建大量的BitmapDrawable,資源圖片存在重復(fù)的元素阱扬。這樣不僅浪費了大量的手機內(nèi)存泣懊,占用CPU時間片做計算,而且也無形中增大了App的大小麻惶。而安卓的矢量動畫的實現(xiàn)馍刮,則擺脫了對位圖的依賴,以描述性語句的形式來實現(xiàn)動畫用踩。但是有些場景下單純用矢量繪圖的方式又顯得格外的復(fù)雜渠退。
由此便產(chǎn)生了VenusDrawable,VenusDrawable的具體實現(xiàn)便是:將圖片元素切分脐彩,通過將每個元素的繪制路徑 描述出來碎乃,在畫布上繪制,實現(xiàn) 位圖動畫惠奸。
類似 airbnb 的 lottie 梅誓,最近 SVGAPlayer (yyued開源的)。

效果展示

可以動的小螞蟻
可以旋轉(zhuǎn)的小動物

Drawable 實現(xiàn)

VenusDrawable 的實現(xiàn)部分比較簡單佛南,大概的流程圖如下:

實現(xiàn)流程

整個的實現(xiàn)流程比較簡單梗掰,核心內(nèi)容是按照幀序列的方式將位圖和矢量圖繪制到View上,系分一下大概分以下幾個部分:

描述數(shù)據(jù)的格式

使用json這種輕量級的方式來表述嗅回,大概的格式如下:

{
    "version": "1.0",//版本描述
    "count": 60,//總幀數(shù)
    "size": {//大小
        "width": 500,
        "height": 500
    },
    "frames": [
      {
            "key": "位圖字符或矢量標(biāo)志",//元素類型
            "layout": {//元素大小
                "x": 14,
                "y": 14
            }
            "sprites": [
                {
                    "index": 0,//序列為0 的幀
                    "martix": {/**位圖位置描述或矢量描述**/},
                },
                ......
            ]
        },
        ......
    ]
}

其中及穗,若動畫元素中使用到圖片,我們可以將其轉(zhuǎn)化為字符存儲到描述文件中绵载。

描述數(shù)據(jù)的序列化和反序列化

單純通過json的方式是可以實現(xiàn)整個流程的埂陆,但是json的序列化和反序列化效率不是很高,特別在移動設(shè)備上娃豹,更加的追求效率焚虱,因此VenusDrawable 采用了FlatBuffers 實現(xiàn)序列化和反序列化。


i效率對比

繪制流程實現(xiàn)

VenusDrawable 實現(xiàn)

將描述文件解析后懂版,傳遞給VenusDrawable鹃栽,由其中的VenusDrawer 繪制到View上面canvas.drawBitmap,其中VenusValueAnimator控制幀繪制的速率躯畴。

AE拓展實現(xiàn)

對AE拓展比較陌生的話民鼓,可以看下AE 擴展開發(fā)系統(tǒng)教程,實現(xiàn)AE拓展的目的:為了高保真的將動畫效果由設(shè)計師直達軟件界面蓬抄,類似于lottie的一些插件摹察。不僅可以減少開發(fā)成本,還可以提高工作效率倡鲸。

CEP 架構(gòu)

我們需要實現(xiàn)AE拓展大概描述一下:將設(shè)計師設(shè)計并輸出的.aep文件轉(zhuǎn)換成我們能識別的flatbuffers文件結(jié)構(gòu)供嚎。
帶著這個目的,我們需要完成兩部分工作:

 1. 和我們的宿主程序(AE)的交互:通過宿主提供的功能(api接口),將.aep文件拆解克滴,獲取我們所需要的信息逼争。
 2. 另一部分則是我們拓展的展現(xiàn)邏輯:寫一個html,使用js做文件的生成操作劝赔。

而這兩部分則通過CSInterface.js 聯(lián)系在一起誓焦。

第一部分可以直接查閱API使用;
第二部分大致流程圖如下:

生成最終文件流程

效率對比

相同條件下,用了兩個小螞蟻的動畫着帽,一個是通過AnimationDrawable 實現(xiàn)杂伟,另外一個通過VenusDrawable實現(xiàn),gc后對比圖如下:
VenusDrawable:
[圖片上傳失敗...(image-a2a13f-1557552400900)]

AnimationDrawable:
[圖片上傳失敗...(image-6f3321-1557552400900)]

對比可發(fā)現(xiàn):相較于AnimationDrawable仍翰,VenusDrawable減少了近1m的內(nèi)存占用赫粥。

后續(xù)優(yōu)化

  1. 在多機型上的兼容性問題,硬件繪制的兼容性問題予借。
  2. 增加x元素來影響 動畫的呈現(xiàn)越平,如手勢,touch 事件等灵迫,使動畫更具趣味性秦叛。
  3. 繪制的效率持續(xù)調(diào)優(yōu)。
  4. 支持矢量動畫的繪制

參考

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末瀑粥,一起剝皮案震驚了整個濱河市挣跋,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌狞换,老刑警劉巖浆劲,帶你破解...
    沈念sama閱讀 217,277評論 6 503
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異哀澈,居然都是意外死亡,警方通過查閱死者的電腦和手機度气,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,689評論 3 393
  • 文/潘曉璐 我一進店門割按,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人磷籍,你說我怎么就攤上這事适荣。” “怎么了院领?”我有些...
    開封第一講書人閱讀 163,624評論 0 353
  • 文/不壞的土叔 我叫張陵弛矛,是天一觀的道長。 經(jīng)常有香客問我比然,道長丈氓,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,356評論 1 293
  • 正文 為了忘掉前任,我火速辦了婚禮万俗,結(jié)果婚禮上湾笛,老公的妹妹穿的比我還像新娘。我一直安慰自己闰歪,他們只是感情好嚎研,可當(dāng)我...
    茶點故事閱讀 67,402評論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著库倘,像睡著了一般临扮。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上教翩,一...
    開封第一講書人閱讀 51,292評論 1 301
  • 那天杆勇,我揣著相機與錄音,去河邊找鬼迂曲。 笑死靶橱,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的路捧。 我是一名探鬼主播关霸,決...
    沈念sama閱讀 40,135評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼杰扫!你這毒婦竟也來了队寇?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 38,992評論 0 275
  • 序言:老撾萬榮一對情侶失蹤章姓,失蹤者是張志新(化名)和其女友劉穎佳遣,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體凡伊,經(jīng)...
    沈念sama閱讀 45,429評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡零渐,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,636評論 3 334
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了系忙。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片诵盼。...
    茶點故事閱讀 39,785評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖银还,靈堂內(nèi)的尸體忽然破棺而出风宁,到底是詐尸還是另有隱情,我是刑警寧澤蛹疯,帶...
    沈念sama閱讀 35,492評論 5 345
  • 正文 年R本政府宣布戒财,位于F島的核電站,受9級特大地震影響捺弦,放射性物質(zhì)發(fā)生泄漏饮寞。R本人自食惡果不足惜孝扛,卻給世界環(huán)境...
    茶點故事閱讀 41,092評論 3 328
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望骂际。 院中可真熱鬧疗琉,春花似錦、人聲如沸歉铝。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,723評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽太示。三九已至柠贤,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間类缤,已是汗流浹背臼勉。 一陣腳步聲響...
    開封第一講書人閱讀 32,858評論 1 269
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留餐弱,地道東北人宴霸。 一個月前我還...
    沈念sama閱讀 47,891評論 2 370
  • 正文 我出身青樓,卻偏偏與公主長得像膏蚓,于是被迫代替她去往敵國和親瓢谢。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 44,713評論 2 354

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