Android项目引入Flutter

博客介绍了在老项目中实现Flutter与Android混编的方法。包括创建Flutter模块,可通过特定命令创建,编译后会生成相关aar文件;主APP依赖Flutter Module,需处理minSdkVersion不一致问题并添加jdk1.8支持;还提到在main.dart中添加路由以点击显示flutter view。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

创建Flutter模块

假如老项目目录在/Users/xq/Android/Projects/NativeFlutter/
cd ..切换到上目录执行flutter create -t module flutter_module

上面的命令会创建一个flutter的项目模块,
在这里插入图片描述
在flutter_module文件夹中有一个.android的隐藏文件夹,里面包裹了一个安卓库的工程模块。
可以使用如下命令编译,不编译也可以

cd .android/
./gradlew flutter:assembleDebug

编译后会在.android/Flutter/build/outputs/aar/路径下产生flutter-debug.aar的文件。

主 APP 依赖 Flutter Module

再app的module导入flutter

dependencies {
  implementation project(':flutter')
}

在这里插入图片描述
uses-sdk:minSdkVersion 与 Flutter Module 的不一致。改一下项目的minSdkVersion 即可。
在这里插入图片描述
appde Module添加jdk1.8支持

android {
   ...
    compileOptions {
        sourceCompatibility JavaVersion.VERSION_1_8
        targetCompatibility JavaVersion.VERSION_1_8
    }
    ...
}

在这里插入图片描述
settings.gradle中加入

include ':app'
setBinding(new Binding([gradle:this]))
evaluate(new File(
        settingsDir.parentFile,'flutter_module/.android/include_flutter.groovy'
))

点击显示flutter view

    fun showFlutter(v: View) {
        val flutterView = Flutter.createView(this@MainActivity, lifecycle, "route1")
        val layout = FrameLayout.LayoutParams(600, 800)
        layout.leftMargin = 100
        layout.topMargin = 200
        addContentView(flutterView, layout)
    }

main.dart中添加路由

void main() => runApp(_widgetForRoute(window.defaultRouteName));

Widget _widgetForRoute(String route) {
  switch (route) {
    case 'route1':
      return MyHomePage();
    default:
      return Center(
        child: Text('Unknown route: $route', textDirection: TextDirection.ltr),
      );
  }
}

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值