全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

Android RecyclerView实现下拉刷新和上拉加载更多

使用官方的刷新控件SwipeRefreshLayout来实现下拉刷新,当RecyclerView滑到底部实现下拉加载(进度条效果用RecyclerView加载一个布局实现)

需要完成控件的下拉监听和上拉监听,其中,下拉监听通过SwipRefreshLayout的setOnRefreshListener()方法监听,而上拉刷新,需要通过监听列表的滚动,当列表滚动到底部时触发事件,具体代码如下

主布局

<?xml version="1.0" encoding="utf-8"?>
<android.support.v4.widget.SwipeRefreshLayout
 android:id="@+id/refresh_layout"
 xmlns:android="http://schemas.android.com/apk/res/android"
 android:layout_width="match_parent"
 android:layout_height="match_parent">

 <android.support.v7.widget.RecyclerView
  android:id="@+id/recycler_list"
  android:layout_width="match_parent"
  android:layout_height="match_parent"/>

</android.support.v4.widget.SwipeRefreshLayout>

public class MainActivity extends AppCompatActivity implements SwipeRefreshLayout.OnRefreshListener {
 private SwipeRefreshLayout refreshLayout;
 private RecyclerView recyclerView;
 private LinearLayoutManager layoutManager;

 private RecyclerAdapter mAdapter;

 @Override
 protected void onCreate(Bundle savedInstanceState) {
  super.onCreate(savedInstanceState);
  setContentView(R.layout.activity_main);
  initViews();
 }

 private void initViews() {
  refreshLayout = (SwipeRefreshLayout) findViewById(R.id.refresh_layout);
  recyclerView = (RecyclerView) findViewById(R.id.recycler_list);
  layoutManager = new LinearLayoutManager(this);

  refreshLayout.setColorSchemeResources(R.color.colorAccent, R.color.colorPrimary);//设置刷新时进度条

颜色,最多四种
  refreshLayout.setOnRefreshListener(this);

  mAdapter = new RecyclerAdapter();//自定义的适配器
  recyclerView.setAdapter(mAdapter);
  recyclerView.setLayoutManager(layoutManager);
  recyclerView.addOnScrollListener(new OnRecyclerScrollListener());
 }

 /**
  * 用于下拉刷新
  */
 @Override
 public void onRefresh() {
 }

 /**
  * 用于上拉加载更多
  */
 public class OnRecyclerScrollListener extends RecyclerView.OnScrollListener {

  int lastVisibleItem = 0;

  @Override
  public void onScrollStateChanged(RecyclerView recyclerView, int newState) {
   super.onScrollStateChanged(recyclerView, newState);

   if (mAdapter != null && newState == RecyclerView.SCROLL_STATE_IDLE && lastVisibleItem + 1 == 

mAdapter.getItemCount()) {
    //滚动到底部了,可以进行数据加载等操作
   }
  }

  @Override
  public void onScrolled(RecyclerView recyclerView, int dx, int dy) {
   super.onScrolled(recyclerView, dx, dy);
   lastVisibleItem = layoutManager.findLastVisibleItemPosition();
  }
 }
}

下面是实现上拉时进度条转动的效果

item_list_footer.xml

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent">

 <TextView
  android:id="@+id/tv_item_footer_load_more"
  android:layout_width="match_parent"
  android:layout_height="wrap_content"
  android:layout_margin="16dp"
  android:gravity="center"
  android:text="上拉加载更多"
 />

 <ProgressBar
  android:id="@+id/pb_item_footer_loading"
  android:layout_width="match_parent"
  android:layout_height="wrap_content"
  android:layout_margin="16dp"
android:visibility="gone"/>
</RelativeLayout>

适配器

public class RecyclerAdapter extends RecyclerView.Adapter<ViewHolder> {

 private static final int TYPE_CONTENT = 0;
 private static final int TYPE_FOOTER = 1;

 private ArrayList<DataBean> dataList;

 private ProgressBar pbLoading;
 private TextView tvLoadMore;

 public RecyclerAdapter() {
  dataList = new ArrayList<>();
 }

 @Override
 public ViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {
  if (viewType == TYPE_CONTENT) {
   return new ContentViewHolder(LayoutInflater.from(parent.getContext()).inflate

(R.layout.item_list_content, parent, false));
  } else if (viewType == TYPE_FOOTER) {//加载进度条的布局
   return new FooterViewHolder(LayoutInflater.from(parent.getContext()).inflate

(R.layout.item_list_footer, parent, false));
  }
  return null;
 }

 @Override
 public void onBindViewHolder(ViewHolder holder, int position) {
  int type = getItemViewType(position);
  if (type == TYPE_CONTENT) {
   DataBean bean = dataList.get(position);
   ((ContentViewHolder) holder).tvId.setText("" + bean.getId());
   ((ContentViewHolder) holder).tvName.setText(bean.getName());
  } else if (type == TYPE_FOOTER) {
   pbLoading = ((FooterViewHolder) holder).pbLoading;
   tvLoadMore = ((FooterViewHolder) holder).tvLoadMore;
  }
 }

 /**
  * 获取数据集加上一个footer的数量
  */
 @Override
 public int getItemCount() {
  return dataList.size() + 1;
 }


 @Override
 public int getItemViewType(int position) {
  if (position + 1 == getItemCount()) {
   return TYPE_FOOTER;
  } else {
   return TYPE_CONTENT;
  }
 }

 /**
  * 获取数据集的大小
  */
 public int getListSize() {
  return dataList.size();
 }



 /**
  * 内容的ViewHolder
  */
 public static class ContentViewHolder extends ViewHolder {
  private TextView tvId, tvName;

