新网创想网站建设,新征程启航
为企业提供网站建设、域名注册、服务器等服务
今天就跟大家聊聊有关如何在Android应用中利用ListView实现一个分页功能,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。
专注于为中小企业提供做网站、成都网站制作服务,电脑端+手机端+微信端的三站合一,更高效的管理,为中小企业长顺免费做网站提供优质的服务。我们立足成都,凝聚了一批互联网行业人才,有力地推动了上千家企业的稳健成长,帮助中小企业通过网站建设实现规模扩充和转变。Android ListView分页简单实现
分页,开发应用中必不可少。那么,现在就来实现分页功能。
首先来想想实现它要有哪些步骤,
1, 实现的组件,
2、初始化第一页数据,
3,底部布局 ,
4,加载数据的条件
5、获取下一页的数据。
有了思路,我们一步步来实现就行了。先来想想我们用什么组件实现,我们知道列表UI我们常用ListView或者RecyclerView,初始化数据,我们就在通过一个for循环来准备数据,底部布局我们直接使ProgressBar控件和一个TextView来显示就可以了。至于,加载的数据,我们就使用OnScrollListener来监听滑动事件,然后在满足加载条件时,我们就可以加载下一页的数据了。
先来看看ListView实现:
自定义ListView (LoadListView.Java):
public class LoadListView extends ListView implements AbsListView.OnScrollListener{ private LayoutInflater mInflater; //判断是否滚动最后一行 private boolean isLastRow = false; //底部View布局 private View mFooter; //实现接口加载更多数据 public OnLoadMoreListener moreListener; public void setLoadMoreListener(OnLoadMoreListener moreListener){ this.moreListener = moreListener; } public LoadListView(Context context) { super(context); initView(); } public LoadListView(Context context, AttributeSet attrs) { super(context, attrs); initView(); } public LoadListView(Context context, AttributeSet attrs, int defStyleAttr) { super(context, attrs, defStyleAttr); initView(); } private void initView(){ mInflater = LayoutInflater.from(getContext()); mFooter = mInflater.inflate(R.layout. listview_footer,null); this.addFooterView(mFooter); mFooter.setVisibility(View.GONE); setOnScrollListener(this); } @Override public void onScrollStateChanged(AbsListView absListView, int scrollState) { //正在滚动时回调,回调2-3次,手指没抛则回调2次。scrollState = 2的这次不回调 //回调顺序如下 //第1次:scrollState = SCROLL_STATE_TOUCH_SCROLL(1) 正在滚动 //第2次:scrollState = SCROLL_STATE_FLING(2) 手指做了抛的动作(手指离开屏幕前,用力滑了一下) //第3次:scrollState = SCROLL_STATE_IDLE(0) 停止滚动 //当屏幕停止滚动时为0;当屏幕滚动且用户使用的触碰或手指还在屏幕上时为1; //由于用户的操作,屏幕产生惯性滑动时为2 //当滚到最后一行且停止滚动时,执行加载 if(isLastRow&&scrollState== OnScrollListener.SCROLL_STATE_IDLE){ mFooter.setVisibility(View.VISIBLE); isLastRow = false; if(moreListener!=null){ moreListener.loadMore(); } } } @Override public void onScroll(AbsListView absListView, int firstVisibleItem, int visibleItemCount, int totalItemCount) { //滚动时一直回调,直到停止滚动时才停止回调。单击时回调一次。 //firstVisibleItem:当前能看见的第一个列表项ID(从0开始) //visibleItemCount:当前能看见的列表项个数(小半个也算) //totalItemCount:列表项共数 //判断是否滚到最后一行 if (firstVisibleItem + visibleItemCount == totalItemCount && totalItemCount > 0) { isLastRow = true; } } public interface OnLoadMoreListener{ void loadMore(); } }