ListView作为Android上几乎使用最多的控件,一定是要好好掌握的。这里介绍一些ListView的基础知识和特点,并提供一个简单的样例。
首先,我们来定义下layout:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
|
<
LinearLayout
xmlns:android
=
"http://schemas.android.com/apk/res/android"
xmlns:tools
=
"http://schemas.android.com/tools"
android:id
=
"@+id/ll_root"
android:layout_width
=
"match_parent"
android:layout_height
=
"match_parent"
android:orientation
=
"vertical"
tools:context
=
"com.example.listview.MainActivity"
>
<
ListView
android:id
=
"@+id/lv"
android:layout_width
=
"match_parent"
android:layout_height
=
"match_parent"
>
ListView
>
LinearLayout
>
|
界面很简单,只是一个线性布局加上一个ListView控件,接下来是数据显示的问题,这里要说一下Android下的Adapter(数据适配器),一个Adapter可以看成是 ListView 的数据源, ListView 要展示的数据都是以Adapter的形式传递给 ListView 的。
关于Adapter的具体知识,在之后的文章会单独讲到。
要注意的是,ListView的设计也是遵从的MVC模式,即:
M model 数据模型(要显示的数据条目类型)
V View 即Listview
C Controller 即Adapter
我们来看看具体代码如何实现:首先是onCreate方法:
1
2
3
4
5
6
7
8
9
|
protected
void
onCreate(Bundle savedInstanceState) {
super
.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
lv = (ListView) findViewById(R.id.lv);
for
(
int
i=
0
;i<
50
;i++){
strList.add(
"我是条目"
+i);
}
lv.setAdapter(
new
MyAdapter());
}
|
要让Listview显示出条目,只需要调用lv.setAdapter方法即可,只是这里面的MyAdapter类需要我们自己去写,这里我们可以通过继承的方法来实现。这里介绍的是基本的BaseAdapter,以后的文章会逐步介绍其他的适配器:
//默认实现类,一般以: Base Simple default开头
private class MyAdapter extends BaseAdapter{
private static final String TAG = “MyAdapter”;
/**
* 控制ListView里面总共有多少个条目
*/
@Override
public int getCount() {
return strList.size();
}
@Override
public Object getItem(int position) {
return null;
}
@Override
public long getItemId(int position) {
return 0;
}
@Override
public View getView(int position, View convertView, ViewGroup parent) {
Log.i(TAG, “返回view对象,位置”+position);
TextView tv = new TextView(getApplicationContext());
tv.setTextSize(20);
//获取对应位置的str信息
String str = strList.get(position);
tv.setText(str);
return tv;
}
}
要实现简单的显示功能,只用完成其中的两个方法即可,一个是getView,即返回一个要显示的view,另外是getCount,即返回总的条目数。
另外关于 ListView要注意的是,在程序执行的时候,ListView会根据屏幕显示的长度来自动决定要生成的view对象的数量,即不在屏幕范围内的view对象是不会生成的,只有等到快要滚动到的时候才自动生成。另外已经存在的对象如果被滚动走了,会通过Java的垃圾回收器处理掉这一对象。
这样的好处就是,假如整个程序有很多很多个条目,系统不会一次性的全部生成view对应的对象,能够提高程序性能,防止内存溢出。
完整代码:
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
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
|
package
com.example.listview;
import
java.util.ArrayList;
import
java.util.List;
import
android.app.Activity;
import
android.database.DataSetObserver;
import
android.nfc.Tag;
import
android.os.Bundle;
import
android.util.Log;
import
android.view.View;
import
android.view.ViewGroup;
import
android.widget.Adapter;
import
android.widget.BaseAdapter;
import
android.widget.ListAdapter;
import
android.widget.ListView;
import
android.widget.TextView;
public
class
MainActivity
extends
Activity {
private
static
final
String TAG =
"MainActivity"
;
private
ListView lv;
private
List
new
ArrayList
@Override
protected
void
onCreate(Bundle savedInstanceState) {
super
.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
lv = (ListView) findViewById(R.id.lv);
for
(
int
i=
0
;i<
50
;i++){
strList.add(
"我是条目"
+i);
}
lv.setAdapter(
new
MyAdapter());
}
//默认实现类,一般以: Base Simple default开头
private
class
MyAdapter
extends
BaseAdapter{
private
static
final
String TAG =
"MyAdapter"
;
/**
* 控制ListView里面总共有多少个条目
*/
@Override
public
int
getCount() {
return
strList.size();
}
@Override
public
Object getItem(
int
position) {
return
null
;
}
@Override
public
long
getItemId(
int
position) {
return
0
;
}
@Override
public
View getView(
int
position, View convertView, ViewGroup parent) {
Log.i(TAG,
"返回view对象,位置"
+position);
TextView tv =
new
TextView(getApplicationContext());
tv.setTextSize(
20
);
tv.setTextColor(Color.BLACK);
//获取对应位置的str信息
String str = strList.get(position);
tv.setText(str);
return
tv;
}
}
}
|
效果截图:
欢迎转载,请注明出处。
搬运自本人博客,xge技术博客:
http://www.xgezhang.com/android_listview_intro.html