Android学习笔记(9)——ListView简介
ListView作为Android上几乎使用最多的控件,一定是要好好掌握的。这里介绍一些ListView的基础知识和特点,并提供一个简单的样例。
首先,我们来定义下layout:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
|
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<String> strList = new
ArrayList<String>(); @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技术博客:
郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。