Android|Android EventBus 简单使用
1.集成:
GitHub 地址EventBus
1.1:
implementation 'org.greenrobot:eventbus:3.0.0'
1.2 注册EventBus (在需要回调的页面注册)
EventBus.getDefault().register(this);
别忘记在 onDestory 中解绑
EventBus.getDefault().unregister(this);
回调有一下几种,其对应的功能:
onEvent:如果使用onEvent作为订阅函数,那么该事件在哪个线程发布出来的,onEvent就会在这个线程中运行,也就是说发布事件和接收事件线程在同一个线程。使用这个方法时,在onEvent方法中不能执行耗时操作,如果执行耗时操作容易导致事件分发延迟。
onEventMainThread:如果使用onEventMainThread作为订阅函数,那么不论事件是在哪个线程中发布出来的,onEventMainThread都会在UI线程中执行,接收事件就会在UI线程中运行,这个在Android中是非常有用的,因为在Android中只能在UI线程中跟新UI,所以在onEvnetMainThread方法中是不能执行耗时操作的。
onEventBackground:如果使用onEventBackgrond作为订阅函数,那么如果事件是在UI线程中发布出来的,那么onEventBackground就会在子线程中运行,如果事件本来就是子线程中发布出来的,那么onEventBackground函数直接在该子线程中执行。
onEventAsync:使用这个函数作为订阅函数,那么无论事件在哪个线程发布,都会创建新的子线程在执行onEventAsync.
1.3 发送消息:
EventBus.getDefault().post("sssssss");
2. 报错:
Caused by: org.greenrobot.eventbus.EventBusException: Subscriber class com.duke.mvvmtesr.MainActivity and its super classes have no public methods with the @Subscribe annotation
需要在接收方法上加
@Subscribe(threadMode = ThreadMode.MAIN)
在3.0以后回调方法可以自定义, 但需要加上线程模型
- POSTING:默认,表示事件处理函数的线程跟发布事件的线程在同一个线程。
- MAIN:表示事件处理函数的线程在主线程(UI)线程,因此在这里不能进行耗时操作。
- BACKGROUND:表示事件处理函数的线程在后台线程,因此不能进行UI操作。如果发布事件的线程是主线程(UI线程),那么事件处理函数将会开启一个后台线程,如果果发布事件的线程是在后台线程,那么事件处理函数就使用该线程。
- ASYNC:表示无论事件发布的线程是哪一个,事件处理函数始终会新建一个子线程运行,同样不能进行UI操作。
3.疑问:
如果有多个页面注册了EventBus 并且也有接收方法,系统如何区分消息发给了谁?
解答:
在post 的 时候,后面有个参数,在接收方法后面也有个参数,
EventBus.getDefault().post("sssssss");
public void onEventMainThread(String event)
如需要区分具体给哪个接收器发消息,就得通过实体类,去区分不同的类型。
至此就可以简单的玩玩 EventBus了,然后如需学习 EventBus 的具体原理等,请参照其他文章。
【Android|Android EventBus 简单使用】
推荐阅读
- android第三方框架(五)ButterKnife
- Android中的AES加密-下
- 科学养胃,别被忽悠,其实真的很简单
- 带有Hilt的Android上的依赖注入
- opencv|opencv C++模板匹配的简单实现
- android|android studio中ndk的使用
- 松软可口易消化,无需烤箱超简单,新手麻麻也能轻松成功~
- Android事件传递源码分析
- RxJava|RxJava 在Android项目中的使用(一)
- 简单心理2019春A期+32+张荣