ListView异步加载网络图片之二
上一篇文章中卖了一个关子,遗留下来两个bug,不知道有没有同学发现,或者已经解了,那么这一篇文章我将解决其中一个bug(呵呵继续卖。。。)
问题描述:当我们把列表向下滚动再向上滚动反复的操作,本来应该是iteye的logo和妮露(看死神的同学应该知道)交替显示的,但是悲剧却发生了,图片乱了。
问题产生的原因:由于listview中列表项的view是复用的,当后台返回图片,并执行onPostExecute方法中调用这一句mViewHolder.mImageView.setImageBitmap(result)的时候,他会影响到所有复用的item,而这个时候你的列表已经滚动了,所以你就看到图片显示不正常了。
问题解决方案:根据问题产生的原因,我们就不要在onPostExecute方法中去调用mViewHolder.mImageView.setImageBitmap(result)方法,那么我们应该在哪儿调用呢?这儿不调用,那么我们的imageview怎么知道图片已经下载好了呢?我们只需要调用adapter的notifyDataSetChanged()方法,他会触发getView方法的调用,而在getView方法中就直接去缓存中拿图片了(这样在屏幕可见范围的item都是正常的,不可见的无聊他显示神马我们都不用关心),所以在onPostExecute方法中我们只需要将下载好的图片放入缓存,并且通知adapter数据发生了变化。
class ImageLoadTask extends AsyncTask<Object, Void, Bitmap> {
int position;
@Override
protected Bitmap doInBackground(Object... params) {
String url = (String) params[0];
position = (Integer) params[1];
Bitmap drawable = ImageLoader.loadImage(url);// 获取网络图片
return drawable;
}
@Override
protected void onPostExecute(Bitmap result) {
if (result == null) {
return;
}
/**
* 由于列表项的view是复用的,所以所有复用的view的图片都会被改变
*/
//mViewHolder.mImageView.setImageBitmap(result);
cacheImage(position, result);// 放入缓存
/**
* 通知数据发生改变,会触发adapter的getView方法调用
* 将视图的更新统一到getView方法去调用,因为我们只需要关心屏幕内的内容
* 屏幕中看不到的内容我们是不需要去调用setImageBitmap这个方法的
*/
notifyDataSetChanged();
}
}
总结:说了这么多,我也不知道看这篇文章的同学能不能够看懂,这个问题还是挺绕的,我的文字表达能力很有限。如果不明白的可以单聊。当然这个bug是解决了,还有一个更严重的bug,可以直接让我们脆弱的demo崩掉,不信你试一试,预知详解,敬请关注下一期博客
分享到:
相关推荐
android listview 异步加载网络图片
ListView异步加载网络图片,SoftReference,有重复的Url直接返回资源
简洁 明确 listview异步加载图片
Android Listview异步加载图片,图片错位解决方案
listview异步加载
Android实现ListView异步加载图片
listview异步加载图片,使用到了强引用
android listview异步加载图片实例 用到了线程池 下载的图片会保存到本地 并在数据库中保留记录 再次加载时会直接从本地读取
Android 异步加载图片,对ListView的异步加载图片的功能演示,主要根据url读取图片返回流的方法。为了方便演示,将请求图片的链接先固定,每读取好一个图片就更新,界面比较简单,当然你可以做成比较好的,像很多好...
实现了异步加载图片进度条,代码更具有规范性
Android初学者之Listview异步加载网络图片并动态更新编程小技巧共13页.pdf.zip
listview 异步加载图片
本文实例讲述了Android实现Listview异步加载网络图片并动态更新的方法。分享给大家供大家参考,具体如下: 应用实例:解析后台返回的数据,把每条都显示在ListView中,包括活动图片、店名、活动详情、地址、电话和...
android listview异步加载网络图片,需要的可以直接移植到项目中
BitMap高效显示策略(二):在ListView上异步加载网络图片 http://blog.csdn.net/ohehehou/article/details/40678741