前言 这两天在做一个新的APP,在考虑用户体验上要一个两级的列表嵌套,于就想看看RecyclerView是否能做出这样的效果,自己写了一个DEMO来做一下测试,最后的效果还是比较满意的。...下面我就说一下RecyclerView嵌套RecyclerView的实现。...视频效果 https://v.qq.com/x/page/g1359605wnb.html 代码演示 定义基础类 由于我们要做RecyclerView的嵌套,所以也要使用List套List的方法。...ItemAdapter的类 public class ItemAdapter extends RecyclerView.AdapterRecyclerView.ViewHolder> { private...然后我们通过创建GridLayoutManager把子的RecyclerView改为Grid为两排的布局。 ?
本文是介绍 RecyclerView 入门 系列文章 的第三篇。如果您已经对创建 RecyclerView 有了一定的认识,请继续阅读本文。如果尚未熟悉,建议您首先阅读本系列中的 第一篇文章。...相关的响应事件虽然数不胜数,但是它们均需要通过 onClick() 来实现。 定义点击动作 在创建监听器之前,在 Activity 类中添加一个函数用于处理点击之后的响应操作。 (FlowerDiffCallback()) 在 Activity 类中,在初始化 Adapter 的时候传入刚刚创建的点击事件函数。...(itemView) 在初始化的代码中,调用 itemView 的 setOnClickListener{}。...现在您的 RecyclerView 可以响应点击事件了。 编程快乐! 下一步 请查阅包含 onClick() 的 完整示例。 感谢您阅读 RecyclerView 系列 文章的第三篇。
文章目录 一、RecyclerView 简介 二、RecyclerView 特点 三、RecyclerView 涉及到的类 四、RecyclerView 相关资料 一、RecyclerView 简介 -...布局管理器 , RecyclerView 展示的就是 瀑布流 样式的布局 ; 二、RecyclerView 特点 ---- RecyclerView 特点 : ① 功能强大 : 实现 表格 , 网格...避免了 ListView 中自定义 ViewHolder , 给出了相应的 规范 ; 三、RecyclerView 涉及到的类 ---- RecyclerView 使用必须有的关键类 : RecyclerView.ViewHolder..., RecyclerView.Adapter , LayoutManager ; RecyclerView.ViewHolder 用于 定义 RecyclerView 中每个独立元素的显示的组件 ,...创建时不关联数据 , 创建后会在 RecyclerView.Adapter 适配器 的 onBindViewHolder 方法中为其关联数据 ; RecyclerView.Adapter 主要作用是
,那么,在RecyclerView源码中,是怎么用使用ItemDecoration的呢。...--垂直方向 ,最后一个不设置padding--> if (parent.getChildAdapterPosition(view) 水平方向 ,最后一个不设置padding--> if (parent.getChildAdapterPosition(view) 的时机放到LayoutManager的onMeasure中,对全展开的RecyclerView来说,其实就是将所有child测量一遍,之后将每个child需要高度或者宽度累加...,而是要将每一行或者每一列的尺寸叠加,这里假定行高或者列宽都是相同的,其实在使用中这两种场景也是最常见的,看如下代码,其实除了加了行与列判断逻辑,其他基本跟上面的全展开线性的类似。
本文会分析两个问题: RecyclerView的View是在什么时候放入到Recycler中的。以及在Recycler中是如何保存的。...本文不会分析RecyclerView动画时view的复用逻辑。 为了接下来的内容更容易理解,先回顾一下Recycler的组成结构: ?...但比较疑惑的可能就是上述ViewHolder缓存集合中什么时候会保存ViewHolder。接下来分几个RecyclerView的具体情形,来一点一点弄明白这些ViewHolder缓存集合的问题。...其实在上一篇文章Recycler刷新机制中,LinearLayoutManager在确定好布局锚点View之后就会把当前attach在RecyclerView上的子View全部设置为scrap状态: void...在前一篇文章RecyclerView刷新机制中分析过,RecyclerView在滑动时会调用LinearLayoutManager.fill()方法来根据滚动的距离来向RecyclerView填充子View
文章目录 一、为 RecyclerView 设置不同的布局样式 二、完整代码 三、RecyclerView 相关资料 一、为 RecyclerView 设置不同的布局样式 ---- 为 RecyclerView...: 在 onCreateViewHolder( ) 方法中 , 根据当前的 int viewType 参数 , 加载不同的布局文件 ; @Override public...: 在 onBindViewHolder( ) 方法中为布局组件绑定数据时 , 可以调用 getItemViewType 方法 , 获取当前的布局类型 , 然后根据该布局类型 , 将 ViewHolder...适配器 * RecyclerView.Adapter 中的 ViewHolder 泛型设置为 RecyclerView.ViewHolder * 同理 onBindViewHolder...中的泛型也要是该类型的 */ public class Adapter extends RecyclerView.AdapterRecyclerView.ViewHolder> {
RecyclerView中的NestedScroll流程 手指触碰之后,onInterceptTouchEvent触发ACTION_DOWN: 调用startNestedScroll,沿着View...在ACTION_DOWN分支中,会初始化Touch的X,Y位置,并且判断当前RecyclerView是允许横向或者纵向滑动,最后将滑动标志位以及滑动类型交给startNestedScroll 在ACTION_UP...开始进行RecyclerView的滑动 通过mLayout.scrollHorizontallyBy获取LayoutManager的对于scroll的消费距离 调用dispatchNestedScroll...onNestedScroll将已经消费的距离与未消费的距离传入 在父View中的回调函数中可以操作RecyclerView进行移动 移动完后得到与移动前的偏移差,返回给scrollByInternal进行滑动距离的计算...ACTION_UP中调用stopNestedScroll结束整个嵌套滑动的过程 Fling的流程与Touch的流程接近,也是先询问耗费多少再在内部进行处理
就是被观察者,而最终的视图RecyclerView就是观察者,当Adpater数据变动时,RecyclerView会被通知到并根据数据变动视图。...requestLayout和invalidate都会调用父类视图的同名方法,最终到达ViewRootImpl中的同名方法,而ViewRootImpl会根据一些标记来决定是否执行measure/layout...的数量是有所变化的,变成了1,那么条件满足,会执行triggerUpdateProcessor方法: //RecyclerView.java void triggerUpdateProcessor...= true; RecyclerView.this.requestLayout(); } } } 方法中的第一行判断是否成立...话说回来,也就是在triggerUpdateProcessor方法中,没有意外情况的话,仍然会执行requestLayout方法。
今天碰见一个问题在RecyclerView中,用状态去记录RadioButton是否被选中,结果状态被修改,导致状态错乱。...错误代码如下: holder.rbn_pill.setOnCheckedChangeListener(((buttonView, isChecked) -> { //用于装填数据的Bean
之前一篇文章介绍了 ListView 和 RecyclerView 的对比, 这里继续记录下RecyclerView中常用的性能优化方案。...优化方案1:关于点击事件 RecyclerView尽量在onCreateViewHolder()设置点击事件,而不在onBindViewHolder()中设置点击事件。...优化方案2:RecyclerView嵌套布局 在嵌套布局中(竖则滚动 + 局部横向滚动),可以在内部嵌套的RecyclerView中设置LinearLayoutManager.setInitialPrefetchItemCount...不过 这个方法可以提升 内部嵌套RecyclerView的预加载性能。...notifyItemChanged(int position): 刷新指定postion位置上的数据(需要准确知道变化数据的postion) DiffUtil: 查找新/旧 数据的差异,然后执行差异中的变化
在刷新的时候调用对应的刷新 api 即可看到动画 强制实现 ViewHolder RecyclerView 的源码是非常解耦的,且性能非常好 2,RecyclerView 中重要的组件 RecyclerView...5,RecyclerView 的缓存机制 RecyclerView 中缓存的其实是 ViewHolder。...6,RecyclerView 中 item 广告的统计 在 ListView 中通过 getView() 方法进行统计是没有问题的。每次滑动的时候都会调用 getView() 方法。...在 RecyclerView 中 通过 onBindViewHolder() 统计?可能错误!...多个 RecyclerView 共用 RecycledViewPoll 注意这个 RecycledViewPool 不是 四级缓存中的 RecyclerViewPool RecyclerView
(orientation); } /** * 设置item的显示 水平 or 垂直 * * @param orientation */...); } 为RecyclerView添加item的点击事件 方法一:利用回调的方式实现(不太完善,仍可实现) 实现步骤如下: 在adapter类中,定义接口,接口中定义两个方法分别对应click...而“为RecyclerView的每个子item设置setOnClickListener”在Adapter中设置。其实直接在onClick中也能完全处理item的点击事件,但是这样会破坏代码的逻辑。...()中的v.getTag()方法,这需要在onBindViewHolder()方法中设置和item相关的数据 @Override public void onBindViewHolder(ViewHolder...中,典型的观察者模式,有点绕的地方在于,这里涉及到两个观察者模式的使用,view的setOnClickListener本来就是观察者模式,我们将这个观察者模式的事件监听传递给了我们自己的观察者模式。
collectInitialPrefetchPositions定义当此LayoutManager的RecyclerView嵌套在另一个RecyclerView中时应预取多少内部项目。...也就是说只有RecyclerView嵌套才会生效,否则无效 3.setHasFixedSize setHasFixedSize 会给 mHasFixedSize 赋值,看一下用到的地方 // 第一处...当mHasFixedSize是true的时候只会执行onMeasure。...当然,有个前提,adapter的数据变化不会导致RecycleView的大小变化 。...具体我也写过,参考 RecyclerView的缓存机制和内存优化
也就是说,只能是RecyclerView的ViewHolder被滑出屏幕后,再滑回来显示的情景。 也不难看出,从mCachedViews中,我们取得的ViewHolder是不需要重新绑定数据的。...显而易见,它的主要作用是让已经显示过的ViewHolder需要再次显示时,能够快速显示。RecyclerView中,mCachedViews的默认大小为2 。...所以我们通常用它来提升某个特定position的ItemView的回看性能。比如,我们有某个ItemView,界面构建很废时,处在RecyclerView的固定位置中,且界面不需要刷新。...在RecyclerView从页面中消失时,我们可以清空它的ViewHolder到RecycledViewPool中,为我们其他RecyclerView提供更多的缓存。...只有这样,我们才能感受到RecyclerView的巧妙设计,也为我们后续自己工作中的设计提供思路。 技术嘛,需要知其然,知其所以然。
ItemAnimation,可以设置加载和移除时的动画,方便做出各种动态浏览的效果) 用法 1、导入 在Module的build.gradle的Dependencies中添加依赖(对应自己appcompat-v7...RecyclerView的Adapter强制要求使用ViewHolder,该ViewHolder须继承RecyclerView.ViewHolder。 对应的item布局 垂直排布 StaggeredGridLayoutManager layoutManager1 =...效果 我们在使用ListView的时候,一般都会使用分割线,只要在布局中说明就好了。相比ListView,RecyclerView添加分割线就有些复杂了。...平时在ListView中用的addHeader,还有常用的上拉加载,下拉刷新呢?别急,先熟悉RecyclerView的基本用法,再来深入也不迟啊。
自从Android中引入RecyclerView之后,它就逐步的替换掉了ListView和GridView。本文很简单,行文目的是记录和备忘。如果能帮到你,那再好不过了。...关于控制RecyclerView item的宽度,说起来还不是那么清晰,上一张图,就明白了。 ?...上面的实际上是一个Grid布局 前三行每个item均分RecyclerView的宽度 最后一行的Others占大概三分之一,而Flipboard则占据了三分之二。...上面的图和描述就是我们今天想要实现的效果。...spanCount,这里值为3 getSpanSize方法中,最后一个item占据2个span,其他占据一个span 完整示例源码 recyclerview_span_size
官方介绍 RecyclerView是ListView的一个更高级、更灵活的版本。RecyclerView组件是为大量的视图组件提供的一种容器,使得它们可以有效的在其中循环和滚动。...RecyclerView的使用 最终要达到的效果 如下图所示 image.png 编写相关的布局文件 MainItem布局如下: 的Adapter类 class MainItemAdapter(private val itemList: List) : RecyclerView.Adapter<MainItemAdapter.ViewHolder...holder.itemIcon.setImageResource(mainItem.iconId) } override fun getItemCount(): Int = itemList.size } 在Activity中初始化数据和...= findViewByIdRecyclerView>(R.id.recycler_view) recyclerView.layoutManager = GridLayoutManager(
您可能在开发过程中遇到过这种情况,在 Activity/Fragment 被重新创建后,RecyclerView 丢失了它之前保有的滚动位置信息。...通常这种情况发生的原因是由于异步加载 Adapter 数据,且数据在 RecyclerView 需要进行布局的时候尚未加载完成,导致 RecyclerView 无法恢复到之前的滚动位置。...其中最好的一种方法是将数据提前缓存在内存、ViewModel 或 Repository 中,然后确保在第一次布局传入之前,将缓存的数据设置到 Adapter 中去。...如果根据您的项目实际情况无法采用这种方法,那也可以使用其他的方法,只是要么比较复杂 (比如避免在 RecyclerView 中设置 Adapter,但这样又有可能导致像 header 等 item 的显示问题...() > 0) 的时候,才恢复 RecyclerView 的状态。
有时候,一个列表中的Item会有EditText的出现,而由于View复用机制,如果不好好处理EditText,将会出现一些问题。...其实有些问题的出现,还是由于没有理解RecyclerView的复用机制和EditText,主要原因还是菜,哈哈。...菜是原罪 EditText在RecyclerView中的问题 例子是这样的,每个Item包含一个title、一张图片以及一个评分,这个评分就是通过输入框来输入的。...先看下效果如下: 这里,每张图片输入图片title对应的分数,可以看到,由于未绑定数据和RecyclerView的复用机制的存在,在一些图片中还没输入分数,就已经出现分数了。...首先我是试了一个,removeTextWatcher的方法,那就是在Adapter的detachViewHolderFromWindow方法中移除TextWatcher,如下: class PicAdapter
在刷新的时候调用对应的刷新 api 即可看到动画 强制实现 ViewHolder RecyclerView 的源码是非常解耦的,且性能非常好 2,RecyclerView 中重要的组件 RecyclerView...5,RecyclerView 的缓存机制 RecyclerView 中缓存的其实是 ViewHolder。...6,RecyclerView 中 item 广告的统计 在 ListView 中通过 getView() 方法进行统计是没有问题的。每次滑动的时候都会调用 getView() 方法。...在 RecyclerView 中 通过 onBindViewHolder() 统计?可能错误!...多个 RecyclerView 共用 RecycledViewPoll 注意这个 RecycledViewPool 不是 四级缓存中的 RecyclerViewPool RecyclerView 会默认给自己创建一个
领取专属 10元无门槛券
手把手带您无忧上云