在之前的文章鸿蒙Flutter实战:09-现有Flutter项目支持鸿蒙中,介绍了如何改造项目,适配鸿蒙平台。
文中讲述了整体的理念和思路,本文更进一步,结合可实操的项目代码,详细说明如何实施。
通过模块化、鸿蒙壳工程,结合 FVM 管理多版本 Flutter SDK,最终,保持原 Flutter 代码纯净,最小化修改,完成了鸿蒙化的适配示例。
本项目代码地址: https://gitee.com/zacks/flutter-ohos-demo
dart pub global activate melos
分别安装官方的3.22版本,以及鸿蒙社区的 3.22.0 版本
参考文章《鸿蒙Flutter实战:01-搭建开发环境》
# 创建项目目录
mkdir flutter-ohos-demo
设置使用的 Flutter SDK 版本
推荐在 VsCode 的命令行中执行以下命令,这将创建 .fvm 目录, .vscode/setting.json 文件, 和.fvmrc 文件
fvm use 3.22.0
创建目录,项目结构如下所示:
.
├── packages
│ ├── apps #该目录用于存放各端应用壳工程
│ ├── common #该目录用于存放公共库,均为纯 dart 代码,不依赖于 ios/android 等原生实现
│ │ ├── domains #领域对象,存放各类实体文件,如枚举/模型/vo/事件等
│ │ ├── extensions #存放扩展类文件,对于类的扩展方法/属性
│ │ ├── services #服务类:如请求服务/授权服务/缓存服务/平台调用服务/路由服务/工具类等
│ │ └── widgets #通用小型 widgets, 纯dart编写的 Flutter UI 组件
│ ├── components #封装组件库,可以依赖于第三方库/第三方插件,或依赖于 plugins中的插件
│ │ ├── image_uploader
│ │ └── player
│ ├── modules
│ │ ├── address
│ │ ├── home
│ │ ├── me
│ │ ├── message
│ │ ├── order
│ │ ├── shop
│ │ └── support
│ └── plugins #插件库,自行封装的插件库,依赖于原生平台(ios/android)的代码
│ └── printer
├── README.md
├── melos.yaml
└── pubspec.yaml
melos bootstrap
在各个 package 初始化代码,如在 packages/common/domains
目录运行
fvm flutter create --template package .
新建两个壳工程,一个为 app,另外一个为 ohos_app
进入 package/apps/app
目录, 创建 app 项目,该项目为一个 App 项目,用于各平台(ios/android/mac 等, 不包含鸿蒙)打包
fvm flutter create --template app --org com.moguyun.flutter app
修改 pubspec.yaml,添加以下内容
services:
path: '../../common/services'
domains:
path: '../../common/domains'
widgets:
path: '../../common/widgets'
home:
path: '../../modules/home'
me:
path: '../../modules/me'
support:
path: '../../modules/support'
运行以下命令,安装依赖
fvm flutter pub get
首先在 flutter-ohos-demo 项目根目录,将 Flutter 版本切换到鸿蒙化的版本
fvm use custom_3.22.0
SDK 变更以后,需要重启 IDE (或者 Dart:Restart Analysis Server),以便让 Flutter 插件重启
进入 packages/apps 目录,创建 ohos_app 项目
fvm flutter create --template app --platforms ohos --org com.moguyun.flutter ohos_app
进入 packages/apps/ohos_app 目录中的 pubspec.yaml, 同样增加依赖项
services:
path: '../../common/services'
domains:
path: '../../common/domains'
widgets:
path: '../../common/widgets'
home:
path: '../../modules/home'
me:
path: '../../modules/me'
support:
path: '../../modules/support'
编辑 pubspec.yaml文件,增加以下配置,通过 dependency_overrides 来替换鸿蒙化的三方库,注意鸿蒙化的库与原库,保持版本统一
# 鸿蒙适配
dependency_overrides:
flutter_inappwebview:
git:
url: https://gitee.com/openharmony-sig/flutter_inappwebview.git
path: "flutter_inappwebview"
每次修改完 pubspec.yaml,使用
fvm flutter pub get
更新下依赖安装。
用 Deveco 打开apps/ohos_app/ohos 目录。
在 Deveco 左上角 打开 File -> Project Structure..., 点击 Siging Configs, 勾选 Automatically generate signature, 对鸿蒙项目签名。
在 ohos_app 目录下,使用 fvm flutter run,或者点击运行按钮,运行flutter项目。
sdkPath: .fvm/flutter_sdk
配置了 melos 使用的 flutter SDK 版本,即由FVM 配置的当前项目版本如何判断三方库是否需要鸿蒙化,简而言之,如果三方库由纯 Dart 实现,则不需要单独适配,直接使用;如果三方库依赖系统底层实现,则需要鸿蒙化适配。
三方库的适配情况,可以查询 Gitee/Github,或者查阅表格 Flutter三方库适配计划
ohos/oh-package.json5
1.jpeg
640.jpeg
640 (1).jpeg
dependency_overrides
配置,逐个替换鸿蒙化的三方库