Android EventBus技能點梳理

EventBus爲Github上的開源項目,地址:https://github.com/greenrobot/EventBusjava

疑問:1. 如今都是Android Studio建立的項目,如何導入這些項目(對工具不熟悉);2. 如何獲得這些開源項目的.jar包?android

EventBus概念分析(獲取感性認識):git

所述publisher爲發佈者,subscriber爲訂閱者;Event的Publisher爲事件的全部者,而各個Subscriber會收到對應的Event。github

其主要功能是替代Intent、Handler、BroadCast在Fragment、Activity、Service以及線程之間傳遞消息。app

優勢在於:開銷小(jar包小~50KB)、代碼優雅、代碼運行高效、通過多個APK測試...ide

EventBus使用基本流程:工具

實例分析:在EventBusActivity中點擊按鍵,跳轉到ActivitySecond界面;並在上述界面中點擊按鍵,跳轉到ActivityThird界面;並在上述界面中輸入用戶名和密碼,點擊跳轉,返回到EventBusActivity中並顯示傳遞過來的用戶名和密碼。post

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代碼實例:this

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()的參數相同,則這些方法都將接收到這個消息。

相關文章
相關標籤/搜索