Android中使用ListView实现分页刷新(线程休眠模拟)

当要显示的数据过多时,为了更好的提升用户感知,在很多APP中都会使用分页刷新显示,比如浏览新闻,向下滑动到当前ListView的最后一条信息(item)时,会提示刷新加载,然后加载更新后的内容。此过程大致分以下几步:

1.当前Activity implements OnScallListenner;

2.实现接口的方法;

3.ListView注册滚动监听;

4. Adapter(自定义或者安卓自带)为每个item填充数据;

5.获得第二页以后的数据后,adater增加数据并刷新notifyDateSetChanged();(需要用到Handler)

现在我们就通过线程休眠的的方式模拟ListView页面刷新的实现(每次加载10条信息,向下滑动会分页刷新加载)

显示效果(设置显示十条后开启刷新,添加使用AlertDialog浏览示例):

Layout中ListView布局activity_main.xml文件:

 1 <?xml version="1.0" encoding="utf-8"?>
 2 <RelativeLayout
 3     xmlns:android="http://schemas.android.com/apk/res/android"
 4     xmlns:tools="http://schemas.android.com/tools"
 5     android:id="@+id/activity_main"
 6     android:layout_width="match_parent"
 7     android:layout_height="match_parent"
 8     tools:context="com.example.administrator.day08.MainActivity">
 9     <ListView
10         android:id="@+id/lv"
11         android:layout_width="match_parent"
12         android:layout_height="match_parent"
13         android:layout_alignParentTop="true"
14         android:layout_alignParentStart="true" />
15 </RelativeLayout>

Layout中item(填充ListView每行)布局item.xml文件:

 1 <?xml version="1.0" encoding="utf-8"?>
 2 <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
 3     android:orientation="vertical" android:layout_width="match_parent"
 4     android:layout_height="match_parent">
 5     <TextView
 6         android:text="Tile"
 7         android:textSize="30dp"
 8         android:layout_width="match_parent"
 9         android:layout_height="wrap_content"
10         android:id="@+id/textView" />
11     <TextView
12         android:text="Message"
13         android:textSize="20dp"
14         android:layout_width="match_parent"
15         android:layout_height="wrap_content"
16         android:id="@+id/textView2" />
17 </LinearLayout>

Layout中页面刷新提示布局(页脚)login_item.xml文件:

 1 <?xml version="1.0" encoding="utf-8"?>
 2 <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
 3     android:orientation="horizontal" android:layout_width="match_parent"
 4     android:layout_height="match_parent" android:gravity="center">
 5     <ProgressBar
 6         style="?android:attr/progressBarStyle"
 7         android:layout_width="wrap_content"
 8         android:layout_height="wrap_content"
 9         android:layout_gravity="center"
10         android:id="@+id/progressBar" />
11     <TextView
12         android:text="玩命加载中"
13         android:layout_width="wrap_content"
14         android:layout_height="wrap_content"
15         android:id="@+id/textView3" />
16 </LinearLayout>

Java中自定义对象类(每条新闻有对应的标题以及内容)

1 public class News {
2     String title;
3     String message;
4 }

