Glide 加载图片

  //通过model获取到图片的url,将Url转换成bitmap对象;
  //设置不保存内存和硬盘缓存,
1 Glide.with(mContext).load(model.getVideoUrl()).asBitmap()
.diskCacheStrategy(DiskCacheStrategy.NONE)
.skipMemoryCache(true)
.into(new SimpleTarget<Bitmap>() {
@Override
public void onResourceReady(Bitmap resource, GlideAnimation<? super Bitmap> glideAnimation) {
if (null != resource) {
//holder.smallVideo_gl.setForeground(new BitmapDrawable(mContext.getResources(), resource));
holder.smallVideo_gl.setBackground(new BitmapDrawable(mContext.getResources(), resource));
}
}
});
 /****
*使用Glide加載URL圖片時有緩存
*/
public static void ImageNeedMerryWithUrl(Context context, String imagePath, ImageView imageView){
Glide.with(context).load(imagePath).into(imageView);
}
/****
*使用Glide加載本地圖片時有緩存
*/
public static void ImageNeedMerryWithId(Context context, int imageId, ImageView imageView){
Glide.with(context).load(imageId).into(imageView);
}
/****
*使用Glide加載圖片時不添加緩存
*/
public static void ImageNotMerry(Context context, String imagePath, ImageView imageView){
Glide.with(context).load(imagePath).diskCacheStrategy( DiskCacheStrategy.NONE ).skipMemoryCache(true).into(imageView);
}

项目开发中遇到使用Glide中的placeholder方法的进行设置占位图(在我们使用了CircleImageView自定义的圆形头像中加载图片)的效果;使用这个方法,会导致图片第一次加载的老是占位图,在ListView上下滑动后,才能正常显示。

(一)第一开始自己图省事,为了解决问题,并没有采用placeholder的方法,而是直接

holder.iv_homepage_dypost_head.setImageDrawable(context.getResources().getDrawable(R.mipmap.homg_ctf_touxiangdian));
Glide.with(context).load(dynamticModel.getHeadImgUrl()).error(R.mipmap.homg_ctf_touxiangdian).dontAnimate().into(holder.iv_homepage_dypost_head);
在加载图片之前,先代码设置一张图片。

(二)但是后来同事又遇到了这个问题,所以才想搜索解决这个问题:发现了http://www.jianshu.com/p/4a3177b57949/comments/902902这个楼主发表的帖子,发现了使用下面方法,就可以解决图片第一开始不显示的问题了。

Glide.with(cnt).load(headUrl)
.asBitmap()
.animate(R.anim.umeng_socialize_fade_in)//淡入动画效果
.placeholder(R.mipmap.homg_ctf_touxiangdian)
.error(R.mipmap.homg_ctf_touxiangdian)
.dontAnimate()
.into(holder.iv_head); 问题三:在ListView中使用Glide加载多张图片时,可能会出现卡顿的现象。
我们项目中使用的LoadListView来实现下拉加载;里面的方法监听是不是在滚动结束后加载图片
  @Override
public void onScrollStateChanged(AbsListView view, int scrollState) {
switch(scrollState){
case AbsListView.OnScrollListener.SCROLL_STATE_IDLE://空闲状态
Glide.with(mContext).resumeRequests();//在停止滑动的情况下,请求加载图片
if (totalItemCount == lastVisibleItem){
if(canLoad) {
//Glide.with(mContext).pauseRequests();
if (!isLoading) {//不是正在加载
isLoading = true;
//加载更多
footerview.setVisibility(View.VISIBLE);
if (listener != null) {
listener.onLoad();
}
}
}/*else{
18 Glide.with(mContext).resumeRequests();
19 }*/
}
break;
case AbsListView.OnScrollListener.SCROLL_STATE_FLING://滚动状态
Glide.with(mContext).pauseRequests();//在滚动状态时,取消加载
break;
case AbsListView.OnScrollListener.SCROLL_STATE_TOUCH_SCROLL://触摸后滚动
Glide.with(mContext).pauseRequests();
break;
}
}

问题:设置头像所在布局的模糊效果:使用Glide返回一个bitmap;设置模糊效果:会出现问题Glide 加载图片

                    Glide.with(context).load(userModel.getHEAD_IMAGE()).asBitmap().diskCacheStrategy(DiskCacheStrategy.NONE)
.skipMemoryCache(true)
.into(new SimpleTarget<Bitmap>() {
@Override
public void onResourceReady(Bitmap resource, GlideAnimation<? super Bitmap> glideAnimation) {
if(null!=resource) {
//blur_bitmap = Blur.fastblur(MyInfoActivity.this,resource, 5);
//rl_head_bg.setBackground(new BitmapDrawable(getResources(), blur_bitmap)); //给图片
//rl_head_bg.setBackground(new BitmapDrawable(getResources(), resource)); //直接设置将获取到的bitmap展示给布局,图片显示是放大;但是没有模糊小效果
iv_head.setImageBitmap(resource);
}
}
});

暂时的解决方案:

Thread  myThread=new Thread(new Runnable() {
@Override
public void run() {
blur_bitmap = Blur.fastblur(MyHomePageActivity.this, ImageUtils.returnBit(imgHeaderUrl), );
runOnUiThread(new Runnable() {
@Override
public void run() {
rl_head_bg.setBackground(new BitmapDrawable(getResources(), blur_bitmap));
}
});
}
});
myThread.start();
/*try {
myThread.join();//是在子线程请求完成后;再设置头像布局背景;当时导致界面展示有点卡顿
} catch (InterruptedException e) {
e.printStackTrace();
}
rl_head_bg.setBackground(new BitmapDrawable(getResources(), blur_bitmap));
*/
上一篇:浅谈Linux下CPU利用率和CPU负载【转】


下一篇:[Effective JavaScript 笔记] 第14条:当心命名函数表达式笨拙的作用域