烦人的ListView

上回说到跟ListView相关的Adapter,这次就来说说ListView。其实,这两者不应该分开说的,应该写到一篇文章里面。但是我就是要分开写,不服你来打我呀。/手动斜眼


在安卓中,用的最多的控件或者说最难用的控件就是ListView了。微信联系人,刷朋友圈,刷微博这些都是listView。我打赌目前以我这个战五渣的水平,listView我肯定写不好,没有关系,先挖坑,日后再填。不服你再打我呀?/手动滑稽


ListView三要素:

1.ListVeiw 用来展示列表的View。//今天的重点

2.适配器 用来把数据映射到ListView上的中介。//这个我们已经说过了ArrayAdapter了。跟1密不可分

3.数据    具体的将被映射的字符串,图片,或者基本组件。//数据就是数据啊,兄弟


根据列表的适配器类型,列表分为三种,ArrayAdapter,SimpleAdapter和SimpleCursorAdapter

其中以ArrayAdapter最为简单,只能展示一行字。SimpleAdapter有最好的扩充性,可以自定义出各种效果。SimpleCursorAdapter可以认为是SimpleAdapter对数据库的简单结合,可以方面的把数据库的内容以列表的形式展示出来。

 我们从最简单的ListView开始:

ArrayAdapter:

public class MyListView extends Activity {

    private ListView listView;

    private List<String> data = new ArrayList<String>();

    @Override

    public void onCreate(Bundle savedInstanceState){

        super.onCreate(savedInstanceState);

         

        listView = new ListView(this);
	//创建listView对象

        listView.setAdapter(new ArrayAdapter<String>(this, android.R.layout.simple_expandable_list_item_1,getData()));
	//匿名内部类创建ArrayAdapter适配器对象,并适配器对象传递给listView
	//多注释一句,adapter适配器需要三个参数,分别是上下文的this(context),系统默认的只显示一行数据的view的ID,data

        setContentView(listView);

    }

      

    private List<String> getData(){

         

       //List<String> data = new ArrayList<String>();

        data.add("测试数据1");

        data.add("测试数据2");

        data.add("测试数据3");

        data.add("测试数据4");

         

        return data;

    }

}

上面代码使用了ArrayAdapter(Context context, int textViewResourceId, List<T> objects)来装配数据,要装配这些数据就需要一个连接ListView视图对象和数组数据的适配器来两者的适配工作,ArrayAdapter的构造需要三个参数,依次为this,布局文件(注意这里的布局文件描述的是列表的每一行的布局,android.R.layout.simple_list_item_1是系统定义好的布局文件只显示一行文字,数据源(一个List集合)。同时用setAdapter()完成适配的最后工作。



SimpleAdapter:

simpleAdapter的扩展性最好,可以定义各种各样的布局出来,可以放上ImageView(图片),还可以放上Button(按钮),CheckBox(复选框)等等。下面的代码都直接继承了ListActivity,ListActivity和普通的Activity没有太大的差别,不同就是对显示ListView做了许多优化,方便显示而已。

下面的程序是实现一个带有图片的类表

首先需要定义好一个用来显示每一个列内容的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="fill_parent">

 

 

    <ImageView android:id="@+id/img" 

        android:layout_width="wrap_content"

        android:layout_height="wrap_content" 

        android:layout_margin="5px"/>

 

    <LinearLayout android:orientation="vertical"

        android:layout_width="wrap_content" 

        android:layout_height="wrap_content">

 

        <TextView android:id="@+id/title" 

            android:layout_width="wrap_content"

            android:layout_height="wrap_content" 

            android:textColor="#FFFFFFFF"

            android:textSize="22px" />

        <TextView android:id="@+id/info" 

            android:layout_width="wrap_content"

            android:layout_height="wrap_content" 

            android:textColor="#FFFFFFFF"

            android:textSize="13px" />

 

    </LinearLayout>

 

 

</LinearLayout>

实现代码:


public class MyListView3 extends ListActivity {

 

 

    // private List<String> data = new ArrayList<String>();

    @Override

    public void onCreate(Bundle savedInstanceState) {

        super.onCreate(savedInstanceState);

 

        SimpleAdapter adapter = new SimpleAdapter(this,getData(),R.layout.vlist,

                new String[]{"title","info","img"},

                new int[]{R.id.title,R.id.info,R.id.img});

        setListAdapter(adapter);

    }

 

    private List<Map<String, Object>> getData() {

        List<Map<String, Object>> list = new ArrayList<Map<String, Object>>();

 

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

        map.put("title", "G1");

        map.put("info", "google 1");

        map.put("img", R.drawable.i1);

        list.add(map);

 

        map = new HashMap<String, Object>();

        map.put("title", "G2");

        map.put("info", "google 2");

        map.put("img", R.drawable.i2);

        list.add(map);

 

        map = new HashMap<String, Object>();

        map.put("title", "G3");

        map.put("info", "google 3");

        map.put("img", R.drawable.i3);

        list.add(map);

         

        return list;

    }

}


使用simpleAdapter的数据用一般都是HashMap构成的List,list的每一节对应ListView的每一行。HashMap的每个键值数据映射到布局文件中对应id的组件上。因为系统没有对应的布局文件可用,我们可以自己定义一个布局vlist.xml。下面做适配,new一个SimpleAdapter参数一次是:this,布局文件(vlist.xml),HashMap的 title 和 info,img。布局文件的组件id,title,info,img。布局文件的各组件分别映射到HashMap的各元素上,完成适配。



坑太大,下次再填!!!



















评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值