Android RecyclerView 分页加载

 1.布局文件

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    android:orientation="vertical">
    <com.scwang.smartrefresh.layout.SmartRefreshLayout
        android:id="@+id/srl_id"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:elevation="10dp"
        app:srlAccentColor="#00000000"
        app:srlEnablePreviewInEditMode="true"
        app:srlPrimaryColor="#00000000"
        tools:ignore="MissingClass">

        <com.scwang.smartrefresh.layout.header.ClassicsHeader
            android:layout_width="match_parent"
            android:layout_height="wrap_content" />

        <androidx.recyclerview.widget.RecyclerView
            android:id="@+id/rv_id"
            android:layout_width="match_parent"
            android:layout_height="wrap_content" />

        <com.scwang.smartrefresh.layout.footer.ClassicsFooter
            android:layout_width="match_parent"
            android:layout_height="wrap_content" />

    </com.scwang.smartrefresh.layout.SmartRefreshLayout>

</RelativeLayout>

2.代码

public class TestFragment extends LazyLoadFragment {

    private ListAdapter listAdapter;
    private SmartRefreshLayout srl_id;
    private RecyclerView rv_id;
    private List<String> list;
    private int page = 1;
    private int count = 10;

   
    @Override
    protected int setContentView() {
        return R.layout.fragment_test;
    }


    @Override
    protected void lazyLoad() {

        srl_id = findViewById(R.id.srl_id);
        rv_id = findViewById(R.id.rv_id);
        rv_id.setLayoutManager(new LinearLayoutManager(getActivity()));

        list = new ArrayList<>();
        for (int i = 1; i <= count ; i++){
            list.add(i+1+"");
        }

        listAdapter = new ListAdapter(getActivity());
        rv_id.setAdapter(listAdapter);
        listAdapter.setList(list);

        //刷新
        srl_id.setOnRefreshListener(new OnRefreshListener() {
            @Override
            public void onRefresh(RefreshLayout refreshlayout) {
                refreshlayout.finishRefresh(2000);
                list.clear();
                for (int i = 1; i <= count ; i++){
                    list.add(i+1+"");
                }
            }
        });

        //加载
        srl_id.setOnLoadmoreListener(new OnLoadmoreListener() {
            @Override
            public void onLoadmore(RefreshLayout refreshlayout) {
                refreshlayout.finishLoadmore(1000);

                count =+ 10;
                page++;

                for (int i = 1; i <= count ; i++){
                    list.add(i+1+"");
                }

                listAdapter.notifyDataSetChanged();
            }
        });
    }
}

3.adapter

public class ListAdapter extends RecyclerView.Adapter<ListAdapter.Myvh> {

    Context context;
    List<String> list;

    public ListAdapter(Context context) {
        this.context = context;
        list = new ArrayList<>();
    }

    public void setList(List<String> list) {
        this.list = list;
        notifyDataSetChanged();
    }

    @NonNull
    @Override
    public Myvh onCreateViewHolder(@NonNull ViewGroup parent, int viewType) {
        View inflate = LayoutInflater.from(context).inflate(R.layout.item_list, null);
        return new Myvh(inflate);
    }

    @Override
    public void onBindViewHolder(@NonNull Myvh holder, int position) {
        holder.item_tv.setText(position+1+"");
    }

    @Override
    public int getItemCount() {
        return list.size();
    }

    public class Myvh extends RecyclerView.ViewHolder {

        private final TextView item_tv;

        public Myvh(@NonNull View itemView) {
            super(itemView);
            item_tv = itemView.findViewById(R.id.item_tv);
        }
    }
}

  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
可以使用 `Paging Library` 来实现 `RecyclerView` 的分页加载显示,以下是具体的步骤: 1. 添加依赖 在 `build.gradle` 文件中添加以下依赖: ```groovy implementation "androidx.paging:paging-runtime-ktx:3.0.0" ``` 2. 创建数据源 创建继承自 `PagingSource` 的数据源,实现 `load` 方法来加载数据。例如: ```kotlin class MyPagingSource(private val api: ApiService) : PagingSource<Int, MyData>() { override suspend fun load(params: LoadParams<Int>): LoadResult<Int, MyData> { try { // 加载数据 val page = params.key ?: 1 val response = api.getData(page) val data = response.body()?.data ?: emptyList() // 返回结果 return LoadResult.Page( data = data, prevKey = if (page == 1) null else page - 1, nextKey = if (data.isEmpty()) null else page + 1 ) } catch (e: Exception) { // 处理异常 return LoadResult.Error(e) } } } ``` 3. 创建 `PagingData` 对象 使用 `Pager` 类创建 `PagingData` 对象,指定数据源和配置参数。例如: ```kotlin val pager = Pager( config = PagingConfig( pageSize = 20, // 每页加载的数据量 enablePlaceholders = false // 是否显示占位符 ), pagingSourceFactory = { MyPagingSource(api) } ) val pagingData = pager.flow.cachedIn(viewModelScope) ``` 4. 绑定数据到 `RecyclerView` 使用 `PagingDataAdapter` 类来绑定数据到 `RecyclerView` 上。例如: ```kotlin class MyAdapter : PagingDataAdapter<MyData, MyViewHolder>(diffCallback) { override fun onCreateViewHolder(parent: ViewGroup, viewType: Int): MyViewHolder { val view = LayoutInflater.from(parent.context).inflate(R.layout.item_my_data, parent, false) return MyViewHolder(view) } override fun onBindViewHolder(holder: MyViewHolder, position: Int) { val data = getItem(position) data?.let { holder.bind(it) } } companion object { private val diffCallback = object : DiffUtil.ItemCallback<MyData>() { override fun areItemsTheSame(oldItem: MyData, newItem: MyData): Boolean { return oldItem.id == newItem.id } override fun areContentsTheSame(oldItem: MyData, newItem: MyData): Boolean { return oldItem == newItem } } } } ``` 然后在 `Activity` 或 `Fragment` 中创建 `RecyclerView` 对象并绑定 `PagingData` 对象即可。例如: ```kotlin val adapter = MyAdapter() recyclerView.adapter = adapter lifecycleScope.launch { adapter.submitData(pagingData) } ``` 这样就可以实现 `RecyclerView` 的分页加载显示了。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值