Flutter与原生交互

一、Flutter交互初始化

1、初始化Method Channel,定义交互名:message Method Channel

java 复制代码
static const methodChannel = MethodChannel('messageMethodChannel');

2、flutter发起原生调用

java 复制代码
methodChannel.invokeMethod(method, arguments);

其中method为调用原生函数对应key,arguments为传递数据,可多个任意类型值;同时返回值为Future,则可通过await或者then进行回调监听:

java 复制代码
HiChannel.invokeMethod(HiChannel.PERMISSION, {
'permissions': [HiPremissionKey.ACCESS_FINE_LOCATION]
}).then((value) {
  if (value) {
    homeIsLocation(() {
       eventBus.fire(UpdateDataEvent());
       yesCallback();
   }, noCallback);
  }
});

3、flutter监听原生调用

java 复制代码
methodChannel.setMethodCallHandler((call) {
  if (call.method == TOAST) {
    toast(call.arguments);
  } else if (call.method == SHOW_LOADING) {
    showLoading();
  } else if (call.method == HIDE_LOADING) {
    hideLoading();
  }
  return Future(() => "接受成功");
});

通过调用setMethodCallHandler监听原生调用,其中call.method为调用函数对应的key,call.arguments为传递数据,可为任意类型值。并原生可监听flutter的回调;

其中flutter回调通知原生,通过return Future(() => "接受成功");实现。

二、Android原生相关

1、Main Activity继承FlutterActivity类,并实现configureFlutterEngine函数:如下:

其中优先初始化调用监听:

java 复制代码
methodChannel = MethodChannel(
    flutterEngine.dartExecutor.binaryMessenger,
    "messageMethodChannel"
)

其中messageMethodChannel为flutter初始化时定义的交互名。

2、调用监听函数setMethodCallHandler,如下:

通过call.method判断调用方法。call.argument("error")获取flutter传递数值。调用完毕后,可通过result.success(value)进行回调flutter,其中value为任意类型值。

3、Android原生调用Flutter函数代码

调用invokeMethod函数实现。其中method为调用函数key,arguments为传递参数。并监听Result回调。通过success获取。

三、IOS原生相关

1、在application中初始化iOS通信

java 复制代码
let controller : FlutterViewController = window?.rootViewController as! FlutterViewController
let channel = FlutterMethodChannel(name: "messageMethodChannel", binaryMessenger: controller.binaryMessenger)

2、调用监听函数setMethodCallHandler

java 复制代码
channel.setMethodCallHandler { (call:FlutterMethodCall, result:@escaping FlutterResult) in
    if (call.method == "sendData") {
       if let dict = call.arguments as? Dictionary<String, Any> {
           let name:String = dict["name"] as? String ?? ""
           let age:Int = dict["age"] as? Int ?? -1
          result(["name":"hello,\(name)","age":age])
      }
   }
}

其中call.method为调用函数key,call.arguments为传递参数值。并且通过result(value)进行回调,value为任意类型参数。

3、IOS原生主动向Flutter发送数据

java 复制代码
channel.invokeMethod(method, arguments:args)

👀关注公众号:Android老皮!!!欢迎大家来找我探讨交流👀

相关推荐
独行soc6 分钟前
2026年渗透测试面试题总结-17(题目+回答)
android·网络·安全·web安全·渗透测试·安全狮
金融RPA机器人丨实在智能14 分钟前
Android Studio开发App项目进入AI深水区:实在智能Agent引领无代码交互革命
android·人工智能·ai·android studio
科技块儿15 分钟前
利用IP查询在智慧城市交通信号系统中的应用探索
android·tcp/ip·智慧城市
独行soc44 分钟前
2026年渗透测试面试题总结-18(题目+回答)
android·网络·安全·web安全·渗透测试·安全狮
ujainu1 小时前
Flutter + OpenHarmony 实现经典打砖块游戏开发实战—— 物理反弹、碰撞检测与关卡系统
flutter·游戏·openharmony·arkanoid·breakout
微祎_1 小时前
构建一个 Flutter 点击速度测试器:深入解析实时交互、性能度量与响应式 UI 设计
flutter·ui·交互
王码码20351 小时前
Flutter for OpenHarmony 实战之基础组件:第二十七篇 BottomSheet — 动态底部弹窗与底部栏菜单
android·flutter·harmonyos
2501_915106321 小时前
app 上架过程,安装包准备、证书与描述文件管理、安装测试、上传
android·ios·小程序·https·uni-app·iphone·webview
vistaup2 小时前
OKHTTP 默认构建包含 android 4.4 的TLS 1.2 以及设备时间不对兼容
android·okhttp
常利兵2 小时前
ButterKnife在Android 35 + Gradle 8.+环境下的适配困境与现代化迁移指南
android