[DEPRECATED]一个实用的RxJava1工具类库
请移步RxUtil2
- RxBus 支持多事件定义,支持数据携带,支持全局和局部的事件订阅和注销。
- 订阅池管理。
- 支持非侵入式的订阅生命周期绑定。
- 线程调度辅助工具。
- RxBinding 使用工具类。
- RxJava常用方法工具类。
目前支持主流开发工具AndroidStudio的使用,直接配置build.gradle,增加依赖即可.
先在项目根目录的 build.gradle 的 repositories 添加:
allprojects {
repositories {
...
maven { url "https://jitpack.io" }
}
}
然后在dependencies添加:
dependencies {
...
implementation 'io.reactivex:rxjava:1.3.6'
implementation 'io.reactivex:rxandroid:1.2.1'
//rxbinding的sdk
implementation 'com.jakewharton.rxbinding:rxbinding:1.0.1'
implementation 'com.github.xuexiangjys:RxUtil:1.1.3'
}
1.使用RxBusUtils.get().onMainThread方法注册事件,并指定订阅发生在主线程。
RxBusUtils.get().onMainThread(EventKey.EVENT_HAVE_DATA, new Action1<Event>() {
@Override
public void call(Event event) {
showContent(EventKey.EVENT_HAVE_DATA, event.toString());
}
});
2.使用RxBusUtils.get().on方法注册事件,订阅所在线程为事件发生线程,也可指定订阅发生的线程。
RxBusUtils.get().on(EventKey.EVENT_BACK_NORMAL, new Action1<String>() {
@Override
public void call(String eventName) {
final String msg = "事件Key:" + EventKey.EVENT_BACK_NORMAL + "\n EventName:" + eventName + ", 当前线程状态: " + Event.getLooperStatus();
showContent(msg);
}
});
1.使用RxBusUtils.get().post(Object eventName)发送不带数据的事件。
RxBusUtils.get().post(EventKey.EVENT_NO_DATA);
2.使用RxBusUtils.get().post(Object eventName, Object content)发送携带数据的事件。
RxBusUtils.get().post(EventKey.EVENT_HAVE_DATA, new Event(EventKey.EVENT_HAVE_DATA, "这里携带的是数据"));
RxBusUtils.get().post(EventKey.EVENT_HAVE_DATA, true);
1.使用RxBusUtils.get().unregisterAll(Object eventName)取消事件的所有订阅并注销事件。
RxBusUtils.get().unregisterAll(EventKey.EVENT_HAVE_DATA);
2.使用RxBusUtils.get().unregister(Object eventName, SubscribeInfo subscribeInfo)取消事件的某个指定订阅。 SubscribeInfo是事件注册订阅后返回的订阅信息。如果在取消该订阅后,该事件如无其他订阅,便自动注销该事件。
RxBusUtils.get().unregister(EventKey.EVENT_CLEAR, mSubscribeInfo);
1.RxIOTask:在io线程中操作的任务
RxJavaUtils.doInIOThread(new RxIOTask<String>("我是入参123") {
@Override
public Void doInIOThread(String s) {
Log.e(TAG, "[doInIOThread] " + getLooperStatus() + ", 入参:" + s);
return null;
}
});
2.RxUITask:在UI线程中操作的任务
RxJavaUtils.doInUIThread(new RxUITask<String>("我是入参456") {
@Override
public void doInUIThread(String s) {
Log.e(TAG, "[doInUIThread] " + getLooperStatus() + ", 入参:" + s);
}
});
3.RxAsyncTask:在IO线程中执行耗时操作 执行完成后在UI线程中订阅的任务。
RxJavaUtils.executeAsyncTask(new RxAsyncTask<String, Integer>("我是入参789") {
@Override
public Integer doInIOThread(String s) {
Log.e(TAG, "[doInIOThread] " + getLooperStatus() + ", 入参:" + s);
return 12345;
}
@Override
public void doInUIThread(Integer integer) {
Log.e(TAG, "[doInUIThread] " + getLooperStatus() + ", 入参:" + integer);
}
});
4.RxIteratorTask:遍历集合或者数组的任务,在IO线程中执行耗时操作 执行完成后在UI线程中订阅的任务。
RxJavaUtils.executeRxIteratorTask(new RxIteratorTask<String, Integer>(new String[]{"123", "456", "789"}) {
@Override
public Integer doInIOThread(String s) {
RxLog.e("[doInIOThread]" + getLooperStatus() + ", 入参:" + s);
return Integer.parseInt(s);
}
@Override
public void doInUIThread(Integer integer) {
RxLog.e("[doInUIThread] " + getLooperStatus() + ", 入参:" + integer);
}
});
1.SimpleSubscriber:简单的订阅者,已对错误进行捕获处理,并对生命周期进行日志记录。可设置IExceptionHandler接口自定义错误处理,设置ILogger接口自定义日志记录。
2.ProgressLoadingSubscriber:带进度条加载的订阅者,实现IProgressLoader接口可自定义加载方式。
Observable.just("加载完毕!")
.delay(3, TimeUnit.SECONDS)
.observeOn(AndroidSchedulers.mainThread())
.subscribe(new ProgressLoadingSubscriber<String>(mProgressLoader) {
@Override
public void onNext(String s) {
Toast.makeText(RxJavaActivity.this, s, Toast.LENGTH_SHORT).show();
}
});
SubscriptionPool:RxJava的订阅池
1.增加订阅:add(@NonNull Object tagName, Subscription m) 或者 add(Subscription m, @NonNull Object tagName)
SubscriptionPool.get().add(RxJavaUtils.polling(5, new Action1() {
@Override
public void call(Object o) {
Toast.makeText(RxJavaActivity.this, "正在监听", Toast.LENGTH_SHORT).show();
}
}), "polling");
2.取消订阅:remove(@NonNull Object tagName)、remove(@NonNull Object tagName, Subscription m)、removeAll()
SubscriptionPool.get().remove("polling");
1.setViewClicks:设置点击事件
RxBindingUtils.setViewClicks(mBtnClick, 5, TimeUnit.SECONDS, new Action1<Void>() {
@Override
public void call(Void aVoid) {
toast("触发点击");
}
});
2.setItemClicks:设置条目点击事件
3.textChanges:设置文本变化监听事件
RxBindingUtils.textChanges(mEtInput, 1, TimeUnit.SECONDS, new Action1<CharSequence>() {
@Override
public void call(CharSequence charSequence) {
toast("输入内容:" + charSequence);
}
})
- 订阅发生在主线程 ( -> -> main)
.compose(RxSchedulerUtils.<T>_main())
- 订阅发生在io线程 ( -> -> io)
.compose(RxSchedulerUtils.<T>_io())
- 处理在io线程,订阅发生在主线程( -> io -> main)
.compose(RxSchedulerUtils.<T>_io_main())
- 处理在io线程,订阅也发生在io线程( -> io -> io)
.compose(RxSchedulerUtils.<T>_io_io())
- 自定义线程池
由于Schedulers.io()
内部使用的是CachedWorkerPool
,而他最终创建线程池的方法是newScheduledThreadPool
,它是一个核心只有1个线程,有效时间为60s,但是线程池的线程容纳数量是Integer.MAX_VALUE
的线程池。
如果线程在执行的过程中发生了长时间的阻塞,导致线程一直在工作状态的话,线程池将无法回收线程,只能不断地创建线程,最终有可能造成线程创建的数量过多,导致程序OOM。
使用RxSchedulerUtils
进行切换时,可传入Executor
更换工作线程池:
.compose(RxSchedulerUtils.<Integer>_io_main(AppExecutors.get().poolIO()))
1.使用RxLifecycle.injectRxLifecycle
进行生命周期的绑定。
(1)在Activity的onCreate
方法中进行注入和生命周期绑定
@Override
protected void onCreate(@Nullable Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(getLayoutId());
RxLifecycle.injectRxLifecycle(this);
}
(2)当然,如果你嫌麻烦,可以在Application的onCreate
方法中进行注入和生命周期绑定。
RxLifecycle.injectRxLifecycle(this);
2.使用compose
将订阅绑定至生命周期。
使用RxLifecycle.with
可以获取生命周期管理者LifecycleManager
,通过它我们可以将订阅绑定至生命周期。
-
bindToActivityLifecycle
:绑定到特定的Activity生命周期进行订阅注销 -
bindToLifecycle
:自动绑定Activity生命周期进行订阅注销 -
bindOnDestroy
:绑定到Activity的OnDestroy进行订阅注销
RxJavaUtils.polling(5)
.compose(RxLifecycle.with(this).<Long>bindToLifecycle())
.subscribe(new SimpleSubscriber<Long>() {
@Override
public void onNext(Long aLong) {
toast(" 正在监听 :" + aLong);
}
});