PullToRefreshListView 史上最详解释

 

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

 

布局代码:

<span style="color:#333333"><?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:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:text="请刷新"
        android:layout_gravity="center"
        android:gravity="center"
        android:textSize="20dp"
        android:textColor="#67ff67ff"
        />
    <com.handmark.pulltorefresh.library.PullToRefreshListView
        android:id="@+id/listview"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        />
</LinearLayout></span>
<span style="color:#333333">java代码:</span>
<span style="color:#333333">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<String> mList;
    private ArrayList<String> 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<String>();
        list=new ArrayList<String>();
        adapter=new MyAdapter(this,mList);
        listview.setAdapter(adapter);
        listview.setMode(PullToRefreshBase.Mode.BOTH);
        listview.setOnRefreshListener(new PullToRefreshBase.OnRefreshListener2<ListView>() {
            @Override
            public void onPullDownToRefresh(PullToRefreshBase<ListView> refreshView) {
                page=1;
               dialogs();
                initData();
            }

            @Override
            public void onPullUpToRefresh(PullToRefreshBase<ListView> 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<String> list;
        public MyAdapter(Context context,ArrayList<String> list)
        {
            this.context=context;
            this.list=list;
        }
        public void addLast(ArrayList<String> 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("正在加载中。。。");

    }
}
</span>

 

 

 

 

 

 

 

  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值