  public ContentViewHolder(View itemView) {
   super(itemView);
   tvId = (TextView) itemView.findViewById(R.id.tv_item_id);
   tvName = (TextView) itemView.findViewById(R.id.tv_item_name);
  }
 }

 /**
  * footer的ViewHolder
  */
 public static class FooterViewHolder extends ViewHolder {
  private TextView tvLoadMore;
  private ProgressBar pbLoading;

  public FooterViewHolder(View itemView) {
   super(itemView);
   tvLoadMore = (TextView) itemView.findViewById(R.id.tv_item_footer_load_more);
   pbLoading = (ProgressBar) itemView.findViewById(R.id.pb_item_footer_loading);
  }
 }

 /**
  * 显示正在加载的进度条,滑动到底部时,调用该方法,上拉就显示进度条,隐藏"上拉加载更多"
  */
 public void showLoading() {
  if (pbLoading != null && tvLoadMore != null) {
   pbLoading.setVisibility(View.VISIBLE);
   tvLoadMore.setVisibility(View.GONE);
  }
 }

 /**
  * 显示上拉加载的文字,当数据加载完毕,调用该方法,隐藏进度条,显示“上拉加载更多”
  */
 public void showLoadMore() {
  if (pbLoading != null && tvLoadMore != null) {
   pbLoading.setVisibility(View.GONE);
   tvLoadMore.setVisibility(View.VISIBLE);
  }
 }
}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。


# RecyclerView  # 下拉刷新  # 上拉加载  # Android实现上拉加载更多以及下拉刷新功能(ListView)  # Android RecyclerView 上拉加载更多及下拉刷新功能的实现方法  # Android ListView实现上拉加载更多和下拉刷新功能  # Android下拉刷新上拉加载更多左滑动删除  # Android XListView下拉刷新和上拉加载更多  # Android RecyclerView下拉刷新和上拉加载更多  # Android 仿硅谷新闻下拉刷新/上拉加载更多  # Android中Listview下拉刷新和上拉加载更多的多种实现方案  # android使用PullToRefresh框架实现ListView下拉刷新上拉加载更多  # Android实践之带加载效果的下拉刷新上拉加载更多  # 加载  # 进度条  # 最多  # 自定义  # 四种  # 而上  # 来实现  # 正在加载  # 大家多多  # 滑到  # mAdapter  # layoutManager  # RecyclerAdapter  # Override  # onCreate  # void  # protected  # LinearLayoutManager  # AppCompatActivity  # implements 


相关文章: 如何用西部建站助手快速创建专业网站?  怎么用手机制作网站链接,dw怎么把手机适应页面变成网页?  如何选择高效稳定的ISP建站解决方案?  免费制作统计图的网站有哪些,如何看待现如今年轻人买房难的情况?  如何选择服务器才能高效搭建专属网站?  建站主机数据库如何配置才能提升网站性能?  c# await 一个已经完成的Task会发生什么  如何在服务器上配置二级域名建站?  微信h5制作网站有哪些,免费微信H5页面制作工具?  太原网站制作公司有哪些,网约车营运证查询官网?  建站之星备案流程有哪些注意事项?  车管所网站制作流程,交警当场开简易程序处罚决定书,在交警网站查询不到怎么办?  如何破解联通资金短缺导致的基站建设难题?  如何通过主机屋免费建站教程十分钟搭建网站?  如何快速搭建二级域名独立网站?  广德云建站网站建设方案与建站流程优化指南  建站主机功能解析:服务器选择与快速搭建指南  专业的网站制作设计是什么,如何制作一个企业网站,建设网站的基本步骤有哪些?  如何挑选最适合建站的高性能VPS主机?  建站主机选购指南:核心配置与性价比推荐解析  建站之星如何配置系统实现高效建站?  网站制作怎么样才能赚钱,用自己的电脑做服务器架设网站有什么利弊,能赚钱吗?  定制建站流程解析:需求评估与SEO优化功能开发指南  免费网站制作模板下载,除了易企秀之外还有什么H5平台可以制作H5长页面,最好是免费的?  新网站制作渠道有哪些,跪求一个无线渠道比较强的小说网站,我要发表小说?  微信小程序制作网站有哪些,微信小程序需要做网站吗?  招商网站制作流程,网站招商广告语?  营销式网站制作方案,销售哪个网站招聘效果最好?  企业网站制作公司网页,推荐几家专业的天津网站制作公司?  如何在阿里云部署织梦网站?  代刷网站制作软件,别人代刷火车票靠谱吗?  广州顶尖建站服务:企业官网建设与SEO优化一体化方案  公司网站的制作公司,企业网站制作基本流程有哪些?  建站与域名管理如何高效结合?  小程序网站制作需要准备什么资料,如何制作小程序?  如何获取开源自助建站系统免费下载链接?  如何在Golang中引入测试模块_Golang测试包导入与使用实践  网站建设设计制作营销公司南阳,如何策划设计和建设网站?  网站微信制作软件,如何制作微信链接?  建站VPS推荐:2025年高性能服务器配置指南  建站之星安装需要哪些步骤及注意事项?  宝塔新建站点为何无法访问?如何排查?  C++如何编写函数模板?(泛型编程入门)  详解jQuery停止动画——stop()方法的使用  北京网站制作公司哪家好一点,北京租房网站有哪些?  再谈Python中的字符串与字符编码(推荐)  济南网站建设制作公司,室内设计网站一般都有哪些功能?  建站之星安装路径如何正确选择及配置?  西安大型网站制作公司,西安招聘网站最好的是哪个?  香港服务器网站推广:SEO优化与外贸独立站搭建策略 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。