最近了一个动态加载listview类表项的列子,分享出来大家学习学习,我说说这个例子的实现过程,首先我限定每次加载的列表项数据为10条数据,当我拖动listview滚动到最后一条数据的时候再加载10条,并在Listview下方显示加载提示。
下面是我的java源码:
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
|
private
void
showContent() {
listView = (ListView) findViewById(R.id.journals_list_one);
loadData();
adapter =
new
MyListAdapter(
this
, data);
footerView = View.inflate(TestLayout.
this
,
R.layout.journal_listitem_loading_bar,
null
);
listView.addFooterView(footerView,
null
,
true
);
listView.setAdapter(adapter);
listView.setOnScrollListener(listener);
}
private
AbsListView.OnScrollListener listener =
new
AbsListView.OnScrollListener() {
@Override
public
void
onScrollStateChanged(AbsListView view,
int
scrollState) {
if
(view.getLastVisiblePosition() == view.getCount() -
1
) {
loadData();
adapter.notifyDataSetChanged();
}
}
@Override
public
void
onScroll(AbsListView view,
int
firstVisibleItem,
int
visibleItemCount,
int
totalItemCount) {
}
};
/**
* 构造List列表数据
*/
private
void
loadData() {
if
(data.size() <=
40
) {
for
(
int
i =
0
; i <
10
; i++) {
Map<String, String> map =
new
HashMap<String, String>();
map.put(
"title"
, getString(R.string.title));
map.put(
"desc"
, getString(R.string.content));
data.add(map);
}
}
else
{
listView.removeFooterView(footerView);
}
}
|
实现这个功能主要是添加ListView的OnScrollListener监听,判断是否列表项到了最有一条,如果是最后一条就加载数据。加载数据时的加载效果是ListView.addFooterView()方法实现这个方法必须在listview.setAdapter()前才有用,当所有数据加载完成就调用listView.removeFooterView把footerview移除就可以了.