Android原生頁面跳轉(zhuǎn)flutter頁面時報錯Must be able to initialize the VM.

最近在Android原生項(xiàng)目集成flutter,參照wiki步驟助赞,寫了個demo編譯打包運(yùn)行都沒有任何問題效斑。

但是集成到公司項(xiàng)目上時非春,碰到一個很坑的問題,集成編譯沒問題缓屠,在原生頁面跳轉(zhuǎn)flutter頁面時閃退奇昙,報錯Must be able to initialize the VM,字面上意思就是flutter vm初始化失敗了敌完。于是Google搜了一下储耐,大致可以確定是flutter_assets(https://github.com/flutter/flutter/issues/19818)這個目錄沒有編譯進(jìn)去。

于是將公司的apk和我寫的demo的apk解壓對比了一下滨溉,確實(shí)是flutter_assets沒有打包進(jìn)去弧岳。
下面是正常打包進(jìn)去的flutter_assets

image.png

其中:

  • isolate_snapshot_data 應(yīng)用程序數(shù)據(jù)段
  • isolate_snapshot_instr 應(yīng)用程序指令段
  • vm_snapshot_data VM虛擬機(jī)數(shù)據(jù)段
  • vm_snapshot_instr VM虛擬機(jī)指令段

這些都是flutter vm必須的文件业踏,缺少了這些vm無法正常啟動禽炬,所以可以完全確定是缺少flutter_assets導(dǎo)致的。

嘗試解決1

image.png

上面的辦法是說把flutter module生成aar中的flutter_assets解壓拷貝到Android工程下勤家。
于是我到目錄下找到aar腹尖,解壓打開,我擦伐脖。热幔。。讼庇。绎巨。根本沒有flutter_assets。該方法行不通蠕啄!

但是他猜測是gradle配置導(dǎo)致flutter_assets沒有被打包進(jìn)去(確實(shí)是因?yàn)間radle配置)场勤。

嘗試解決2

于是繼續(xù)google,找了線索歼跟,是因?yàn)?strong>多渠道打包導(dǎo)致flutter_assets沒有被打包進(jìn)去和媳。

這個issue碰到的主要問題有兩個:

  1. 沒有遵循wiki步驟,沒有將Android project和my_flutter 放在同級目錄
  2. 沒有在flutter module的build.gradle中配置渠道信息
image.png

不幸的是哈街,我參照上面的步驟留瞳,編譯出來的aar依舊沒有flutter_assets。骚秦。她倘。璧微。。

嘗試解決3

網(wǎng)上搜不到其他的解決辦法了硬梁,沒辦法往毡,只能看編譯過程中哪里出了問題,于是對比了我的demo的build目錄和公司項(xiàng)目的build目錄靶溜,
下面是demo的flutter build目錄


image.png

下面是公司項(xiàng)目的flutter目錄


image.png

可以看出公司項(xiàng)目沒有打包assets,于是我就對比了一下build日志懒震,把關(guān)于flutter的日志都對比了一下罩息。

這個是demo編譯的日志


image.png

這個是公司項(xiàng)目的編譯日志


image.png

大致可以定位到時沒有執(zhí)行copyFlutterAssetsDevelopmentDebug

flutter module的build.gradle沒有執(zhí)行copyFlutterAssets,是它依賴的flutter.gradle執(zhí)行的个扰。
找到$flutterRoot/packages/flutter_tools/gradle/flutter.gradle瓷炮,搜索copyFlutterAssets。

可以找到有個copyFlutterAssetsTask递宅,就是它沒有被執(zhí)行娘香,看下gradle里是怎么寫的。

image.png

加了打印日志后發(fā)現(xiàn)走的是上面的if分支办龄,通過代碼可以看出:
gradle根據(jù)mainModuleName去找mergeAssets烘绽,如果Android項(xiàng)目沒有配置project.rootProject.ext.mainModuleName,就會默認(rèn)用"app"這個名字去找mergeAssets俐填,而我們公司項(xiàng)目的app module的名字不是"app"安接,也沒有配置project.rootProject.ext.mainModuleName,所以沒找到mergeAssets英融,mergeAssets為null盏檐,就沒有去執(zhí)行copyFlutterAssets

