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)
    }

然后就很丝滑了。

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

需求效果

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

=== 2020-03-23 发现有人需要,终于补上来了,欢迎Start ====

底部带波纹效果的RecyclerView:

https://github.com/victorfan336/RippleRecyclerView

 

  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值