【转】关于ListActivity的简单体验

简介: 今天学习点轻松的内容吧,看看android.app包里的几个类。首先是这个在平台自的例子中被广泛使用的ListActivity。这个类其实就是一 个含有一个ListView组件的Activity类。也就是说,如果我们直接在一个普通的Activity中自己加一个ListView也是完全可以取 代这个ListActivity的,只是它更方便而已,方便到什么程度呢?来做个例子瞧瞧。

今天学习点轻松的内容吧,看看android.app包里的几个类。首先是这个在平台自的例子中被广泛使用的ListActivity。这个类其实就是一 个含有一个ListView组件的Activity类。也就是说,如果我们直接在一个普通的Activity中自己加一个ListView也是完全可以取 代这个ListActivity的,只是它更方便而已,方便到什么程度呢?来做个例子瞧瞧。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
public class HelloTwoB extends ListActivity
{    
    public void onCreate(Bundle icicle) {
        super.onCreate(icicle);
        setTheme(android.R.style.Theme_Dark);
        setContentView(R.layout.mainb);
 
        List<String> items = fillArray();        
        ArrayAdapter<String> adapter = new ArrayAdapter<String>(this,R.layout.list_row,items);
 
        this.setListAdapter(adapter);
    }
    private List<String> fillArray()
    {
        List<String> items = new ArrayList<String>();
        items.add("日曜日");
        items.add("月曜日");
        items.add("火曜日");
        items.add("水曜日");
        items.add("木曜日");
        items.add("金曜日");
        items.add("土曜日");
        return items;
    }
 
    @Override
    protected void onListItemClick(ListView l, View v, int position, long id)
    {
        TextView txt = (TextView)this.findViewById(R.id.text);
        txt.setText("あすは "+l.getSelectedItem().toString()+"です。");
    }
}

的确可以简单到只需准备一个List对象并借助Adapter就可以构造出一个列表。重载onListItemClick方法可以响应选择事件, 利用第一个参数可以访问到这个ListView实例以得到选中的条目信息。这里有一点要说明的,就是如果更简单的话,其实连那个 setContentView都可以不要了,Android也会自动帮我们构造出一个全屏的列表。但是本例中我们需要一个TextView来显示选中的条 目,所以我们需要一个layout.mainb描述一下这个列表窗口。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:orientation="vertical"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"
    >
<TextView id="@+id/text"
    android:layout_width="fill_parent"
    android:layout_height="wrap_content"
    android:text=""
    />
<ListView id="@id/android:list"
    android:layout_width="fill_parent"
    android:layout_height="0dip"
    android:layout_weight="1"
    android:drawSelectorOnTop="false"
    />
</LinearLayout>

这里需要注意的是那个ListView的ID,是系统自定义的android:list,不是我们随便取的,否则系统会说找不到它想要的listview了。然后,在这个listview之外,我们又增加了一个TextView,用来显示选中的条目。

再 来说说这里用到的ArrayAdapter,它的构造函数中第二个参数是一个资源ID,ArrayAdapter的API文档中说是要求用一个包含 TextView的layout文件,平台用它来显示每个选择条目的样式,这里的取值是R.layout.list_row,所以,我们还有一个 list_row.xml文件来描述这个布局,相当简单。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
<?xml version="1.0" encoding="utf-8"?>
<TextView id="@+id/item"
          xmlns:android="http://schemas.android.com/apk/res/android"
          android:layout_width="wrap_content"
          android:layout_height="wrap_content"/>

从ArrayAdapter上溯到BaseAdapter,发现还有几个同源的Adapter也应该可以使用,象SimpleAdapter和CursorAdapter,还是做个例子来实验一下吧。

先看看SimpleAdapter,说是simple却不simple。

