自定义上拉加载更多--利用swiperefreshlayout

git上写的比简书详细,各位可以直接在git上看

git地址      https://github.com/huxingxin123/Refresh_up


讲一下swiperefreshlayout的上拉加载


Swipe自带下拉刷新,我们只需要把swipe初始化,在新线程中把要更新的数据传上去了好了


下拉加载,要理解下拉加载的原理


正常情况下,我们都是要加载一页,然后拉到最下面,最下面的item显示:正在刷新,然后在sleep几秒之后,再加载出下一页,一直到最后一页,判断了没有item可以再组成一页了,就显示加载完毕,理解了这一点,自定义下拉加载就简单了。


布局:swipe里镶套一个recycle

两个子布局,一个正常布局,一个脚布局


适配器

首先,两个状态,一个是正常状态VIEW_NORMAL,一个是滑倒最后一个item的状态VIEW_FOOT

然后我们要判断(boolean)是否要继续向下加载,加载到最后“正在加载”那个要消失

所以我们两个持有器(viewholder),各自的子布局在其中初始化

,adapter里有一个方法,叫viewtype,他通过判断当前item处于什么位置而返回一个参数,通过这个参数我们找到对应的持有器

值得注意的是,因为我们加了个脚item,所以此时的item比list中的要多一个,

通过持有期器在oncreateview找到自己相应的布局,

然后在onbindview进行数据操作

普通状态,正常操作

脚持有器,判断是否还能继续加载,如果能,就让foot item显示正在加载

如果不能,就显示加载到最后了

然后开个新线程,sleep几秒,把是否能继续加载重新设置为true,目的是下次进来又能继续上拉加载

public void onBindViewHolder(@NonNullRecyclerView.ViewHolder viewHolder, int i) {


if (viewHolderinstanceof ViewHolder){

        ((ViewHolder) viewHolder).

textView.setText(mlist.get(i));


}else

if (viewHolder instanceof FooterHolder){

        ((FooterHolder) viewHolder).

tips.setVisibility(View.VISIBLE);

        if

(loadmore==true){


fadetips=false;

            if

(mlist.size()>0){

                ((FooterHolder)viewHolder).

tips.setText("正在加载");


}

        }

else {


if (mlist.size()>0){

                ((FooterHolder)viewHolder).

tips.setText("没有更多数据了");


(new android.os.Handler()).postDelayed(new Runnable() {


@Override


public void run() {

                        ((FooterHolder)

viewHolder).tips.setVisibility(View.GONE);


loadmore=true;


fadetips=true;


}

                }

,3000);


}

        }

    }

}


最后我们在adapter中定义一个方法,你肯定会疑惑,怎么分页,这个方法的作用就是把list的几个item取出来,组成一个页


Adapter准备好了,接下来就是在activity中操作


初始化这些就不说了,最重要的是下拉刷新那段代码 initrecycle()


private void initrecycleview() {


adapter=new MyAdapter(getDatas(0,PAGE_COUNT),this,getDatas(0,PAGE_COUNT).size()>0 ?true :false);


//传三个参数 第一个getdatas里的划定的加载的item数,第二个context,第三个判断剩下的item数是否还能继续加载,是的话loadmore就是true

    LinearLayoutManager manager=new LinearLayoutManager(this);


recyclerView.setAdapter(adapter);


recyclerView.setLayoutManager(manager);


recyclerView.setItemAnimator(new DefaultItemAnimator());


recyclerView.addOnScrollListener(new RecyclerView.OnScrollListener() {


@Override


public void onScrollStateChanged(@NonNull RecyclerView recyclerView, int newState) {


super.onScrollStateChanged(recyclerView,newState);


//加载新的一页

            if (newState==recyclerView.SCROLL_STATE_IDLE){


if (adapter.isFadetips()==false&&LastVisibleItem+1==adapter.getItemCount()){

                    (

new Handler()).postDelayed(new Runnable() {


@Override


public void run() {

                            upDataRecycleView(

adapter.getRealLastPosition(),adapter.getRealLastPosition()+PAGE_COUNT);


}

                    }

,3000);


}


//tips被隐藏了,说明是最后一页了,该一直加载到底部

                if (adapter.isFadetips()==true&&LastVisibleItem+2==adapter.getItemCount()){

                    (

new Handler()).postDelayed(new Runnable() {


@Override


public void run() {

                            upDataRecycleView(

adapter.getRealLastPosition(),adapter.getRealLastPosition()+PAGE_COUNT);


}

                    }

,3000);


}

            }

        }


@Override


public void onScrolled(@NonNull RecyclerView recyclerView, int dx, int dy) {


super.onScrolled(recyclerView, dx, dy);


LastVisibleItem=manager.findLastVisibleItemPosition();


}

    })

;

}

//划定最开始呈现的item数public List<String> getDatas(final int firstIndex,final int lastIndex) {

    List reslist=

new ArrayList<>();

    for

(int i=firstIndex;i<lastIndex;i++){


if (i<mlist.size()){

            reslist.add(

mlist.get(i));


}

    }


return reslist;//把mlist的数据拷贝到第一页的list

}

public void upDataRecycleView(int fromIndex,int toIndex){

    List newsData=getDatas(fromIndex

, toIndex);

    if

(newsData.size()>0){


adapter.upDates(newsData,true);


}else {


adapter.upDates(null,false);


}

}

public void initswiperefresh() {


swipeRefreshLayout.setOnRefreshListener(this::initswiperefresh);

}

private void initlayout() {


recyclerView=(RecyclerView)findViewById(R.id.recycleview);


swipeRefreshLayout=(SwipeRefreshLayout) findViewById(R.id.swipe);

}

private void additem() {


for (int i=0;i<20;i++){


mlist.add("2333"+i);


}

}

@Override

public void onRefresh() {


swipeRefreshLayout.setRefreshing(true);


adapter.reseData();


upDataRecycleView(0,PAGE_COUNT);


(new Handler()).postDelayed(new Runnable() {


@Override


public void run() {



swipeRefreshLayout.setRefreshing(false);


}

    }

,3000);

}

adpter要传入三个重要参数,第一个,你要加载的第一页的item,第二个,context,第三个,是否能加载更多

public List<String> getDatas(final int firstIndex,final int lastIndex) {

    List reslist=

new ArrayList<>();

    for

(int i=firstIndex;i<lastIndex;i++){


if (i<mlist.size()){

            reslist.add(

mlist.get(i));


}

    }


return reslist;//把mlist的数据拷贝到第一页的list

}

这里这个getDatas()方法是将list前几个拷贝进一个新的集合


然后给recyclerview设置适配器,布局管理器等,接下来进行重要的

重写onScrollChanged()

在这个方法里,要判断继续加载这个foot item是否消失了,如果没消失,说明还能继续加载下一页,如果消失了,说明不能加载下一页,就是最后一页了


其他的方法都比较好理解了



这个图片供大家理解

最后呈上git地址      https://github.com/huxingxin123/Refresh_up

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 211,290评论 6 491
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,107评论 2 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 156,872评论 0 347
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,415评论 1 283
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,453评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,784评论 1 290
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,927评论 3 406
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,691评论 0 266
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,137评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,472评论 2 326
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,622评论 1 340
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,289评论 4 329
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,887评论 3 312
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,741评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,977评论 1 265
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,316评论 2 360
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,490评论 2 348