首页
学习
活动
专区
圈层
工具
发布

恢复 RecyclerView 的滚动位置

您可能在开发过程中遇到过这种情况,在 Activity/Fragment 被重新创建后,RecyclerView 丢失了它之前保有的滚动位置信息。...通常这种情况发生的原因是由于异步加载 Adapter 数据,且数据在 RecyclerView 需要进行布局的时候尚未加载完成,导致 RecyclerView 无法恢复到之前的滚动位置。...从  1.2.0-alpha02 版本开始,Jetpack RecyclerView 提供了一个新的 API,可以让 Adapter  在数据加载完成之前阻塞布局行为 ,从而避免丢失滚动位置信息。...接下来我们会介绍如何使用这个新的 API,以及它的工作原理。 恢复至原有滚动位置 有好几种方法可以用来恢复 RecyclerView 至正确的滚动位置,您可能已经在实际项目中用到了这些方法。...它有三个选项: ALLOW — 默认状态,会在下一次布局完成时立即恢复 RecyclerView 状态; PREVENT_WHEN_EMPTY — 仅当 adapter 不为空 (即 adapter.getItemCount

2.1K10
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    vue返回上一页面时回到原先滚动的位置

    项目结束,测试时发现在首页商品列表中,向上滑动几页后点击进入详情,从详情页面返回商品列表时,页面回到了最顶部,测试不通过说是用户体验不好,要求从哪里点击进去返回该页面时回到原先的滚动页面。...component: index, meta: { keepAlive: true } }, 这样在index.vue中,mounted方发只走一次,在浏览器上实现了返回原来滚动位置的目的...但是在手机上测试,发现没用, 解决手机上实现目的的方法: //在页面离开时记录滚动位置 beforeRouteLeave (to, from, next) { this.scrollTop =...document.documentElement.scrollTop || document.body.scrollTop next() }, //进入该页面时,用之前保存的滚动位置赋值 beforeRouteEnter

    3.6K20

    RecyclerView预加载!

    监听列表滚动状态 第一个想到的方案是监听列表滚动状态,当列表快滚动到底部时执行预加载,RecyclerView.OnScrollListener提供了两个回调: public class RecyclerView...dx, int dy){} } } 在onScrolled()可以拿到LayoutManager,它提供了很多和表项位置有关的方法: // 为 RecyclerView 新增扩展方法,用于监听预加载事件...就测出 bug:当快速滚动列表时onPreload()没有执行,当慢慢滚动列表时onPrelaod()会执行多次。...列表在被显示之前必然经历了onBindViewHolder(holder: ViewHolder, position: Int),该方法中就能轻松的获取表项索引,可以把刚才的判断逻辑移到RecyclerView.Adapter...// 更新滚动状态 scrollState = newState super.onScrollStateChanged(recyclerView

    3.2K00

    Android:让你明明白白的使用RecyclerView——SnapHelper详解

    简介 RecyclerView在24.2.0版本中新增了SnapHelper这个辅助类,用于辅助RecyclerView在滚动结束时将Item对齐到某个位置。...SnapHelper是一个抽象类,官方提供了一个LinearSnapHelper的子类,可以让RecyclerView滚动停止时相应的Item停留中间位置。...在snapFromFling()方法中会创建一个SmoothScroller,并且根据速率计算出滚动停止时的位置,将该位置设置给SmoothScroller并启动滚动。...),得到对应的snapPosition,然后通过estimateNextPositionDiffForFling()方法估算位置偏移量,snapPosition加上位置偏移量就得到最终滚动结束时的位置,...希望读到这的您能转发分享和关注一下我,以后还会更新技术干货,谢谢您的支持! 转发+点赞+关注,第一时间获取最新知识点 Android架构师之路很漫长,一起共勉吧!

    7K40

    Android必知必会 - RecyclerView 恢复上次滚动位置

    记录 RecyclerView 滚动位置并恢复是一个很常见的需求,通常需要精准恢复到上次的位置。...预计会用到 RecyclerView 相关的三个知识点: 监听 RecyclerView 滚动状态 监听 RecyclerView 完成绘制 滚动 RecyclerView 到指定的位置 思路: 在「RecyclerView...完成绘制」时,记录首个元素的偏移量作为基础偏移量;此步非必须流程,根据自己实际情况看是否需要,有些情况此基础偏移量为0,即不存在基础偏移量的问题; 在「监听 RecyclerView 滚动状态」里,滚动结束时...,记录最左侧的元素坐标和偏移量; 再次打开当前页面时,检查是否存在偏移量信息的记录,有则进行位置恢复,即「滚动 RecyclerView 到指定的位置」。...== null) { return; } rvOffset = leftView.getLeft(); //获取该view的左边的偏移量,垂直布局时获取

    2.6K20

    写给初学者的Jetpack Compose教程,Lazy Layout

    本文同步发表于我的微信公众号,扫一扫文章底部的二维码或在微信搜索 郭霖 即可关注,每个工作日都有文章更新。 大家好,写给初学者的Jetpack Compose教程又来了。...因此最好的设计方案就是,当用户向下滚动列表时,我们就认为用户不再需要和Fab按钮交互,此时将按钮进行隐藏。 下面具体看一下如何在Compose中实现这种效果。...每当你认为自己需要用到嵌套滚动时,我觉得都应该先暂停一下,想想是不是有其他的替代方案,如ConcatAdapter等。...其中,VerticalScrollable()函数是垂直方向的滚动列表,它在第一行的位置又嵌套了HorizontalScrollable()函数。...相比于RecyclerView,基于Compose的Lazy Layout在这一点上确实非常劣势,因为RecyclerView就完全不会有重组的困扰,只需要offset一下子项的位置就可以了。

    1.5K10

    项目需求讨论- 自定义滚轮(第二波新实现)

    而且如果你手指快速的滑动,不停的滚动,你就会滑到顶部的位置。因为我们的是ScrollView 最后选中哪一项,才让它滚动到中间相应的那一项。 那有些人可能会说,那我就不只弄这几组。...然后就只能通过其他方式来获取滚动的距离。...---- 滚动后调整距离让RecyclerView 滚到特定的position位置: 我简单介绍,就只分二种情况来谈下(正好滑到一个标准的距离,让Item正好完全显示这种情况我就去除了): 顶部的Item...这时候大家也知道,应该是让当前的屏幕内获取到的first Item 滚动出界面,所以大家一想就说获取第一个Item的Position值,然后调用RecyclerView.smoothScrollToPosition...但是结果是不会滚动,原来这个方法当我们的Position + 1已经出现在屏幕上了。不管是不是第一个,不管处于屏幕的哪个位置,这个RecyclerView就不会滚动。我忍不住又一句 WHF!!。

    1.4K20

    recycleview的优化_recyclerview原理

    都有一个唯一的id来标识,通过getItemId()来获取这个唯一标识id,当然我们不能用position来标识,因为itemView会复用,位置会乱序。...这个机制会导致一个问题,启动应用之后,在屏幕可见范围内,如果只有一张卡片可见,当滚动的时 候,RecyclerView找不到可以重用的view了,它将创建一个新的,因此在滑动到第二个feed的时候就会有一定的延时...具体实现方式是:在 RecyclerView 开始一个滚动时new Runnable对象,根据 layout manager 和滚动的方向预取即将进入视野的条目,可以同时取出一个或多个条目,例如在使用...我们在给RecyclerView的ArrayList data添加一个Data数据时,一般需要自己通知RecyclerView更新,尤其是遇到去重操作,还需要遍历一次data,定位后再决定是插入还是更新现有数据...如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

    5.5K21

    5个Android 手势和动画方面深度面试题

    当用户在屏幕上进行触摸操作时,系统会生成一系列的 MotionEvent,并将其传递给当前处于焦点的视图(View)。...通过分析MotionEvent中的数据(如位置、时间、动作等)来实现更复杂的手势识别。 面试题目2:描述如何在Android中实现一个自定义手势识别器。...解答: 实现流畅的滚动列表需要考虑以下几个方面: 1、 使用ViewHolder模式: 在RecyclerView的适配器中使用ViewHolder模式来缓存视图,减少findViewById的调用。...5、 减少视图层级: 减少布局的嵌套层级,避免过度绘制。 6、 使用RecyclerView: 相比ListView,RecyclerView提供了更好的性能和更灵活的布局管理。...通过这些方法,可以显著提高滚动列表的性能,提升用户体验。 END 点赞转发,让精彩不停歇!关注我们,评论区见,一起期待下期的深度好文!

    1.1K10

    图文讲解RecyclerView的复用机制 ||Recyclerview进阶

    从Recycler中获取一个ViewHolder的逻辑 LayoutManager会调用Recycler.getViewForPosition(pos)来获取一个指定位置(这个位置是子View布局所在的位置...根据LayoutManager的position更新到对应的Adapter的position。...情形三 : 滚动复用 这个情形分析是在情形二的基础上向下滑动时ViewHolder的复用情况以及Recycler中ViewHolder的保存情况, 如下图: ?...在前一篇文章RecyclerView刷新机制中分析过,RecyclerView在滑动时会调用LinearLayoutManager.fill()方法来根据滚动的距离来向RecyclerView填充子View...如果用户此时再下滑的话,可以参考文章开头的从Recycler中获取ViewHolder的逻辑: 1. 先按照位置从mCacheViews集合中获取 2.

    3K30
    领券