YHFlutterAdapter
YHFlutterAdapter copied to clipboard
Componentized Flutter requires only three lines of code! 三行代码组件化集成 Flutter!可用于已有 iOS 项目,对原工程无侵入,无需更改原项目配置,集成后可直接以组件形式开发 Flutter 业务。
YHFlutterAdapter 
三行代码组件化集成 Flutter!可用于已有 iOS 项目,对原工程无侵入,无需更改原项目配置,集成后可直接以组件形式开发 Flutter 业务。
结构图
层级

依赖关系

| 模块 | 描述 |
|---|---|
| YHFlutterAdapter | 负责 Flutter 功能与原生端代码的隔离解耦,并提供一定的插件注册功能,该模块对 YHFlutterSDK 以及 YHFlutterPlugin 无依赖关系,并且其中的功能应逐渐下沉为通用功能,可供多个业务线直接复用。 |
| YHFlutterSDK | 存放 Flutter 项目编译后生成的产物,各个业务线可针对于自己的 Flutter 项目需求来生成对应的独立产物,与 YHFlutterAdapter 和 YHFlutterPlugin 组装使用。 |
| YHFlutterPlugin | 主要配合 YHFlutterAdapter 实现部分桥接方法与插件的功能。可创建多个,一些用于提供通用基础桥接功能,另一些专门用于具体特定业务实现逻辑,上层项目选择性的引入即可。 |
多业务线复用

YHFlutterAdapter 、YHFlutterSDK 、YHFlutterPlugin1、YHFlutterPlugin2 ... 可以按照自身业务线的需要选择性的组合使用。
集成方式
Podfile 内添加
pod 'YHFlutterAdapter' # :podspec => 'xxx' or :path => 'xxx'
pod 'YHFlutterSDK' # :podspec => 'xxx' or :path => 'xxx'
pod 'YHFlutterPlugin' # :podspec => 'xxx' or :path => 'xxx'
具体集成细节,podspec指向等可参照项目内 Demo 。
使用方式
1. 添加引用
#import <YHFlutterAdapter/YHFlutterModule.h>
2. 加载 Flutter 界面的两种方式
- 在项目内直接显示调用
UIViewController *flutterViewController = [[YHFlutterModule service] flutterViewControllerForKey:@"XXXX" properties:nil];
[self presentViewController:flutterViewController animated:YES completion:nil];
- 【推荐】将
YHFlutterModule注册进项目内已有的组件化服务内并调用YHFlutterServiceProtocol的相关方法使用
3. 扩增与 Flutter 交互的桥接方法,或者添加新的 Plugin 的两种方式
- 可参照 Demo 内的
YHFlutterFeatureChannel,具体的业务使用方在上层项目内可自行注册监听并处理自己需要的消息; - 也可参照
YHFlutterPlugin编写新的 pod 仓库组件独立实现;
4. Plugin & Channel 注册的三种方式
- 【推荐】将
YHFlutterModule注册进项目已有的组件化服务内,并调用YHFlutterServiceProtocol的相关方法进行注册 [[YHFlutterModule service] registMethodChannelHandler:self.class];[YHFlutterRegistrant registMethodChannelHandler:self.class];
5. YHFlutterSDK 内产物更新方式
自动更新【建议】
编写对应的脚本实现 编译-转移产物-更新到远端 Pod 的操作,同时将 YHFlutterPlugin 中需要添加的依赖类自动更新并注册进 YHFlutterAdapter
手动更新
- Flutter 工程目录下
./.ios/内对应工程的 BundleId 以及证书更换为当前电脑中任何一个可用的,保证通过编译 - Flutter 工程目录下使用
flutter build iosorflutter build ios --debug命令生成对应的releaseordebug版本的产物 - cd 到
./.ios/Flutter/目录下将对应的三个产物更换到 YHFlutterSDK 内
更新产物库版本号可能会遇到的问题:
issue:pod lib lint 将产物更新至私有库, i386 验证不通过问题讨论
示例图(请使用真机运行该 Demo)

| 功能 | 实现类 | channelName |
|---|---|---|
Read feature description |
YHFlutterFeatureChannel.m业务层内实现 |
yaheng.feature.flutter.bridge |
Write log file |
YHFlutterLogChannel.mYHFlutterPlugin 内实现 |
yaheng.base.flutter.bridge |
Client HTTP request |
YHFlutterHttpChannel.mYHFlutterPlugin 内实现 |
yaheng.base.flutter.bridge |
Close |
YHFlutterPageChannel.mYHFlutterAdapter 内实现 |
yaheng.base.flutter.bridge |
部分代码使用示例
只要在具体类内部实现相应方法即可,不需要外部任何调用。

LICENSE
All source code is licensed under the MIT License.