在《Android网络请求框架------Retrofit的使用1》中,简单介绍了Retrofit的基本使用,本节就介绍一下Rxjava配合Retrofit的使用。
在使用之前,首先添加Rxjava的依赖
implementation 'io.reactivex.rxjava2:rxjava:2.1.0'
implementation 'io.reactivex.rxjava2:rxandroid:2.0.1'
implementation 'com.squareup.retrofit2:adapter-rxjava2:2.7.1'
在Retrofit加载的接口中,就不再使用Call对象,使用Observable对象。
@GET("getAppConfig.php")
Observable<DataBean> getData(
@Query("appid") String appid
);
和Call对象做一下对比:
@GET("getAppConfig.php")
public Call<DataBean> getData(
@Query("appid") String appid
);
在创建Retrofit对象的时候,要添加RxJava适配平台;这个时候,去加载接口中的方法,将不再是得到Call对象,而是得到一个Observable对象,这个Observable对象会将请求的结果通过onNext()方法发出,然后将数据回调,剩下的步骤和之前纯Retrofit基本一致。
Retrofit retrofit = new Retrofit.Builder()
.baseUrl(Constant.BASE_URL_GET)
.addConverterFactory(GsonConverterFactory.create())
.addCallAdapterFactory(RxJava2CallAdapterFactory.create())
.build();
DataService dataService = retrofit.create(DataService.class);
Observable<DataBean> observable = dataService.getData(appid);
observable.subscribeOn(Schedulers.io())
.subscribe(new Consumer<DataBean>() {
@Override
public void accept(DataBean dataBean) throws Exception {
String url = dataBean.getUrl();
callback.complete(url);
}
});
在接口类中,还支持Response类,如下:
@GET("getAppConfig.php")
Observable<Response<DataBean>> getData2(
@Query("appid") String appid
);
那么最终得到的就是一个Response对象,可以根据body得到对应的参数。
public void loadData(String appid, DataCallback callback) {
Retrofit retrofit = new Retrofit.Builder()
.baseUrl(Constant.BASE_URL_GET)
.addConverterFactory(GsonConverterFactory.create())
.addCallAdapterFactory(RxJava2CallAdapterFactory.create())
.build();
DataService dataService = retrofit.create(DataService.class);
Observable<Response<DataBean>> observable = dataService.getData2(appid);
observable.subscribeOn(Schedulers.io())
.subscribe(new Consumer<Response<DataBean>>() {
@Override
public void accept(Response<DataBean> dataBeanResponse) throws Exception {
DataBean body = dataBeanResponse.body();
Log.e("TAG","body==="+body.toString());
callback.complete(body.getUrl());
}
});
}
那么为什么喜欢RxJava呢?因为它的操作符,灵活运用这些操作符,就可能让我们的功能实现地更加简单,在后续的章节中,会陆续介绍这些操作符的用法。