RecyclerView学习(三)

  • 时间:
  • 浏览:1
  • 来源:彩神快乐8_神彩快乐8官方

举个例子:

scrollTo(200,200)会将View位置移动到指定位置,多次调用无效

scrollBy(200,200)会将View位置移动到指定位置,每调用一次会在现有位置基础上进行移动

结合这人 例子分析一下,手指滑动的距离而是 整体View移动的距离,另另另兩个们都还后能 直接使用scrollBy(x,y)措施来进行处置,将手指滑动的距离作为第另另兩个参数传递进去,而不让考虑当前View滑动的位置。

https://github.com/18722527635/MyRecyclerView

评论里有小伙伴说换成点击事件后必须 效果,会产生事件冲突。谢谢这位小伙伴的提醒,完后 必须 考虑这方面的问题报告 。或者周末在家完善了一下,看看缘何处置的吧。

源码地址:

RecyclerView的点击事件无非而是 接口回调获取position的过程,其他人 在MotionEvent.ACTION_DOWN的完后 肯能拿到了position。必须 只要在点击的完后 将这人 position传递给Activity呢。现在只要判断哪些地方动作是点击就都还后能 了!!!随便说说只要对比一下MotionEvent.ACTION_DOWN与MotionEvent.ACTION_UP的X,Y坐标差,小于默认的滑动最小距离的完后 ,就认为是点击动作,将得到的position传递即可。最后让Activity实现这人 接口,获取参数,进行事件的处置就欧了~

这里有其他一阵一阵需要注意的是:这里遍历的是当前可见范围内的子项。使用getChildCount()与getChildAt()进行取值,必须是当前可见区域的子项!取值范围在0到getLastVisiblePosition()减去getFirstVisiblePosition()之间(可取等于)。

当滑动的距离大于一半的完后 ,执行删除操作。 将删除措施写在RecyclerAdapter中:

viewHolder是存放视图与数据的地方,只要拿到当前item的viewHolder,就都还后能 获取到其他人 的itemLayout,也而是 需要滑动的LinearLayout。RecyclerView提供了另另兩个getChildViewHolder()的措施来获取当前item的viewHolder,传进去的参数而是 通过getChildAt(index)获取到的view。

其他人 在上一步肯能拿到了item的position与itemLayout,在MotionEvent.ACTION_MOVE的完后 使用itemLayout就都还后能 进行滑动,在MotionEvent.ACTION_UP的完后 使用position就都还后能 进行删除。

初始化Scroller:

首先向Scroller获取当前的滑动起点,通过scrollTo措施实现滑动,或者再调用invalidate()来进行重绘,又会调用computeScroll()措施,或者再获取当前的起点,使用scrollTo措施滑动到新的位置。必须 往复,直到整个滑动现在刚开始。随便说说Scroller的设计思你而是 小幅度滑动组成整个的弹性滑动。

补充:

(2)滑动方向

在Android屏幕直角坐标系中,原点在屏幕左上角,向右X为正,向下Y为正。

scrollBy()的参数的正负影响滑动的方向,这里其他人 只考虑水平方向上的滑动,而是将第六个参数设置为0。

按其他人 正常的理解,应该是参数为负的完后 ,向坐标轴负方向滑动;当参数为正的完后 ,向坐标轴正方向滑动。

scrollBy()在参数为负的完后 ,向坐标轴正方向滑动;当参数为正的完后 ,向坐标轴负方向滑动。

这是肯能在scrollBy()源码执行过程的最后,会调用这人 措施 :

invalidateInternal(l - scrollX, t - scrollY, r - scrollX, b - scrollY, true, false);

其中l,t,r,b为另另另兩个坐标点,scrollX,scrollY为目标坐标点,必须当目标坐标点值是负数时,负负得正,移动到的位置才为正数,另另另兩个才会重新绘制,整体的View就会向坐标轴正方向滑动。

综上,其他人 想让子Item从右往左沿X轴的负方向滑动,scrollBy(X,0)中的X一定是大于0的

startScroll()六个参数依次为:现在刚开始移动时的X坐标;现在刚开始移动时的Y坐标;沿X轴移动距离,为负时,子控件向右移动;沿Y轴移动距离。肯能后面 必须 duration这人 参数,系统会使用默认的时长:2200毫秒

或者调用invalidate()是使view进行重绘,在view的onDraw()措施中又会去调用computeScroll()措施,view才能实现弹性滑动

1.准备工作:

(1)数据准备:另另兩个存放数字的List数组来模拟RecyclerView的数据

(2)子Item的布局:整体线性布局水平排列,左侧是显示的每项,右侧是不显示的每项,也而是 删除的每项。删除的每项是另另兩个相对布局,或者通过滑动的距离来控制字体与图片的显示与隐藏。

(3)RecyclerView三每项:RecyclerAdapter,RecyclerViewHolder,LayoutManager依次设置即可。

5.RecyclerView的滑动优化

完后 说到当滑动的距离小于红块的一半,松开手指完后 ,会自动收缩当前item,或者这人 滑动比较生硬,用户体验很差。其他人 需要实现渐进式滑动,也而是 View的弹性滑动。这里其他人 使用的是Scroller。

在Listview当中,有另另兩个pointToPosition(x, y)措施都还后能 根据坐标获取到当前的position,在RecyclerView中必须 这人 措施,需要其他人 买车人动手写另另兩个。

(3)滑动实现

现在滑动的措施与方向都肯能选用了,接下来的重点而是 计算滑动的距离,也而是 scrollBy(X,0)中的X的大小了。

当滑动的距离小于红块的一半,松开手指完后 ,会自动收缩当前item;当滑动的距离超过一半,松开手指完后 ,会自动将当前item删除。一并看看缘何实现的吧:

4.RecyclerView的删除实现

Scroller的使用措施:

移动计算值 = 最现在刚开始点坐标 - 最后移动到的坐标

欢迎Star,fork,提issues,一并进步!

第六个参数是另另兩个匀速插值器

(2)通过position得到item的viewHolder

偶尔就看知乎首页的侧滑删除,感觉还不错。完后 用RecyclerView的ItemTouchHelper类来实现了Item的拖动和删除功能,今天带来的则是纯手工打造的另另兩个侧滑删除。老规矩,先看看效果图:

本文已授权微信公众号:鸿洋(hongyangAndroid)在微信公众号平台原创首发。

其中itemLayout为另另兩个水平的LinearLayout,textView为LinearLayout中的”删除”,imageView为LinearLayout中的眼睛图片。

(1)通过触碰的坐标计算当前的position

这里其他人 肯定要自定义另另兩个MyRecyclerView继承自RecyclerView,或者重写onTouchEvent()措施,在MotionEvent.ACTION_DOWN的完后 就要拿到你触碰的item的position。

前面肯能实现了将另另兩个LinearLayout左右进行滑动,现在关键而是 将这人 LinearLayout的滑动与其他人 RecyclerView的滑动相结合。

处置措施而是 将这人 水平排列的LinearLayout作为子item布局的一每项,或者再获取每另另兩个item的LinearLayout就都还后能 进行滑动了。这里肯定需要另另兩个参数position,必须获取到item的position才能得到item的LinearLayout,才能进行删除操作。

2.View的滑动实现:

(1)滑动措施:

这里我是使用View这人 提供的scrollTo/scrollBy措施来实现滑动,scrollBy实际上也是调用了scrollTo措施,scrollTo实现的是基于所传递参数的绝对滑动,而scrollBy实现的是基于当前位置的相对滑动。

3.RecyclerView的滑动实现

至此,另另兩个漂亮的侧滑删除就肯能实现了,零碎的东西不少,记录下来一并学习~~