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老皮!!!欢迎大家来找我探讨交流👀

相关推荐
码途漫谈几秒前
Easy-Vibe高级开发篇阅读笔记(十三)——多平台开发之Android App 原生开发
android·人工智能·笔记·ai·开源·ai编程
街灯L2 分钟前
【ADB】使用ADB工具箱卸载安卓系统软件
android·adb
赏金术士10 分钟前
Kotlin 从入门到进阶 之泛型 模块(七)
android·开发语言·kotlin
恋猫de小郭1 小时前
经典,Flutter iOS 又修复了一个构建问题,还是很抽象
android·前端·flutter
Kapaseker1 小时前
不吹牛逼!精通 Compose 绘制(一)
android·kotlin
黄林晴1 小时前
Android 终于做桌面了,而三星 DeX 早已把路趟完
android
Digitally1 小时前
如何连接安卓手机到 Mac?2026 年 7 种可靠方法
android·macos·智能手机
克里斯蒂亚诺更新1 小时前
Android Studio的运行一个简单的apk和模拟器
android·ide·android studio
克里斯蒂亚诺更新1 小时前
android studio导出apk
android·ide·android studio
鹏晨互联1 小时前
《Jetpack Compose vs 传统 XML:一个纯色+渐变色背景的直观对比》
android