应用场景:在已有的Android原生项目中,引入Flutter模块,摸索了两天,终于给整出来了;
如果是新项目,最好直接创建Flutter项目,然后在Fluter的 android / ios目录中,写原生代码;
本文讲解 Android原生和Flutter混合开发情况下,在使用 Gradle 高版本 和 低版本 时可能出现的问题;
剧透一下,无法使用一些Gradle高版本,因为目前Flutter对高版本的Gradle并不是百分百同步。
官方指导文档:将 Flutter module 集成到 Android 项目 - Flutter 中文文档 - Flutter 中文开发者网站 - Flutter
基础配置版本:
1、Flutter版本 :3.13.2
2、Gradle版本:gradle-8.0-bin.zip
3、Android Studio 版本:2022.3.1
4、Android Studio Gradle 插件版本:8.1.1
5、原生项目由 Android Studio 2022.3.1 创建
注意:Project type 要选 Module
Ps:低版本的Android Studio,New Module 里面直接可以添加 Flutter Module,而且关连的配置代码自动生成,但高版本却没有这个 Flutter Module,比如 Android Studio 2021.4.2.2 就有,我使用的高版本 Android Studio 2022.3.1就没有,是真的坑爹!!!
至此,先将谷歌管这块的产品经理拉出去枪毙10分钟,再继续观看本文档。
将根目录下的 settings.gradle 里的代码,修改为低版本的方式;
// 高版本 方式(默认生成的)
//pluginManagement {
// repositories {
// google()
// mavenCentral()
// gradlePluginPortal()
// }
//}
//dependencyResolutionManagement {
// repositoriesMode.set(RepositoriesMode.FAIL_ON_PROJECT_REPOS)
// repositories {
// google()
// mavenCentral()
// }
//}
// 低版本 方式
rootProject.name = "AndroidInsertFlutter"
include ':app'
setBinding(new Binding([gradle: this]))
evaluate(new File(
settingsDir,
'flutter_module/.android/include_flutter.groovy'
))
将根目录下的 build.gradle 里的代码,修改为低版本的方式;
// 高版本 方式(默认生成的)
// Top-level build file where you can add configuration options common to all sub-projects/modules.
//plugins {
// id 'com.android.application' version '8.1.1' apply false
// id 'org.jetbrains.kotlin.android' version '1.9.0' apply false
//}
// 低版本 方式
// Top-level build file where you can add configuration options common to all sub-projects/modules.
buildscript {
ext.kotlin_version = "1.9.0"
repositories {
maven { url 'https://maven.aliyun.com/nexus/content/groups/public/' }
maven { url 'https://maven.aliyun.com/nexus/content/repositories/jcenter' }
maven { url 'https://maven.aliyun.com/nexus/content/repositories/google' }
maven { url 'https://maven.aliyun.com/nexus/content/repositories/gradle-plugin' }
google()
mavenCentral()
}
dependencies {
classpath "com.android.tools.build:gradle:8.1.1"
classpath "org.jetbrains.kotlin:kotlin-gradle-plugin:$kotlin_version"
// NOTE: Do not place your application dependencies here; they belong
// in the individual module build.gradle files
}
}
allprojects {
repositories {
maven { url 'https://maven.aliyun.com/nexus/content/groups/public/' }
maven { url 'https://maven.aliyun.com/nexus/content/repositories/jcenter' }
maven { url 'https://maven.aliyun.com/nexus/content/repositories/google' }
maven { url 'https://maven.aliyun.com/nexus/content/repositories/gradle-plugin' }
google()
mavenCentral()
jcenter() // Warning: this repository is going to shut down soon
}
}
task clean(type: Delete) {
delete rootProject.buildDir
}
project 就写 flutter,不要写成 flutter_module,做完这4步,Sync gradle;
dependencies {
implementation project(':flutter')
... ...
}
为什么要将 settings.gradle 和 build.gradle 里的代码改为低版本方式,因为flutter内嵌android项目的gradle版本,有极大概率会低于原生项目的gradle版本,我使用的Flutter版本是 3.13.2,已经算很新了,实际开发中很少用到最新版本,目前最新的beat版本也才3.19.0,如果不修改为低版本代码方式,可能会出现以下异常:
PluginApplicationException
网上的解决方案:是将 RepositoriesMode.FAIL_ON_PROJECT_REPOS 改为 RepositoriesMode.PREFER_PROJECT,然并卵,直接引发第二个异常。
依赖下载失败
原生项目中的Gradle 和 Flutter中android的Gradle,发生版本冲突,高版本测试到这步被终结了。
当我解决了前两个异常,以为可以顺利运行时,结果卡在这,目前找到的解决方案,都是降低Gradle版本;
基础配置版本:
1、Flutter版本 :3.13.2
2、Gradle版本:gradle-6.7.1-bin.zip
3、Android Studio 版本:2021.4.2.2
4、Android Studio Gradle 插件版本:4.2.2
5、原生项目由 Android Studio 2021.4.2.2 创建
创建完原生项目后,先运行一下,因为可能一些版本差异导致出现异常;
每个Android Studio版本,都有一个最小和最大Gradle版本的限制,我尝试将Android原生的Gradle版本,改成和Flutter内嵌android的Gradle版本一致。结果它提示我升级Android Studio;
这些警告的意思是,想让我升级Gradle版本,直接忽略,不影响运行。
注意:创建完成后,先独立运行一下Flutter项目,检查是否正常,比如可能需要设置Flutter SDK;
在Project Location 处只需要进入Android原生项目根目录下即可,它会自动生成 flutter项目的目录,默认项目名为 flutter_module;
正确路径:xxx/xxx/Android原生项目根目录
错误路径:xxx/xxx/Android原生项目根目录/flutter_module
这待遇怎么到了高版本Android Studio就没了呢???
来人,再把相关产品经理拉出去枪毙10分钟!!!
将 MainActivity 改为 FlutterActivity;
GitHub - LanSeLianMa/AndroidAddFlutter: Android原生项目引入Flutter模块的简单案例
目前 Android原生混合Flutter 最佳开发方案:
如果是新项目,最好直接创建Flutter项目,然后在Fluter的 android / ios目录中,写原生代码;
如果是已有Android原生项目引入Flutter,注意一下原生项目的Gradle版本,如果不能降低,那就尝试使用高版本的Flutter,因为Flutter版本越高,它内嵌android的Gradle版本就越高;
各版本Android Studio仓库地址:Android Studio download archives | Android Developers
Ps:免安装版本,就是下载下来就能用,不会覆盖你当前电脑上原有的Android Studio,这样一台电脑上,就有多个不同版本的Android Studio,可以切换使用。
Android Studio 2021.4.2.2 免安装版本 + Window版本
https://redirector.gvt1.com/edgedl/android/studio/ide-zips/4.2.2.0/android-studio-ide-202.7486908-windows.zip
Android Studio 2021.4.2.2 免安装版本 + Mac版本
https://redirector.gvt1.com/edgedl/android/studio/ide-zips/4.2.2.0/android-studio-ide-202.7486908-mac.zip