转载请注明出处:王亟亟的大牛之路

本来周末就想发了然后各种拖拉就没有然后了,那么就今天早上写吧,废话不多開始正题

什么是RxJava或者RxAndroid我就不多废话了,理论知识一大堆人给我们做好了。仅仅要自己肯去看就能理解,我这里直接给出传送门:https://github.com/lzyzsd/Awesome-RxJava(非常丰富,看完就基本有概念了)


那么问题来了,人家都解释完了我干嘛?实操个简单的样例吧。正好上周讲了篇Glide的那么这次就实践下

效果图:

我们点开App然后就是一个RecycleView里面有一堆图然后还有文字,文字是本地的,图是网上下的。逻辑流程非常easy,来说一下怎么实现的然后引出主角。

包结构:

GlideModuleConfig配置Glide

StatusBarCompat沉浸式菜单条实现(翔哥那扣来的,这个事实上可有可无主要默认的颜色太丑)

TestOBJ页面对象的属性模型(你也能够不用,个人习惯)

然后就是业务实现的MainActivity和适配器DataAdapter了

我们一个一个类看先是GlideModuleConfig

/**
* Created by jiajiewang on 16/3/25.
*/
public class GlideModuleConfig implements GlideModule { //在这里创建设置内容,之前文章所提及的图片质量就能够在这里设置
//还能够设置缓存池參数什么的
@Override
public void applyOptions(Context context, GlideBuilder builder) {
//设置了默认图片格式
builder.setDecodeFormat(DecodeFormat.PREFER_ARGB_8888);
//设置了缓存的位置
builder.setDiskCache(new ExternalCacheDiskCacheFactory(context,"MY_CACHE_LOCATION", 100*1024*1024));
} //在这里注冊ModelLoaders
@Override
public void registerComponents(Context context, Glide glide) { }
}

这里做一些配置工作,详细干什么能够看凝视

TestOBJ用于给RecycleView引用图片地址和文字内容

public class TestOBJ {
public String imageUrl;
public String content;
}

翔哥那个类不解释了,能够自己去搜搜百度第一条就是。我们再来看看适配器

DataAdapter(重要步骤的解释也在凝视里了)

public class DataAdapter extends RecyclerView.Adapter {
Context context;
List<TestOBJ> testOBJs; public DataAdapter(Context context) {
this.context = context;
} //获取布局
@Override
public RecyclerView.ViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {
View view = LayoutInflater.from(parent.getContext()).inflate(R.layout.item_layout, parent, false);
return new DataViewHolder(view);
} //详细item的载入图片填充数据
@Override
public void onBindViewHolder(RecyclerView.ViewHolder holder, int position) {
DataViewHolder dataViewHolder = (DataViewHolder) holder;
TestOBJ obj = testOBJs.get(position);
//先获取上下文对象,再载入详细的URL然后填充到控件里去
Glide.with(holder.itemView.getContext()).load(obj.imageUrl).into(dataViewHolder.imageIV);
dataViewHolder.contentTV.setText(obj.content);
} @Override
public int getItemCount() {
return testOBJs == null ? 0 : testOBJs.size();
} //控件对象Holder
static class DataViewHolder extends RecyclerView.ViewHolder {
ImageView imageIV;
TextView contentTV; public DataViewHolder(View itemView) {
super(itemView);
imageIV = (ImageView) itemView.findViewById(R.id.imageIV);
contentTV = (TextView) itemView.findViewById(R.id.contentTV);
}
} //刷新数据用
public void updateData(List<TestOBJ> testOBJs) {
this.testOBJs = testOBJs;
notifyDataSetChanged();
}
}

数据层已经OK了,我们来看看业务层

