Android RecyclerView上拉加载和下拉刷新

之前写过一篇刷新加载《RecyclerView上拉加载和下拉刷新(基础版)》 ,这次是进行改装完善。

代码中注释的很详细,所以就直接上代码了。

核心实现

package com.example.fly.recyclerviewrefresh.base;

import android.os.Bundle;
import android.support.annotation.Nullable;
import android.support.v4.widget.SwipeRefreshLayout;
import android.support.v7.widget.LinearLayoutManager;
import android.support.v7.widget.RecyclerView;
import com.example.fly.recyclerviewrefresh.R;
import java.util.ArrayList;
import java.util.List;

/**
 * 类名:
 * 类描述:下拉刷新和上拉加载
 * 创建人:fly
 * 创建日期: 2017/2/2.
 * 版本:V1.0
 */
public abstract class RefreshActivity<T extends Object,A extends RecyclerView.Adapter> extends BaseActivity implements SwipeRefreshLayout.OnRefreshListener {
 protected SwipeRefreshLayout swipeRefreshLayout;
 protected RecyclerView recyclerView;
 protected LinearLayoutManager linearLayoutManager;
 protected A adapter;
 protected List<T> lists = new ArrayList<>();
 protected T dataBeanLoadMore = createBean();
 protected boolean isLoadDataIng; // 默认为false 是否正在加载数据, false 不在加载, true 正在加载
 protected boolean isScrollY; // 是否在Y轴(垂直方向)上滑动, false 没滑动, true 滑动

 @Override
 protected void onCreate(@Nullable Bundle savedInstanceState) {
 super.onCreate(savedInstanceState);
 setContentView(setLayout());
 swipeRefreshLayout = (SwipeRefreshLayout) findViewById(R.id.swipeRefreshLayout);
 swipeRefreshLayout.setOnRefreshListener(this);
 swipeRefreshLayout.setColorSchemeResources(Refresh.colors); // 设置变化的颜色
 recyclerView = (RecyclerView) findViewById(R.id.recyclerView);
 linearLayoutManager = new LinearLayoutManager(this);
 recyclerView.setLayoutManager(linearLayoutManager);
 loadMore();
 }

 /**作用就是能在父类中初始化公共的控件如上面的onCreate(@Nullable Bundle savedInstanceState)初始化的控件*/
 protected abstract int setLayout();

 public abstract T createBean();

// public abstract A createAdapter();

 /**上拉加载*/
 protected void loadMore() {
 recyclerView.addOnScrollListener(new RecyclerView.OnScrollListener() {

 /**
 *
 * @param recyclerView 当前在滚动的RecyclerView
 * @param newState 当前滚动状态
 *  newState有三种值:
 //静止,没有滚动
 public static final int SCROLL_STATE_IDLE = 0;

 //正在被外部拖拽,一般为用户正在用手指滚动
 public static final int SCROLL_STATE_DRAGGING = 1;

 //自动滚动开始
 public static final int SCROLL_STATE_SETTLING = 2;
 */
 @Override
 public void onScrollStateChanged(RecyclerView recyclerView, int newState) {
 super.onScrollStateChanged(recyclerView, newState);
 if (newState == RecyclerView.SCROLL_STATE_IDLE && isLoadDataIng == false ) {
  int lastVisibleItem = linearLayoutManager.findLastCompletelyVisibleItemPosition(); // 获取最后一个item的角标
  int totalItemCount = linearLayoutManager.getItemCount(); // 获取item的总数
  if (lastVisibleItem == (totalItemCount - 1)) { // 判断滑到最后一个item
  if (!swipeRefreshLayout.isRefreshing()) { //不再下拉刷新状态
  if (isScrollY) { // 在Y轴(垂直方向)上有滑动
  // TODO 执行上拉加载
  onShowRefresh();
  loadMoreData();
  }
  }
  }
 }
 }

 /**
 *
 * @param recyclerView 当前滚动的view
 * @param dx 水平滚动距离
 * @param dy 垂直滚动距离
 */
 @Override
 public void onScrolled(RecyclerView recyclerView, int dx, int dy) {
 super.onScrolled(recyclerView, dx, dy);
 if (dy > 0) {
  isScrollY = true;
 }else{
  isScrollY = false;
 }
 }
 });
 }

