PullToRefreshListView是使用pullToRefresh的框架
需要Import Module导入 然后添加依赖 里面的版本号要一致 版本号在build.gradle里面
有几个值得注意的地方:
1. PullToRefreshListView 实现下拉或者上拉加载时候,可能在上拉完成时候,调用onRefreshComplete方法去停止刷新操作,但是,可能无效,测试产生原因,刷新获取数据时候,时间太短,就会出现该问题,我们可以 延迟 1秒左右,在调用onRefreshComplete 方法,可以解决该问题
listview.postDelayed(new Runnable() {
@Override
public void run() {
listview.onRefreshComplete();
} },1000);
记得是在 setadpter后面执行,不然 无效
2. listview.isFooterShown()的意思是是否显示尾部的加载ILoadingLayout,如果是true,说明是上拉加载操作,需要往容器里塞数据,否则就是下拉刷新,重新获取第一页数据。
isFooterShown()和isHeaderShown()是对应的,有的需要自己往库里边添加,找到这个抽象类PullToRefreshAdapterViewBase,直接添加下面这两个方法:
public boolean isHeaderShown() {
return getHeaderLayout().isShown();
}
public boolean isFooterShown() {
return getFooterLayout().isShown();
}
//仅支持下拉刷新
pullToRefreshListView.setMode(PullToRefreshBase.Mode.PULL_FROM_START);
//仅支持上拉刷新
//pullToRefreshListView.setMode(PullToRefreshBase.Mode.PULL_FROM_END);
//支持上拉,下拉刷新
//pullToRefreshListView.setMode(PullToRefreshBase.Mode.BOTH);
//禁用下拉刷新
//pullToRefreshListView.setMode(PullToRefreshBase.Mode.DISABLED);
//仅支持手动
//pullToRefreshListView.setMode(PullToRefreshBase.Mode.MANUAL_REFRESH_ONLY);
布局代码:
java代码:
package com.example.sfhan.ldjn;
import android.app.ProgressDialog;
import android.content.Context;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.util.Log;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.BaseAdapter;
import android.widget.Button;
import android.widget.ListView;
import android.widget.TextView;
import com.handmark.pulltorefresh.library.ILoadingLayout;
import com.handmark.pulltorefresh.library.PullToRefreshBase;
import com.handmark.pulltorefresh.library.PullToRefreshListView;
import java.util.ArrayList;
public class MainActivity extends AppCompatActivity {
private PullToRefreshListView listview;
private ArrayList mList;
private ArrayList list;
private MyAdapter adapter;
private int page = 1;
private ProgressDialog dialog;
private View headView;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
listview= (PullToRefreshListView) findViewById(R.id.listview);
initListView();
mList=new ArrayList();
list=new ArrayList();
adapter=new MyAdapter(this,mList);
listview.setAdapter(adapter);
listview.setMode(PullToRefreshBase.Mode.BOTH);
listview.setOnRefreshListener(new PullToRefreshBase.OnRefreshListener2() {
@Override
public void onPullDownToRefresh(PullToRefreshBase refreshView) {
page=1;
dialogs();
initData();
}
@Override
public void onPullUpToRefresh(PullToRefreshBase refreshView) {
page++;
dialogs();
initData();
}
});
}
/**
* 初始化列表控件上下拉的状态
*/
public void initListView()
{
ILoadingLayout startLabels=listview.getLoadingLayoutProxy(true,false);
startLabels.setPullLabel("下拉刷新。。。");// 刚下拉时,显示的提示
startLabels.setRefreshingLabel("正在载入。。。");// 刷新时
startLabels.setReleaseLabel("放开刷新。。。");// 下来达到一定距离时,显示的提示
ILoadingLayout endLabels = listview.getLoadingLayoutProxy(false, true);
endLabels.setPullLabel("上拉刷新...");// 刚下拉时,显示的提示
endLabels.setRefreshingLabel("正在载入...");// 刷新时
endLabels.setReleaseLabel("放开刷新...");// 下来达到一定距离时,显示的提示
headView= LayoutInflater.from(this).inflate(R.layout.headview,null);
listview.getRefreshableView().addHeaderView(headView);//为ListView添加头布局
}
private void initData()
{
//模拟从服务端返回的数据集合
list.clear();
//page++改变i的大小 所以会下拉刷新无线累加
for (int i=10*(page-1);i<10*page;i++)
{
Log.e("-------------","第"+i+"条数据");
list.add("第"+i+"条数据");
}
if(mList != null)
{
/*
* listview.isFooterShown()的意思是是否显示尾部的加载ILoadingLayout,如果是true,
* 说明是上拉加载操作,需要往容器里塞数据,否则就是下拉刷新,重新获取第一页数据。
*/
if (!listview.isFooterShown())
{
mList.clear();
mList.addAll(list);
/*
*notifyDataSetChanged方法通过一个外部的方法
* 控制如果适配器的内容改变时需要强制调用getView来刷新每个Item的内容
*/
adapter.notifyDataSetChanged();
listview.postDelayed(new Runnable() { //此方法会引起屏幕刷新,因此常用于启动页面的进度条刷新, 其他页面慎用
@Override
public void run() {
/*
*我们在使用框架:
*PullToRefreshListView 实现下拉或者上拉加载时候,可能在上拉 完成时候,调用onRefreshComplete方法去
*停止 刷新操作,但是,可能无效,测试产生原因,刷新获取数据时候,时间太短,就会出现该问题
*我们可以 延迟 1秒左右,在调用onRefreshComplete 方法,可以解决该问题
* 记得是在 setadpter后面执行,不然无效
*/
listview.onRefreshComplete();
}
},1000);
//dismiss() 主要作用是让dialog从屏幕上消失
dialog.dismiss();
}else {
adapter.addLast(list); //addLast是尾插,插到当前最后一个的后面,不是说一直保持在最后。。
adapter.notifyDataSetChanged();
listview.postDelayed(new Runnable() {
@Override
public void run() {
listview.onRefreshComplete();
}
},1000);
}
dialog.dismiss();
}
}
private class MyAdapter extends BaseAdapter {
private Context context;
private ArrayList list;
public MyAdapter(Context context,ArrayList list)
{
this.context=context;
this.list=list;
}
public void addLast(ArrayList list)
{
this.list.addAll(list);
}
@Override
public int getCount() {
if (list==null)
{
return 0;
}
return list.size();
}
@Override
public Object getItem(int position) {
return list.get(position);
}
@Override
public long getItemId(int position) {
return position;
}
@Override
public View getView(int position, View convertView, ViewGroup parent) {
View view = LayoutInflater.from(context).inflate(R.layout.llll,null);
TextView tv1= (TextView) view.findViewById(R.id.tv1);
// TextView textView=new TextView(context);
// textView.setText(list.get(position));
tv1.setText(list.get(position));
return tv1;
}
}
public void dialogs()
{
dialog=new ProgressDialog(this);
dialog.show();
dialog.setMessage("正在加载中。。。");
}
}