recyclerview底部加载方案

因为项目中多个列表都需要用到底部加载,所以我想了一个简单的底部加载方案。


先分析一下整个底部加载过程吧,首先为recyclerview设置滑动监听,recyclerview滑动时判断是否到达底部,到达就调用加载更多的方法。另外,还要控制加载过程的同步。

实现:

1.创建了一个类用来管理整个底部加载过程:

package sdu.edu.cn.utribe.bean;

import android.support.v7.widget.RecyclerView;

import sdu.edu.cn.utribe.util.Tool;

/**
 * Created by lenovo on 2017/8/26.
 */

public class BottomManager {
    private RecyclerView rv;
    private Task task;
    private boolean loading;
    private boolean end;

    public BottomManager(final RecyclerView rv, final Task task) {
        this.rv = rv;
        this.task = task;

        this.end=false;
        this.loading=false;

        rv.addOnScrollListener(new RecyclerView.OnScrollListener() {
            @Override
            public void onScrolled(RecyclerView recyclerView, int dx, int dy) {
                super.onScrolled(recyclerView, dx, dy);
                if (loading||end){
                    return;
                } else {
                    if (Tool.isSlideToBottom(rv))
                    {
                        loading=true;
                        new Thread(new Runnable() {
                            @Override
                            public void run() {
                                task.work();
                            }
                        }).start();
                    }
                }
            }
        });
    }

    public boolean isLoading() {
        return loading;
    }

    public void setLoading(boolean loading) {
        this.loading = loading;
    }

    public boolean isEnd() {
        return end;
    }

    public void setEnd(boolean end) {
        this.end = end;
    }


    public RecyclerView getRv() {
        return rv;
    }

    public void setRv(RecyclerView rv) {
        this.rv = rv;
    }

    public interface Task{
        void work();
    }
}


类中持有的几个变量:loading标志当前是否在加载,end标志是否到底(没有更多数据),rv就是目标recyclerview,task是判断到底时要调用的加载更多的方法,是一个接口。

Tool.isSlideToBottom是我写在工具类里的一个静态方法,根据recyclerview的滑动距离判断是否到底。

//判断列表是否滑到底部
    public static boolean isSlideToBottom(RecyclerView recyclerView) {
        if (recyclerView == null) return false;
        if (recyclerView.computeVerticalScrollExtent() + recyclerView.computeVerticalScrollOffset() >= recyclerView.computeVerticalScrollRange())
            return true;
        return false;
    }


2.activity中的使用:

创建一个BotomManager实例,传入目标列表和加载更多的方法

        manager=new BottomManager(rv, new BottomManager.Task() {
            @Override
            public void work() {
                getData();
            }
        });


在加载更多的方法中,加载完毕后设置manager的loading为false,如果获取到的是空数组设置end为true(这里用了retrofit和gson)

private void getData(int offsets) {
        appUrl.getMyTieziList(page,rows,offsets).subscribe(new Subscriber<ResponseBody>() {
            @Override
            public void onCompleted() {
                manager.setLoading(false);
                handler.post(new Runnable() {
                    @Override
                    public void run() {
                        adapter.notifyDataSetChanged();
                    }
                });
            }

            @Override
            public void onError(Throwable e) {
                Log.v("tag","我的帖子error:"+e.getMessage());
            }

            @Override
            public void onNext(ResponseBody responseBody) {
                try {
                    String s=responseBody.string();
                    JSONObject obj=new JSONObject(s);
                    switch (obj.getInt("status")){
                        case 200://请求成功
                            Type listType = new TypeToken<List<TieziItem>>(){}.getType();
                            List<TieziItem> list1= new Gson().fromJson(obj.getString("data"),listType);
                            Log.v("tag","我的帖子:"+obj.getString("data"));
                            if (list1.size()<=0){
                                manager.setEnd(true);
                            }
                            list.addAll(list1);
                            break;
                        case 300:
                            break;
                        case 400:
                            break;
                    }
                } catch (JSONException e) {
                    e.printStackTrace();
                } catch (IOException e) {
                    e.printStackTrace();
                }
            }
        });
    }


3.其他


这里判断recyclerview是否到底的方法(isSlideToBottom)不适用于嵌套在滚动条中的recyclerview,因为嵌套之后滚动行为完全是滚动条的滚动行为,而滚动条占得高度是自己的完全高度,recyclerview的isSlideToBottom永远会返回真。所以这种情况下要监听滚动条是否到底:
scroll.setOnScrollChangeListener(new NestedScrollView.OnScrollChangeListener() {
            @Override
            public void onScrollChange(NestedScrollView v, int i, int scrollY, int i2, int i3) {
                if (scrollY == (v.getChildAt(0).getMeasuredHeight() - v.getMeasuredHeight())) {
                    //底部加载
                    Log.v("tag","底部加载");
                    rvBottom();
                }
            }
        });

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
RecyclerView初次加载卡顿的原因可能有多种。其中一种可能是数据量过大导致的卡顿。当RecyclerView初次加载时,如果数据量过大,会导致UI线程阻塞,从而引发卡顿现象。此时可以考虑使用分页加载的方式,将数据分批加载,避免一次性加载大量数据。 另外一种可能是布局复杂度过高导致的卡顿。如果RecyclerView的item布局过于复杂,包含了大量嵌套的View或者复杂的绘制操作,都会增加UI线程的负担,导致卡顿。为了解决这个问题,可以尝试优化布局,减少不必要的嵌套和绘制操作,或者使用更高效的布局管理器。 此外,还有一种可能是加载图片或其他资源过程中引起的卡顿。如果RecyclerView的item包含了大量的图片或其他耗时的操作,比如网络请求,都会影响加载速度,导致卡顿。在这种情况下,可以考虑使用异步加载的方式,比如使用图片加载库来加载图片,或者使用多线程来处理耗时操作,避免阻塞UI线程。 综上所述,针对RecyclerView初次加载卡顿的问题,可以采取以下措施: 1. 分页加载数据,避免一次性加载大量数据。 2. 优化布局,减少不必要的嵌套和绘制操作。 3. 使用异步加载方式,比如图片加载库来加载图片,或者使用多线程处理耗时操作。 通过以上措施可以提升RecyclerView加载性能,减少初次加载的卡顿现象。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [RecyclerView各种加载效果](https://download.csdn.net/download/gaoqingliang521/9787141)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *2* *3* [基于Android官方AsyncListUtil优化改进RecyclerView分页加载机制(一)](https://blog.csdn.net/zhangphil/article/details/78603499)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值