美文网首页
【推荐】recyclerview_helper多功能封装,让你应

【推荐】recyclerview_helper多功能封装,让你应

作者: passiontim | 来源:发表于2017-09-23 14:37 被阅读41次

一、简介

如上所示,recyclerview_helper针对不同应用场景封装了不同的功能。

具体功能如下:

1.封装了ViewHolder以及Adapter,避免每次都要重复写创建ViewHolder以及重写onCreateViewHolder,onBindViewHolder方法,支持单/多类型Item。

2.封装了OnItemClickListener以及OnItemLongClickListener,不必每次写接口,定义回调。仅支持对Item的点击事件。

3.具有各种炫酷的动画效果,功能装饰者模式封装Adapter添加初始化动画效果 ,以及自定义ItemAnimator实现各种炫酷的Item增删动画效果。

4.支持添加头尾布局,以及支持下拉刷新和上拉加载更多功能。同时支持自定义下拉刷新布局及动画,以及上拉加载更多的布局,可实现各种炫酷效果,跟随你的想象放飞。

二、使用

1.添加依赖

①.在项目的 build.gradle 文件中添加

②.在 module 的 build.gradle 文件中添加依赖

2.单/多类型Item使用

单类型

通过实现CommonAdapter,传入context,布局以及数据,然后实现convert方法,设置view的显示数据就完成了。很简洁方便。

多类型

和单类型的区别就是需要实现MultiItemTypeSupport,在MultiItemCommonAdapter对象中传入实现的该对象,该对象完成两个方法,功能是通过类型判别Item布局以及通过位置和数据判断返回类型。通过这个对象,避免我们在Adapter中进行类别判断的书写。

该部分实现参考了鸿洋大神对RecyclerView的封装。

3.事件监听使用

事件监听的使用就比较简单了,和正常使用一样。

4.动画使用

gif录制效果不太明显,实际手机上看着效果还是不错的。

动画效果分两种:

第一种:adapter初始化item的动画效果

第二种:ItemAnimator定义的动画效果

第一种动画效果使用了装饰者模式,需要再封装一层,然后通过setAdapter添加进去。

第二种直接和平时使用一样。

除此之外,ItemAnimator还有以下高级功能:

设置动画时长

插值器

也可以通过自定义AnimateViewHolder实现类,实现其他动画效果。

Adapter也有一些高级功能:

动画时长

插值器

是否仅显示一次动画效果

设置成true,则动画效果只在第一次创建Item使用,设置成false,则每次上下滑动都带动画效果。

复杂情况下,可以设置成true。

复合动画

recyclerview_helper中已经自定义了各种动画效果,如果有好的实现动画,可以通过自定义实现。

该部分实现参考了recyclerview-animators这个动画库。

5.添加头/尾布局

自定义头/尾布局,随意添加。

几行代码搞定。

6.下拉刷新/上拉加载

布局设置

其中头/尾布局需要自定义View实现。在例子中已经分别实现了一种

如果想实现不同的加载图片以及动画效果,可以对比实现。

首先设置监听

实现回调方法

开启刷新/关闭刷新

根据不同情况设置不同加载状态:

出现错误,还可以通过实现onRetry方法,实现再次加载。

以上两部分效果参考了IRecyclerView实现。

三、原理

上面介绍了使用,那么下面就介绍下实现原理,如果需要自定义实现,可以参考完成。

1.ViewHolder及Adapter封装

参考鸿洋大神的实现,针对ViewHolder的功能:实现View缓存,避免重复findViewById,进行封装。针对Adapter在实际项目中重复书写onCreateViewHolder,onBindViewHolder方法,进行封装处理。

ViewHolder

将View存放在集合类中,进行缓存,getView方法可以在Adapter中直接调用,避免每次创建不同类型的ViewHolder,一个BaseViewHolder搞定一切情况。

Adapter
基类CommonAdapter

封装实现onCreateViewHolder方法,并把convert方法抽象出去,实现数据绑定工作。使得结构简单。

针对多类型情况,需要判断类型,设置不同布局,所以需要个帮助类:

剩下来基础CommonAdapter实现MultiItemCommonAdapter来应对多类型Item。

整个实现很简单,但是效果不错。关于事件点击监听,很简单,就不介绍了。

2.动画效果实现

先介绍个简单的,Adapter的动画效果:

其实就是实现一个包装类AnimationAdapter,在其中onBindViewHolder方法中添加了动画效果。

下面继续介绍ItemAnimator的实现。关于这部分实现,实际代码比较长。就简要介绍下实现主要流程,具体实现可以看下这篇文章:recyclerview-animators,让你的RecyclerView与众不同。

其实RecyclerView中已经为我们默认提供了Item动画效果,就是通过这个类:DefaultItemAnimator,而这个类又从哪来?

搞清楚源头,那么我们也可以 比照着进行实现动画效果,所以通过继承SimpleItemAnimator实现自定义动画类。
主要针对对animateRemove, animateAdd, animateMove, animateChange 这4个方法的实现,增加数据增、删、动、改的动画效果。

3.头布局/尾布局实现

其实头布局,尾布局的添加和上面实现Adapter动画效果的方式一致,都是通过装饰者模式。

因为下面要实现上拉加载/下拉刷新,所以这两部分布局也像添加.头布局/尾布局一样实现。

先定义一个WrapperAdapter。

主要是针对上拉加载/下拉刷新,头布局/尾布局进行特殊处理。

其次,由于上面四部分都要独占一行,在LinearLayoutManager下没问题,但是在StaggeredGridLayoutManager以及GridLayoutManager要特殊处理。

GridLayoutManager

StaggeredGridLayoutManager

最后可以放心的添加了,通过自定义RecyclerView,重写setAdapter()方法

这样就加入了头/尾布局以及上拉加载/下拉刷新布局。

4.上拉加载/下拉刷新

首先是上拉加载,这个比较简单,通过监听OnScrollListener来实现

需要先判断是否触发加载条件,其中主要判断当前是否处于最后一条Item。满足触发条件,触发接口回调onLoadMore()方法。

然后是下拉刷新实现,这个比较复杂,但是说起来也比较简单,是通过onTouchEvent的监听来实现。

首先也是判断触发下拉条件

其中主要的是这个方法canTriggerRefresh

判断当前是否滑动到第一条Item。

满足触发条件,先是让下拉刷新的布局高度随下拉而改变:

同时在滑动过程中,需要根据高度判断刷新应该处于的状态:下拉刷新,释放刷新,以及动画的实现,在这个过程中需要回调RefreshHeaderView(就是你自定义的下拉刷新View,必须实现RefreshTrigger接口,面向接口编程)。

下面最重要的就是要监听抬起的一瞬间:ACTION_UP。

这个时候分两种情况:一种还处于下拉刷新的状态(下拉长度太短),返回默认状态。二是处于释放刷新状态,需要开启刷新。

然后就是开启动画,监听动画实现,更新状态,以及接口回调,虽然不难,但是逻辑还是比较复杂。

四、总结

目前由于多类型+头尾以及上拉刷新/下拉加载,判断类型过多,在头布局会出现卡顿,所以在使用多类型的情况下,不建议加入头尾布局,可以考虑重写setAdapter方法,去掉不需要的布局。

从效果,到使用,最后到原理,加深了对RecyclerView的理解,recyclerview_helper可以应对一般的使用场景,不过如有特殊应用场景,也可进行比对自定义实现。

Github地址:https://github.com/LRH1993/recyclerview_helper,给个star支持下。


相关文章

网友评论

      本文标题:【推荐】recyclerview_helper多功能封装,让你应

      本文链接:https://www.haomeiwen.com/subject/lfecextx.html