• 由浅入深了解EventBus:(一)


    概述

      由greenrobot织贡献(该组织还贡献了greenDAO),一个Android事件发布/订阅轻量级框架;

      EventBus是一个消息总线,以观察者模式实现,用于简化程序的组件、线程通信,可以轻易切换线程、开辟线程。EventBus分离了事件的发送者和接收者的耦合关系;它可以替代我们传统的Intent,Handler,Broadcast在Fragment,Activity,Service,线程之间传递数据,执行方法。

    用法

      EventBus的git地址:https://github.com/greenrobot/EventBus

      在Android项目中的build.gradle中添加依赖:

        compile 'org.greenrobot:eventbus:3.0.0'

      1.使用EventBus首先要创建一个传递的事件类   

      public class MessageEvent {
        public MessageEvent(String message) {
            this.message = message;
        }
    
        public String getMessage() {
            return message;
        }
        public void setMessage(String message) {
            this.message = message;
        }
    
        private String message;
     }

       从代码中可以看出EventBus传递的事件类不需要继承任何的接口和基类,就是一个普通的java类;

      2.用于EventBus内部采用的是观察者模式,因此要使用EventBus框架,首先就是要先注册/订阅事件,在EventBus框架中注册/订阅事件也非常的简单,只需要一行代码;

      EventBus.getDefault().register(this);
    

     注册方法中的this就是我们的订阅类,也就是观察者,可以是一个Fragment,Activity,Service;

     3.在EventBus框架中可以注册/订阅一个事件,也可以取消注册/订阅事件,同样也很简单;

    EventBus.getDefault().unregister(this);

     4.在观察者模式中当被观察者发生事件后,观察者内部就有消息接收的方法,在EventBus也同样,需要在订阅类中实现我们的消息接收的方法;  

      @Subscribe
        public  void  onMoonEvent(MessageEvent messageEvent){
            textView.setText(messageEvent.getMessage());
        } 
    

     在EventBus框架中对于观察者的消息接收方法有一定的限制,首先方法必须是Public,而且方法的参数的类型必须是我们定义的事件类;而且方法必须添加”@Subscribe“注解,因为在EventBus内部查找方法时,是根据注解来进行区分;

     在消息处理方法中我们也可以终止事件的传递,后续的事件不再调用,只能在传递事件的时候调用;

      EventBus.getDefault().cancelEventDelivery(event) ;

     5.最后一步就是被观察者触发事件,在EventBus框架使用post(粘性事件触发使用postSticky)方法;

       EventBus.getDefault().post(new MessageEvent("我是从SecondActivity 传过来的信息"));
    

     整个EventBus框架的使用就是这么简单;关于事件类的分发中转都是EventBus框架内部进行了实现,使用者可以不用关心,只关心自己业务逻辑的实现;

  • 相关阅读:
    人月神话阅读笔记
    12周总结
    IOS成长之路-用NSXMLParser实现XML解析
    沟通能力的表达
    IOS中UIScrollView的contentSize、contentOffset和contentInset属性
    Block 的使用时机
    drawAdapter
    drawpoly()函数的用法
    @synchronized(self)
    Swift2
  • 原文地址:https://www.cnblogs.com/h20064528/p/6762795.html
Copyright © 2020-2023  润新知