public class MainActivity extends AppCompatActivity {
Toolbar toolBar;
RecyclerView recycleView;
DataAdapter dataAdapter;
//URL数据源
String data[] = {"http://hiphotos.baidu.com/zhixin/abpic/item/4651a712c8fcc3cea97dbce49045d688d53f206c.jpg"
, "http://pic.5442.com/2014/0930/06/5442.jpg",
"http://img5q.duitang.com/uploads/item/201410/22/20141022214043_5EEKH.thumb.224_0.jpeg",
"http://img5.duitang.com/uploads/item/201512/08/20151208163159_HGEM2.thumb.224_0.png",
"http://img4.duitang.com/uploads/item/201510/29/20151029224537_ijEKF.thumb.224_0.jpeg",
"http://img5.imgtn.bdimg.com/it/u=1230273521,1023320328&fm=21&gp=0.jpg"
}; //被观察者
Observable observable = Observable.create(new Observable.OnSubscribe<List<TestOBJ>>() {
@Override
public void call(Subscriber<? super List<TestOBJ>> subscriber) {
subscriber.onNext(makeData());
subscriber.onCompleted();
}
}); //观察者
Observer<List<TestOBJ>> observer = new Observer<List<TestOBJ>>() { @Override
public void onCompleted() {
LogUtils.d("--->onCompleted");
} @Override
public void onError(Throwable e) {
Toast.makeText(MainActivity.this, "载入失败", Toast.LENGTH_SHORT).show();
} @Override
public void onNext(List<TestOBJ> testOBJs) {
testOBJs.size();
LogUtils.d("--->onNext testOBJs.size() " + testOBJs.size());
//刷新数据
dataAdapter.updateData(testOBJs);
}
}; @Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main); init();
logic();
setSupportActionBar(toolBar);
StatusBarCompat.compat(this, getResources().getColor(R.color.status_bar_color));
StatusBarCompat.compat(this);
} private void init() {
LogUtils.d("--->init");
toolBar = (Toolbar) findViewById(R.id.toolBar);
recycleView = (RecyclerView) findViewById(R.id.recycleView); observable.subscribeOn(Schedulers.io())
.observeOn(AndroidSchedulers.mainThread())
.subscribe(observer); } private void logic() {
LogUtils.d("--->logic");
dataAdapter = new DataAdapter(MainActivity.this);
recycleView.setLayoutManager(new LinearLayoutManager(MainActivity.this));
recycleView.setAdapter(dataAdapter); LogUtils.d("--->Glide.getPhotoCacheDir " + Glide.getPhotoCacheDir(MainActivity.this, "MY_CACHE_LOCATION")); } //制造数据
private List<TestOBJ> makeData() {
List<TestOBJ> list = new ArrayList<>();
TestOBJ testOBJ;
for (int k = 0; k < 5; k++) {
testOBJ = new TestOBJ();
testOBJ.content = "标题啊,你服不服 " + k + " 个 ";
testOBJ.imageUrl = data[k];
list.add(testOBJ);
}
LogUtils.d("--->list的长度等于 " + list.size());
return list;
} @Override
protected void onPause() {
super.onPause();
//清除请求
Glide.clear(recycleView);
} @Override
protected void onDestroy() {
super.onDestroy();
LogUtils.d("--->onDestroy");
//必须主线程使用
Glide.get(this).clearMemory();
//Glide.get(this).clearDiskCache(); 非主线程
}
}

解释:

我们定义了一个观察者和一个被观察者然后自从

 observable.subscribeOn(Schedulers.io())
.observeOn(AndroidSchedulers.mainThread())
.subscribe(observer);

注冊的行为開始后,仅仅咬被观察者一有风吹草动,观察者的相关回调就会被触发,我们来看下Log的打印顺序



还是在一堆的Activity生命周期里先跑在我们数据摸你的过程中看了可能我们Glide缓存的文件夹,跟我们的预设一致,接着就运行了 onNext再是onCompleted。由于没出什么意外也就没刷出onError

/data/user/0/sample.wjj.rxandroidglidedemo/cache/MY_CACHE_LOCATION

源代码地址:https://github.com/ddwhan0123/RxAndroidDemo

