android ListView详解.docx
- 文档编号:6967257
- 上传时间:2023-01-13
- 格式:DOCX
- 页数:16
- 大小:174.84KB
android ListView详解.docx
《android ListView详解.docx》由会员分享,可在线阅读,更多相关《android ListView详解.docx(16页珍藏版)》请在冰豆网上搜索。
androidListView详解
androidListView详解
在android开发中ListView是比较常用的组件,它以列表的形式展示具体内容,并且能够根据数据的长度自适应显示。
抽空把对ListView的使用做了整理,并写了个小例子,如下图。
下载(28.09KB)
2010-6-2206:
42
列表的显示需要三个元素:
1.ListVeiw用来展示列表的View。
2.适配器用来把数据映射到ListView上的中介。
3.数据 具体的将被映射的字符串,图片,或者基本组件。
根据列表的适配器类型,列表分为三种,ArrayAdapter,SimpleAdapter和SimpleCursorAdapter
其中以ArrayAdapter最为简单,只能展示一行字。
SimpleAdapter有最好的扩充性,可以自定义出各种效果。
SimpleCursorAdapter可以认为是SimpleAdapter对数据库的简单结合,可以方面的把数据库的内容以列表的形式展示出来。
我们从最简单的ListView开始:
1.
2./**
3.*@authorallin
4.*
5.*/
6.publicclassMyListViewextendsActivity{
7.privateListViewlistView;
8.//privateList
9.@Override
10.publicvoidonCreate(BundlesavedInstanceState){
11. super.onCreate(savedInstanceState);
12.
13. listView=newListView(this);
14. listView.setAdapter(newArrayAdapter
15. setContentView(listView);
16.}
17.
18.
19.
20.privateList
21.
22. List
23. data.add("测试数据1");
24. data.add("测试数据2");
25. data.add("测试数据3");
26. data.add("测试数据4");
27.
28. returndata;
29.}
30.}
上面代码使用了ArrayAdapter(Contextcontext,inttextViewResourceId,List
同时用setAdapter()完成适配的最后工作。
运行后的现实结构如下图:
下载(22.49KB)
2010-6-2206:
45
SimpleCursorAdapter
sdk的解释是这样的:
AneasyadaptertomapcolumnsfromacursortoTextViewsorImageViewsdefinedinanXMLfile.Youcanspecifywhichcolumnsyouwant,whichviewsyouwanttodisplaythecolumns,andtheXMLfilethatdefinestheappearanceoftheseviews。
简单的说就是方便把从游标得到的数据进行列表显示,并可以把指定的列映射到对应的TextView中。
下面的程序是从电话簿中把联系人显示到类表中。
先在通讯录中添加一个联系人作为数据库的数据。
然后获得一个指向数据库的Cursor并且定义一个布局文件(当然也可以使用系统自带的)。
1./**
2.*@authorallin
3.*
4.*/
5.publicclassMyListView2extendsActivity{
6.
7. privateListViewlistView;
8. //privateList
9. @Override
10. publicvoidonCreate(BundlesavedInstanceState){
11. super.onCreate(savedInstanceState);
12.
13. listView=newListView(this);
14.
15. Cursorcursor=getContentResolver().query(People.CONTENT_URI,null,null,null,null);
16. startManagingCursor(cursor);
17.
18. ListAdapterlistAdapter=newSimpleCursorAdapter(this,android.R.layout.simple_expandable_list_item_1,
19. cursor,
20. newString[]{People.NAME},
21. newint[]{android.R.id.text1});
22.
23. listView.setAdapter(listAdapter);
24. setContentView(listView);
25. }
26.
27.
28.}
Cursorcursor=getContentResolver().query(People.CONTENT_URI,null,null,null,null);先获得一个指向系统通讯录数据库的Cursor对象获得数据来源。
startManagingCursor(cursor);我们将获得的Cursor对象交由Activity管理,这样Cursor的生命周期和Activity便能够自动同步,省去自己手动管理Cursor。
SimpleCursorAdapter构造函数前面3个参数和ArrayAdapter是一样的,最后两个参数:
一个包含数据库的列的String型数组,一个包含布局文件中对应组件id的int型数组。
其作用是自动的将String型数组所表示的每一列数据映射到布局文件对应id的组件上。
上面的代码,将NAME列的数据一次映射到布局文件的id为text1的组件上。
注意:
需要在AndroidManifest.xml中如权限:
name="android.permission.READ_CONTACTS"> 运行后效果如下图 下载(12.17KB) 2010-6-2206: 47 SimpleAdapter simpleAdapter的扩展性最好,可以定义各种各样的布局出来,可以放上ImageView(图片),还可以放上Button(按钮),CheckBox(复选框)等等。 下面的代码都直接继承了ListActivity,ListActivity和普通的Activity没有太大的差别,不同就是对显示ListView做了许多优化,方面显示而已。 下面的程序是实现一个带有图片的类表。 首先需要定义好一个用来显示每一个列内容的xml vlist.xml 1. 2. xmlversion="1.0"encoding="utf-8"? > 3. android=" 4.android: orientation="horizontal"android: layout_width="fill_parent" 5.android: layout_height="fill_parent"> 6. 7. id="@+id/img" 8. android: layout_width="wrap_content" 9. android: layout_height="wrap_content" 10. android: layout_margin="5px"/> 11. orientation="vertical" 12. android: layout_width="wrap_content" 13. android: layout_height="wrap_content"> 14. id="@+id/title" 15. android: layout_width="wrap_content" 16. android: layout_height="wrap_content" 17. android: textColor="#FFFFFFFF" 18. android: textSize="22px"/> 19. id="@+id/info" 20. android: layout_width="wrap_content" 21. android: layout_height="wrap_content" 22. android: textColor="#FFFFFFFF" 23. android: textSize="13px"/> 24. 25. 26. 下面是实现代码: 1. 2./** 3.*@authorallin 4.* 5.*/ 6.publicclassMyListView3extendsListActivity{ 7. 8.//privateList 9.@Override 10.publicvoidonCreate(BundlesavedInstanceState){ 11. super.onCreate(savedInstanceState); 12. SimpleAdapteradapter=newSimpleAdapter(this,getData(),R.layout.vlist, 13. newString[]{"title","info","img"}, 14. newint[]{R.id.title,R.id.info,R.id.img}); 15. setListAdapter(adapter); 16.} 17.privateList 18. List 19. Map 20. map.put("title","G1"); 21. map.put("info","google1"); 22. map.put("img",R.drawable.i1); 23. list.add(map); 24. map=newHashMap 25. map.put("title","G2"); 26. map.put("info","google2"); 27. map.put("img",R.drawable.i2); 28. list.add(map); 29. map=newHashMap 30. map.put("title","G3"); 31. map.put("info","google3"); 32. map.put("img",R.drawable.i3); 33. list.add(map); 34. 35. returnlist; 36.} 37.} 使用simpleAdapter的数据用一般都是HashMap构成的List,list的每一节对应ListView的每一行。 HashMap的每个键值数据映射到布局文件中对应id的组件上。 因为系统没有对应的布局文件可用,我们可以自己定义一个布局vlist.xml。 下面做适配,new一个SimpleAdapter参数一次是: this,布局文件(vlist.xml),HashMap的title和info,img。 布局文件的组件id,title,info,img。 布局文件的各组件分别映射到HashMap的各元素上,完成适配。 运行效果如下图: 下载(27.14KB) 2010-6-2206: 48 有按钮的ListView 但是有时候,列表不光会用来做显示用,我们同样可以在在上面添加按钮。 添加按钮首先要写一个有按钮的xml文件,然后自然会想到用上面的方法定义一个适配器,然后将数据映射到布局文件上。 但是事实并非这样,因为按钮是无法映射的,即使你成功的用布局文件显示出了按钮也无法添加按钮的响应,这时就要研究一下ListView是如何现实的了,而且必须要重写一个类继承BaseAdapter。 下面的示例将显示一个按钮和一个图片,两行字如果单击按钮将删除此按钮的所在行。 并告诉你ListView究竟是如何工作的。 效果如下: 下载(30.46KB) 2010-6-2206: 48 vlist2.xml 1. 2. xmlversion="1.0"encoding="utf-8"? > 3. android=" 4.android: orientation="horizontal" 5.android: layout_width="fill_parent" 6.android: layout_height="fill_parent"> 7. 8. id="@+id/img" 9. android: layout_width="wrap_content" 10. android: layout_height="wrap_content" 11. android: layout_margin="5px"/> 12. orientation="vertical" 13. android: layout_width="wrap_content" 14. android: layout_height="wrap_content"> 15. id="@+id/title" 16. android: layout_width="wrap_content" 17. android: layout_height="wrap_content" 18. android: textColor="#FFFFFFFF" 19. android: textSize="22px"/> 20. id="@+id/info" 21. android: layout_width="wrap_content" 22. android: layout_height="wrap_content" 23. android: textColor="#FFFFFFFF" 24. android: textSize="13px"/> 25. 26. 27. id="@+id/view_btn" 28. android: layout_width="wrap_content" 29. android: layout_height="wrap_content" 30. android: text="@string/s_view_btn" 31. android: layout_gravity="bottom|right"/> 32. 程序代码: 1. 2./** 3.*@authorallin 4.* 5.*/ 6.publicclassMyListView4extendsListActivity{ 7. 8.privateList 9. 10.@Override 11.publicvoidonCreate(BundlesavedInstanceState){ 12. super.onCreate(savedInstanceState); 13. mData=getData(); 14. MyAdapteradapter=newMyAdapter(this); 15. setListAdapter(adapter); 16.} 17.privateList 18. List 19. Map 20. map.put("title","G1"); 21. map.put("info","google1"); 22. map.put("img",R.drawable.i1); 23. list.add(map); 24. map=newHashMap 25. map.put("title","G2"); 26. map.put("info","google2"); 27. map.put("img",R.drawable.i2); 28. list.add(map); 29. map=newHashMap 30. map.put("title","G3"); 31. map.put("info","google3"); 32. map.put("img",R.drawable.i3); 33. list.add(map); 34. 35. returnlist; 36.} 37. 38.//ListView中某项被选中后的逻辑 39.@Override 40.protectedvoidonListItemClick(ListViewl,Viewv,intposition,longid){ 41. 42. Log.v("MyListView4-click",(String)mData.get(position).get("title")); 43.} 44. 45./** 46. *listview中点击按键弹出对话框 47. */ 48.publicvoidshowInfo(){ 49. newAlertDialog.Builder(this) 50. .setTitle("我的listview") 51. .setMessage("介绍...") 52. .setPositiveButton("确定",newDialogInterface.OnClickListener(){ 53. @Override 54. publicvoidonClick(DialogInterfacedialog,intwhich){ 55. } 56. }) 57. .show(); 58. 59.} 60. 61. 62. 63.publicfinalclassViewHolder{ 64. publicImageViewimg; 65. publicTextViewtitle; 66. publicTextViewinfo; 67. publicButtonviewBtn; 68.} 69. 70. 71.publicclassMyAdapterextendsBaseAdapter{ 72. privateLayoutInflatermInflater; 73. 74. 75. publicMyAdapter(Contextcontext){ 76. this.mInf
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- android ListView详解 ListView 详解