事件总线EventBus框架的使用介绍
.
EventBus
介绍
EventBus是一款针对Android优化的发布-订阅事件总线。它简化了应用程序内各组件间、组件与后台线 程间的通信。其优点是开销小,代码更优雅,以及将发送者和接收者解耦。
.
EventBus 的三要素
Event: 事件,可以是任意类型的对象
Subscriber: 事件订阅者,在 EventBus 3.0 之前我们必须定义以onEvent开头的那几个方法,分别是
onEvent
、onEventMainThread
、onEventBackgroundThread
和onEventAsync
,而在3.0之后事件处理的方法名可以随意取,不过需要加上注解@subscribe,并且指定线程模型,默认是POSTING。Publisher: 事件发布者,可以在任意线程任意位置发送事件, 直接调用。一般情况下,使用EventBus.getDefault()就可以得到一个EventBus对象,然后再调用post(Object)方法即可
.
四种线程模型
EventBus3.0有四种线程模型,分别是:
POSTING(默认): 表示事件处理函数的线程跟发布事件的线程在同一个线程
MAIN: 表示事件处理函数的线程在主线程(UI)线程,因此在这里不能进行耗时操作
BACKGROUND: 表示事件处理函数的线程在后台线程,因此不能进行UI操作。如果发布事件的线程是主线程(UI线程),那么事件处理函数将会开启一个后台线程,如果果发布事件的线程是在后台线程,那么事件处理函数就使用该线程
ASYNC: 表示无论事件发布的线程是哪一个,事件处理函数始终会新建一个子线程运行,同样不能进行UI操作
可以在 处理事件 的时候来设置线程模型,如下所示:
//设置线程模型
@Subscribe(threadMode = ThreadMode.MAIN)
public void XXXX(MessageEvent message) {
//消息的内容
Log.d("接收的信息内容:",message);
}
.
.
EventBus基本用法
引入依赖
在使用之前先要在build.gradle
引入如下依赖:
dependencies{
implementation 'org.greenrobot:eventbus:3.1.1'
}
.
EventBus使用起来分为以下5个步骤:
.
1. 自定义一个事件类
作用: 在程序内部就使用该对象作为通信的信息
public class MessageEvent {
public final String message;
private MessageEvent(String message) {
this.message = message;
}
public static MessageEvent getInstance(String message) {
return new MessageWrap(message);
}
}
2. 在需要订阅事件的地方注册事件
在MainActivity中注册事件,如下所示:
public class MainActivity extends AppCompatActivity{
@Override
protected void onCreate (Bundle savedInstanceState){
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_,ain);
initData();
}
public vaid init(){
//注册事件
EventBus.getDefault().register(this);
}
}
3. 发送事件
创建了SecondActivity来发布消息,代码如下所示:
public class SecondActivity extends AppCompatActivity{
@Override
protected void onCreate (Bundle savedInstanceState){
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_,ain);
sendMessag();