好了,今天就通过一个瀑布流demo,来使用Volley框架请求网络图片。
前言:
我们使用NetworkImageView显示图片:
1、因为该控件可以自动的管理好请求的生命周期,当与父控件detach或者它移出屏幕时可以自动取消网络请求
2、该控件会根据我们所设置的NetworkImageView宽高来进行图片的压缩
3、该控件可以设置默认状态下显示的图片,可以设置在请求失败时候显示的图片
还用了ImageLoader来加载图片,使用ImageCache缓存来防止程序OOM,由于Volley自动会处理硬盘缓存,所以在没网情况下它还是能正常显示图片
好了,我先来看看效果吧:
由于gif上传大小限制,我就录了前一部分,我们从这部分的效果就可以看出,在加载图片时候,默认时会先显示我们设置的默认的图片,然后通过网络加载,再显示加载到的图片,因为ImageCache自动管理了内存缓存、而NetworkImageView又自动会根据它自身的宽高来压缩图片,所以即使图片数量多、图片大小比较大也可以很好的避免OOM。
下面我们打开缓存目录来看下缓存的文件:
现在我们把网络断开,来看看效果:
可以看到,在没有网络状态下,还是可以加载出图片,因为它会从缓存中取,即:
在没有网络的条件下会自动从缓存中取数据,在有网络的状态下,会先判断缓存中有没有该缓存文件,如有则取出,没有则开启网络请求获取,再存入硬盘缓存中。
好了,代码就贴个主要的:
RecyclerView适配器:
public class RecyclerAdapter extends RecyclerView.Adapter<RecyclerViewHolder> {
private Context mContext;
private List<String> datas;
private ImageLoader mImageLoader;
private BitmapCache mBitmapCache;
private List<Integer> heights;
public RecyclerAdapter(Context context, List<String> datas) {
this.mContext = context;
this.datas = datas;
getRandomHeights();
mBitmapCache = new BitmapCache();
mImageLoader = new ImageLoader(MyApplication.getRequestQueue(), mBitmapCache);
}
private void getRandomHeights() {
heights = new ArrayList<>();
for (int i = 0; i < datas.size(); i++) {
heights.add((int) (300 + Math.random() * 200));
}
}
@Override
public RecyclerViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {
View view = LayoutInflater.from(mContext).inflate(R.layout.layout_item, parent, false);
RecyclerViewHolder holder = new RecyclerViewHolder(view);
return holder;
}
@Override
public void onBindViewHolder(RecyclerViewHolder holder, int position) {
ViewGroup.LayoutParams params = holder.itemView.getLayoutParams();
params.height = heights.get(position);
holder.itemView.setLayoutParams(params);
holder.mNetworkImageView.setDefaultImageResId(R.mipmap.ic_crop_original_black_48dp);
holder.mNetworkImageView.setErrorImageResId(R.mipmap.ic_filter_hdr_black_48dp);
holder.mNetworkImageView.setImageUrl(datas.get(position), mImageLoader);
}
@Override
public int getItemCount() {
return datas.size();
}
}
BitmapCache代码:
public class BitmapCache implements ImageLoader.ImageCache {
private LruCache<String,Bitmap> mLruCache;
public BitmapCache(){
int maxMemory = (int) Runtime.getRuntime().maxMemory();
int maxCacheSize = maxMemory/8;
mLruCache = new LruCache<String,Bitmap>(maxCacheSize){
@Override
protected int sizeOf(String key, Bitmap value) {
return value.getByteCount();
}
};
}
@Override
public Bitmap getBitmap(String s) {
return mLruCache.get(s);
}
@Override
public void putBitmap(String s, Bitmap bitmap) {
mLruCache.put(s,bitmap);
}
}
版权声明:本文为博主原创文章,未经博主允许不得转载。转载注明出处:http://blog.csdn.net/u010687392
原文地址:http://blog.csdn.net/u010687392/article/details/47682641