一、直接使用ListView组件创建
1.直接在XML中创建ListView用entries属性附上一个数组资源
其中divider属性是设置分割线可以使用颜色和drawable资源分割
在values下定义一个数组资源文件arrays.xml
- 情景模式1
- 情景模式2
- 情景模式3
2.创建ArrayAdapter指定要显示的列表项
在oncreat方法中关联适配器
simple_list_item_1:列表项为普通文本
simple_list_item_2:列表项为普通文本字体略大
simple_list_item_checked:列表项为一个已选中的
simple_list_item_multiple_choice:带有复选框的列表项
simple_list_item_single_choice:带有单选按钮的列表项
listview = (ListView) findViewById(R.id.listView1); ArrayAdapteradapter = ArrayAdapter.createFromResource(this,R.array.ctype, android.R.layout.simple_list_item_checked); listview.setAdapter(adapter);
二、让Activity继承ListActivity实现
public class ActivityMain extends ListActivity { @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); String[] ctype ={"1","2","3"}; ArrayAdapteradapter = new ArrayAdapter (this,android.R.layout.simple_list_item_1,ctype); setListAdapter(adapter); } @Override protected void onListItemClick(ListView l, View v, int position, long id) { super.onListItemClick(l, v, position, id); } }
三、SimpleAdapter和BaseAapter的使用(重点)
SimpleAdapter的使用
在main.xml中添加ListView组件
编写用于布局列表项内容的布局文件items.xml
创建一个简单适配器与ListView关联
public class MainActivity extends Activity { @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.main); ListView listview = (ListView) findViewById(R.id.listView1); // 获取列表视图 int[] imageId = new int[] { R.drawable.img01, R.drawable.img02, R.drawable.img03, R.drawable.img04, R.drawable.img05, R.drawable.img06, R.drawable.img07, R.drawable.img08 }; // 定义并初始化保存图片id的数组 String[] title = new String[] { "保密设置", "安全", "系统设置", "上网", "我的文档", "GPS导航", "我的音乐", "E-mail" }; // 定义并初始化保存列表项文字的数组 List
三、BaseAdapter的使用及ListView的优化
使用方法同上主要是BaseAdapter的使用更加灵活也更加强大,可以向其中添加其他控件。
public class MainActivity extends Activity { private ListView lv; private Listinfos; private Random random; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); lv = (ListView) findViewById(R.id.listView1); infos = new ArrayList (); //通过for循环将name和number添加到List集合中 for (int i = 0; i < 100; i++) { MyInfo userInfo = new MyInfo(); userInfo.setName("name"+i); userInfo.setNumber("number"+i); infos.add(userInfo); System.out.println(userInfo.toString()); } lv.setAdapter(new MyAdapter()); } private class MyAdapter extends BaseAdapter{ @Override public int getCount() { return infos.size();//返回listview的长度 } @Override public View getView(int position, View convertView, ViewGroup parent) { MyInfo userInfo = infos.get(position); View view; ViewHolder holder; //减少内存中view对象创建的次数 if (convertView != null && convertView instanceof RelativeLayout) { view = convertView;//复用已经回收掉的view对象 holder = (ViewHolder) view.getTag();//得到他们的引用 } else { view = View.inflate(getApplicationContext(), R.layout.item_layout, null);//把布局文件转化成View对象 holder = new ViewHolder(); //把ID存到存到holder对象中 //注意是在view下findViewById holder.iv = (ImageView) view.findViewById(R.id.imageView1); holder.tv1 = (TextView) view.findViewById(R.id.textView1); holder.tv2 = (TextView) view.findViewById(R.id.textView2); view.setTag(holder);//对象创建出来时找到他们的引用存到holder中 } holder.tv1.setText(infos.get(position).getName()); holder.tv2.setText(infos.get(position).getNumber()); return view; } @Override public Object getItem(int position) { return null; } @Override public long getItemId(int position) { return 0; } } /* * view对象的容器记录View对象的内存地址相当于一个记事本 */ static class ViewHolder{ TextView tv1; TextView tv2; ImageView iv; } } public class MyInfo { private String name; private String number;//也可以添加Bitmap @Override public String toString() { return "MyInfo [name=" + name + ", number=" + number + "]"; } public String getName() { return name; } public void setName(String name) { this.name = name; } public String getNumber() { return number; } public void setNumber(String number) { this.number = number; } }
注意:(很多人不注意下面的这条语句是在view下findViewById,少了view会造成空指针异常)
holder.iv = (ImageView) view.findViewById(R.id.imageView1);
优化的原理就是动态循环复用已经回收掉的ListView对象(回收后为convertview),保持一个界面下的ListView的条目数的动态平衡。(具体内容参考代码注释即可)