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();
  }
}

底部布局listfooter.xml

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
  android:layout_width="match_parent"
  android:layout_height="wrap_content"
  android:orientation="vertical">
  <ProgressBar
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_toLeftOf="@+id/id_loadmore"
    android:layout_marginRight="5dp" />
  <TextView
    android:id="@+id/id_loadmore"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:text="加载更多"
    android:layout_centerHorizontal="true"
    android:layout_centerVertical="true"/>
</RelativeLayout>

MainActivity.java的源码:

public class MainActivity extends Activity implements LoadListView.OnLoadMoreListener {
  private List<News> list = new ArrayList<>() ;
  private loadAdapter mAdapter;
  private LoadListView mListView;
  @Override
  protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);
    loadMoreData();
    mListView =(LoadListView) findViewById(R.id.id_list_view);
    mAdapter = new loadAdapter(this,list);
    mListView.setAdapter(mAdapter);
    mListView.setLoadMoreListener(this);
  }
  private void loadMoreData(){
    for(int i = 0 ; i <10;i++){
      News news = new News();
      news.setTitle("许巍");
      news.setContent("蓝莲花");
      list.add(news);
    }
  }

  @Override
  public void loadMore() {
    new Handler().postDelayed(new Runnable() {
      @Override
      public void run() {
        loadMoreData();
        showLoadMore();
      }
    },2000);

  }
  private void showLoadMore(){
    mAdapter.notifyDataSetChanged();
  }
}

LoadAdapter.java

public class loadAdapter extends BaseAdapter {
  private List<News> list;
  private Context mContext;
  public loadAdapter(Context context,List<News> list){
    this.list = list;
    this.mContext = context;
  }

  @Override
  public int getCount() {
    return list.size();
  }

  @Override
  public Object getItem(int position) {
    return position;
  }

  @Override
  public long getItemId(int position) {
    return position;
  }

  @Override
  public View getView(int position, View convertView, ViewGroup parent) {
    ViewHolder viewHolder;
    if(convertView==null){
      viewHolder = new ViewHolder();
      convertView = LayoutInflater.from(mContext).inflate(R.layout.item_news,null);
      viewHolder.title = (TextView) convertView.findViewById(R.id.id_title);
      viewHolder.content = (TextView)convertView.findViewById(R.id.id_content);
      convertView.setTag(viewHolder);
    }else {
      viewHolder = (ViewHolder) convertView.getTag();
    }
    viewHolder.title.setText(list.get(position).getTitle());
    viewHolder.content.setText(list.get(position).getContent());
    return convertView;
  }

  public class ViewHolder{
    private TextView title;
    private TextView content;
  }

}

activity_main.xml:

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
  android:layout_width="match_parent"
  android:layout_height="match_parent">
  <view.LoadListView
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:id="@+id/id_list_view"
    />
</LinearLayout>

item_news.xml:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
  android:layout_width="match_parent"
  android:layout_height="match_parent"
  android:orientation="vertical">
<TextView
  android:id="@+id/id_title"
  android:layout_width="match_parent"
  android:layout_height="wrap_content"
  android:text=""
  android:gravity="center"
  android:padding="5dp"/>
  <TextView
    android:id="@+id/id_content"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:text=""
    android:gravity="center"
    android:padding="5dp"/>
</LinearLayout>

其实只要掌握了OnScrollListener的回调,那么就很简单了。RecyclerView也出现很久了,慢慢的,RecyclerView也会替代了ListView,所以ListView分页似乎就过时了,我们想知道的是RecyclerView怎么实现分页。但是我们知道RecyclerView不能实现头部和底部的添加,所以我们要自己来实现一个能添加头部和底部的ReyclerView。

感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!

(0)

