这篇文章将为大家详细讲解有关如何在Retrofit中利用Rxjava实现一个图片下载功能,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。
首先我们看一下Retrofit常规的用法,在不使用Rxjava的情况下,我们默认返回的是Call。
public interface ServiceApi { //下载文件 @GET Call<ResponseBody> downloadPicFromNet(@Url String fileUrl); }
但是如果我们要配合Rxjava使用,那么就要按照如下方式来重新定义我们的方法:
@GET Observable<ResponseBody> downloadPicFromNet(@Url String fileUrl);
返回一个Observable,方法名很直观就是从网络下载图片 参数是图片的URL路径
完成请求接口的定义,我们接下来创建Retrofit 对象
Retrofit retrofit = new Retrofit.Builder() .baseUrl(BASE_URL) .addCallAdapterFactory(RxJavaCallAdapterFactory.create()) //添加Rxjava .addConverterFactory(GsonConverterFactory.create()) // <span >定义转化器 可以将结果返回一个json格式</span> .build();
接下来我们给刚才定义的ServiceApi创建实例,通过上面创建的retrofit来创建
ServiceApi serviceApi = retrofit.create(ServiceApi.class);
ok,现在我们可以通过serviceApi来调用我们刚才定义的 downloadPicFromNet方法来下载一张图片,可以随意百度一张图片,复制图片地址来做测试。
serviceApi.downloadPicFromNet("https://cache.yisu.com/upload/information/20200623/125/129764.gif") .subscribeOn(Schedulers.newThread())//在新线程中实现该方法 .map(new Func1<ResponseBody, Bitmap>() { @Override public Bitmap call(ResponseBody arg0) { if(saveFileToDisc(arg0)) {//保存图片成功 Bitmap bitmap = BitmapFactory.decodeFile(getExternalFilesDir(null) + File.separator + "baidu.png"); return bitmap;//返回一个bitmap对象 } return null; } }) .observeOn(AndroidSchedulers.mainThread())//在Android主线程中展示 .subscribe(new Subscriber<Bitmap>() { ProgressDialog dialog = new ProgressDialog(MainActivity.this); @Override public void onStart() { dialog.show(); super.onStart(); } @Override public void onCompleted() { dialog.dismiss(); } @Override public void onError(Throwable arg0) { Log.d(TAG, "onError ===== " + arg0.toString()); } @Override public void onNext(Bitmap arg0) { imageIv.setImageBitmap(arg0); } });
上面的示例就实现了一个下载、保存、并展示的过程,跟传统的AsyncTask相比,代码很简洁,没有很多回调。当然在实际使用中还可以封装一层,把Retrofit 和 ServiceApi 的创建放在一个ServiceApiImpl的实现类中。
关于如何在Retrofit中利用Rxjava实现一个图片下载功能就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。