Flutter和原生交互---EventChannel

本文介绍了如何使用Flutter的EventChannel在Android原生代码和Flutter之间进行事件通信。通过创建一个单例类实现EventChannel,监听Android的重力感应等状态变化,并将这些事件通知给Flutter端,实现原生与Flutter的一对多广播通知功能。在Flutter应用的MainActivity中注册通信类,并在Flutter端订阅事件通道,接收到事件后打印输出。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

EventChannel,用于Android原生事件流向Flutter端的发送,例如通过原生监听重力感应等状态变化后向Flutter发送通知,一对多通知,类似于原生广播

原生端实现代码:

1.实现EventChannel:单例类,通过sendEventData通知Flutter

package com.example.flutter_event_channel_plugin;

import android.util.Log;

import androidx.annotation.NonNull;

import io.flutter.embedding.engine.plugins.FlutterPlugin;
import io.flutter.plugin.common.EventChannel;

public class FlutterEventChannel implements FlutterPlugin, EventChannel.StreamHandler {
    public static final String CHANNEL_NAME = "event_channel_name";
    private EventChannel eventChannel;
    private EventChannel.EventSink eventSink;

    private static volatile FlutterEventChannel instance;

    private FlutterEventChannel () {
    }

    public static FlutterEventChannel getInstance() {
        if (instance == null) {
            synchronized (FlutterEventChannel .class) {
                if (instance == null) {
                    instance = new FlutterEventChannel ();
                }
            }
        }
        return instance;
    }

    /**
     * 处理设置事件流的请求。
     *
     * @param arguments 流配置参数,可能为空。
     * @param events    用于向flutter接收器发射事件。
     */
    @Override
    public void onListen(Object arguments, EventChannel.EventSink events) {
        this.eventSink = events;
    }

    /**
     * 处理请求以删除最近创建的事件流。
     *
     * @param arguments 流配置参数,可能为空。
     */
    @Override
    public void onCancel(Object arguments) {

    }

    public void sendEventData(Object data) {
        if (eventSink != null) {
            eventSink.success(data);
        }
    }

    @Override
    public void onAttachedToEngine(@NonNull FlutterPlugin.FlutterPluginBinding binding) {
        eventChannel = new EventChannel(binding.getBinaryMessenger(), CHANNEL_NAME);
        eventChannel.setStreamHandler(this);
    }

    @Override
    public void onDetachedFromEngine(@NonNull FlutterPlugin.FlutterPluginBinding binding) {
        eventSink.endOfStream();
        eventChannel.setStreamHandler(null);
    }
}

2.注册通信类:需要注意的是这里的FlutterActivity是io.flutter.embedding.android包下的

FlutterEventChannel 

package com.example.example;

import android.os.Bundle;

import com.example.FlutterEventChannel;

import io.flutter.embedding.android.FlutterActivity;

public class MainActivity extends FlutterActivity {

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        
        FlutterEventChannel eventChannel = FlutterEventChannel.getInstance();
        getFlutterEngine().getPlugins().add(eventChannel);
    }
}

3.Flutter中注册并调用

void main() {
  runApp(MyApp());
}

class MyApp extends StatefulWidget {
  @override
  _MyAppState createState() => _MyAppState();
}

class _MyAppState extends State<MyApp> {

  var _eventChannel = EventChannel('event_channel_name');

  @override
  void initState() {
    super.initState();
    _eventChannel.receiveBroadcastStream().listen((event) {
      print("event: $event");
    });
  }

  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      home: Scaffold(
        appBar: AppBar(
          title: const Text('Plugin example app'),
        ),
      ),
    );
  }
}

 

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值