安卓OTTO框架淺析

 

今天要介紹的是一個Android中使用得比較多的android 事件總線 EventBus模式的一個框架Otto。

Otto 官網: http://square.github.io/otto/


一、Android Studio中配置Otto (Eclipse中直接下載jar包導入)

跟之前介紹的其他的框架一樣,它只需要簡單地在build.gradle中配置下面一行紅色字體即可

dependencies { 
    compile fileTree(dir: 'libs', include: ['*.jar']) 
    compile 'com.android.support:appcompat-v7:19.+' 
    / /otto 所需要依賴的包 
    compile 'com.squareup:otto:+'
 


二、Otto事件總線框架淺析

1、爲什麼要用Otto框架?

Otto框架的主要功能是幫助我們來降低多個類之間的耦合度的(解耦)。

譬如:一個類A和另一個類B之間,如果A要操作B中的某個方法。


傳統的方法:A直接調用B對象的該方法(耦合在一起)

事件總線機制:A不需要調用B類的方法,而僅僅需要產生併發出 一個“事件通知”, 如果B訂閱了該“事件”

那麼它將會接受到這個事件,做出相應的操作。這樣就被解耦了。


2. Otto框架使用(結合代碼介紹)

Otto框架其實相對之前的幾個Android開源框架來說,更容易理解。

它主要運用到一個類: Bus類(用於註冊類,註銷類,發佈事件)

兩個註解: @Subscribe (訂閱)    @Produce (生產)    【都是針對“事件”的註解】




爲了方便,我這邊沒有使用兩個類來做這個Demo, 不過如果大家要試的話也可以,不過記住一點,無論是

發佈者類  還是 訂閱者類, 都需要用Bus進行類的註冊,還有註銷。否則將沒法被Bus識別,這樣就無法生效了。

下面的Demo, 僅爲了讓大家知道“事件”被產生了之後,post出來,所有訂閱了該事件的類都會接到該事件,接受的先後順序,不由我們控制!

public class MyActivity extends ActionBarActivity {

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_my);
        findViewById(R.id.button_change).setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View view) {
                BusProvider.getBusInstance().post(new DataChangedEvent("this is changed String"));//發佈事件
            }
        });
    }

    @Override
    protected void onResume() {
        super.onResume();
        BusProvider.getBusInstance().register(this);//註冊
        
    }

    @Override
    protected void onPause() {
        super.onPause();
        BusProvider.getBusInstance().unregister(this);//註銷
    }

    @Subscribe   //訂閱事件DataChangedEvent
    public void sayGoodOnEvent(DataChangedEvent event){
        Log.e("event", "good");
    }

    @Subscribe  //訂閱事件
    public void sayBadOnEvent(DataChangedEvent event){
        Log.e("event", "bad");
    }

    @Produce    //產生事件
    public DataChangedEvent produceDataChangedEvent(){
        return new DataChangedEvent("this is changed String");
    }

}
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章