至此原因找到驶悟,在Android project根目錄build.gradle配置下mainModuleName胡野,clean Android module和flutter module,重新編譯運(yùn)行痕鳍,搞定硫豆!

問題總結(jié)

  1. 遵循wiki步驟,flutter project和Android project 在同級目錄
  2. 如果是多渠道打包笼呆,需要在flutter module的build.gradle中配置渠道信息
  3. 如果Android項(xiàng)目app module的名字不是”app“够庙,需要配置project.rootProject.ext.mainModuleName

這個問題阿里大佬也發(fā)現(xiàn)了https://github.com/flutter/flutter/pull/27154

  1. flutter和studio升級到最新穩(wěn)定版抄邀,注意是穩(wěn)定版T耪!!境肾!dev剔难,master分支上通常都有bug
后續(xù)打包遇到的問題

1胆屿、debug包正常,release包跳轉(zhuǎn)flutter頁面崩潰

解決方法:配置flutter混淆http://www.reibang.com/p/338422e3ecc1

2. 所有Android路由跳轉(zhuǎn)失效偶宫,我用的是com.chenenyu.router

解決辦法:更新路由插件到最新版

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末非迹,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子纯趋,更是在濱河造成了極大的恐慌憎兽,老刑警劉巖,帶你破解...
    沈念sama閱讀 218,858評論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件吵冒,死亡現(xiàn)場離奇詭異纯命,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)痹栖,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,372評論 3 395
  • 文/潘曉璐 我一進(jìn)店門亿汞,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人揪阿,你說我怎么就攤上這事疗我。” “怎么了南捂?”我有些...
    開封第一講書人閱讀 165,282評論 0 356
  • 文/不壞的土叔 我叫張陵吴裤,是天一觀的道長。 經(jīng)常有香客問我溺健,道長嚼摩,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,842評論 1 295
  • 正文 為了忘掉前任矿瘦,我火速辦了婚禮枕面,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘缚去。我一直安慰自己潮秘,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,857評論 6 392
  • 文/花漫 我一把揭開白布易结。 她就那樣靜靜地躺著枕荞,像睡著了一般。 火紅的嫁衣襯著肌膚如雪搞动。 梳的紋絲不亂的頭發(fā)上躏精,一...
    開封第一講書人閱讀 51,679評論 1 305
  • 那天,我揣著相機(jī)與錄音鹦肿,去河邊找鬼矗烛。 笑死,一個胖子當(dāng)著我的面吹牛箩溃,可吹牛的內(nèi)容都是我干的瞭吃。 我是一名探鬼主播碌嘀,決...
    沈念sama閱讀 40,406評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼歪架!你這毒婦竟也來了股冗?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,311評論 0 276
  • 序言:老撾萬榮一對情侶失蹤和蚪,失蹤者是張志新(化名)和其女友劉穎止状,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體攒霹,經(jīng)...
    沈念sama閱讀 45,767評論 1 315
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡怯疤,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,945評論 3 336
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了剔蹋。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片晴叨。...
    茶點(diǎn)故事閱讀 40,090評論 1 350
  • 序言:一個原本活蹦亂跳的男人離奇死亡睹欲,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出等孵,到底是詐尸還是另有隱情洛口,我是刑警寧澤矫付,帶...
    沈念sama閱讀 35,785評論 5 346
  • 正文 年R本政府宣布,位于F島的核電站第焰,受9級特大地震影響买优,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜挺举,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,420評論 3 331
  • 文/蒙蒙 一杀赢、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧湘纵,春花似錦脂崔、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,988評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至铺敌,卻和暖如春汇歹,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背偿凭。 一陣腳步聲響...
    開封第一講書人閱讀 33,101評論 1 271
  • 我被黑心中介騙來泰國打工产弹, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人弯囊。 一個月前我還...
    沈念sama閱讀 48,298評論 3 372
  • 正文 我出身青樓取视,卻偏偏與公主長得像硝皂,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子作谭,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,033評論 2 355

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