当前位置:   article > 正文

Flutter与Android混合编码配置笔记

android flutter混编怎么配置

学习Flutter一小段时间,对纯Flutter项目有了一些基本的了解,但更趋近实际开发的应该是将Flutter模块作为一个依赖库添加到原生的Android项目中。

本文笔者将尝试分享个人针对FlutterAndroid混编时的配置步骤,以及踩坑过程。

一、初始化Flutter-Module

参考 官方文档 ,首先需要确认Flutter-Module依赖库文件夹的位置,简单来说,这里有两种方式:

  • 1.创建在项目的根目录下(内部);
  • 2.创建和项目文件夹的同一层级(外部),这也是官方推荐的方式。

其实这些方式没什么区别,但是个人更倾向于第二种,我们在项目文件夹的目录层级下对Flutter-Module文件夹进行 创建初始化

  1. $ flutter create -t module module_flutter
  2. 复制代码

成功后,Flutter-ModuleAndroid项目本身应该是这样的(红框内的两个项目):

二、配置Android项目

接下来我们需要将这个项目和刚刚创建的module-flutter进行依赖,我们先打开Android原生项目,并为项目根目录下的settings.gradle文件中添加如下配置:

  1. setBinding(new Binding([gradle: this]))
  2. evaluate(new File(
  3. settingsDir.parentFile,
  4. 'module_flutter/.android/include_flutter.groovy'
  5. ))
  6. 复制代码

如果module-flutter模块是创建在项目内部,那么需要稍微改一改:

  1. setBinding(new Binding([gradle: this]))
  2. evaluate(new File(
  3. settingsDir.path,
  4. 'module_flutter/.android/include_flutter.groovy'
  5. ))
  6. 复制代码

然后,我们需要打开appbuild.gradle文件,添加对flutter的依赖:

  1. dependencies {
  2. implementation fileTree(dir: 'libs', include: ['*.jar'])
  3. implementation 'androidx.appcompat:appcompat:1.0.0'
  4. implementation 'androidx.annotation:annotation:1.0.0'
  5. ......
  6. implementation project(':flutter')
  7. }
  8. 复制代码

这样,对于简单的Android原生项目而言,Flutter已经配置成功了。

三、AndroidX的迁移

由于笔者的项目迁移了AndroidX, 但是低版本的Flutter命令生成的module默认依赖的是support包, 因此我们需要将默认support的依赖手动迁移到AndroidX

截止笔者发文前,FlutterV1.7已经提供了对AndroidX的支持,当创建 Flutter 项目的时候,你可以通过添加 --androidx 来确保生成的项目文件支持AndroidX,详情参考这里

手动迁移的方式有两种:

  • 1.通过Android Studio 自动迁移 过去。

首先通过Android Studio打开flutter-module,这时候是不能直接迁移AndroidX的,需要通过flutter - Open Android module in AS 方式新打开一个窗口。

这样编译成功后,就可以点击Refactor - Migrate to AndroidX进行迁移了,后续步骤网上有很多,不赘述。

  • 2.手动配置过去,这个方式也很简单,打开Flutter-build.gradle文件,对依赖进行更新:
  1. android {
  2. //...
  3. defaultConfig {
  4. // ...
  5. testInstrumentationRunner "androidx.test.runner.AndroidJUnitRunner"
  6. }
  7. // ...
  8. }
  9. dependencies {
  10. testImplementation 'junit:junit:4.12'
  11. implementation 'androidx.appcompat:appcompat:1.0.0'
  12. implementation 'androidx.annotation:annotation:1.0.0'
  13. // ...
  14. }
  15. 复制代码

手动配置网上有很多博客,不赘述。

需要注意的是,一定要保证Flutter模块中对AndroidX相关依赖的版本和实际原生项目中相关依赖的版本是一致的,否则可能会导致依赖冲突。

四、多模块项目的配置

上文说到,简单的项目已经配置完毕了,但是多模块的项目来说则稍显复杂,比如笔者的项目:

首先,需要在底层library(本文中是library-core)的build.gradle文件中添加对flutter的依赖:

  1. dependencies {
  2. // ...
  3. api project(':flutter')
  4. }
  5. 复制代码

添加之后并进行同步,原生的项目就会对settings.gradle文件中指向的module-flutter文件夹进行依赖。

同步、编译成功后,我运行了项目,但我很快遇到了问题:

  1. [ERROR:flutter/runtime/dart_vm_data.cc(19)] VM snapshot invalid and could not be inferred from settings.
  2. [ERROR:flutter/runtime/dart_vm.cc(241)] Could not setup VM data to bootstrap the VM from.
  3. [ERROR:flutter/runtime/dart_vm_lifecycle.cc(89)] Could not create Dart VM instance.
  4. [FATAL:flutter/shell/common/shell.cc(218)] Check failed: vm. Must be able to initialize the VM.
  5. 复制代码

这个问题纠结了很久,最后在 这个issue中 找到了答案:

@yk3372 大佬提示,原来是以为项目中配置了ProductFlavors, 因此,Flutter模块中对应的build.gradle文件也需要进行对应的配置,比如这样:

  1. buildTypes {
  2. release {}
  3. debug {}
  4. }
  5. flavorDimensions "environment"
  6. productFlavors {
  7. dev {}
  8. qa {}
  9. prod {}
  10. }
  11. 复制代码

配置好之后,还需要手动将相关moduleProductFlavors配置相同,否则会提示一堆错误,比如我的一个原生的module依赖了fluttermodule,它们就必须都保持同一个状态:

???这是不是意味着所有的modulebuild.gradle都配置相同的productFlavors信息?

实践给予我答案,是的。

虽然折腾了很久,还好前人栽树,后人乘凉,解决了问题还是happy ending, Github大法好。

最后:更多Flutter混合开发姿势

本文提供了 官方文档 提供混合开发的集成方式,实际上,国内很多大厂都分享过相关的技术文章,这里也一并放出来:


关于我

Hello,我是却把清梅嗅,如果您觉得文章对您有价值,欢迎 ❤️,也欢迎关注我的博客或者Github

如果您觉得文章还差了那么点东西,也请通过关注督促我写出更好的文章——万一哪天我进步了呢?

转载于:https://juejin.im/post/5d2726f1f265da1b855c81da

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/知新_RL/article/detail/515368
推荐阅读
相关标签
  

闽ICP备14008679号