 /**加载数据*/
 public abstract void loadMoreData();

 /**显示加在更多的View*/
 protected void onShowRefresh() {
 isLoadDataIng = true; // 正在加载数据
 lists.add(dataBeanLoadMore);
 adapter.notifyDataSetChanged();
 }

 /**隐藏加在更多的View*/
 protected void onHintLoadMore() {
 lists.remove(dataBeanLoadMore);
 isLoadDataIng = false; // 不在加载数据
 adapter.notifyDataSetChanged();
 }
}
package com.example.fly.recyclerviewrefresh;

import android.os.Handler;
import android.os.Bundle;
import com.example.fly.recyclerviewrefresh.adapter.RecyclerAdapter;
import com.example.fly.recyclerviewrefresh.base.Refresh;
import com.example.fly.recyclerviewrefresh.base.RefreshActivity;
import com.example.fly.recyclerviewrefresh.bean.DataBean;

/**
 * 类名:
 * 类描述:RecyclerView刷新 方法二
 * 创建人:fly
 * 创建日期: 2017/2/2.
 * 版本:V1.0
 */
public class MainActivity extends RefreshActivity<DataBean,RecyclerAdapter>{

 @Override
 protected void onCreate(Bundle savedInstanceState) {
 super.onCreate(savedInstanceState);
 for (int i = 0; i < 20; i++) {
 DataBean dataBean = new DataBean(Refresh.COMMON);
 dataBean.number = String.valueOf(i);
 lists.add(dataBean);
 }
 adapter = new RecyclerAdapter(lists,this);
 recyclerView.setAdapter(adapter);
 }

 @Override
 public void onRefresh() {
 new Handler().postDelayed(new Runnable() {
 @Override
 public void run() {
 lists.clear();
 adapter.notifyDataSetChanged();
 swipeRefreshLayout.setRefreshing(false);
 }
 },1000);
 }

 @Override
 protected int setLayout() {return R.layout.activity_main;}

 @Override
 public DataBean createBean() {return new DataBean(Refresh.LOAD_MORE);}

 @Override
 public void loadMoreData() {
 for (int i = 0; i < 5; i++) {
 DataBean dataBean = new DataBean(Refresh.COMMON);
 dataBean.number = String.valueOf(i) + "fly";
 lists.add(dataBean);
 }
 adapter.notifyDataSetChanged();
 onHintLoadMore();
 }
}

源码下载:RecyclerViewRefresh刷新加载

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

(0)

