ListView—Adapter的使用

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;
	}
}


运行结果如下图


发布了9 篇原创文章 · 获赞 4 · 访问量 4410
展开阅读全文

没有更多推荐了,返回首页

©️2019 CSDN 皮肤主题: 编程工作室 设计师: CSDN官方博客

分享到微信朋友圈

×

扫一扫,手机浏览