ListView是最常见的控件之一,本文章主要说的是他的adapter的使用方法和分类。
其他adapter有三种方式:
1、ArrayAdapter(文本内容)
2、SimpleAdapter(图片、文本)
3、自定义的Adapter(更为复杂的布局)
先说第一种,最简单的
private ArrayAdapter<String> adapter;
绑定ListView控件,然后实例化一个ArrayAdapter对象
adapter = new ArrayAdapter<String>(this, android.R.layout.simple_list_item_1, data);
其中参数表示(上下文,item布局文件,数据源String[]);再创建一个String[] data = new String[20];利用for循环添加数据,之后ListView.setAdapter(adapter);就可以了
再说第二种SimpleAdapter,前期准备一样
private SimpleAdapter adapter;
private ListView listView;
private List<Map<String, Object>> data;
初始化ListView,实例化Adapter
listView = (ListView) findViewById(R.id.id_listView);
adapter = new SimpleAdapter(this, getData(), R.layout.item_layout, new String[] { "img", "text" },
new int[] { R.id.id_img, R.id.id_text });
其中构造函数中有5个参数(上下文,数据源,自定义的item布局文件,自定义String数组,自定义int数组);
到这里不懂别着急,下面会有解释
这是自定义item的布局文件
<ImageView
android:id="@+id/id_img"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:src="@drawable/ic_launcher" />
<TextView
android:id="@+id/id_text"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:text="这是文本内容" />
这里自定义一个方法用来获得构造函数中的第二个参数数据源
private List<Map<String, Object>> getData() {
data = new ArrayList<Map<String, Object>>();
for (int i = 0; i < 20; i++) {
Map map = new HashMap<String, Object>();
map.put("img", R.drawable.ic_launcher);
map.put("text", "这是测试数据" + i);
data.add(map);
}
return data;
}
最好进行listView.setAdapter(adapter);绑定Adapter即可。
接下用自定义Adapter来操作分3部
1、新建一个Bean类
2、自定义布局
3、自定义一个Adapter
4、绑定自定义的Adapter
第一步新建Bean类,提供get、set方法,有参无参构造函数
private int img;
private String title;
private String text;
第二部自定义布局文件
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="horizontal" >
<ImageView
android:id="@+id/id_img"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:src="@drawable/ic_launcher" />
<LinearLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:orientation="vertical"
android:padding="2dp" >
<TextView
android:id="@+id/id_title"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginLeft="3dp"
android:layout_marginTop="3dp"
android:text="标题" />
<TextView
android:id="@+id/id_text"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginLeft="3dp"
android:layout_marginTop="3dp"
android:text="今天是个好日子" />
</LinearLayout>
</LinearLayout>
第三部自定义Adapter
新建类MyAdapter继承BaseAdapter,并重写方法
public class MyAdapter extends BaseAdapter {
private LayoutInflater inflater;
private List<Bean> mData;
public MyAdapter(Context context, List<Bean> Data) {
inflater = LayoutInflater.from(context);
this.mData = Data;
}
// 要绑定的条目的数目
@Override
public int getCount() {
return mData.size();
}
// 根据一个索引(位置)获得该位置的对象
@Override
public Object getItem(int position) {
return mData.get(position);
}
// 获取条目的id
@Override
public long getItemId(int position) {
return position;
}
// 获取该条目要显示的界面
@Override
public View getView(int position, View convertView, ViewGroup parent) {
ViewHolder holder;
if (convertView == null) {
convertView = inflater.inflate(R.layout.item_layout, parent, false);
holder = new ViewHolder();
holder.mImg = (ImageView) convertView.findViewById(R.id.id_img);
holder.mTitle = (TextView) convertView.findViewById(R.id.id_title);
holder.mText = (TextView) convertView.findViewById(R.id.id_text);
convertView.setTag(holder);
} else {
holder = (ViewHolder) convertView.getTag();
}
Bean bean = mData.get(position);
holder.mImg.setImageResource(bean.getImg());
holder.mTitle.setText(bean.getTitle());
holder.mText.setText(bean.getText());
return convertView;
}
// 新建holder类,对listview进行简单优化
private class ViewHolder {
ImageView mImg;
TextView mTitle;
TextView mText;
}
}
运行结果如下图