Flutter 与原生交互之BasicMessageChannel

该方式可以实现双向通道, 感觉适用于Android或ios的数据需要实时刷新在ui上,碎片连续性的消息传递。

直接上效果图

 

 

直接上代码 首先是Flutter端  分为2步 

1.发送消息,获取回调

首先获取 BasicMessageChannel 的对象,注册消息通道,原生端也要注册,字符串必须跟原生一致

 static const messageChannel = const BasicMessageChannel(
      'com.demo.test.messageChannel', StandardMessageCodec());

然后Flutter发送消息到原生,并接收原生函数的回调。

Map<String, String> map = {
     "text": "BasicMessageChannel 发送了一条消息给原生",
};
String message = await MethodChannelManage.messageChannel.send(map);

2.监听原生端主动发送的消息

注册监听

MethodChannelManage.messageChannel.setMessageHandler((message){
      // 这个message就是原生发送的消息
    });

接下来是Android端的代码


  public static String BASIC_MESSAGE_CHANNEL = "com.demo.test.messageChannel";

  static BasicMessageChannel basicMessageChannel;

  public static void registerWith(PluginRegistry.Registrar registrar) {
        basicMessageChannel = new BasicMessageChannel<>(registrar.messenger(), BASIC_MESSAGE_CHANNEL, StandardMessageCodec.INSTANCE);
        //setMethodCallHandler在此通道上接收方法调用的回调
        basicMessageChannel.setMessageHandler(new BasicMessageChannel.MessageHandler() {
            @Override
            public void onMessage(Object message, BasicMessageChannel.Reply reply){
                Map<String, String> arguments = (Map<String, String>) message;
                String str = arguments.get("text");
                reply.reply("Android接收到Flutter返回的消息:" + str + "  单次函数回调");
                androidToFlutter();
            }
        });
    }

 private static void androidToFlutter() {
    basicMessageChannel.send("Android主动发送消息,Flutter监听。消息 " + duration);
 }

然后是ios端的代码

-(void) BasicMessageChannelFunction{
    //获取当前的 controller
    FlutterViewController* controller = (FlutterViewController*)self.window.rootViewController;
    messageChannel = [FlutterBasicMessageChannel messageChannelWithName:@"com.demo.test.messageChannel" binaryMessenger:controller];
    
    // 接收消息监听
    [messageChannel setMessageHandler:^(id message, FlutterReply callback) {
        
        NSString *method=message[@"text"];
        
        NSMutableDictionary *dic = [NSMutableDictionary dictionary];

        callback(@"IOS接收到Flutter返回的消息: 单次函数回调");
        
        [messageChannel sendMessage:@"IOS主动发送消息,Flutter监听"];
    }];
    
}

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
FlutterAndroid交互可以通过平台通道(platform channel)来实现。平台通道允许Flutter应用程序与原生Android代码之间进行双向通信。 以下是使用平台通道进行FlutterAndroid交互的一般步骤: 1. 在Flutter应用程序中,使用`flutter create`命令创建一个新的Flutter项目,或者在现有项目中添加一个新的Android模块。 2. 在Flutter应用程序中创建一个`MethodChannel`对象,该对象用于在FlutterAndroid之间进行方法调用通信。例如,在Dart代码中添加以下代码: ```dart import 'package:flutter/services.dart'; // 创建 MethodChannel 对象 MethodChannel channel = MethodChannel('com.example.channelName'); // 在需要的地方调用原生 Android 方法 Future<void> callNativeMethod() async { try { final String result = await channel.invokeMethod('methodName'); print(result); } catch (e) { print('Error: $e'); } } ``` 3. 在Android项目中,创建一个类来处理来自Flutter应用程序的方法调用。例如,在Java代码中添加以下代码: ```java import io.flutter.app.FlutterActivity; import io.flutter.plugin.common.MethodChannel; import io.flutter.plugin.common.MethodCall; import io.flutter.plugin.common.MethodChannel.MethodCallHandler; import io.flutter.plugin.common.MethodChannel.Result; public class MainActivity extends FlutterActivity { private static final String CHANNEL = "com.example.channelName"; @Override public void configureFlutterEngine(FlutterEngine flutterEngine) { super.configureFlutterEngine(flutterEngine); // 注册方法调用处理器 new MethodChannel(flutterEngine.getDartExecutor().getBinaryMessenger(), CHANNEL) .setMethodCallHandler(new MethodCallHandler() { @Override public void onMethodCall(MethodCall call, Result result) { if (call.method.equals("methodName")) { // 处理来自Flutter的方法调用 String response = someNativeMethod(); result.success(response); } else { result.notImplemented(); } } }); } // 原生 Android 方法的实现 private String someNativeMethod() { // 实现自己的逻辑 return "Response from Android"; } } ``` 在上述代码中,我们首先定义了一个与Flutter应用程序通信的通道名称(CHANNEL),然后注册了一个方法调用处理器。当Flutter应用程序调用`methodName`方法时,处理器将调用`someNativeMethod`方法并返回响应。 4. 最后,您可以在Flutter应用程序中调用`callNativeMethod`方法,这将触发与Android交互,并返回来自Android的响应。 请注意,上述代码只是示例,并且可以根据您的需求进行修改和扩展。此外,您还可以使用平台通道传递参数和接收回调,以实现更复杂的交互逻辑。 这是使用平台通道在FlutterAndroid之间进行基本交互的基本步骤。希望对您有所帮助!如果有任何进一步的问题,请随时提问。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值