初涉RxAndroid结合Glide实现多图片载入操作的更多相关文章

  1. Android图片载入框架最全解析(一),Glide的基本使用方法

    转载请注明出处:http://blog.csdn.net/guolin_blog/article/details/53759439 本文同步发表于我的微信公众号.扫一扫文章底部的二维码或在微信搜索 郭 ...

  2. Android图片载入缓存框架Glide

    Glide开源框架是Google推荐的图片载入和缓框架,其在Github上的开源地址是:https://github.com/bumptech/glide 当然一个Google推荐的框架肯定就是Vol ...

  3. Universal-Image-Loader(UIL)图片载入框架使用简介

    这个也是近期项目中使用到的第三方图片载入框架.在这里也自己总结一下,简单的介绍一些使用的方式. UIL图片载入框架特点 简单介绍: 项目地址:https://github.com/nostra13/A ...

  4. Android Glide加载图片时转换为圆形、圆角、毛玻璃等图片效果

     Android Glide加载图片时转换为圆形.圆角.毛玻璃等图片效果 附录1简单介绍了Android开源的图片加载框架.在实际的开发中,虽然Glide解决了快速加载图片的问题,但还有一个问题悬 ...

  5. Cocos2d-x 3.0心得(01)-图片载入与混合模式

    近期開始用cocos2dx 3.0做东西,略有心(cao)得(dian),略微作下记录吧. v3.0相对v2.2来说,最引人注意的,应该是对触摸层级的优化.和lambda回调函数的引入(嗯嗯.不枉我改 ...

  6. RoundedImageView使用吐槽心得(RoundedImageView与Glide加载图片,第一次加载无法圆角问题)

    最近使用的时候发现一个问题, RoundedImageView与Glide搭配使用的时候,第一次加载图片(内存中没有),后图片无法圆角,后来尝试各种改,最后想到了一个办法,就是让Glide加载图片的 ...

  7. Glide加载图片缓存库出现——You cannot start a load for a destroyed activity

    请记住一句话:不要再非主线程里面使用Glide加载图片,如果真的使用了,请把context参数换成getApplicationContext.

  8. Android图片加载框架最全解析(五),Glide强大的图片变换功能

    大家好,又到了学习Glide的时间了.前段时间由于项目开发紧张,再加上后来又生病了,所以停更了一个月,不过现在终于又可以恢复正常更新了.今天是这个系列的第五篇文章,在前面四篇文章的当中,我们已经学习了 ...

  9. Android批量图片载入经典系列——afinal框架实现图片的异步缓存载入

    一.问题描写叙述 在之前的系列文章中,我们使用了Volley和Xutil框架实现图片的缓存载入,接下来我们再介绍一下afinal 框架的使用. Afinal 是一个android的http框架.sql ...

随机推荐

  1. Solr4:配置Data Import,从数据库直接创建索引

    1. 要求 将数据库中的数据直接创建到Solr索引中去.先做全部索引,然后定期做增量索引. 2. 环境 Solr4.4版本,Tomcat7.0版本,Oracle 11g,已经配置好Tomcat与Sol ...

  2. TransitionsTest

    CCTransitionScene* createTransition(int nIndex, float t, CCScene* s) { // fix bug #486, without setD ...

  3. angular学习笔记(三)-视图绑定数据的两种方式

    绑定数据有两种方式: <!DOCTYPE html> <html ng-app> <head> <title>2.2显示文本</title> ...

  4. selenium初探:WebDriverException解决方法探索(以Chrome浏览器|IE浏览器|Edge浏览器为例)

    环境参考:win10-64位, python3.6.3, selenium3.7 在初试selenium运行以下代码时 from selenium import webdriver browser = ...

  5. HttpClient 教程 (五)

    第五章 HTTP客户端服务 5.1 HttpClient门面 HttpClient接口代表了最重要的HTTP请求执行的契约.它没有在请求执行处理上强加限制或特殊细节,而在连接管理,状态管理,认证和处理 ...

  6. ClouderaManager之CDH-LZO配置

    CDH-LZO配置 下载和CDH版本对应的hadoop-lzo版本 如下: 下载地址:http://archive.cloudera.com/gplextras5/parcels/ 需要下载如下三个文 ...

  7. js队列的实现问题

    所谓队列就是排队的序列问题,有出有进,比如在银行排队办理业务,一般都是前一个办理完成后下一个自动进入队列 <script>  /* * 模拟队列 */ var Qu ={}; //构造函数 ...

  8. HTML DOM addEventListener() 方法

    实例 为 <button> 元素添加点击事件. 当用户点击按钮时,在 id="demo" 的 <p> 元素上输出 "Hello World&quo ...

  9. LeetCode: Max Points on a Line 解题报告

    Max Points on a Line Given n points on a 2D plane, find the maximum number of points that lie on the ...

  10. android 使用 sqlite

    SQLiteHelper .class  (升级的时候,做点小技巧) package com.keyue.qlm.util;  import android.content.Context;  imp ...