当要显示的数据过多时,为了更好的提升用户感知,在很多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文件:
<?xml version="1.0" enCoding="utf-8"?><relativeLayout xmlns:androID="http://schemas.androID.com/apk/res/androID" xmlns:tools="http://schemas.androID.com/tools" androID:ID="@+ID/activity_main" androID:layout_wIDth="match_parent" androID:layout_height="match_parent" tools:context="com.example.administrator.day08.MainActivity"> <ListVIEw androID:ID="@+ID/lv" androID:layout_wIDth="match_parent" androID:layout_height="match_parent" androID:layout_alignParenttop="true" androID:layout_alignParentStart="true" /></relativeLayout>
Layout中item(填充ListVIEw每行)布局item.xml文件:
<?xml version="1.0" enCoding="utf-8"?><linearLayout xmlns:androID="http://schemas.androID.com/apk/res/androID" androID:orIEntation="vertical" androID:layout_wIDth="match_parent" androID:layout_height="match_parent"> <TextVIEw androID:text="Tile" androID:textSize="30dp" androID:layout_wIDth="match_parent" androID:layout_height="wrap_content" androID:ID="@+ID/textVIEw" /> <TextVIEw androID:text="Message" androID:textSize="20dp" androID:layout_wIDth="match_parent" androID:layout_height="wrap_content" androID:ID="@+ID/textVIEw2" /></linearLayout>
Layout中页面刷新提示布局(页脚)login_item.xml文件:
<?xml version="1.0" enCoding="utf-8"?><linearLayout xmlns:androID="http://schemas.androID.com/apk/res/androID" androID:orIEntation="horizontal" androID:layout_wIDth="match_parent" androID:layout_height="match_parent" androID:gravity="center"> <Progressbar androID:layout_wIDth="wrap_content" androID:layout_height="wrap_content" androID:layout_gravity="center" androID:ID="@+ID/progressbar" /> <TextVIEw androID:text="玩命加载中" androID:layout_wIDth="wrap_content" androID:layout_height="wrap_content" androID:ID="@+ID/textVIEw3" /></linearLayout>
Java中自定义对象类(每条新闻有对应的标题以及内容)
public class News { String Title; String message; }
Java中功能实现类(通过实现OnScrollListener接口)
import androID.content.DialogInterface;import androID.os.Handler;import androID.os.Message;import androID.support.v7.app.AlertDialog;import androID.support.v7.app.AppCompatActivity;import androID.os.Bundle;import androID.vIEw.VIEw;import androID.vIEw.VIEwGroup;import androID.Widget.AbsListVIEw;import androID.Widget.AdapterVIEw;import androID.Widget.BaseAdapter;import androID.Widget.ListVIEw;import androID.Widget.TextVIEw;import java.util.ArrayList;import java.util.List;/** * Created by panchengjia on 2016/11/29. */public class MainActivity extends AppCompatActivity implements AbsListVIEw.OnScrollListener{ private ListVIEw lv; private List<News> news;//声明存储新闻标题与内容的List private int total=1;//计数器(设置默认从1开始)用于集合内数据初始化 MyAdapter adapter; @OverrIDe protected voID onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentVIEw(R.layout.activity_main); lv= (ListVIEw) findVIEwByID(R.ID.lv); //为当前ListVIEw设置OnScrollListener实现分页刷新 lv.setonScrollListener(this); //将login_item(下拉刷新效果的item)通过布局 填充器声明 VIEw v = getLayoutInflater().inflate(R.layout.login_item,null); //将login_item设置到ListVIEw页脚 lv.addFooterVIEw(v); //实例化存储内容资源的List news = new ArrayList<>(); //调用初始化List的方法 initList(); adapter = new MyAdapter(); //设置单击item的事件 lv.setonItemClickListener(new AdapterVIEw.OnItemClickListener() { @OverrIDe public voID onItemClick(AdapterVIEw<?> parent,VIEw vIEw,int position,long ID) { show(vIEw);//事件处理为调用show方法(显示AlertDialog对话框) } }); lv.setAdapter(adapter); } //AlertDialog对话框的调用这里就不多说了,前期有专门的博文解释 public voID show(VIEw v){ AlertDialog.Builder builder = new AlertDialog.Builder(this); TextVIEw Title = (TextVIEw) v.findVIEwByID(R.ID.textVIEw); TextVIEw message = (TextVIEw) v.findVIEwByID(R.ID.textVIEw2); builder.setTitle(Title.getText().toString()); builder.setMessage(message.getText().toString()); builder.setPositivebutton("已经浏览完毕",new DialogInterface.OnClickListener() { @OverrIDe public voID onClick(DialogInterface dialog,int which) { } }); builder.show(); } //初始化List内的元素,模拟每次可刷新10条信息 private voID initList() { for(int i=1;i<=10;i++){ News n = new News(); //加total是因为total在刷新页面后不会继续从一开始 n.Title = "Title--"+total; n.message="Message"+total; news.add(n); totaL++; } }// int currenVisibleItemCount;//声明截止当前页面看到的item总数(演示用) boolean isLastRow=false;//判断是否到ListVIEw的最后一个item @OverrIDe public voID onScroll(AbsListVIEw vIEw,int firstVisibleItem,int visibleItemCount,int totalitemCount) { //firstVisibleItem位可见页面的第一条在ArrayList中的下标,visibleItemCount为当前页面item数// currenVisibleItemCount = firstVisibleItem+visibleItemCount-1=totalitemCount;(演示用) if(firstVisibleItem+visibleItemCount==totalitemCount&&totalitemCount>0){ isLastRow=true;//判断已经到最后一个item(即为footerVIEw) } } @OverrIDe public voID onScrollStateChanged(AbsListVIEw vIEw,int scrollState) { /*判断是否刷新页面之前,解释一下scrollState的三种状态 * 1.scrollState = SCRolL_STATE_touch_SCRolL为手指按住屏幕滚动(未脱离屏幕); * 2.scrollState = SCRolL_STATE_FliNG可以理解为手指离开屏幕前,用力滑了一下, * 手指离开后,页面已然保持滚动; * 3.scrollState = SCRolL_STATE_IDLE手指未接触屏幕,且屏幕页面保持静止 * 开启刷新页面的线程前,确保ListVIEw已经到最后一行(Item)并且屏幕页面保持静止 * */ if(isLastRow&&scrollState==SCRolL_STATE_IDLE){ new Thread(new MyThread()).start(); } } //创建分页刷新线程(模拟刷新) class MyThread implements Runnable{ @OverrIDe public voID run() { try { Thread.sleep(500);//设置线程休眠时间为500毫秒刷新一次 } catch (InterruptedException e) { e.printstacktrace(); } initList();//重新初始化List //线程内调用Handler执行页面刷新(后面会写文对handler进行详细剖析) handler.sendEmptyMessage(1); } } Handler handler = new Handler(){ @OverrIDe public voID handleMessage(Message msg) { super.handleMessage(msg); switch (msg.what){ case 1: //强制调用适配器的getVIEw来刷新每个Item的内容。 adapter.notifyDataSetChanged(); break; } } }; //自定义适配器 class MyAdapter extends BaseAdapter{ @OverrIDe public int getCount() { return news.size(); } @OverrIDe public Object getItem(int position) { return news.get(position); } @OverrIDe public long getItemID(int position) { return position; } @OverrIDe public VIEw getVIEw(int position,VIEw convertVIEw,VIEwGroup parent) { VIEwHolder vh; if(convertVIEw==null){ convertVIEw = getLayoutInflater().inflate(R.layout.item,null); vh=new VIEwHolder(); vh.message = (TextVIEw) convertVIEw.findVIEwByID(R.ID.textVIEw2); vh.Title= (TextVIEw) convertVIEw.findVIEwByID(R.ID.textVIEw); convertVIEw.setTag(vh); } vh= (VIEwHolder) convertVIEw.getTag(); vh.Title.setText(news.get(position).Title); vh.message.setText(news.get(position).message); return convertVIEw; } class VIEwHolder{ TextVIEw Title; TextVIEw message; } }}
至此ListVIEw的分页刷新源码已全部展示完成,个人认为实现此功能的核心为判断是否达到当前ListVIEw中的最后一条item(包含页脚刷新提示)以及理解scrollState的状态,理解了这两点,该功能的实现起来事半功倍。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程小技巧。
总结以上是内存溢出为你收集整理的Android使用listview实现分页刷新(线程休眠模拟)全部内容,希望文章能够帮你解决Android使用listview实现分页刷新(线程休眠模拟)所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)