Android列表视图(List View)
Android列表视图(ListView)
ListView是一个显示滚动项列表的示视图组(viewgroup),通过使用适配器(Adapter)把这些列表项自动插入到列表中。适配器比如从一个数组或是数据库查询获取到数据,然后转换每一项成为可放入到列表的视图。
列表的显示需要三个元素:
(1) ListView:用来展示列表的view。
(2) 适配器:用来把数据映射到ListView上。
(3) 数据:具体的将被映射的字符串、图片或是基本组件。
图1
对于我们如何使用适配器来动态插入view,参考链接:
http://developer.android.com/guide/topics/ui/declaring-layout.html#AdapterViews
1. 使用加载器(Using a Loader)
为了实现异步加载数据,且为了避免在查询时阻塞APP主线程,从Android3.0开始引入CursorLoader,这是一种查询Cursor的标准方式。当CursorLoader接收到Cursor结果(查询结束),LoaderCallbacks接收到对onLoadFinished()方法的回调,此方法使用新的Cursor来更新适配器,然后列表视图显示这个结果。
虽然CursorLoader的API是从Android3.0(API 11)开始引入的,但可以通过使用支持的库来使用:http://developer.android.com/tools/extras/support-library.html,但要求Android系统版本在1.6及之后的版本。
public
class ListViewLoader
extends ListActivity
implements
LoaderManager.LoaderCallbacks<Cursor>
{
// This is the Adapter being used to display the list's data
SimpleCursorAdapter mAdapter;
// These are the Contacts rows that we will retrieve
static final
String[] PROJECTION
= new
String[] {ContactsContract.Data._ID,
ContactsContract.Data.DISPLAY_NAME};
// This is the select criteria
static final
String SELECTION =
"((" +
ContactsContract.Data.DISPLAY_NAME
+ " NOTNULL)AND ("
+
ContactsContract.Data.DISPLAY_NAME
+ " != ''))";
@Override
protected void onCreate(Bundle savedInstanceState)
{
super.onCreate(savedInstanceState);
// Create a progress bar to display whilethe list loads
ProgressBar progressBar
= new ProgressBar(this);
progressBar.setLayoutParams(new
LayoutParams(LayoutParams.WRAP_CONTENT,
LayoutParams.WRAP_CONTENT,
Gravity.CENTER));
progressBar.setIndeterminate(true);
getListView().setEmptyView(progressBar);
// Must add the progress bar to the root ofthe layout
ViewGroup root
= (ViewGroup) findViewById(android.R.id.content);
root.addView(progressBar);
// For the cursor adapter, specify whichcolumns go into which views
String[] fromColumns
= {ContactsContract.Data.DISPLAY_NAME};
int[] toViews
= {android.R.id.text1};
// The TextViewin simple_list_item_1
// Create an empty adapter we will use todisplay the loaded data.
// We pass null for the cursor, then updateit in onLoadFinished()
mAdapter =
new SimpleCursorAdapter(this,
android.R.layout.simple_list_item_1,
null,
fromColumns, toViews,
);
setListAdapter(mAdapter);
// Prepare the loader. Eitherre-connect with an existing one,
// or start a new one.
getLoaderManager,
null,
this);
}
// Called when a new Loader needs to be created
public Loader<Cursor> onCreateLoader(int
id, Bundle args)
{
// Now create and return a CursorLoaderthat will take care of
// creating a Cursor for the data beingdisplayed.
return new
CursorLoader(this,
ContactsContract.Data.CONTENT_URI,
PROJECTION, SELECTION,
null,
null);
}
// Called when a previously created loader has finished loading
public void onLoadFinished(Loader<Cursor>
loader, Cursor data)
{
// Swap the new cursor in. (Theframework will take care of closing the
// old cursor once we return.)
mAdapter.swapCursor(data);
}
// Called when a previously created loader is reset, making the dataunavailable
public void onLoaderReset(Loader<Cursor>
loader) {
// This is called when the last Cursorprovided to onLoadFinished()
// above is about to be closed. We needto make sure we are no
// longer using it.
mAdapter.swapCursor(null);
}
@Override
public void onListItemClick(ListView l,
View v,
int position,
long id) {
// Do something when a list item is clicked
}
}
链接:
Android开发者:
http://developer.android.com/guide/topics/ui/layout/listview.html
Android之ListView原理学习与优化总结
http://mzh3344258.blog.51cto.com/1823534/889879
androidListView详解
http://www.cnblogs.com/allin/archive/2010/05/11/1732200.html
Android的CursorLoader用法小结
http://www.linuxidc.com/Linux/2013-05/84572.htm
Android列表视图(List View)的更多相关文章
- Android——列表视图(ListView)
列表视图是android中最常用的一种视图组件,它以垂直列表的形式列出需要显示的列表项.在android中有两种方法向屏幕中添加列表视图:一种是直接使用ListView组件创建:另外一种是让Activ ...
- Android的视图(View)组件
Android的绝大部分UI组件都放在android.widget包及其子包.android,view包及其子包中,Android应用的所有UI组件都继承了View类,View组件非常类似于Swing ...
- Android——列表视图 ListView(三)BaseAdapter
activity_activitybase.xml <?xml version="1.0" encoding="utf-8"?> <ListV ...
- Android列表视图ListView和ListActivity-android学习之旅(二十四)
ListView简介 ListView是android中常用的一种控件,创建ListView有两种方式: 1.在xml中使用ListView控件创建. 2.使用activity继承ListActivi ...
- Android——列表视图 ListView(二)SimpleAdapter
SimpleAdapter:可显示文字加图片 activity_activitysimple.xml <?xml version="1.0" encoding="u ...
- Android——列表视图 ListView(一)Arrayadapter
一.ArrayAdapter 只显示文字 activitylistview_layout.xml <?xml version="1.0" encoding="utf ...
- Android应用开发学习之列表视图
作者:刘昊昱 博客:http://blog.csdn.net/liuhaoyutz 列表视图我们会经常用到,可以通过两种方式来创建列表视图,一种方式是直接使用ListView组件创建,另一种方式是通过 ...
- 【Android】9.3 自定义列表视图的外观
分类:C#.Android.VS2015: 创建日期:2016-02-18 一.简介 自定义的列表视图通常用Resources/Layout文件夹下的axml文件中的资源来声明,适配器则通过Id去加载 ...
- <Android>列表、网格、画廊视图及适配器的绑定
列表视图和适配器的绑定 列表视图既可以使用ListView组件,也可以继承ListActivity.显示可以是ArrayAdapter,也可以是游标SimpleCursorAdapter,还可以是继承 ...
随机推荐
- JqueryMoblie 之 loading
显示“正在加载........”等字样,并且带有加载图片的显示. //显示加载器function showLoader() { $.mobile.loading('show', { text: '正在 ...
- 微软职位内部推荐-Senior Software Development Engineer
微软近期Open的职位: Job posting title: Senior Software Development Engineer Location: China, Beijing Divisi ...
- android开发设置dialog的高宽
这里设置为跟屏幕一样的宽度,:看代码 dlg.show(); WindowManager.LayoutParams params = dlg.getWindow().getAttributes(); ...
- Getting Started with Java
“学前”说明:<Learn Java for Android>这本书内容很多,都是精华,建议大家看英文版的.在这里我不打算一一总结书中的内容,书中每章节后面的exercises都很好,非常 ...
- 1069: [SCOI2007]最大土地面积 - BZOJ
Description 在某块平面土地上有N个点,你可以选择其中的任意四个点,将这片土地围起来,当然,你希望这四个点围成的多边形面积最大.Input 第1行一个正整数N,接下来N行,每行2个数x,y, ...
- HDU 5629 Clarke and tree dp+prufer序列
题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=562 题意: 求给每个节点的度数允许的最大值,让你求k个节点能组成的不同的生成树个数. 题解: 对于n ...
- CSDN——【低调的草原狼】——Ext4.2学习目录整理
最近在研究ExtJS,发现CSDN中有个博客中一系列文档非常优秀,但是没有对目录进行整理,在此稍作整理,也为以后自己研究打下一个基础: 原文作者:低调的草原狼 目录: 1.ExtJS4.2学习 ...
- linux进程管理之开机启动
下面用自启动apache为例;自启动脚本:/usr/local/apache2/bin:./apachectl start文件位于/etc/rc.d/init.d下,名为apached, 注意要可执行 ...
- java中判空
一.概述 java中判等似乎很简单,==用来判断对象引用(内存地址)是否相同,equals用来判断值是否相同.你可以试用String对象轻松区分这一点. 那么在null判等(也就是判空操作)时呢? 可 ...
- T-SQL操作表结构(转)
在网上整理的一牛人资料,收集与此与君共享 用SQL语句添加删除修改字段1.增加字段 ALTER TABLE [yourTableName] ADD [newColumnName] newCo ...