天天看點

Android開發學習之路--RxAndroid之初體驗

    學了一段時間android,看了部分的項目代碼,然後想想老是學基礎也夠枯燥乏味的,那麼就來學習學習新東西吧,相信很多學java的都聽說過RxJava,那麼android下也有RxAndroid。

    RxJava最核心的兩個東西是Observables(被觀察者,事件源)和Subscribers(訂閱者)。Observables發出一系列事件,Subscribers處理這些事件。這裡的事件可以是任何你感興趣的東西,觸摸事件,web接口調用傳回的資料等等。

    關于RxAndroid的github:https://github.com/ReactiveX/RxAndroid。

    建立emRxAndroidStudy工程, 然後在build.grade的dependencies裡添加:

compile 'io.reactivex:rxandroid:1.1.0'
    compile 'io.reactivex:rxjava:1.1.0'
           

    接着我們來試下RxAndroid了, 首先這裡我們還是使用上次的注解的方式,把4個和Annotation相關的檔案拷貝到工程,編寫MainActivity代碼如下:

package com.jared.emrxandroidstudy;

import android.os.Bundle;
import android.util.Log;
import android.view.View;
import android.widget.Button;
import android.widget.TextView;

import rx.Observable;
import rx.Subscriber;

@EMLayoutBinder(R.layout.activity_main)
public class MainActivity extends BaseActivity {

    private static final String TAG = "MainActivity";
    private Subscriber<String> subscriber;
    private Observable<String> observable;

    @EMViewBinder(R.id.hello)
    private TextView mHello;
    @EMViewBinder(R.id.test1)
    private Button mTest1;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        createSubscriber();
    }

    private void bindSubscriber() {
        observable.subscribe(subscriber);
    }

    private void createSubscriber() {

        subscriber = new Subscriber<String>() {

            @Override
            public void onCompleted() {
                Log.d(TAG, "onCompleted");
            }

            @Override
            public void onError(Throwable e) {
                e.printStackTrace();
            }

            @Override
            public void onNext(String t) {
                Log.d(TAG, "onNext");
                mHello.setText(t);
            }
        };
    }

    private String getHello() {
        return "Hello RxAndroid";
    }

    private String getHello1() {
        return "Hello RxAndroid 1";
    }

    @EMOnClickBinder({R.id.test1})
    public void myOnClick(View view) {
        switch (view.getId()) {
            case R.id.test1:
                createObservable();
                break;
            default:
                break;
        }
    }

    private void createObservable() {
        Log.d(TAG, "observable");
        observable = Observable.create(new Observable.OnSubscribe<String>() {
            @Override
            public void call(Subscriber<? super String> subscriber) {
                subscriber.onNext(getHello());
                subscriber.onCompleted();
            }
        });
        bindSubscriber();
    }
}
           

     布局檔案如下:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout
    xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical"
    tools:context="com.jared.emrxandroidstudy.MainActivity">

    <TextView
        android:id="@+id/hello"
        android:text="Hello World!"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content" />

    <Button
        android:id="@+id/test1"
        android:text="Test"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:textAllCaps="false"/>
</LinearLayout>
           

    這裡建立了Observable,用來發送一字元串,然後建立了Subscriber,用來接收事件處理,然後把這兩個綁定,按下按鈕後,subscriber會調用onNext方法和onCompleted方法。

    當然這裡的createObservable可以通過just方法簡化:

private void createObservableByJust() {
        Log.d(TAG, "createObservable");
        observable = Observable.just(getHello());
        bindSubscriber();
    }
           

    效果和上述的是一樣一樣的。接着簡化subscriber了:

private void createSubscriberByAction() {
        onNextAction = new Action1<String>() {
            @Override
            public void call(String s) {
                mHello.setText(s);
            }
        };
    }
           

    這裡通過Action1來實作,完全沒有了subscriber了的感覺,接着修改綁定如下:

private void bindSubscriber() {
        //observable.subscribe(subscriber);
        observable.subscribe(onNextAction);
    }
           

    效果還是一樣一樣的。

    好了,接着我們來使用下操作符map,修改如下:

private void createObservableByMap() {
        Log.d(TAG, "createObservableByMap");
        Observable.just(getHello()).map(new Func1<String, String>() {
            @Override
            public String call(String s) {
                return s + " by eastmoon";
            }
        }).subscribe(onNextAction);
    }
           

    運作結果後原來字元串加上了by eastmoon了。其實map的功能就是在observable和subscribe之間可以對資料進行操作。