相关推荐

  • android RecyclerView侧滑菜单,滑动删除,长按拖拽,下拉刷新上拉加载

    本文介绍的库中的侧滑效果借鉴自SwipeMenu,并对SipwMenu的源码做了修改与Bug修复,然后才开发出的SwipeRecyclerView. 需要说明的是,本库没有对RecyclerView做大的修改,只是ItemView的封装.看起来是对RecyclerView的修改,其实仅仅是为RecyclerView添加了使用的方法API而已. 本库已经更新了三个版本了,会一直维护下去,根据小伙伴的要求,以后也会添加一些其它功能. SwipeRecyclerView将完美解决这些问题: 以下功能全

  • XRecyclerView实现下拉刷新、滚动到底部加载更多等功能

    介绍: 一个实现了下拉刷新,滚动到底部加载更多以及添加header功能的的RecyclerView.使用方式和RecyclerView完全一致,不需要额外的layout,不需要写特殊的adater. 加载效果内置了AVLoadingIndicatorView上的所有效果,可以根据需要指定. 项目地址:https://github.com/jianghejie/XRecyclerView 效果: 使用: xml <RelativeLayout xmlns:android="http://sc

  • Android之RecyclerView轻松实现下拉刷新和加载更多示例

    今天研究了下RecyclerView的滑动事件,特别是下拉刷新和加载更多事件,在现在几乎所有的APP显示数据列表时都用到了.自定义RecyclerView下拉刷新和加载更多听上去很复杂,实际上并不难,只要是对滑动事件的监听和处理. 一.自定义RecyclerView实现下拉刷新和加载更多 1.如何判断RecyclerView是在上滑还是下滑 在RecyclerView的OnScrollListener滑动事件监听中有个好用的方法,就是onScrolled(RecyclerView recycle

  • Android RecyclerView 上拉加载更多及下拉刷新功能的实现方法

    RecyclerView 已经出来很久了,但是在项目中之前都使用的是ListView,最近新的项目上了都大量的使用了RecycleView.尤其是瀑布流的下拉刷新,网上吧啦吧啦没有合适的自己总结了一哈. 先贴图上来看看: 使用RecyclerView实现上拉加载更多和下拉刷新的功能我自己有两种方式: 1.使用系统自带的Android.support.v4.widget.SwipeRefreshLayout这个控价来实现. 2.自定义的里面带有RecyleView的控件. 使用RecycleVie

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

    使用官方的刷新控件SwipeRefreshLayout来实现下拉刷新,当RecyclerView滑到底部实现下拉加载(进度条效果用RecyclerView加载一个布局实现) 需要完成控件的下拉监听和上拉监听,其中,下拉监听通过SwipRefreshLayout的setOnRefreshListener()方法监听,而上拉刷新,需要通过监听列表的滚动,当列表滚动到底部时触发事件,具体代码如下 主布局 <?xml version="1.0" encoding="utf-8&

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

    RecyclerView已经出来很久了,许许多多的项目都开始从ListView转战RecyclerView,那么,上拉加载和下拉刷新是一件很有必要的事情. 在ListView上,我们可以通过自己添加addHeadView和addFootView去添加头布局和底部局实现自定义的上拉和下拉,或者使用一些第三方库来简单的集成,例如Android-pulltorefresh或者android-Ultra-Pull-to-Refresh,后者的自定义更强,但需要自己实现上拉加载. 而在下面我们将用两种方式

  • RecyclerView下拉刷新上拉加载

    一 .前言 最近实在太忙,一个多礼拜没有更新文章了,于是今晚加班加点把demo写出来,现在都12点了才开始写文章. 1.我们的目标 把RecyclerView下拉刷新上拉加载更多加入到我们的开发者头条APP中. 2.效果图 3.实现步骤 找一个带上拉刷新下载加载更多的RecyclerView开源库,我们要站在巨人的肩膀上 下载下来自己先运行下demo,然后看看是不是我们需要的功能,觉得不错就把module依赖进来,整合主项目. 整合进来了之后,我们肯定需要进行修改,例如我这边就有滑动冲突,有多个

  • Android使用recyclerview打造真正的下拉刷新上拉加载效果

    前言 前段时间需要用到recyclerview,就想找个封装好的下拉刷新,上拉加载的库,结果愣是没找到,便自己写了一个. 注意:我说的是"上拉加载",不是滑到底部自动加载. 虽然现在自动加载是主流和趋势,但也不排除有时候就需要用到上拉加载啊,毕竟林子大了,什么样的产品经理都有对吧. 代码写好后,准备发布到bintray的时候,向同事征求这个项目的名字,同事说:"就叫DZTRecyclerview!" 不解,同事解释:"叼炸天Recyclerview!&qu

  • Android RecyclerView上拉加载和下拉刷新(基础版)

    这里讲述的是用谷歌原生的SwipeRefreshLayout,进行刷新,以及利用RecycleView的滚动事件,判断是否到最后一个item,进行加载更多,这里加载更多是在RecycleView的适配器中使用不同item进行完成的. 这是activity的xml布局: <?xml version="1.0" encoding="utf-8"?> <RelativeLayout xmlns:android="http://schemas.a

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

    今天终于有点时间,来写了一下: 为RecyclerView实现下拉刷新和上拉加载更多.今天会在前面的两篇文章的基础上: RecyclerView系列之(1):为RecyclerView添加Header和Footer RecyclerView系列之(2):为RecyclerView添加分隔线 继续讲述RecyclerView中一些常用组件的实现下拉刷新和上拉加载更多的功能. 在现在的Android手机应用中,几乎每一个APP都有下拉刷新和上拉加载更多的功能,它们的重要性不言而喻. 先不多说,先看效

随机推荐