Java中功能实现类(通过实现OnScrollListener接口)

  1 import android.content.DialogInterface;
  2 import android.os.Handler;
  3 import android.os.Message;
  4 import android.support.v7.app.AlertDialog;
  5 import android.support.v7.app.AppCompatActivity;
  6 import android.os.Bundle;
  7 import android.view.View;
  8 import android.view.ViewGroup;
  9 import android.widget.AbsListView;
 10 import android.widget.AdapterView;
 11 import android.widget.BaseAdapter;
 12 import android.widget.ListView;
 13 import android.widget.TextView;
 14 import java.util.ArrayList;
 15 import java.util.List;
 16 /**
 17  * Created by panchengjia on 2016/11/29.
 18  */
 19 public class MainActivity extends AppCompatActivity implements AbsListView.OnScrollListener{
 20     private ListView lv;
 21     private List<News> news;//声明存储新闻标题与内容的List
 22     private int total=1;//计数器(设置默认从1开始)用于集合内数据初始化
 23     MyAdapter adapter;
 24     @Override
 25     protected void onCreate(Bundle savedInstanceState) {
 26         super.onCreate(savedInstanceState);
 27         setContentView(R.layout.activity_main);
 28         lv= (ListView) findViewById(R.id.lv);
 29         //为当前ListView设置OnScrollListener实现分页刷新
 30         lv.setOnScrollListener(this);
 31         //将login_item(下拉刷新效果的item)通过布局 填充器声明
 32         View v = getLayoutInflater().inflate(R.layout.login_item,null);
 33         //将login_item设置到ListView页脚
 34         lv.addFooterView(v);
 35         //实例化存储内容资源的List
 36         news = new ArrayList<>();
 37         //调用初始化List的方法
 38         initList();
 39         adapter = new MyAdapter();
 40         //设置单击item的事件
 41         lv.setOnItemClickListener(new AdapterView.OnItemClickListener() {
 42             @Override
 43             public void onItemClick(AdapterView<?> parent, View view, int position, long id) {
 44                 show(view);//事件处理为调用show方法(显示AlertDialog对话框)
 45             }
 46         });
 47         lv.setAdapter(adapter);
 48     }
 49     //AlertDialog对话框的调用这里就不多说了,前期有专门的博文解释
 50     public void show(View v){
 51         AlertDialog.Builder builder = new AlertDialog.Builder(this);
 52         TextView title = (TextView) v.findViewById(R.id.textView);
 53         TextView message = (TextView) v.findViewById(R.id.textView2);
 54         builder.setTitle(title.getText().toString());
 55         builder.setMessage(message.getText().toString());
 56         builder.setPositiveButton("已经浏览完毕", new DialogInterface.OnClickListener() {
 57             @Override
 58             public void onClick(DialogInterface dialog, int which) {
 59
 60             }
 61         });
 62         builder.show();
 63     }
 64     //初始化List内的元素,模拟每次可刷新10条信息
 65     private void initList() {
 66         for(int i=1;i<=10;i++){
 67             News n = new News();
 68             //加total是因为total在刷新页面后不会继续从一开始
 69             n.title = "Title--"+total;
 70             n.message="Message"+total;
 71             news.add(n);
 72             total++;
 73         }
 74     }
 75 //    int currenVisibleItemCount;//声明截止当前页面看到的item总数(演示用)
 76     boolean isLastRow=false;//判断是否到ListView的最后一个item
 77     @Override
 78     public void onScroll(AbsListView view, int firstVisibleItem, int visibleItemCount, int totalItemCount) {
 79         //firstVisibleItem位可见页面的第一条在Arraylist中的下标,visibleItemCount为当前页面item数
 80 //        currenVisibleItemCount = firstVisibleItem+visibleItemCount-1=totalItemCount;(演示用)
 81         if(firstVisibleItem+visibleItemCount==totalItemCount&&totalItemCount>0){
 82             isLastRow=true;//判断已经到最后一个item(即为footerView)
 83         }
 84     }
 85     @Override
 86     public void onScrollStateChanged(AbsListView view, int scrollState) {
 87         /*判断是否刷新页面之前,解释一下scrollState的三种状态
 88         * 1.scrollState = SCROLL_STATE_TOUCH_SCROLL为手指按住屏幕滚动(未脱离屏幕);
 89         * 2.scrollState = SCROLL_STATE_FLING可以理解为手指离开屏幕前,用力滑了一下,
 90         *       手指离开后,页面已然保持滚动;
 91         * 3.scrollState = SCROLL_STATE_IDLE手指未接触屏幕,且屏幕页面保持静止
 92         * 开启刷新页面的线程前,确保ListView已经到最后一行(Item)并且屏幕页面保持静止
 93         * */
 94         if(isLastRow&&scrollState==SCROLL_STATE_IDLE){
 95             new Thread(new MyThread()).start();
 96         }
 97     }
 98     //创建分页刷新线程(模拟刷新)
 99     class MyThread implements Runnable{
100
101         @Override
102         public void run() {
103             try {
104                 Thread.sleep(500);//设置线程休眠时间为500毫秒刷新一次
105             } catch (InterruptedException e) {
106                 e.printStackTrace();
107             }
108             initList();//重新初始化List
109             //线程内调用Handler执行页面刷新(后面会写文对handler进行详细剖析)
110             handler.sendEmptyMessage(1);
111         }
112     }
113     Handler handler = new Handler(){
114         @Override
115         public void handleMessage(Message msg) {
116             super.handleMessage(msg);
117             switch (msg.what){
118                 case 1:
119                     //强制调用适配器的getView来刷新每个Item的内容。
120                     adapter.notifyDataSetChanged();
121                     break;
122             }
123         }
124     };
125     //自定义适配器
126     class MyAdapter extends BaseAdapter{
127         @Override
128         public int getCount() {
129             return news.size();
130         }
131         @Override
132         public Object getItem(int position) {
133             return news.get(position);
134         }
135         @Override
136         public long getItemId(int position) {
137             return position;
138         }
139         @Override
140         public View getView(int position, View convertView, ViewGroup parent) {
141             ViewHolder vh;
142             if(convertView==null){
143                 convertView = getLayoutInflater().inflate(R.layout.item,null);
144                 vh=new ViewHolder();
145                 vh.message = (TextView) convertView.findViewById(R.id.textView2);
146                 vh.title= (TextView) convertView.findViewById(R.id.textView);
147                 convertView.setTag(vh);
148             }
149             vh= (ViewHolder) convertView.getTag();
150             vh.title.setText(news.get(position).title);
151             vh.message.setText(news.get(position).message);
152             return convertView;
153         }
154         class ViewHolder{
155             TextView title;
156             TextView message;
157         }
158     }
159 }

