EventBus3.0 使用详解(一)

*.EventBus的github地址: https://github.com/greenrobot/EventBus
*.EventBus的官方网站: http://greenrobot.org/eventbus/

基于EventBus 3.0的使用方法:
1.根据官方文档我们可以看到EventBus的基本使用方式 分5步:
1>.将EventBus 3.0引入AS,当然如果是Eclispse的开发者可以下载相应的jar(地址: http://search.maven.org/#search%7Cga%7C1%7Cg%3A%22de.greenrobot%22%20AND%20a%3A%22eventbus%22 ):
     compile 'org.greenrobot:eventbus:3.0.0'
如图:

3>.在事件监听者的Activity中注册及解除事件的绑定:
public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    //绑定事件接受
    EventBus.getDefault().register(this);

}
@Override
protected void onDestroy() {
    super.onDestroy();
    //注销事件接受
    EventBus.getDefault().unregister(this);
}
3>.创建EventMessage类(注意这里的EventMessage是个POJO,PS:不知道啥是POJO的请百度之):
 
   public class MessageEvent {
    public final String message;

    public MessageEvent(String message) {
        this.message = message;
    }
   }

4>.在你的事件监听方法上加上 @Subscribe注解,这里跟老版本的EventBus有所不同,老版本的你需要在注解后面配上你所监听的事件的名字,3.0后你不需要做这步操作了,直接写上注解就搞定了,而且监听方法的名字也可以随便起了,没有特殊要求。
你可以这样写:
    @Subscribe
public void onMessageEvent(MessageEvent event){
    Toast.makeText(getActivity(), event.message, Toast.LENGTH_SHORT).show();
}
也可以这样写:
@Subscribe
public void onMessageEvent(MessageEvent event){
    Toast.makeText(getActivity(), event.message, Toast.LENGTH_SHORT).show();
}


5>.做完上边的操作后 你就可以在代码的任何地方,发送事件了。
    
EventBus.getDefault().post(new MessageEvent("Hello everyone!"));

注意事项:
1.事件被post后哪个事件的监听者会响应的问题,这个取决于你写的监听方法所跟的参数类型。
2.你写的事件监听方法得是public修饰的,如果你写成private了,则不会收到消息。
3.如果你所有的事件监听方法都不用public修饰(包括父类),则会直接报错:
      Caused by: org.greenrobot.eventbus.EventBusException: Subscriber class com.koosol.flowwaternote.MainActivity and its super classes have no public methods with the @Subscribe annotation
    
  • 4
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值