RxJava + Retrofit 的实际应用场景

      关于

RxJava Retrofit

      很多篇文章都有详细的说明,在这里我想分享一个具体的使用案例,在我的开源项目

就看天气

      里的实际应用。也希望跟大家探讨如何优雅的使用。

准备

项目中用到的依赖:


compile ‘io.reactivex:rxjava:1.1.0‘

compile ‘io.reactivex:rxandroid:1.1.0‘

compile ‘com.google.code.gson:gson:2.4‘

compile ‘com.squareup.retrofit2:retrofit:2.0.2‘

compile ‘com.squareup.retrofit2:converter-gson:2.0.2‘

compile ‘com.squareup.retrofit2:adapter-rxjava:2.0.2‘

compile ‘com.squareup.okhttp3:okhttp:3.0.1‘

compile ‘com.squareup.okhttp3:logging-interceptor:3.0.1‘

compile ‘com.squareup.okio:okio:1.6.0‘

因为要用到网络,所以千万别忘记了这个权限。


<uses-permission android:name="android.permission.INTERNET"/>

组件

Rx 封装的工具

使用compose操作符

compose()里接收一个Transformer对象,Transformer继承自Func1<Observable<T>, Observable<R>>,可以通过它将一种类型的Observable转换成另一种类型的Observable

RxSchedulerHelper

封装 Rx 线程相关操作


public static <T> Observable.Transformer<T, T> rxSchedulerHelper() {

return tObservable -> tObservable.subscribeOn(Schedulers.io())

.unsubscribeOn(AndroidSchedulers.mainThread())

.observeOn(AndroidSchedulers.mainThread());

}

handleResult

封装 API 请求后统一处理


public static <T> Observable.Transformer<Result<T>, T> handleResult() {

return resultObservable -> resultObservable.flatMap(tResult -> {

if (tResult.code == 1) {

return createData(tResult.data);

} else {

return Observable.error(new ApiException(tResult.code));

}

});

}

RetrofitSingleton

自己封装了下 Retrofit。可以学习下小艾的方式

自己将请求是写在该类,使用者只需要关心如何处理拿到的数据和相应的 UI 操作。


public Observable<Weather> fetchWeather(String city) {

return apiService.mWeatherAPI(city, C.KEY)

.filter(weatherAPI -> weatherAPI.mHeWeatherDataService30s.get(0).status.equals("ok"))

.map(weatherAPI -> weatherAPI.mHeWeatherDataService30s.get(0))

.compose(RxUtils.rxSchedulerHelper());

}

public Observable<VersionAPI> fetchVersion() {

return apiService.mVersionAPI(C.API_TOKEN).compose(RxUtils.rxSchedulerHelper());

}

使用

网络拉取读取缓存用 Rx 结合。
这里就要使用 concat 操作符,官方解释.

首先看看获取网络是如何写的:


private Observable<Weather> fetchDataByNetWork() {

String cityName = Util.replaceCity(mSetting.getCityName());

return RetrofitSingleton.getInstance()

.fetchWeather(cityName)

.onErrorReturn(throwable -> {

PLog.e(throwable.getMessage());

return null;

});

}

这里的 onErrorReturn 待会儿说。

再来看看读取缓存的代码:


private Observable<Weather> fetchDataByCache() {

return Observable.defer(() -> {

Weather weather = (Weather) aCache.getAsObject(C.WEATHER_CACHE);

return Observable.just(weather);

});

}

然后我们将他们连接起来:


private void load() {

Observable.concat(fetchDataByNetWork(), fetchDataByCache())

.first(weather -> weather != null)

.doOnError(throwable -> {

mErroImageView.setVisibility(View.VISIBLE);

mRecyclerView.setVisibility(View.GONE);

})

.doOnNext(weather -> {

mErroImageView.setVisibility(View.GONE);

mRecyclerView.setVisibility(View.VISIBLE);

})

.doOnTerminate(() -> {

mRefreshLayout.setRefreshing(false);

mProgressBar.setVisibility(View.GONE);

})

.subscribe(observer);

}

concat + first 连接和过滤的操作实现了,网络+缓存的逻辑。

刚刚为什么说要在网络代码那里使用 onErrorReturn 呢?

如果不写,网络发生异常的话,整个流就会直接走 onError ,不会执行到读取缓存的流。

结语

Rx 的各种操作符的不同组合就可以实现不同的效果。本身 Rx 封装已经足够好了,我们加工的时候一定要想到是否破坏了他本身的优雅。

因为 Rx 是一种数据流链式结构的编程思想,我们在封装时应该不能打断其链式结构。

时间: 2024-08-28 01:50:32

RxJava + Retrofit 的实际应用场景的相关文章

最适合使用RxJava处理的四种场景

