在上一篇已经讲述了BaseAdapter的普通重写方法,并且对listview进行了加载适配器,现在我们来说说关于BaseAdapter的进一步的优化方法,之前的封装对象类的方法和xml文件代码我就不放了,没有看的童鞋去看下上一篇。
好,那么我们要优化它,主要是我们在重写getView()这个方法时候,对于每一个新的view都是创建一个新的view去加载,没有去用到getview()方法中的参数,而这个方法的参数却是很有用处,public View getView(int position, View convertView, ViewGroup parent){},covertView是表示那些已经没有显示但是缓存的界面布局,我们每次刷出新的item时候,可以去利用这些缓存的布局而不用说每次都去创建一个新的布局,能够大大的节省资源和增加程序的性能。
现在我们先新建一个ViewHolder类,去避免每次的空间声明。
package com.exam.listviewdemotest;
import android.widget.ImageView;
import android.widget.TextView;
public class ViewHolder {
public ImageView imageView;
public TextView textView_title;
public TextView textView_content;
}
在这里对各个控件先进行声明。然后到Adapter中去重写方法,代码如下:
public class MyAdapter extends BaseAdapter {
private List<MyItemObject> mList;
private LayoutInflater inflater;
public MyAdapter(Context context,List<MyItemObject> list) {
this.mList = list;
this.inflater = LayoutInflater.from(context);
}
@Override
public int getCount() {
// TODO Auto-generated method stub
return mList.size();
}
@Override
public Object getItem(int position) {
// TODO Auto-generated method stub
return mList.get(position);
}
@Override
public long getItemId(int position) {
// TODO Auto-generated method stub
return position;
}
@Override
public View getView(int position, View convertView, ViewGroup parent) {
ViewHolder viewHolder;
if (convertView == null) {
viewHolder = new ViewHolder();
convertView = inflater.inflate(R.layout.item, null);
viewHolder.imageView = (ImageView) convertView.findViewById(R.id.iv_image);
viewHolder.textView_title = (TextView) convertView.findViewById(R.id.tv_title);
viewHolder.textView_content = (TextView) convertView.findViewById(R.id.tv_content);
convertView.setTag(viewHolder);
}else {
viewHolder = (ViewHolder) convertView.getTag();
}
MyItemObject itemObject = mList.get(position);
viewHolder.imageView.setImageResource(itemObject.imageId);
viewHolder.textView_title.setText(itemObject.title);
viewHolder.textView_content.setText(itemObject.content);
return convertView;
}
}
这样我们就避免了多次的重复去声明,每次都只要从convertView缓存里面去找布局控件就行,这样就大大的减少了资源的浪费,最后再在主界面对listview进行加载适配器。
public class MainActivity extends ActionBarActivity {
private int[] res = new int[] { R.drawable.img1, R.drawable.img2,
R.drawable.img3, R.drawable.img4, R.drawable.img5, R.drawable.img6,
R.drawable.img7, R.drawable.img8, R.drawable.img9,
R.drawable.img10, R.drawable.img11, R.drawable.img12,
R.drawable.img13, R.drawable.img14, R.drawable.img15 };
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
List<MyItemObject> itemObjects = new ArrayList<MyItemObject>();
for (int i = 0; i < 15; i++) {
itemObjects.add(new MyItemObject(res[i], "这是第" + i + "个题目", "这是第"
+ i + "条内容"));
}
ListView listView = (ListView) findViewById(R.id.listView);
listView.setAdapter(new MyAdapter(this, itemObjects));
}
这样就完成了,运行的效果和上篇一样,所以不放效果图了,或许大家觉得没啥区别,但是如果碰到更加复杂的item内容界面,就会很明显的体现差别了。
落幕,鼓掌!end~