Android开发系列(十九):为SimpleAdapter设置样式

Adapter的作用:数据在adapter中做了处理之后,显示在视图上

一般的对于ArrayAdapter来说,只需要把一个数组和一个样式传递给ArrayAdapter之后就可以在视图上用一个列表显示出这个字符串数组。

例如下边的代码:

listView.setAdapter(new ArrayAdapter(this,android.R.layout.simple_list_item_1,ls)); 


但是,比如我们手机的联系人目录所示,不仅仅是有列表,而且有头像,可能还有手机号码。所以,单纯的ArrayAdapter是不能够实现这种复杂的视图的。
我们可以用SimpleAdapter来实现这种复杂的视图,不过需要设计样式。


我们新建一个Android项目,然后,我们在layout目录下定义一个ListView,来存放列表:

main.xml:







在定义这个之后,我们就可以写java代码了:

SimpleAdapterTest.java:

package org.crazyit.ui;

import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;

import android.app.Activity;
import android.graphics.Color;
import android.os.Bundle;
import android.view.View;
import android.widget.AdapterView;
import android.widget.AdapterView.OnItemClickListener;
import android.widget.AdapterView.OnItemSelectedListener;
import android.widget.ListView;
import android.widget.SimpleAdapter;
import android.widget.TextView;
import android.widget.Toast;

public class SimpleAdapterTest extends Activity
{
	private String[] names = new String[]
		{ "虎头", "弄玉", "李清照", "李白"};
	private String[] descs = new String[]
		{ "可爱的小孩", "一个擅长音乐的女孩"
			, "一个擅长的文学的女性", "浪漫主义诗人"};	
	//这是三张图片的id的集合
	private int[] imageIds = new int[]
		{ R.drawable.tiger , R.drawable.nongyu
		, R.drawable.qingzhao , R.drawable.libai};

	@Override
	public void onCreate(Bundle savedInstanceState)
	{
		super.onCreate(savedInstanceState);
		setContentView(R.layout.main);
		
		// 创建一个List集合,List集合的元素是Map
		List> listItems = new ArrayList>();
		for (int i = 0; i < names.length; i++)
		{
			Map listItem = new HashMap();
			listItem.put("header", imageIds[i]);
			listItem.put("personName", names[i]);
			listItem.put("desc", descs[i]);
			listItems.add(listItem);
		}
		// 创建一个SimpleAdapter
		SimpleAdapter simpleAdapter = new SimpleAdapter(this, listItems,
			R.layout.simple_item, 
			new String[] { "personName", "header" , "desc"},
			new int[] { R.id.name, R.id.header , R.id.desc });
		
		ListView list = (ListView) findViewById(R.id.mylist);
		// 为ListView设置Adapter
		list.setAdapter(simpleAdapter);
		// 为ListView的列表项单击事件绑定事件监听器
		list.setOnItemClickListener(new OnItemClickListener()
		{
			// 第position项被单击时激发该方法。
			@Override
			public void onItemClick(AdapterView parent, View view,
					int position, long id)
			{
				Toast.makeText(getApplicationContext(), names[position]+ "被单击了", 1).show();
			}
		});
		list.setOnItemSelectedListener(new OnItemSelectedListener()
		{
			// 第position项被选中时激发该方法。
			@Override
			public void onItemSelected(AdapterView parent, View view,
					int position, long id)
			{	
				Toast.makeText(getApplicationContext(), names[position]+ "被选中了", 1).show();
			}
			@Override
			public void onNothingSelected(AdapterView parent)
			{
			}
		});
	}
}


在上边java代码中,创建SimpleAdapter对象的时候,我们用到了一个视图:R.layout.simple_item,这个就是我们自定义的样式,可以通过这个样式来实现复杂的视图。
simple_item.xml:














把这些组合起来就可以构成下边的效果:

Android开发系列(十九):为SimpleAdapter设置样式_第1张图片


你可能感兴趣的:(Android,Android基础知识学习系列)