下面我们开始介绍RxJava最适合使用的四种场景,代码示例基于RxJava1 场景一: 单请求异步处理 由于在Android UI线程中不能做一些耗时操作,比如网络请求,大文件保存等,所以在开发中经常会碰到异步处理的情况,我们最典型的使用场景是RxJava+Retrofit处理网络请求 MyService myService = retrofit.create(MyService.class);myService.getSomething() .subscribeOn(Schedulers.io

开发 Material Design+RxJava+Retrofit+MVP App 参考资料

前言 在开发一个基于 Material Design+RxJava+Retrofit+MVP 框架的 App 过程中学习的资料整理 —— 由G军仔分享 这里记录了我开发 大象 项目时,所学习的开发资料以及参考的开源项目,稍微整理了一下,全当笔记记录,跟大家一起分享,也许能给正在使用 RxJava + Retrofit + MVP + Material Design 框架开发的人一个参考学习,如果有人从我分享的资料当中学习到东西,那是我的荣幸,希望大家能与我一起努力. 之前看到很多人都使用 RxJ

Rxjava+ReTrofit+okHttp深入浅出-终极封装

Rxjava+ReTrofit+okHttp深入浅出-终极封装 背景: 学习Rxjava和retrofit已经很长时间了,功能确实很强大,但是使用起来还是有点复杂,代码的重复性太高,所以决定把基于retrofit和rxjava的处理统一封装起来,实现的功能: 1.Retrofit+Rxjava+okhttp基本使用方法 2.统一处理请求数据格式 3.统一的ProgressDialog和回调Subscriber处理 4.取消http请求 5.预处理http请求 5.返回数据的统一判断 效果: 封装

Rxjava+ReTrofit+okHttp深入浅出-终极封装四(多文件下载之断点续传)

Rxjava+ReTrofit+okHttp深入浅出-终极封装四(多文件下载之断点续传) 背景 断点续传下载一直是移动开发中必不可少的一项重要的技术,同样的Rxjava和Retrofit的结合让这个技术解决起来更加的灵活,我们完全可以封装一个适合自的下载框架,简单而且安全! 效果 实现 下载和之前的http请求可以相互独立,所以我们单独给download建立一个工程moudel处理 1.创建service接口 和以前一样,先写接口 注意:Streaming是判断是否写入内存的标示,如果小文件可以

RxJava + Retrofit完成网络请求

1.前言 本文基于RxJava.Retrofit的使用,若是对RxJava或Retrofit还不了解的简友可以先了解RxJava.Retrofit的用法再来看这篇文章. 在这片文章之前分别单独介绍过Rxjava以及Retrofit的使用: Android Retrofit 2.0 的使用 Android RxJava的使用(一)基本用法 2.使用 在了解了RxJava和Retrofit分别的用法后,RxJava.Retrofit的搭配使用也就不再话下了. 先看看使用Retrofit完成一次网络请

手把手带你走进MVP +Dagger2 + DataBinding+ Rxjava+Retrofit 的世界

0.0 Android开发现在的变化用一个词来形容就是 :翻天覆地 越来越多的项目使用了MVP + Rxjava+Retrofit +Dagger2 + DataBinding等等东西.. 但是这些东西对于木有用过的同学们开起来还是比较头疼的. 转载请标明出处:http://blog.csdn.net/wingichoy/article/details/51981756 网上有很多介绍他们的教程,但是都比较详细(我听到有童鞋问:详细还不好?? 其实他们最好的学习方式还是边敲边踩坑边学,一下介绍的

RxJava+Retrofit实现网络请求

RxJava+Retrofit实现网络请求: 首先要添加依赖 compile 'io.reactivex:rxjava:x.y.z' compile 'io.reactivex:rxandroid:1.0.1' compile 'com.squareup.retrofit2:retrofit:2.0.2' compile 'com.squareup.retrofit2:converter-gson:2.0.2' compile 'com.squareup.retrofit2:adapter-rx

[android架构篇]mvp+rxjava+retrofit+eventBus

android架构篇 mvp+rxjava+retrofit+eventBus 高层不应该知道低层的细节,应该是面向抽象的编程.业务的实现交给实现的接口的类.高层只负责调用. 首先,要介绍一下一个项目中好架构的好处:好的软件设计必须能够帮助开发者发展和扩充解决方案,保持代码清晰健壮,并且可扩展,易于维护,而不必每件事都重写代码.面对软件存在的问题,必须遵守SOLID原则(面向对象五大原则),不要过度工程化,尽可能降低框架中模块的依赖性. 之前的一段时间,学习了一些新的技术,并把自己关注的技术整合

Rxjava + Retrofit 你需要掌握的几个经典技巧

本文出处 :Tamic 文/ http://blog.csdn.net/sk719887916/article/details/52132106 Rxjava +Rterofit 需要掌握的几个技巧 RXjava入门和详解请移步 比较有名的<RxJAVA详解>,这里继续前篇一些列的介绍一些容易忽略的技巧. Retrofit+RxJava结合系列请阅读: Retrofit 2.0 超能实践,完美支持Https传输 Retrofit2.0 完美同步Cookie实现免登录 Retrofit 2.0