地址
https://github.com/greenrobot/EventBus
一般用在 上一级页面的数据自动刷新等方面。
其实是个很简单的东西,观察者模式,机制的一种实现
下面这个就是,肯定都很熟悉
btnGetText.setOnClickListener(new View.OnClickListener() {
public void onClick(View v) {
}
});
基本使用方式
注册观察者 EventBusActivity
public class EventBusActivity extends Activity {
TextView qiehuan ;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_event1);
EventBus.getDefault().register(this);
qiehuan = (TextView)findViewById(R.id.qiehuan);
qiehuan.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
// TODO Auto-generated method stub
startActivity(new Intent(EventBusActivity.this,EventBusActivity2.class));
}
});
}
public void onEventMainThread(EventClass event) {
String msg = "收到了消息:" + event.name;
Toast.makeText(this, msg, Toast.LENGTH_LONG).show();
}
@Override
protected void onDestroy(){
super.onDestroy();
EventBus.getDefault().unregister(this);
}
}
public class EventBusActivity2 extends Activity {
TextView qiehuan ;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_event2);
qiehuan = (TextView)findViewById(R.id.qiehuan);
qiehuan.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
// TODO Auto-generated method stub
EventBus.getDefault().post(
new EventClass("我是2传过来的咯"));
}
});
}
}
onEvent:
如果使用onEvent作为订阅函数,那么该事件在哪个线程发布出来的,onEvent就会在这个线程中运行,也就是说发布事件和接收事件线程在同一个线程。使用这个方法时,在onEvent方法中不能执行耗时操作,如果执行耗时操作容易导致事件分发延迟。
onEventMainThread:
如果使用onEventMainThread作为订阅函数,那么不论事件是在哪个线程中发布出来的,onEventMainThread都会在UI线程中执行,接收事件就会在UI线程中运行,这个在Android中是非常有用的,因为在Android中只能在UI线程中跟新UI,所以在onEvnetMainThread方法中是不能执行耗时操作的。
onEventBackground:
如果使用onEventBackgrond作为订阅函数,那么如果事件是在UI线程中发布出来的,那么onEventBackground就会在子线程中运行,如果事件本来就是子线程中发布出来的,那么onEventBackground函数直接在该子线程中执行。
onEventAsync:
使用这个函数作为订阅函数,那么无论事件在哪个线程发布,都会创建新的子线程在执行onEventAsync.
根据不同情况 或者 塞入的不同 实体类 就可以区分了。分别执行了
如果参数 实体类都一样,
后3个方法是都会接收到的事件的