当前位置: 首页 > news >正文

原生安卓与flutter混编的实现

方案一

  1. 打开顶部窗口Flie->New->New Flutter Project。打开后如下
    在这里插入图片描述
    此处的flutter sdk可自行下载,不做赘述。
  2. 选好sdk后点击下一步。
    在这里插入图片描述
    此处的Project location为原生安卓根目录,Project type为Module.
    亦可在原生安卓项目根目录下打开Terminal执行以下命令。
flutter create -t module --org com.example flutter_module
  1. 创建好之后打开flutter项目下的Terminal。
    在这里插入图片描述
  2. 在终端中输入flutter pub get获取flutter依赖。
flutter pub get

在这里插入图片描述
5. 在原生安卓项目的settings.gradle文件中添加flutter_module,添加到末尾即可。

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

在这里插入图片描述
其中flutter_module为flutter的项目名。

  1. 在原生安卓的app下build.gradle中添加依赖。
implementation project(':flutter')

在这里插入图片描述
此时同步项目会发现有如下报错。
在这里插入图片描述

  1. 在原生安卓项目的settings.gradle中将repositoriesMode设置为PREFER_SETTINGS再次同步即可。
repositoriesMode.set(RepositoriesMode.PREFER_SETTINGS)

在这里插入图片描述
同步完之后会发现缺少io.flutter的包,此时即便运行也会包一样的错误。

  1. 在原生安卓项目的settings.gradle中引入io.flutter的仓库,再次同步即可,完整内容如下。
pluginManagement {repositories {google()mavenCentral()maven{ url 'https://maven.aliyun.com/repository/jcenter' }maven{url 'https://api.mapbox.com/downloads/v2/releases/maven'authentication {basic(BasicAuthentication)}credentials {// Do not change the username below.// This should always be `mapbox` (not your username).username = "mapbox"// Use the secret token you stored in gradle.properties as the passwordpassword = MAPBOX_DOWNLOADS_TOKEN}}maven {url 'https://jitpack.io'}maven {url 'https://developer.huawei.com/repo/'}maven { url 'https://repo1.maven.org/maven2/' }gradlePluginPortal()String storageUrl = System.env.FLUTTER_STORAGE_BASE_URL ?: "https://storage.googleapis.com"maven {url "$storageUrl/download.flutter.io"}}
}
dependencyResolutionManagement {repositoriesMode.set(RepositoriesMode.PREFER_SETTINGS)repositories {google()mavenCentral()maven{ url 'https://maven.aliyun.com/repository/jcenter' }maven{url 'https://api.mapbox.com/downloads/v2/releases/maven'authentication {basic(BasicAuthentication)}credentials {// Do not change the username below.// This should always be `mapbox` (not your username).username = "mapbox"// Use the secret token you stored in gradle.properties as the passwordpassword = MAPBOX_DOWNLOADS_TOKEN}}maven {url 'https://jitpack.io'}maven {url 'https://developer.huawei.com/repo/'}maven { url 'https://repo1.maven.org/maven2/' }String storageUrl = System.env.FLUTTER_STORAGE_BASE_URL ?: "https://storage.googleapis.com"maven {url "$storageUrl/download.flutter.io"}}}
rootProject.name = "HuidaPartner"
include ':app'
include ':libbase'
include ':HttpMqtt'
include ':map'setBinding(new Binding([gradle: this]))
evaluate(new File(settingsDir,'flutter_module/.android/include_flutter.groovy'
))include ':flutter_module'
  1. 此时在原生安卓的代码中添加跳转至flutter页面就没有什么问题了。
val intent: Intent = FlutterActivity.createDefaultIntent(activity)
activity.startActivity(intent)

上述时一个简单的跳转至flutter主界面。

方案二
上述方案一是针对较老的flutter sdk的,对于新版本的sdk官方推荐的方式是以aar的方式引用。引用的方式是以maven仓库的形式。针对maven仓库,本选用本地maven仓和远程maven仓,本文只简单介绍本地maven仓的方式。

  1. 参照方案一的步骤,直至到第4步,创建好flutter_module项目,之后在flutter_module下打开Terminal,输入
flutter build aar

在这里插入图片描述

在等待一段时间后,会在flutter_module项目的/flutter_module/build/host/outputs/repo目录下生成flutter_debug、flutter_profile、flutter_release三个文件,如下所示。
在这里插入图片描述
是不是感觉这个目录结构很眼熟,没错,这结构就是典型的maven仓库的结构,对应的文件也是一应俱全。不熟悉maven本地仓库的可以参考:安卓本地Maven仓的实现这篇文章。

  1. 由于是使用本地代码仓的缘故,flutter_module项目又在我们的原生项目下,可以在settings.gradle中直接引用本地仓库。
		maven {url uri("file://${settingsDir}/flutter_module/build/host/outputs/repo")}
  1. 接下来在build.gradle中按照正常的依赖格式引用即可。
    debugImplementation 'com.example.flutter_module:flutter_debug:1.0'releaseImplementation 'com.example.flutter_module:flutter_release:1.0'

在这里插入图片描述

此处我只引用的debug包和release包,正常情况下我们只需要使用到这两个包。

  1. 当然,io:flutterde的包的引用也是必不可少的,在settings.gradle中引入对应的maven仓
    String storageUrl = System.env.FLUTTER_STORAGE_BASE_URL ?: "https://storage.googleapis.com"maven {url "$storageUrl/download.flutter.io"}
  1. 在完成上述条件后,原生项目在需要的地方直接跳转flutter项目即可。
val intent: Intent = FlutterActivity.createDefaultIntent(activity)
activity.startActivity(intent)

如果想使用远程maven仓的形式,可以参考:安卓使用Gitee搭建远程Maven仓,完成远程maven仓的搭建后,在settings.gradle将仓库替换即可。

http://www.lryc.cn/news/606078.html

相关文章:

  • 是否需要买一个fpga开发板?
  • 嵌入式硬件学习(十)—— LED驱动+杂项设备驱动
  • 【Unity】实现小地图
  • TDengine 中 TDgp 中添加算法模型(异常检测)
  • 【大模型理论篇】跨语言AdaCOT
  • Flutter 页面跳转及传参总结
  • 8.2-使用字符串存储 UTF-8 编码文本
  • RAG:让AI更聪明的“外接大脑“ | AI小知识
  • ECMAScript2023(ES14)新特性
  • C# 基于halcon的视觉工作流-章27-带色中线
  • HTM 5 的离线储存的使用和原理
  • JavaEE初阶1.0
  • 认知绞肉机:个体实践视域下认知暴力与元认知升维的活体实验研究
  • 今日做题练习
  • 记录自己使用gitee和jenkins
  • PHP 核心特性全解析:从实战技巧到高级应用(2)
  • 按键精灵iOS工具元素命令SetText:自动化输入的终极解决方案
  • .NET Core部署服务器
  • Linux网络-------3.应⽤层协议HTTP
  • Java 大视界 -- Java 大数据在智能交通公交客流预测与线路优化中的深度实践(15 城验证,年省 2.1 亿)(373)
  • 快速搭建Node.js服务指南
  • 前端核心技术Node.js(四)——express框架
  • 8,FreeRTOS时间片调度
  • RPA-重塑企业自动化流程的智能引擎
  • 《能碳宝》AI辅助开发系统方案
  • 免费语音识别(ASR)服务深度指南​
  • 深入解析域名并发请求限制与HTTP/2多路复用技术
  • 电脑远程关机的重要性
  • vue3+arcgisAPI4示例:轨迹点模拟移动(附源码下载)
  • 实战教程 ---- Nginx结合Lua实现WAF拦截并可视化配置教程框架