convertView重用和异步加载图片造成错乱问题解决

来源:互联网 发布:陶瓷行业进销存软件 编辑:程序博客网 时间:2024/04/30 03:50

  在使用ListView中的我们经常是这么使用,继承BaseAdapter,重写里面的方法,其中比较重要的方法就是getView方法,这个方法就是返回一个view来填充Listview的每个Item,但是如果我们每次都是重新创建View,当item数量很多时候,这样就很浪费内存。可以重用convertView和使用ViewHolder来进行性能的优化,经常见到的这样的

public View getView(int position, View convertView, ViewGroup parent) {         ViewHolder holder = null;         if(convertView == null){         convertView = mInflater.inflate(R.layout.list_item, null);         holder = new ViewHolder();        convertView.setTag(holder);}else{ holder = (ViewHolder) convertView.getTag();}}
然后进行控件的赋值,如果我们的图片是从网络上面进行加载,并且使用异步线程进行加载,就会出现当ListView进行滑动时,图片的位置错乱,这是因为重用了convertView,具体convertView重用的机制可以参考http://blog.csdn.net/harvic880925/article/details/25335957

  其实如果我们每个item只有一个imageview,第三方的图片加载库就可以完成,其中都有对bitmap的校对,但是如果是类似微博的需求,每个item有数量不定的imageview,这样还是会出现滑动错乱的问题,下面来简单说一下我的解决办法

  简单的思路就是给每个imageview设置一个Tag,然后再进行赋值的时候判断Tag是不是和当前的Tag相等,如果相等就加载并显示,如果不相等就隐藏,修改上面的getView方法

 public View getView(int position, View convertView, ViewGroup parent) {         ViewHolder holder = null;         if(convertView == null){         convertView = mInflater.inflate(R.layout.list_item, null);         holder = new ViewHolder();        convertView.setTag(holder);        setTags( holder,entity);}else{ holder = (ViewHolder) convertView.getTag();      holder.image1.setVisibility(View.GONE);      setTags( holder,entity);  }}private void setTags(ViewHolder holder, Entity entity) {if(entity.getWeibo_pic()!=null){holder.image1.setTag(String.valueOf(entity.getWeibo_pic().get(0)));}else{holder.image1.setTag(null);}}
在进行赋值的时候判断

if(holder.image1.getTag() ==pic2.get(i)){holder.image1.setVisibility(View.VISIBLE);mImageLoader.DisplayImage(pic2.get(i), holder.image1, false);}else{holder.image1.setVisibility(View.GONE);}


这里只写了一个imageview的,有多个imageview时,重用convertView时先设置为隐藏,然后通过判断在选择是否显示。这种方法只是解决了问题,但是依然比较复杂,如果有好的方法希望可以指出

0 0
原创粉丝点击