【EventBus】EventBus 事件总线框架简介 ( EventBus 使用流程 )

简介: 【EventBus】EventBus 事件总线框架简介 ( EventBus 使用流程 )

文章目录

一、EventBus 事件总线框架简介

二、EventBus 使用流程





一、EventBus 事件总线框架简介


Android 中的事件传递机制 :


使用 Intent 在组件间传递信息 ;

使用 BroadcastReceiver 跨进程传递数据 ;

使用 Handler 跨线程通信 ;

使用 接口回调 机制 , Activity 与 Fragment 之间的通信方式 ;


EventBus 事件总线框架 简化了 Android 中的事件传递机制 ;


EventBus 常用于 组件 间的事件传递 , 实现了各个组件间的通信 , 如 Activity 与 Fragment 之间的通信 , Activity 与 Service 之间的通信 ;



EventBus GitHub 地址 : https://github.com/greenrobot/EventBus


EventBus 文档 : https://greenrobot.org/eventbus/documentation/






二、EventBus 使用流程


参考 https://github.com/greenrobot/EventBus 中的使用步骤 ;


1 . 导入 EventBus 依赖 ;


implementation 'org.greenrobot:eventbus:3.2.0'


2 . 声明 EventBus 事件处理方法 ; 使用 @Subscribe 注解修饰处理消息的方法 , 该方法必须是 public void 修饰的 , 只有一个参数 , 参数类型随意 , 调用 EventBus.getDefault().post 即可发送消息到该方法进行处理 ;


/**
     * 使用 @Subscribe 注解修饰处理消息的方法
     *      该方法必须是 public void 修饰的
     *      只有一个参数 , 参数类型随意
     *      调用 EventBus.getDefault().post 即可发送消息到该方法进行处理
     * @param msg
     */
    @Subscribe
    public void onMessgeEvent(String msg){
        textView.setText(msg);
    }


3 . 注册 EventBus , 一般在 onCreate 中注册 , 在 onDestory 中取消注册 ;


@Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        // 首先注册订阅 EventBus
        EventBus.getDefault().register(this);
    }
    @Override
    protected void onDestroy() {
        super.onDestroy();
        // 取消注册
        EventBus.getDefault().unregister(this);
    }


4 . 发送消息 ; 调用 EventBus.getDefault().post 方法 , 将消息发送到消息处理方法中 ;


EventBus.getDefault().post("Hello EventBus !");


目录
相关文章
|
3月前
|
JavaScript 调度
Vue事件总线(EventBus)使用指南:详细解析与实战应用
Vue事件总线(EventBus)使用指南:详细解析与实战应用
124 1
|
7月前
|
消息中间件 设计模式 监控
中间件事件总线(Event Bus)
【6月更文挑战第19天】
140 8
页面第二次进入或者多次进入,事件总线触发事件多次,eventBus触发多次
页面第二次进入或者多次进入,事件总线触发事件多次,eventBus触发多次
|
JavaScript
Vue中 事件总线(eventBus)详解及使用
Vue中 事件总线(eventBus)详解及使用
386 0
Vue中 事件总线(eventBus)详解及使用
|
5月前
|
JavaScript
Vue学习之--------全局事件总线(2022/8/22)
这篇文章介绍了Vue中全局事件总线(GlobalEventBus)的概念和使用方法,它允许不同组件之间进行通信。文章通过图解和代码实例详细解释了如何安装全局事件总线、在组件中接收和提供数据,以及如何在组件销毁前解绑事件,以避免潜在的内存泄漏问题。
Vue学习之--------全局事件总线(2022/8/22)
|
8月前
|
JavaScript
解释 Vue 的事件总线和 emits 属性。
解释 Vue 的事件总线和 emits 属性。
97 3
|
8月前
|
JavaScript
在Vue中,如何使用事件总线来传递数据和触发事件?
在Vue中,如何使用事件总线来传递数据和触发事件?
115 0
|
8月前
|
JavaScript 程序员
Vue中的全局事件总线是什么?如何使用?
Vue中的全局事件总线是什么?如何使用?
88 0