Skip to content

Latest commit

 

History

History
106 lines (81 loc) · 2.6 KB

rxbinding.md

File metadata and controls

106 lines (81 loc) · 2.6 KB

RxBinding(JakeWharton/RxBinding)

讓每個 Android 的元件都包裝成 Rx 。

RxAndroid Before:

ViewObservable.clicks(textView).subscribe(ev -> {});

RxBinding After:

RxTextView.textChanged(textView).subscribe(ev -> {});

範例 1 - 驗證過濾

Observable<CharSequence> rxUsername = RxTextView.textChanges(tvUsername);
Observable<CharSequence> rxPassword = RxTextView.textChanges(tvPassword);
Observable<CharSequence> rxFullName = RxTextView.textChanges(tvFullName).mergeWith(Observable.just(""));
Observable.combineLatest(
  rxUsername, rxPassword, rxFullName, RegistrationModel::new)
  .filter(RegistrationModel::isValid)
  .subscribe(result -> enableSubmitButton());

範例 2 - 流量控制

RxSearchView.queryTextChanges(searchView)
  .filter(charSequence -> !TextUtils.isEmpty(charSequence))
  .throttleLast(100, TimeUnit.MILLISECONDS)
  .debounce(200, TimeUnit.MILLISECONDS)
  .onBackpressureLatest()
  .concatMap(charSequence -> {
    return searchRepositories(charSequence);
  })
  .observeOn(AndroidSchedulers.mainThread())
  .subscribeOn(Schedulers.io())
  .onErrorResumeNext(throwable -> {
    return Observable.empty();
  })
  .subscribe(response -> {
    showRepositories(response.getItems());
});

同名 ogaclejapan/RxBinding

https://github.com/ogaclejapan/RxBinding

主要以 MVVM 雙向連動為主要訴求

Before:

class HogeActivity extends Activity {

    @InjectView(R.id.text)
    private TextView mTextView;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        ButterKnife.inject(this);

        AppObservable.bindActivity(this, Observable.just("hoge"))
            .subscribeOn(Schedulers.io())
            .subscribe(setTextAction());
    }

    Action1<String> setTextAction() {
        return text -> mTextView.setText(text);
    }
}

After:

class HogeActivity extends Activity {
    // ...

    private Rx<TextView> mRxTextView

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        ButterKnife.inject(this);

        mRxTextView = RxView.of(mTextView);
        Subscription s = mRxTextView.bind(Observable.just("hoge"), RxActions.setText());
    }
}

See Also