首先看看这个fillMaps方法,基本上就明白这个simpleAdapter是怎么回事了,在有些场合它还是挺有用的,可以为每个条目绑定一个值:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
private List<HashMap<String, String>> fillMaps()
    {
        List<HashMap<String, String>> items = new ArrayList<HashMap<String,String>>();
 
        HashMap<String,String> i = new HashMap<String,String>();
        i.put("name","日曜日");
        i.put("key", "SUN");
        items.add(i);
        HashMap<String,String> i1 = new HashMap<String,String>();
        i1.put("name","月曜日");
        i1.put("key", "MON");
        items.add(i1);
        HashMap<String,String> i2 = new HashMap<String,String>();
        i2.put("name","火曜日");  
        i2.put("key", "TUE");
        items.add(i2);
        HashMap<String,String> i3 = new HashMap<String,String>();
        i3.put("name","水曜日");
        i3.put("key", "WED");
        items.add(i3);
        HashMap<String,String> i4= new HashMap<String,String>();
        i4.put("name","木曜日");
        i4.put("key", "THU");
        items.add(i4);
        HashMap<String,String> i5 = new HashMap<String,String>();
        i5.put("name","金曜日");
        i5.put("key", "FRI");
        items.add(i5);
        HashMap<String,String> i6 = new HashMap<String,String>();
        i6.put("name","土曜日");
        i.put("key", "SAT");
        items.add(i6);
 
        return items;
    }

然后,在HelloTwoB中的onCreate函数中,修改代码,有几个不同:items的元素是HashMap实例,这是一点变化,然后构造 函数除了要求items以外,还要求提供一个string[]来说明用hash表中的哪个字段显示在列表中,而后是一个资源ID的数组。我的代码是这样 的:

1
2
3
//SimpleAdapter demo
List<HashMap<String, String>> items = fillMaps();
SimpleAdapter adapter=new SimpleAdapter(this,items,R.layout.list_row,new String[]{"name"},new int[]{R.id.item});

编译跑一下可以看到结果了,是吧?只是显示的文字不太对,再改一下:

1
2
3
4
5
protected void onListItemClick(ListView l, View v, int position, long id)
    {
        TextView txt = (TextView)this.findViewById(R.id.text);
        txt.setText("あすは "+((HashMap)l.obtainItem(position)).get("key").toString()+"です。");
    }
lst_row.xml也改一下
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:orientation="vertical"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"
    >
<TextView id="@+id/item"
          xmlns:android="http://schemas.android.com/apk/res/android"
          android:layout_width="wrap_content"
          android:layout_height="wrap_content"/>
<TextView id="@+id/item2"
          xmlns:android="http://schemas.android.com/apk/res/android"
          android:layout_width="wrap_content"
          android:layout_height="wrap_content"/>
</LinearLayout>

这样就好多了,其实一般情况下我们都是用ListView中的obtainItem取得当前选中的条目,然后转成List中的对应类型来使用的。

上面的例子中只显示name对应的值,其实你也可以试一下这样:

1
SimpleAdapter adapter=new SimpleAdapter(this,items,R.layout.list_row,new String[]{"name","key"},new int[]{R.id.item,R.id.item2});

看看是什么效果。

再看看那个CursorAdapter吧,它的列表中元素要求是Cursor,这东西与DB有关,不过最简单的DB就是通讯簿。先从Contacts.People入手吧,同样修改代码:

1
2
3
//CursorAdapter demo
Cursor mCursor = this.getContentResolver().query(Contacts.People.CONTENT_URI, null, null, null, null);
SimpleCursorAdapter adapter=new SimpleCursorAdapter(this,R.layout.list_row,mCursor,new String[]{Contacts.People.NAME},new int[]{R.id.item});

因为单纯的CursorAdapter是抽象类,所以我用的是它的子类SimpleCursorAdapter,很好理解,先用 ContentResolver查询通讯簿得到一个游标,然后告诉SimpleCursorAdapter要用其中的People.NAME作为显示项来 构造出一个adapter即可。

现在的onListItemClick也不一样了,如下:

1
2
3
4
5
6
protected void onListItemClick(ListView l, View v, int position, long id)
    {
        TextView txt = (TextView)this.findViewById(R.id.text);
        Cursor c = (Cursor)l.obtainItem(position);
        txt.setText("SEL = "+c.getString(c.getColumnIndex(Contacts.People.NUMBER)));
    }

