最近有个需求,当横向RecyclerView滑动到底部,不能滑动后,此时在拖动RecyclerView,需要显示底部一个动画效果,如图是做好的效果图:
然后很自然的去自定义RecyclerView。
最后发现在拖动RecyclerView时,需要拖动一段距离后才能显示我的自定义布局,感觉半天拖动不出来底部布局,很卡的样子。而这个起始的拖动距离差一直是25,随后我打印了系统最小滚动距离ViewConfiguration.get(context).scaledTouchSlop
是23,感觉冥冥之中有联系。
经过猜想发现,应该需要在onInterceptTouchEvent时,对ACTION_MOVE事件的滑动距离进行拦截,将这个距离设置很小就可以了,但是不能太小,否则会影响子View的点击事件。
override fun onInterceptTouchEvent(e: MotionEvent): Boolean {
when (e.action) {
MotionEvent.ACTION_DOWN -> {
mLastMotionPos = e.rawX
}
MotionEvent.ACTION_MOVE -> {
if (abs(e.rawX - mLastMotionPos) > MIN_TOUCH_SLOP) {
return true
}
}
}
return super.onInterceptTouchEvent(e)
}
然后就很丝滑了。
本来是还有个波纹弹弹弹的效果的,产品不需要就没做了,但是友商有这个效果。下面是我完成的效果图:
后期打算把这个波纹的效果加上。
=== 2020-03-23 发现有人需要,终于补上来了,欢迎Start ====
底部带波纹效果的RecyclerView:
https://github.com/victorfan336/RippleRecyclerView