新闻中心

EEPW首页 > 嵌入式系统 > 设计应用 > Android 中 ListView 分页加载数据

Android 中 ListView 分页加载数据

作者: 时间:2016-10-08 来源:网络 收藏

熟悉Android的朋友们都知道,不管是微博客户端还是新闻客户端,都离不开列表组件,可以说列表组件是Android数据展现方面最重要的组 件,我们今天就要讲一讲列表组件ListView加载数据的相关内容。通常来说,一个应用在展现大量数据时,不会将全部的可用数据都呈现给用户,因为这不 管对于服务端还是客户端来说都是不小的压力,因此,很多应用都是采用分批次加载的形式来获取用户所需的数据。比如:微博客户端可能会在用户滑动至列表底端 时自动加载下一页数据,也可能在底部放置一个“加载更多”按钮,用户点击后,加载下一页数据。

本文引用地址:https://www.eepw.com.cn/article/201610/305462.htm

我们今天就结合实例来演示一下使用ListView获取数据的过程。

新建一个loadmore项目,我们来看一下结构图和最终效果图:

左图中包含了三个布局文件、一个Adapter和一个Activity,右图是我们运行后的主界面。

其中,main.xml是主界面的布局文件,它包含一个ListView组件,代码如下:

01

02

03 android:orientation=vertical

04 android:layout_width=fill_parent

05 android:layout_height=fill_parent

06 android:paddingLeft=3dp

07 android:paddingRight=3dp>

08

09 android:id=@id/android:list

10 android:layout_width=fill_parent

11 android:layout_height=wrap_content/>

12

这里我们引用了Android内置的名为list的id,因为我们后面要使用到ListActivity,我们的MainActivity继承于它。

然后就是list_item.xml,它是ListView中单个列表项的布局文件,从效果图中可以看到,这里只使用到了一个TextView组件,list_item.xml代码如下:

01

02

03 android:orientation=vertical

04 android:layout_width=fill_parent

05 android:layout_height=fill_parent>

06

07 android:id=@+id/list_item_text

08 android:layout_width=fill_parent

09 android:layout_height=fill_parent

10 android:gravity=center

11 android:textSize=20sp

12 android:paddingTop=10dp

13 android:paddingBottom=10dp/>

14

我们注意到在右图中列表底部有一个按钮不同于其他的列表项,这是什么情况?事实上这个按钮是我们在ListView底部添加的一个视图。ListView 组件提供了两个很实用的功能,那就是可以在顶部和底部添加自定义的视图。我们在此处ListView的底部添加了一个视图用来加载更多数据,这个视图对应 着load_more.xml布局文件,代码如下:

01

02

03 xmlns:android=http://schemas.android.com/apk/res/android

04 android:orientation=vertical

05 android:layout_width=fill_parent

06 android:layout_height=wrap_content>

07

08 android:id=@+id/loadMoreButton

09 android:layout_width=fill_parent

10 android:layout_height=wrap_content

11 android:text=load more

12 android:onClick=loadMore/>

13

接下来我们来了解一下我们的Adapter,ListViewAdapter代码如下:

01package com.scott.loadmore;

02

03import java.util.List;

04

05import android.content.Context;

06import android.view.LayoutInflater;

07import android.view.View;

08import android.view.ViewGroup;

09import android.widget.BaseAdapter;

10import android.widget.TextView;

11

12public class ListViewAdapter extends BaseAdapter {

13 private List items;

14 private LayoutInflater inflater;

15

16 public ListViewAdapter(Context context, List items) {

17 this.items = items;

18 inflater = (LayoutInflater) context.getSystemService(Context.LAYOUT_INFLATER_SERVICE);

19 }

20

21 @Override

22 public int getCount() {

23 return items.size();

24 }

25

26 @Override

27 public Object getItem(int position) {

28 return items.get(position);

29 }

30

31 @Override

32 public long getItemId(int position) {

33 return position;

34 }

35

36 @Override

37 public View getView(int position, View view, ViewGroup parent) {

38 if (view == null) {

39 view = inflater.inflate(R.layout.list_item, null);


上一页 1 2 3 下一页

关键词:

评论


相关推荐

技术专区

关闭