Android的UI组件之ListView(二)

原创 2012年08月07日 17:48:33

接着上篇文章:

二. 通过构建Adapter(适配器)来在ListView显示一个组合控件

UI的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"
     >

    <ListView 
        android:id="@+id/myList"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        ></ListView>
	
</LinearLayout>
list.xml是在ListView中的每个Item的布局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="horizontal"
     >
     <LinearLayout 
        android:layout_width="wrap_content"
    	android:layout_height="wrap_content"
    	android:orientation="vertical" 
         >
         <!-- 定义一个ImageView作为列表项的一部分 -->
	<ImageView 
		android:id="@+id/header"
		android:layout_height="wrap_content"
		android:layout_width="wrap_content"
		android:paddingLeft="10dp"   
	    />
	<TextView 
	    android:id="@+id/name"
	    android:layout_height="wrap_content"
	    android:layout_width="wrap_content"
	    android:textSize="16dp"
	    android:gravity="center_vertical"
	    android:paddingLeft="10dp"
	    />
     </LinearLayout>
     <EditText 
         android:layout_width="match_parent"
         android:layout_height="wrap_content"
         android:hint="请输入"
         android:layout_gravity="center"
         />
</LinearLayout>
Activity的代码如下:

package com.example.simpleadaptertest;

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

import android.R.string;
import android.os.Bundle;
import android.app.Activity;
import android.view.Menu;
import android.view.MenuItem;
import android.widget.ListView;
import android.widget.SimpleAdapter;
import android.support.v4.app.NavUtils;

public class SimpleAdapterTest extends Activity {

    private String [] names=new String[] {"虎头","弄玉","李清照","李白"};
    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.activity_simple_adapter_test);
        //创建一个List集合,List集合的元素是Map
        List<Map<String, Object>> listItems=new ArrayList<Map<String,Object>>();
		for(int i=0;i<names.length;i++){
			Map<String, Object> listItem=new HashMap<String, Object>();
			listItem.put("header", imageIds[i]);
			listItem.put("personName", names[i]);
			listItems.add(listItem);
		}
		SimpleAdapter simpleAdapter=new SimpleAdapter(this, listItems, R.layout.list, new String[]{"personName","header"}, new int[]{R.id.name,R.id.header});
		ListView list=(ListView)findViewById(R.id.myList);
		list.setAdapter(simpleAdapter);
    }

    @Override
    public boolean onCreateOptionsMenu(Menu menu) {
        getMenuInflater().inflate(R.menu.activity_simple_adapter_test, menu);
        return true;
    }

    
}
先看运行结果:

在Activity代码中的第34行:SimpleAdapter simpleAdapter=new SimpleAdapter(this, listItems, R.layout.list, new String[]{"personName","header"}, new int[]{R.id.name,R.id.header});中的R.layout.list即显示每个Item中要显示的组合控件以及其布局。




(图片处理)Android-Universal-Image-Loader三大组件DisplayImageOptions、ImageLoader、ImageLoaderConfiguration详解

一、介绍  Android-Universal-Image-Loader是一个开源的UI组件程序,该项目的目的是提供一个可重复使用的仪器为异步图像加载,缓存和显示。所以,如果你的程序里需要这个功能的话...
  • a876434758
  • a876434758
  • 2015年06月08日 13:39
  • 357

Android常用的UI组件

近来读完《疯狂Android讲义》一书,也将其中的案例都码了一遍。很厚的一本书,就像一本字典,涵盖了大部分的android基础知识。现对里面一些比较不错的内容做出总结。本篇对常用UI组件做出总结,只做...
  • m0_37597069
  • m0_37597069
  • 2017年04月16日 16:37
  • 1489

Android UI 之ListView组件

ListView 列表的显示需要三个元素: 1.ListVeiw 用来展示列表的View。 2.适配器 用来把数据映射到ListView上的中介。 3.数据    具体的将被映射的字符串,图片...
  • LLLAZY520
  • LLLAZY520
  • 2011年12月16日 00:05
  • 1175

Android中常用UI组件总结

UI组件之布局管理器 A.     线性布局(LinearLayout):控制各组件横向排列,到头之后,剩下的组件将不会显示出来。常用属性       1.      android:ba...
  • spanklebobo
  • spanklebobo
  • 2016年08月15日 14:01
  • 561

Android开发教程13:UI之列表:ListView

转自: http://liuzhichao.com/p/365.html ListView是Android开发中比较常用的一个组件,它以列表的形式展示具体内容,并且能够根据数据的长度自适应显示。...
  • meryvn
  • meryvn
  • 2015年09月22日 15:03
  • 738

Android常见UI组件之ListView(二)——定制ListView

这一篇展示ListView中选择多个项及
  • u012904198
  • u012904198
  • 2014年05月06日 15:43
  • 1439

Android应用开发———Android中的常用UI组件

1、Android中常用的的UI组件: 2、TextView文本显示组件:         TextView组件的主要功能是向用户显示文本内容。         TextView组件在功...
  • fang_yang_wa
  • fang_yang_wa
  • 2017年05月10日 13:46
  • 218

ListView UI 混乱问题

该篇内容主要是记录我在实际开发中遇到的ListView滑动时数据错乱的几种情况,以及解决方法。在进行ListView滑动时数据错乱问题讨论之前会对ListView所谓的进行说明。文章末尾分享了几篇文章...
  • h183288132
  • h183288132
  • 2015年08月22日 12:07
  • 441

【Android UI】动态改变ListView布局

当点击了Item时,其布局文件发生改变来达到一个Focus的效果。一般有两种方法。一种是将两种布局文件写在一起,通过控制布局的显示。隐藏,来达到切换布局的效果;另一种则是在getView()的时候,通...
  • yabg_zhi_xiang
  • yabg_zhi_xiang
  • 2016年05月03日 11:34
  • 1091

Android的UI组件之ListView(一)

ListView是一个经常用到的控件,ListView里面的每个子项Item可以使一个字符串,也可以是一个组合控件。 创建ListView有两种方式: 1.在定制UI组件的xml文件中直接添加...
  • haoba1987
  • haoba1987
  • 2012年08月07日 17:24
  • 375
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:Android的UI组件之ListView(二)
举报原因:
原因补充:

(最多只允许输入30个字)