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


运行结果如下图


Adapter的一种写法 package com.xxkjx.jiusanqi; import java.util.List; import android.content.Context; import android.view.LayoutInflater; import android.view.View; import android.view.ViewGroup; import android.widget.BaseAdapter; import android.widget.ImageView; import android.widget.TextView; public class NewsListViewAdapter extends BaseAdapter { List<News> list; LayoutInflater inflater; Context context; public NewsListViewAdapter(List<News> list, Context context) { super(); this.list = list; this.context = context; inflater = LayoutInflater.from(context); } @Override public int getCount() { // TODO Auto-generated method stub return list.size(); } @Override public Object getItem(int position) { // TODO Auto-generated method stub return list.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) { // TODO Auto-generated method stub ViewHolder viewHolder = null; if (convertView == null) { convertView = inflater.inflate(R.layout.activity_news_list_item, null); viewHolder = new ViewHolder(); viewHolder.title = (TextView) convertView .findViewById(R.id.tv_news_title); viewHolder.publish = (TextView) convertView .findViewById(R.id.tv_news_publish); viewHolder.brief = (TextView) convertView .findViewById(R.id.tv_news_brief); viewHolder.image = (ImageView) convertView .findViewById(R.id.img_news); convertView.setTag(viewHolder); } else { viewHolder = (ViewHolder) convertView.getTag(); } viewHolder.title.setText(list.get(position).getTitle()); viewHolder.publish.setText(list.get(position).getPubblish()); viewHolder.brief.setText(list.get(position).getBrief()); viewHolder.image.setImageResource(list.get(position).getImg()); return convertView; } class ViewHolder { TextView title; TextView publish; TextView brief; ImageView image; } }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值