RecyclerView滑动到指定Position

在实现SideBar时遇到RecyclerView滚动问题,当调用smoothMoveToPosition时,可能无法达到预期效果。分析了三种情况:1.目标位置在首项前,能平滑滚动置顶;2.目标在首项后、末项前,无效果;3.目标在末项后,滑动至屏幕底部。为使指定item滑动到顶部,需针对三种情况处理,并在onScrollStateChanged中调整。目前方案存在滑动不连贯和定位偏差的问题,欢迎提供优化建议。
摘要由CSDN通过智能技术生成

Question

最近在写 SideBar 的时候遇到一个问题,当执行 Recyclerview 的 smoothScrollToPosition(position) 的时候,Recyclerview 看上去并没有滚动到指定位置。

Analysis

当然,这并不是方法的bug,而是 smoothScrollToPosition(position) 的执行效果有三种情况,需要区分。

  • 目标position在第一个可见项之前 。
    这种情况调用smoothScrollToPosition能够平滑的滚动到指定位置,并且置顶。

  • 目标position在第一个可见项之后,最后一个可见项之前。
    这种情况下,调用smoothScrollToPosition不会有任何效果···

  • 目标position在最后一个可见项之后。
    这种情况调用smoothScrollToPosition会把目标项滑动到屏幕最下方···

Solution

鉴于这三种情况,我想大多数情况下都无法满足我们的滑动要求。为了实现 Recyclerview 把指定 item 滑动到屏幕顶端的需求,我们需要对上面三种情况分别处理。


    /** 目标项是否在最后一个可见项之后*/
    private boolean 
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值