android pulltorefresh gradle,Android 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);

布局代码:

android:layout_width="match_parent"

android:layout_height="match_parent"

android:orientation="vertical"

>

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"

/>

android:id="@+id/listview"

android:layout_width="match_parent"

android:layout_height="match_parent"

/>

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("正在加载中。。。");

}

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值