相关推荐

  • Android ListView与ScrollView冲突的解决方法总结

    Android ListView与ScrollView冲突的解决方法总结 众所周知ListView与ScrollView都具有滚动能力,对于这样的View控件,当ScrollView与ListView相互嵌套会成为一种问题:  问题一:ScrollView与ListView嵌套导致ListView显示不全面  问题二:ScrollView不能正常滑动 解决方式一: ScrollView+LinearLayout+ListView可以换成ScrollView+LinearLayout+Linear

  • Android使用ListView实现滚轮的动画效果实例

    之前收到一个需求,需要把一个数据展示列表页面做成像滚轮那样的动画效果:中间最大然后向上下两端逐渐缩小.我想了想iOS那边自带滚轮组件,安卓得自己去实现,目前网上仿ios的滚轮组件的也有一些,但是感觉不适合我,我的要求没那么复杂,于是决定自己动手去实现一下. 动手前先分析一下应该怎么做,归根到底只是要实现缩放效果,由中间向两边变小,当一个item越接近中间就放大,越远离中间就缩小.那么可以通过先获取ListView的中点,然后获取当前可视的所有item跟ListView的中点的垂直距离计算出一个比

  • Android控件ListView使用方法详解

    Android控件ListView使用方法介绍,具体如下 一.ListView的简单用法 首先新建一个ListViewTest项目,并让Android Studio自动创建好活动.然后修改activity_main.xml中的代码,如下: <?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/re

  • Android TV listview及焦点处理

    Android TV listview及焦点处理 Android TV上的listview ,因为没有touch事件,只能通过按键处理,因此,用到listview时需要特殊处理: 1.复杂的view需要获取焦点,需要设置: setItemsCanFocus(true) 同时需要设置下能获取焦点view的属性: android:focusable="true 这样子级view就可以获取获取焦点. 2.view中需要获取焦点需要高亮框效果,可以在view画外框: package com.cn21.e

  • Android 实现ListView的点击变色的实例

    Android 实现ListView的点击变色的实例 我做了一个音乐播放器,其中用ListView显示歌曲列表,当我点击某一首歌时,希望这首歌所在的item的背景颜色改变,以突出显示所选择的歌曲. 首先我想到的是在ItemClickListener里面写,如下: private View formerView=null; private class ListViewClickListener implements OnItemClickListener{ @Override public voi

  • Android ListView滑动改变标题栏背景渐变效果

    先上ListView滑动改变标题栏背景渐变效果图,透明转变成不透明效果: 图1: 图2: 图3: 图4: 我用的是小米Note手机,状态栏高度是55px,后面会提到,这里先做个说明: 下面的内容包含了所有代码和一些测试数据: 代码: 代码很简单,也做了注释,这里就不废话了. 先来布局文件: activity的布局 activity_main_10 <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/androi

  • Android ListView列表控件的介绍和性能优化

    ListView列表控件 一.ListView显示数据的原理:mvc模式 m:mode 数据(用javabean规范封装) v:view ListView c:adapter 适配器,负责把数据展示到ListView上 二.ListView最常用适配器 BaseAdapter.SimpleAdapter.ArrayAdapter 三.ListView显示数据的步骤 1.创建ListView 2.自定义ListView的适配器继承BaseAdapter,重写baseAdapter的getCount

  • Android ListView分页简单实现

    Android ListView分页简单实现 分页,开发应用中必不可少.那么,现在就来实现分页功能. 首先来想想实现它要有哪些步骤, 1, 实现的组件, 2.初始化第一页数据, 3,底部布局 , 4,加载数据的条件 5.获取下一页的数据. 有了思路,我们一步步来实现就行了.先来想想我们用什么组件实现,我们知道列表UI我们常用ListView或者RecyclerView,初始化数据,我们就在通过一个for循环来准备数据,底部布局我们直接使ProgressBar控件和一个TextView来显示就可以

  • Android ListView实现简单列表功能

    ListView如何实现简单列表,供大家参考,具体内容如下 效果图: 啥也没干的ListView张这样: fry.Activity01 package fry; import com.example.ListView.R; import android.app.Activity; import android.os.Bundle; import android.view.View; import android.widget.AdapterView; import android.widget.

  • Android ListView分页功能实现方法

    通过本次小Demo我学到了: 1.ListView的小小的一个分页功能 2.加深了对自定义控件的理解 3.对ListView的优化 4.对BaseAdapter的使用 5.自定义Adapter 6.接口的回调 要实现下面的效果--当拖动ListView到底部的时候,显示一个ProgressBar和一个"正在加载..."的TextView.并且过两秒钟后,在下面加载出新的数据.项目的目录结构和程序要实现的效果如下:   首先是布局部分: 我为了实现此效果,首先在布局文件中新建了一个foo

  • Android之ListView分页加载数据功能实现代码

    什么是ListView分页加载数据功能呢?在现在的大数据时代,我们不可能把某些数据全部展示到界面,好比我们经常会看的QQ空间一样,当你看动态的时候,系统不可能会把所有好友的动态都展示在上面,你能看到的一般都是最新好友更新的动态,假如你要看非最新的好友动态,通常你都会手指向上滑动屏幕然后去查看,当界面下滑到一定数量的时候,就会看到一个"查看更多",然后突然停顿一下,系统会通过网络去给你刷新其他动态信息,这样的功能我们一般叫做数据下拉刷新功能,也就是我们的分页加载功能,具体的实现是怎样的呢

  • Android ListView实现仿iPhone实现左滑删除按钮的简单实例

    需要自定义ListView.这里就交FloatDelListView吧. 复写onTouchEvent方法.如下: @Override public boolean onTouchEvent(MotionEvent ev) { switch (ev.getAction()) { case MotionEvent.ACTION_DOWN:<BR> // 获取按下的条目视图(child view) int childCount = getChildCount(); int[] listViewCo

  • android实现listview分页的方法

    本文实例讲述了android实现listview分页的方法.分享给大家供大家参考.具体分析如下: 最近做了下listview的分页,跟WEB上的分页是一个意思,需要那几个分页参数,不同的是sqlite中分页的查询语句,简便的方法需要用Limit,Offset关键字,前者是查询每页展示的记录数,后者是越过多少记录数,说得明白点就是忽略前面多少行记录之后,取多少行记录 我分页采用了一个重要的类Page,通过封装Page类,做为参数传递进来,返回出去也是个Page对象 import java.util

  • android避免弹出软键盘遮盖listview的简单方法

    做开发的时候,我们常常把listview放中间,然后底部放置一个edittext控件,这样导致editext控件获得焦点的时候,输入法弹出,Edittext控件上移,挡住了listview的部分数据,这样不太美观.所以,我们需要让listview也跟着上移,所以需要: 方法一:在xml文件中,设置listview属性时候加上这句就ok了android:transcriptMode="normal": 方法二:在程序中加入语句: listView.setTranscriptMode(Li

  • Android开发之ListView的简单用法及定制ListView界面操作示例

    本文实例讲述了Android开发之ListView的简单用法及定制ListView界面操作.分享给大家供大家参考,具体如下: 效果: 如何从获得listview上item的内容 详见:https://www.jb51.net/article/158000.htm 中遇到的问题部分. 布局实现: 有个listview显示 一个edit和button发送 <?xml version="1.0" encoding="utf-8"?> <RelativeL

  • Android实现ListView分页加载数据

    本文实例为大家分享了ListView分页加载数据的具体代码,供大家参考,具体内容如下 FenyeActivity package com.example.myapplication.fenye; import androidx.appcompat.app.AppCompatActivity; import android.app.ListActivity; import android.os.Bundle; import android.os.Handler; import android.ut

  • Android listview与adapter详解及实例代码

    一个ListView通常有两个职责. (1)将数据填充到布局. (2)处理用户的选择点击等操作. 第一点很好理解,ListView就是实现这个功能的.第二点也不难做到,在后面的学习中读者会发现,这非常简单. 一个ListView的创建需要3个元素. (1)ListView中的每一列的View. (2)填入View的数据或者图片等. (3)连接数据与ListView的适配器. 也就是说,要使用ListView,首先要了解什么是适配器.适配器是一个连接数据和AdapterView(ListView就

随机推荐