已有Android项目集成Flutter寻坑记

作者 : 开心源码 本文共2537个字,预计阅读时间需要7分钟 发布时间: 2022-05-12 共228人阅读

背景

Flutter作为谷歌下一代主推的全平台UI框架,具备很多的优点:

  • 支持全平台,包括Android、iOS、Web甚至桌面端。
  • 全平台都基于同一套代码库,区别于React Native的learn once, write everywhere。
  • 媲美原生的性能。
  • 牛逼的开发效率,这个深有体会,目前笔者公司负责的一个电商app,随意修改一行代码build一次在2018款macbook pro 15下都需要4分钟左右,Flutter可以做到不到一秒。
  • 丰富的组件库,比Android的组件更加丰富。
  • 国内已经有很多大厂已经有使用Flutter在他们的核心项目中了, 比方阿里的咸鱼,腾讯的now直播,京东商城等等。

今年整个互联网寒冬,很多公司都在裁员,手机端跨平台方案能够肯定程度上节约开发成本,而且android ios都是一套代码,也避免了分端开发导致两端逻辑可能不一致的问题。

尝鲜

按照官方文档的指引 flutter/flutter/wiki/Add-Flutter-to-existing-apps,很快我就完成了集成,但是一运行,进入flutter页面时,总是黑屏过段时间就闪退了,查看崩溃信息时发现应该是flutter so库没有打包进去,这个问题是由于我们的项目是只打包armeabi单abi。而flutter只提供armeabi-v7a以上的so。所以我们把abi改成armeabi-v7a即可以顺利打包flutter的so库了,如下:

    splits {        abi {            enable !project.hasProperty('runx86')            reset()            include 'armeabi-v7a'             universalApk false        }    }

满心欢喜的赶紧build再次运行,结果还是一样,进入flutter页面,还是黑屏一下,而后闪退,这时候出现的error log是:

VM snapshot must be valid.Check failed: vm. Must be able to initialize the VM.

WTF:google之,发现一片非常有用的文章 flutter/flutter/issues/19818。在这篇文章中提到:

vmfailed
看起来是说打包的apk的assets中缺少了flutter_assets,flutter_assets里面是什么?我猜他妈的一定是dart vm还有dart的代码。这个哥们也比较实在,他说他也不知道为什么没有打包进去。于是按照这个哥们的方法,手工把flutter module编译出来的flutter_assets的拷贝到安卓项目中,而后重新编译打包,我手指微微颤抖的点开flutter页面,我操,flutter页面终于出来,我第一次流下了幸福的眼泪。但是幸福过后,还是要思考,我不能每次都手工拷贝吧,写个脚本拷贝也行,但是还是显得不太专业,我想要的是直接在IDE上点build按钮就能生成一个完美的apk包。

接着继续查看上面这个issue 19818(这个number还蛮吉利的),有个兄弟说是假如你的项目中有用到productFlavors的话,你的flutter项目也必需要配置相同的productFlavors才会自动把flutter_assets打包进去。按照下面这个方式进行代码调整:

productFlavor
build打包运行,f**k,还是不行。flutter_assets怎么都打包不进apk里面。而后就是无尽的尝试,终于发现有一个中国的兄弟遇到跟我相似的问题https://www.songma.com/p/3a88d9b993cd。
fluttermaster
看起来是需要切到flutter的master分支上才可以,目前我是在stable分支上,那就切把,赶紧执行flutter channel master。这个过程需要翻墙,或者者增加flutter中国镜像。要不然会下载不成功。切成功之后,试了无数次,还行不行。怎样办,我已经生无死恋……………………..

在经过屡次痛哭流涕之后,我真想把电脑合上,背起书包回家(已经是深夜了),但是作为一个对技术有狂热追求的我,我不甘心就这样失败。也许是上帝的安排,冥冥之中我比照了下别的项目module名称都是app这样,而我们的却是vipshop。我想再尝试一把,不行的话,那我就放弃了。 于是我把vipshop重命名为app,build运行。查看下apk打包的内容。

done

flutter_assets终于打包进去了。 进入flutter页面也没闪退了。呜呜… 今晚终于可以安心睡个好觉了。 赶紧掏出手机叫好滴滴,打卡下班回家….

总结

整体的曲折经历上面已经说了,下面总结下具体的改动点,假设你的主工程和flutter module位于:

  • 主工程:/somepath/my_app
  • flutter module: /somepath/flutter_module

主要改动点有:

  1. flutter切到master分支,执行flutter channel master。
  2. 按照官方指引 flutter/flutter/wiki/Add-Flutter-to-existing-apps进行集成。
  3. 确保你的主工程的主module名称是app,/somepath/my_app/app。
  4. 假如你的项目使用了abi splits,确认include的是armeabi-v7a。
    splits {        abi {            enable !project.hasProperty('runx86')            reset()            include 'armeabi-v7a'             universalApk false        }    }
  1. 假设你的主项目配置了dev productFlavor,那么你需要修改 /somepath/flutter_module/.android/Flutter/build.gradle,添加dev productFlavor和buildTypes。

    productflavor

  2. 修改flutter项目 /somepath/flutter_module/.android/app/build.gradle,添加dev productFlavor

    productflavor

大功告成!!

说明
1. 本站所有资源来源于用户上传和网络,如有侵权请邮件联系站长!
2. 分享目的仅供大家学习和交流,您必须在下载后24小时内删除!
3. 不得使用于非法商业用途,不得违反国家法律。否则后果自负!
4. 本站提供的源码、模板、插件等等其他资源,都不包含技术服务请大家谅解!
5. 如有链接无法下载、失效或广告,请联系管理员处理!
6. 本站资源售价只是摆设,本站源码仅提供给会员学习使用!
7. 如遇到加密压缩包,请使用360解压,如遇到无法解压的请联系管理员
开心源码网 » 已有Android项目集成Flutter寻坑记

发表回复