至此ListView的分页刷新源码已全部展示完成,个人认为实现此功能的核心为判断是否达到当前ListView中的最后一条item(包含页脚刷新提示)以及理解scrollState的状态,理解了这两点,该功能的实现起来事半功倍。

时间: 2024-10-12 04:02:43

Android中使用ListView实现分页刷新(线程休眠模拟)的相关文章

Android中使用ListView实现分页刷新(线程休眠模拟)(滑动加载列表)

当要显示的数据过多时,为了更好的提升用户感知,在很多APP中都会使用分页刷新显示,比如浏览新闻,向下滑动到当前ListView的最后一条信息(item)时,会提示刷新加载,然后加载更新后的内容.此过程大致分以下几步: 1.当前Activity implements OnScallListenner: 2.实现接口的方法: 3.ListView注册滚动监听: 4. Adapter(自定义或者安卓自带)为每个item填充数据: 5.获得第二页以后的数据后,adater增加数据并刷新notifyDat

Android中使用ListView绘制自定义表格(2)

上回再写了<Android中使用ListView绘制自定义表格>后,很多人留言代码不全和没有数据样例.但因为项目原因,没法把源码全部贴上来.近两天,抽空简化了一下,做了一个例子. 效果图如 一.功能: 1.支持列合并 2.考虑了界面刷新优化 3.预留部分接口 4.支持左右滚动 1.枚举类:CellTypeEnum package csdn.danielinbiti.custometableview.item; public enum CellTypeEnum { STRING //字符 ,DI

【转】整理一下Android中的ListView

原文网址:http://sunbofu.blog.51cto.com/6431507/1280441 Android中的listview目测是一个使用频率很高的组件,所以今天来总结一下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 45

Android中自定义ListView无法响应OnItemClickListener中的onItemClick方法问题解决方案

如果你的自定义ListViewItem中有Button或者Checkable的子类控件的话,那么默认focus是交给了子控件,而ListView 的Item能被选中的基础是它能获取Focus,也就是说我们可以通过将ListView中Item中包含的所有控件的focusable属性设置为 false,这样的话ListView的Item自动获得了Focus的权限,也就可以被选中了 我们可以通过对Item Layout的根控件设置其android:descendantFocusability="blo

Android中使用ListView绘制自定义表格(3)

把自定义表格又改进了一下,可以支持行合并.表格分为简单和复杂两种模式 1.简单模式就是<Android中使用ListView绘制自定义表格(2)>描述的方式.不支持行合并 2.复杂模式支持行列合并 1.基于上回上传的代码,改动文件如下 package csdn.danielinbiti.custometableview.item; public class ItemCell { private String cellValue = "";//单元格的值 private in

Android中设置ListView内容刷新问题

最近在学习Android的listView控件时遇到了一个问题,如何添加一个Item到ListView中并及时的刷新出来.在网上查了很多帖子,很多人在问,也很多人在解答,但是总的来说都没找到详细的解决方案.对于ListView与数据库的同步,高手们建议使用ContentProvider对象.但是如果我不使用数据库呢?也有人回答用notifyDataSetChanged()方法.这倒是一个正确的解决方案,但是对于新手来说,还是比较困惑怎么去用,这里我贴一下我的用法: 代码 OnClickListe

Android中自定义ListView实现上拉加载更多和下拉刷新

ListView是Android中一个功能强大而且很常用的控件,在很多App中都有ListView的下拉刷新数据和上拉加载更多这个功能.这里我就简单记录一下实现过程. 实现这个功能的方法不止一个,GitHub上有一些开源库可以使用,但是本着学习的精神,我做的是使用自定义ListView实现这个功能. 思路:谷歌提供的ListView是不能提供下拉刷新和下拉加载的,所以我们就需要重写ListView.在ListView的头部和尾部加上我们的布局文件(progressbar). 先说上拉加载更多实现

Android—自定义控件实现ListView下拉刷新

这篇博客为大家介绍一个android常见的功能——ListView下拉刷新(参考自他人博客,网址忘记了,阅读他的代码自己理解注释的,希望能帮助到大家): 首先下拉未松手时候手机显示这样的界面: 下面的代码是自定的扎样的控件: package com.dhsr.smartID.view; import android.content.Context; import android.util.AttributeSet; import android.view.Gravity; import andr

android中设置ListView的选中的Item的背景颜色

ListView中没有默认的选择颜色,只有选择Item后的焦点颜色,鼠标点击时Item有颜色,放开鼠标后颜色也就没有了,要实现放开鼠标后选择项的背景还是有颜色的. 1.配置main.xml Java代码   <?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"