EnventBus的Dome的代码的思路(Avtivity和Activity之间传值)
导入一个依赖
implementation 'org.greenrobot:eventbus:3.1.1'
创建一个bean类
public class MessageEvent {
private String message;
public MessageEvent(String message) {
this.message = message;
}
public String getMessage() {
return message;
}
public void setMessage(String message) {
this.message = message;
}
}
注册EventBus
EventBus.getDefault().register(this);
在FristAcivity里面创建一个方法方法名自定义被忘了加注解
@Subscribe(threadMode = ThreadMode.MAIN)
public void Evn(MessageEvent messageEvent){
text.setText(messageEvent.getMessage());
}
点击Button按钮跳转到第二个Activity
@Override
public void onClick(View v) {
switch (v.getId()) {
case R.id.mButton:
startActivity(new Intent(MainActivity.this,TwActivity.class));
break;
}
}
在第二个Activity中使用Post传值
@Override
public void onClick(View v) {
switch (v.getId()) {
case R.id.btn:
EventBus.getDefault().post(new MessageEvent("666666"));
finish();
break;
}
}
EnventBus粘性事件
概念:粘性事件就是指在EventBus内部被缓存的纳新事件
原理:EventBus.为每个类(class)类型保存了最近一次被发送的事件–sticky.后续发送过来的同类的sticky事件会自动替换之前的缓存事件,当一个监听者向EventBus进行注册时,他会去请求缓存事件.这时,缓存的事件
就是立即自动发送给这个监听者,一定的延时性.
使用场景:Android上跨Activity和Fragment生命周期传递数据这种复杂问题,异步等等
粘性事件小Dome
点击将值传到第二个Activity
@Override
public void onClick(View v) {
switch (v.getId()) {
case R.id.mButton:
EventBus.getDefault().postSticky(new MessageEvent("66666"));
startActivity(new Intent(MainActivity.this,TwActivity.class));
break;
}
}
因为这里传值是粘性的做到第二个页面的时候需要注册取值
这里还需要判断是否注册,因为重复的注册会导致程序的崩溃
@Override
public void onClick(View v) {
switch (v.getId()) {
case R.id.btn:
if(!EventBus.getDefault().isRegistered(this)){
EventBus.getDefault().register(this);
}
break;
}
}
在这里赋值个TextView展示效果
@Subscribe(threadMode = ThreadMode.MAIN,sticky = true)
public void Evn(MessageEvent messageEvent){
text2.setText(messageEvent.getMessage());
}
避免内存的消耗这里要销毁注册的EventBus
@Override
protected void onDestroy() {
super.onDestroy();
EventBus.getDefault().removeStickyEvent(this);
EventBus.getDefault().unregister(this);
}