ListView 创建及使用

                                   ListView列表显示的实现大致分为以下几步:

1、定义ListView将要显示的数据(在这里一维数组或者多维数组都可以)

2、构建适配器,用来将数据映射到ListView上。

3、将ListView控件与适配器进行绑定。

根据列表的适配器的类型分为三类:ArrayAdapter,SimpleAdapterSimpleCursorAdapter.

下面通过实例来分别看一下不同的适配器在实现ListView列表显示有什么不同,首先先看最简单

ArrayAdapter适配器的单行显示。然后是SimpleAdapter适配器,可以显示比较复杂的列表,

包括每行显示图片、文字等。

根据继承的类的不同我们也可以把它分成两类:继承Activity的和继承ListActivity,继承Activity

的与之前的其他项目相同需要关联layout布局文件,然而当继承ListActivity,这时候我们恰恰需

要将xxActivity.java文件中那句关联layout布局文件的语句删除(采用的是相对应的平台中默认

的布局文件),否则程序报异常

下面是我们这次实验的内容:

设计一个ListView,放置中国各省的省会城市,并为每个省会城市安放相应图片。

布局文件:

<RelativeLayout 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: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" >
    <ListView 
        android:id="@+id/listview"
        android:layout_height="fill_parent"
       android:layout_width="fill_parent">
        </ListView>
</RelativeLayout>
     Main.xml:
  <?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/img"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
           android:adjustViewBounds="true"
          android:maxWidth="80dp"
          android:maxHeight="40dp"
            />
          <TextView
                android:id="@+id/textview"
                android:layout_width="match_parent"
                android:layout_height="40dp"
         android:textSize="20dp" 
         android:textColor="#FF0000"
                android:gravity="center">"
            </TextView>
</LinearLayout>
Activity部分:

 import java.util.ArrayList;

importjava.util.HashMap;

import java.util.List;

import java.util.Map;

 

importandroid.os.Bundle;

importandroid.app.Activity;

importandroid.view.Menu;

importandroid.widget.ListView;

importandroid.widget.SimpleAdapter;

 

public classMainActivity extends Activity {

    private ListView listview;

    private List<Map<String,?>> data;

 

    @Override

    protected void onCreate(BundlesavedInstanceState) {

        super.onCreate(savedInstanceState);

        setContentView(R.layout.activity_main);

       listview=(ListView)findViewById(R.id.listview);

        data=getdata();

        SimpleAdapter adapter=newSimpleAdapter(getApplicationContext(),data,R.layout.main,newString[]{"img","textview"},

              newint[]{R.id.img,R.id.textview});

        listview.setAdapter(adapter);

    }

 

 

    private List<Map<String, ?>>getdata() {

       List<Map<String,?>>newdata=new ArrayList<Map<String,?>>();

       Map<String,Object>map1=new HashMap<String,Object>();

       map1.put("img",R.drawable.bj);

       map1.put("textview","北京");

       Map<String,Object>map2=new HashMap<String,Object>();

       map2.put("img",R.drawable.cd);

       map2.put("textview","成都");

       Map<String,Object>map3=new HashMap<String,Object>();

       map3.put("img",R.drawable.cs);

       map3.put("textview","杭州");

       Map<String,Object>map4=new HashMap<String,Object>();

       map4.put("img",R.drawable.jn);

       map4.put("textview","济南");

       Map<String,Object>map5=new HashMap<String,Object>();

       map5.put("img",R.drawable.lz);

       map5.put("textview","兰州");

       Map<String,Object>map6=new HashMap<String,Object>();

       map6.put("img",R.drawable.nn);

       map6.put("textview","南宁");

       Map<String,Object>map7=new HashMap<String,Object>();

       map7.put("img",R.drawable.sjz);

       map7.put("textview","石家庄"); 

       Map<String,Object>map8=new HashMap<String,Object>();

       map8.put("img",R.drawable.tb);

       map8.put("textview","台北");

       Map<String,Object> map9=newHashMap<String,Object>();

       map9.put("img",R.drawable.ty);

       map9.put("textview","太原");

    newdata.add(map1);

       newdata.add(map2);

       newdata.add(map3);

       newdata.add(map4);

       newdata.add(map5);

       newdata.add(map6);

       newdata.add(map7);

       newdata.add(map8);

newdata.add(map9);

returnnewdata;

}

@Override

    publicbooleanonCreateOptionsMenu(Menu menu) {

        // Inflate the menu; this adds items to theaction bar if it is present.

        getMenuInflater().inflate(R.menu.main, menu);

        returntrue;

    }

}


 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值