在使用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时先设置为隐藏,然后通过判断在选择是否显示。这种方法只是解决了问题,但是依然比较复杂,如果有好的方法希望可以指出