在前面的文章中我们简单介绍了事件驱动编程,现在让我们看看真实的代码并介绍EventBus的基础用法。
首先我会参考下图(从EventBus仓库截取的),介绍在事件驱动编程中扮演中心角色的实体们。
唯有亲身实践才能有清晰的认知,下面就让我们来看一个简单的例子:
宿主Activity需要在它的onCreate函数中注册EventBus:
EventBus.getDefault().register(this);
注册之后,宿主Activity就可以从总线上读取数据了,我们同时需要在Activity的onDestroy函数中反注册EventBus:
EventBus.getDefault().unregister(this);
Activity会捕获到两个不同的事件:一个用于更新ActionBar,一个用于加载第一个fragment。我们会编写两个onEvent函数来处理这两个事件:
public void onEvent(ShowFragmentEvent event) {
getFragmentManager().beginTransaction().replace(R.id.container, event.getFragment()).addToBackStack(null).commit();
}
public void onEvent(UpdateActionBarTitleEvent e) {
getActionBar().setTitle(e.getTitle());
}
每个事件需要在类中声明,事件中可以包含变量:
public final class ShowFragmentEvent {
private Fragment fragment;
public ShowFragmentEvent(Fragment fragment) {
this.fragment = fragment;
}
public Fragment getFragment() {
return fragment;
}
}
接下来我们要来创建fragments。第一个fragment包含一个用来打开第二个fragment的按钮,第二个fragment包含一个按钮,当点击按钮时,将刷新TextView。Fragments也需要注册和反注册EventBus,为了得到一个简洁的结构,我们将定义一个BaseFragment来封装这些公共的操作。
现在让我们创建更多一些动作,第一个fragment将通过下面的函数来打开第二个fragment:
@OnClick(R.id.first_button)
public void firstButtonClick() {
EventBus.getDefault().post(new ShowFragmentEvent(new SecondFragment()));
}
需要注意的是这里我使用了ButterKnife中定义的注解,它可以产生更简单和整洁的代码。如果你还没有使用过它,那么现在应该开始使用了。
第二个fragment的按钮会向事件总线发送一个事件,用来更新TextView:
EventBus.getDefault().post(new UpdateTextEvent(getString(R.string.text_updated)));
第二个fragment同时需要监听这个事件,这样当它接收到这个事件时,可以相应的改变文字显示:
public void onEvent(UpdateTextEvent event) {
textView.setText(event.getTitle());
}
我们的简单应用具有两个fragments,通过事件实现两个fragments之间的通信,一个fragment通过事件获得更新。我已经把代码上传到GitHub上面,你可以检出并看一下。
一个关键的问题是如何逐步升级一个事件驱动的架构。在下一篇文章中我将介绍一个简洁的,可理解的架构,来支持Android中的事件驱动编程。