Android RecyclerView滚动到置顶的Item并置顶

方法一:不显示滚动过程动画

(mViewBinding.rcList.layoutManager as LinearLayoutManager).scrollToPositionWithOffset(pos,0)

方法二:有滚动过程的动画,并且可以控制滚动快慢

class LinearTopSmoothScroller(private val context: Context?, needFast: Boolean) :
    LinearSmoothScroller(
        context
    ) {
    /**
     * spead 值越大滚动越慢
     */
    private var spead = 0.03f

    /**
     * @param context  context
     * @param needFast 是否需要快速滑动
     */
    init {
        if (needFast) {
            setScrollFast()
        } else {
            setScrollSlowly()
        }
    }

    override fun getVerticalSnapPreference(): Int {
        return SNAP_TO_START
    }

    override fun calculateSpeedPerPixel(displayMetrics: DisplayMetrics): Float {
        return spead / displayMetrics.density
    }

    /**
     * 缓慢滚动
     */
    fun setScrollSlowly() {
        try {
            if (context == null) {
                return
            }
            // 建议不同分辨率设备上的滑动速度相同
            spead = context.resources.displayMetrics.density * 0.3f
        } catch (e: Exception) {
            // do nothing
        }
    }

    /**
     * 快速滚动
     */
    fun setScrollFast() {
        try {
            if (context == null) {
                return
            }
            spead = context.resources.displayMetrics.density * 0.03f
        } catch (e: Exception) {
            // do nothing
        }
    }
}

代码调用

 mViewBinding.rcList.layoutManager?.startSmoothScroll(LinearTopSmoothScroller(context, true).apply {
                targetPosition = pos
            })

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值