关闭

ListView 使用 ViewHolder

2005人阅读 评论(0) 收藏 举报
Adapter是ListView界面与数据之间的桥梁,当列表里的每一项显示到页面时,都会调用Adapter的getView方法返回一个View。如果列表中有很多的项时会占用极大的系统资源,所以我们需要优化Adapter 

1、convertView的使用 
[java] view plaincopy
  1. Java代码   
  2. public View getView(int position, View convertView, ViewGroup parent) {   
  3. ViewHolder holder;   
  4. if (convertView == null)   
  5. {   
  6. //加载ListView item的布局文件   
  7. convertView = mInflater.inflate(R.layout.list_item_icon_text, null);   
  8. holder = new ViewHolder();   
  9. holder.text = (TextView) convertView.findViewById(R.id.text);   
  10. holder.icon = (ImageView) convertView.findViewById(R.id.icon);   
  11. /**  
  12. * 利用holder,调用convertView.setTag函数  
  13. * 使得convertView创建的内存地址,不为空。  
  14. * 然后调用getTag来获得当前位置的tag  
  15. * 最后利用holder的各种set操作来替换当前位置的tag。  
  16. */   
  17. convertView.setTag(holder);   
  18. }   
  19. else   
  20. {   
  21. holder = (ViewHolder) convertView.getTag();   
  22. }   
  23. holder.text.setText(DATA[position]);   
  24. holder.icon.setImageBitmap((position & 1) == 1 ? mIcon1 : mIcon2);   
  25. return convertView;   
  26. }   
  27. static class ViewHolder {   
  28. private TextView text;   
  29. private ImageView icon;   
  30. }   


上面这种方式对于每个View使用了一个ViewHolder来控制其内部的子item还使用了setTag和getTag的方法 将holder绑定到了view上而不是直接的新建View 是对Adapter的优化。 

2、测试getView被调用的次数 
假设做一个动态刷新的ListView,发现显示的adapter.notifyDataSetChanged()的速度有点慢 那么可以测试下getView调用的次数 是不是太多。调用的次数多的让你觉着莫名其妙 那么说明 肯定是有问题的 一定会影响性能的。 
更改方法: 
Xml代码 
[html] view plaincopy
  1. <ListView android:id="@+id/list"   
  2. android:layout_width="fill_parent"   
  3. android:layout_height="wrap_content" />   



将android:layout_height="wrap_content"修改成:android:layout_height="fill_parent"就可以了。 
如果更改以后没用,ListView周围的控件也是"wrap_content"那么也需要修改。 

3、关于ListView 对于纯色的item背景 其实可以直接设置BackgroundColor 而不要使用图片 这一部分其实可以有不小的提升 同样的 对于任何纯色的背景 应该尽量去设置RGB颜色 而不是全用一张图片做背景。
1
0

查看评论
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场
    个人资料
    • 访问:136377次
    • 积分:1236
    • 等级:
    • 排名:千里之外
    • 原创:14篇
    • 转载:7篇
    • 译文:1篇
    • 评论:26条
    最新评论