这里同样是先用obtainItem取到游标,然后用从记录中取出想要的字段显示即可。在做这个例子时,因为权限的问题我们还得修改一下AndroidManifest.xml文件,让我们的应用可以访问到通讯簿:

1
2
3
4
5
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="cn.sharetop.android.hello.two">
    <uses-permission id="android.permission.READ_CONTACTS" />
    <application android:icon="@drawable/icon">
 ... ...

 http://blog.csdn.net/iris0123456/article/details/6424577

相关文章
|
2月前
|
数据采集 存储 人工智能
体验理解
本文介绍了通过文档智能和RAG技术将业务文档整合到大语言模型(LLM)知识库中的解决方案。文章涵盖了实践原理理解、部署体验、LLM知识库优势及适用场景等内容。对文档智能流程、RAG技术的应用进行了详细阐述,并提出了技术细节、部署引导、知识库更新和性能优化等方面的改进建议。适用于企业内部知识管理、客户服务和业务流程自动化等多种场景。
67 1
|
5月前
|
机器人 开发者 弹性计算
体验心得
OS Copilot 是一款提升编程效率的优秀工具,其清晰的服务器分区便于用户快速定位需求,独特的聊天功能允许与机器人互动。它提供实时代码建议和自动补全,尤其在处理复杂逻辑和重复任务时表现出色。通过理解上下文,它能生成定制化代码,减少错误并节省时间。同时,它能迅速解答技术问题,提供准确的文档和解决方案,是开发者不可或缺的助手。
体验心得
|
弹性计算 运维 监控
第一次体验阿里云服务
第一次ecs云服务器体验
|
弹性计算 Java 关系型数据库
体验不错
我是一名电子信息工程的本科生,目前是大四在读,想要学习Linux操作系统以及部署自己的项目,在云服务器和虚拟机中反复横跳,最后选择了云服务器,因为阿里云在业界享有盛誉,故选择了阿里云,查找有无学生优惠时了解到了“飞天加速计划·高校学生在家实践”活动,因此参加次实践活动
|
存储 弹性计算 固态存储
esct体验心得
云服务器,是一种简单高效,处理能力可以弹性伸缩的计算服务。
|
双11 云计算
体验
一、阿里云在国内起步最早。通过阿里系产品的这么多年大流量、高并发应用,阿里云的基础架构已经很成熟+稳定了。你想啊,都可以应对双12 双11 那么大的瞬间并发,屹立不倒,跑个你的个人博客、大中小型网站还不是 so easy。二、名气大。毕竟是阿里系的一家兄弟,加上多年之间紧密合作,阿里集团旗下的所有应用应该都奔跑在阿里云上面了。包括涉及金融的支付宝在内,可见阿里云的稳定性、速度、安全性都是很棒的。三、老魏说说缺点吧。有点贵,这个算是一个缺点吧。毕竟起步早,技术成熟,2018年国内云计算市场占比一半左右,半壁江山都是阿里云的,很多人就是冲着这个名气也会首选阿里云。
|
弹性计算 Shell Linux
EXS体验
通过学生认证获得了一台ECS服务器,安装了docker部署微服务项目,在性能方面获得了很好的体验.
199 0
|
云安全 弹性计算 安全
阿里云服务体验有感
本文主要分为三个部分介绍。第一部分,个人情况简介(也希望能和大家做个朋友)。第二部分,使用云ECS小感受。第三部分,未来计划和安排
|
Web App开发 IDE Linux
ChromeOS 体验
ChromeOS 是后发的桌面级操作系统,它的 UI 是现代化的。在诞生之处,ChromeOS 目标是可以在廉价的设备上流畅运行,因此流畅度没有问题。最后,ChromeOS 内核基于 Linux,且系统相对封闭,在专用设备上稳定性应该有所保证(FydeOS for PC 这种无法面向一大类机器的发行版,无法保证稳定性)。 ChromeOS 系统层面,通过虚拟机技术,提供了具有独立内核的 Linux 子系统。 ChromeOS 就是对 Chrome 浏览器的操作系统化的产品,浏览器的体验毋庸置疑。
1017 0
|
弹性计算 安全 前端开发
我的体验
服务器使用
136 0