首页 > 代码库 > Android EventBus技能点梳理

Android EventBus技能点梳理

EventBus为Github上的开源项目,地址:https://github.com/greenrobot/EventBus

疑问:1. 现在都是Android Studio创建的项目,如何导入这些项目(对工具不熟悉);2. 如何得到这些开源项目的.jar包?

EventBus概念分析(获取感性认识):

技术分享

所述publisher为发布者,subscriber为订阅者;Event的Publisher为事件的所有者,而各个Subscriber会收到对应的Event。

其主要功能是替代Intent、Handler、BroadCast在Fragment、Activity、Service以及线程之间传递消息。

优点在于:开销小(jar包小~50KB)、代码优雅、代码运行高效、经过多个APK测试...

EventBus使用基本流程:

实例分析:在EventBusActivity中点击按键,跳转到ActivitySecond界面;并在上述界面中点击按键,跳转到ActivityThird界面;并在上述界面中输入用户名和密码,点击跳转,返回到EventBusActivity中并显示传递过来的用户名和密码。

package com.demo;
import android.app.Activity;
import android.content.Intent;
import android.os.Bundle;
import android.view.View;
import android.widget.TextView;
import de.greenrobot.event.EventBus;
public class EventBusActivity extends Activity {
    private TextView mTextView;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        mTextView = (TextView) findViewById(R.id.text);
        // 判断是否已经注册了,避免重复注册
        if (!EventBus.getDefault().isRegistered(this)) {
            // 注册监听,尽量写在各变量初始化之后,避免造成空指针异常
            EventBus.getDefault().register(this);
        }
    }
    public void btnClick(View view) {
        startActivity(new Intent(EventBusActivity.this, ActivitySecond.class));
    }
    /**
     * <功能描述> 订阅者接收事件
     * 
     * @param event [参数说明]
     * @return void [返回类型说明]
     */
    public void onEventMainThread(MessageEvent event) {
        if (event.getUser() != null) {
            mTextView.setText("用户名:" + event.getUser().getUsername() + "; 密码:"
                    + event.getUser().getPassword());
        }
    }
    @Override
    protected void onDestroy() {
        super.onDestroy();
        // 取消注册需要写在onDestory(),写在onStop()中可能会引发异常
        EventBus.getDefault().unregister(this);
    }
}

ActivitySecond.java代码实例:

package com.demo;
import android.app.Activity;
import android.content.Intent;
import android.os.Bundle;
import android.view.View;
public class ActivitySecond extends Activity {
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main2);
    }
    public void btnClick2(View view) {
        startActivity(new Intent(ActivitySecond.this, ActivityThird.class));
        finish();
    }
}

ActivityThird.java代码实例:

package com.demo;
import android.app.Activity;
import android.os.Bundle;
import android.view.View;
import android.widget.EditText;
import de.greenrobot.event.EventBus;
public class ActivityThird extends Activity {
    private EditText mEditUsername;
    private EditText mEditPwd;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main3);
        mEditUsername = (EditText) findViewById(R.id.edit_username);
        mEditPwd = (EditText) findViewById(R.id.edit_pwd);
    }
    public void btnClick3(View view) {
        String userName = mEditUsername.getText().toString().trim();
        String password = mEditPwd.getText().toString().trim();
        // 发送消息
        EventBus.getDefault().post(
                new MessageEvent(new User(userName, password)));
        finish();
    }
}

EventBus注意事项:

接收消息时涉及到的四个方法,以及区分:

1. onEvent():该事件在哪个线程发布的,onEvent()就会在这个线程中运行。也就是说,发布事件和接收事件线程在同一个线程。使用这个方法时,在onEvent()中不能执行耗时操作,如果执行耗时操作容易导致事件分发延迟。

2. onEventMainThread():不论事件在哪个线程中发布出来,onEventMainThread都会在UI线程中执行,接收事件都会在UI线程中运行。这种情况对于Android是非常有用的,因为在Android中只能在UI线程中更新UI,所以不能在该方法中执行耗时操作。

3. onEventBackground():如果事件是从UI线程中被发布出来,那么onEventBackground就会在创建的子线程中运行,如果事件本身就是在子线程中发布出来,那么就直接在该子线程中运行。、

4. onEventAsync():不论事件是在哪个线程中被发布出来,都会创建新的子线程中执行该方法。

如果有多个地方发布事件,有多个地方接收并处理事件,如何进行匹配和判断?

根据上述4种接收事件的方法中涉及到的参数,并进行参数匹配;发送消息的参数是某一个类,接收的也必须是这个类,否则接收不到。如果有多个onEvent()的参数相同,则这些方法都将接收到这个消息。

Android EventBus技能点梳理