RecyclerView拖动动画

最近有个需求,当横向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)
    }

然后就很丝滑了。

本来是还有个波纹弹弹弹的效果的,产品不需要就没做了,但是友商有这个效果。下面是我完成的效果图:

后期打算把这个波纹的效果加上。

你可能感兴趣的:(自定义View)