Android recyclerview上拉加载更多 您所在的位置:网站首页 recyclerview实现上拉加载 Android recyclerview上拉加载更多

Android recyclerview上拉加载更多

2023-11-05 15:40| 来源: 网络整理| 查看: 265

记录一下视频列表(recyclerview)上拉显示一个“加载更多”的item,然后加载数据。

效果图: 在这里插入图片描述

实现思路: 1.写两个item布局,一个用来展示数据,一个用来展示加载中也就是滑到最下方的时候显示的“加载更多”。 2.在adapter中写两个viewholder,对应两个xml文件。 3.adapter中重写getItemViewType用来鉴别当前item是不是最后一个,如果是最后一个则加载底部viewholder(代码有详细注释),并且写一个接受数据刷新的方法供外部调用。 4.写一个recyclerview的滑动监听,当滑动到最后一个并且停止滑动时,开始加载更多。 5.给recyclerview设置监听,实现加载更多数据的方法,获取到数据传给adapter

实现代码:

两个xml布局文件比较简单,我就不附代码了。 adpater代码

public class MyAdapter extends RecyclerView.Adapter { Context mContext; List mList; public MyAdapter(Context context, List list) { mContext = context; mList = list; } @NonNull @Override public RecyclerView.ViewHolder onCreateViewHolder(@NonNull ViewGroup viewGroup, int viewType) { if (viewType == 0) { //你的item View view = LayoutInflater.from(viewGroup.getContext()) .inflate(R.layout.rv_itme_daily, viewGroup, false); ViewHolder viewHolder = new ViewHolder(view); return viewHolder; } else { //底部“加载更多”item View view = LayoutInflater.from(viewGroup.getContext()) .inflate(R.layout.rv_item_footer, viewGroup, false); FooterHolder footerHolder = new FooterHolder(view); return footerHolder; } } @Override public void onBindViewHolder(@NonNull RecyclerView.ViewHolder viewHolder, int i) { if (viewHolder instanceof ViewHolder) { //你的item //展示数据 }else if(viewHolder instanceof FooterHolder){ //底部“加载更多”item (等待动画用一个gif去实现) Glide.with(mContext) .load(R.mipmap.img_load) .into(((FooterHolder) viewHolder).ivLoad); } } @Override public int getItemViewType(int position) { if (position == mList.size()) { //最后一个 是底部item return 1; } else { return 0; } } //提供给外部调用的方法 刷新数据 public void updateData(List list){ //再此处理获得的数据 list为传进来的数据 //... list传进来的数据 添加到mList中 //最后记得刷新item notifyDataSetChanged(); } @Override public int getItemCount() { return mList.size() + 1; } //展示数据的item的 viewholder public class ViewHolder extends RecyclerView.ViewHolder { @BindView(R.id.jz_player) JzvdStd jzPlayer; @BindView(R.id.tv_title) TextView tvTitle; public ViewHolder(@NonNull View itemView) { super(itemView); ButterKnife.bind(this, itemView); } } //底部"加载更多"item viewholder public class FooterHolder extends RecyclerView.ViewHolder { @BindView(R.id.iv_load) ImageView ivLoad; public FooterHolder(View itemView) { super(itemView); ButterKnife.bind(this, itemView); } } }

EndlessRecyclerOnScrollListener代码

public abstract class EndlessRecyclerOnScrollListener extends RecyclerView.OnScrollListener { //用来标记是否正在向上滑动 private boolean isSlidingUpward = false; @Override public void onScrollStateChanged(RecyclerView recyclerView, int newState) { super.onScrollStateChanged(recyclerView, newState); LinearLayoutManager manager = (LinearLayoutManager) recyclerView.getLayoutManager(); // 当不滑动时 if (newState == RecyclerView.SCROLL_STATE_IDLE) { //获取最后一个完全显示的itemPosition int lastItemPosition = manager.findLastCompletelyVisibleItemPosition(); int itemCount = manager.getItemCount(); // 判断是否滑动到了最后一个item,并且是向上滑动 if (lastItemPosition == (itemCount - 1) && isSlidingUpward) { //加载更多 onLoadMore(); } } } @Override public void onScrolled(RecyclerView recyclerView, int dx, int dy) { super.onScrolled(recyclerView, dx, dy); // 大于0表示正在向上滑动,小于等于0表示停止或向下滑动 isSlidingUpward = dy > 0; } /** * 加载更多回调 */ public abstract void onLoadMore(); }

activity/fragment中给recyclerview设置监听:

recyclerview.addOnScrollListener(new EndlessRecyclerOnScrollListener() { @Override public void onLoadMore() { //在这里写获取数据的逻辑 //... //获取数据后 传入adapter中上面写的更新数据的方法 adapter.updateData(list); } });


【本文地址】

公司简介

联系我们

今日新闻

    推荐新闻

    专题文章
      CopyRight 2018-2019 实验室设备网 版权所有