android组件之ListView

   与scrollview类似还有一种组件listview,可以将多个组件加到listview中达到组件滚动的显示效果,但是scrollview是通过布局之上嵌套一层,而ListView是单独存在的组件

  先附上效果图:


main.xml中配置主要用于显示整体界面:

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical"
    android:paddingBottom="@dimen/activity_vertical_margin"
    android:paddingLeft="@dimen/activity_horizontal_margin"
    android:paddingRight="@dimen/activity_horizontal_margin"
    android:paddingTop="@dimen/activity_vertical_margin"
    tools:context=".MainActivity" >

    <TextView
        android:id="@+id/title"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="头像列表" />

    <ListView
        android:id="@+id/mylistview"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content" >
    </ListView>

</LinearLayout>

创建data_item.xml用于布局单条信息布局

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout 
	xmlns:android="http://schemas.android.com/apk/res/android"
	android:orientation="horizontal"
	android:layout_width="fill_parent"
	android:layout_height="wrap_content">
	<ImageView
		android:id="@+id/head_photos"
		android:layout_height="wrap_content"
		android:layout_width="wrap_content"
		android:padding="3px"/>
	<LinearLayout 
		
		android:orientation="vertical"
		android:layout_width="190px"
		android:layout_height="wrap_content"
		android:gravity="left">
		<TextView 
			android:id="@+id/name"
			android:textSize="25px"
			android:padding="3px"
			android:layout_width="wrap_content"
			android:layout_height="wrap_content" />
		<TextView 
			android:id="@+id/details"
			android:padding="3px"
			android:textSize="14px"
			android:layout_width="wrap_content"
			android:layout_height="wrap_content" />
	</LinearLayout>

</LinearLayout>

接下来通过activity控制布局,将信息添加到listview

public class MainActivity extends Activity {
	private ListView mylistview = null;
	private List<Map<String, String>> list = new ArrayList<Map<String, String>>();
	private SimpleAdapter adapter = null;
	private int img[] = { R.drawable.pic_head_01, R.drawable.pic_head_01,
			R.drawable.pic_head_02, R.drawable.pic_head_03,
			R.drawable.pic_head_04, R.drawable.pic_head_05,
			R.drawable.pic_head_06, R.drawable.pic_head_07,
			R.drawable.pic_head_08, R.drawable.pic_head_09,
			R.drawable.pic_head_10, R.drawable.pic_head_11,
			R.drawable.pic_head_12, R.drawable.pic_head_13,
			R.drawable.pic_head_14, R.drawable.pic_head_15,
			R.drawable.pic_head_16, R.drawable.pic_head_17 };

	@Override
	protected void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		super.setContentView(R.layout.activity_main);
		this.mylistview = (ListView) this.findViewById(R.id.mylistview);
		for (int i = 0; i < img.length; i++) {
			Map<String, String> map = new HashMap<String, String>();

			map.put("img", String.valueOf(this.img[i]));
			map.put("name", "name" + i);
			map.put("details", "把鼠标移动到上面的一个QQ头像图片上,点击右键,选择“图片另存为”,把QQ头像保"
					+ "存到桌面上,然后点击QQ面板的“菜单”→“设置”→“个人设置”,这时就进入QQ的..." + i);
			list.add(map);
			adapter = new SimpleAdapter(this,  //创建适配器将信息添加到适配器中
					                    this.list, R.layout.data_item,
					                    new String[] { "img", "name", "details" }, 
					                    new int[] {R.id.head_photos, R.id.name, R.id.details });
			this.mylistview.setAdapter(adapter);
		}

	}

}

如果要对选项增加事件控制的话可以通过OnItemClickListener

private class OnItemClickListenerImpl implements OnItemClickListener{

		@Override
		public void onItemClick(AdapterView<?> parent, View view, int positon,
				long id) {
			
			Toast.makeText(MainActivity.this, "你当前选中了第"+positon+"张图片", Toast.LENGTH_LONG).show();
			
		}}

详细的后续补上~


  

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值