brvah树状结构默认展开第一个_BRVAH(让RecyclerView变得更高效) (2)

本文介绍了如何使用BRVAH库在RecyclerView中实现宫格和列表的混排样式,包括设置GridLayoutManager的spanSize和spanSizeLookup。同时讲解了RecyclerView嵌套RecyclerView的布局,并解决了焦点问题。此外,还详细说明了BRVAH中实现item及子View的点击和长按监听事件的处理方式。
摘要由CSDN通过智能技术生成

本文来自网易云社区

作者:吴思博

1.2 宫格和列表的混排样式

关于 Grid 和List 的混排样式,Grid 样式是一行有多个,而 List样式是一行只有一个。 我们可以把 List 样式看成是Grid 样式,它就相当于把一个 Grid 的 item 拉长了的样子。

9f894a39530ce263525f2b524f159669.png

列表与网格混排的布局效果,我们可以创建 adapter 继承 BaseMultiItemQuickAdapter添加对应 item 类型的布局文件,也可以在 Activity中创建GridLayoutManager对象,设置spanSize属性,通过 Adapter 的setSpanSizeLookup()方法设置每种item类型对应的spanSize。设置Recyclerview的addItemDecoration()方法设置添加分割线或设置 item 间距。

在创建GridLayoutManager对象时, spanSize的参数需要设置,它的作用就是使原来一个item占满一行变为可以最多三个 item 占满一行。

而设置setSpanSizeLookup()方法返回的是对应每种item类型返回具体的横跨大小。比如代码中TYPE_GRID类型的item在设置的spanSize是 1,而 GridLayoutManager 设置的 spanSize 是 3,那么该类型的item 就会以 3 个 item 占满一行,相当于每个 item 占一行的 1/3。

代码片段:

5d55ef998b91372f4a1dd40e631d9579.png

在我们使用addItemDecoration()添加分割线的方法中对这种混排的列表设置item间距的时候,在 getItemOffsets()方法里,通过GridLayoutManager.LayoutParams获取spanSize 来确定 item 类型设置对应间距,

其中spanIndex表示当前行item对应的下标位置,从左到右依次从 0 开始。

1.3 Recyclerview嵌套 Recyclerview 的复杂布局

我们“文学漫画”产品中,那些地方用到这种布局?例如蜗牛的领读ReadTrendFragment、 Lofter发现音乐Fragment、 云阅读书店BookStoreFragment。

73d237ad16342769f24f122775deef0a.png

054c9b9d776e6102ba950de107ba2914.png

蜗牛的领读ReadTrendFragment                                              Lofter发现的音乐Fragment

这种界面布局样式,最外面一个RecyclerView,它里面嵌套一个 RecyclerView。继承BaseMultiItemQuickAdapter 在重写的 convert() 方法中实例化子 Recyclerview。

477952ce85ec71b8fe01c9cfdbfe2bd5.png

需要注意的是Recyclerview 嵌套 Recyclerview 会出现子 Recyclerview 抢焦点的问题, 导致界面顶部部分控件被挤出, 只需在最外面的Recyclerview 的包裹容器中设置属性

Android:descendantFocusability="blocksDescendants" 即可。

2. 实现了点击监听事件

3543326f790d2fd02ce76f4f7537fca3.png

BRVAH为我们提供好了全面的 item 和 item 子 View 的监听事件,我们只需在继承它提供的 Adapter 的基础上,通过adapter 来调用对应的监听。 设置监听子 View 前,我们需要在 adapter 中对应的 item 的子 View 注册对应的监听事件。

2.1对于 item 的监听事件处理

直接在 Activity 中添加 item 点击事件,和listview一样。

25f6cc430ebf721d750d785714a4b62d.png

item 长按监听事件

a9c20d8e09967e3f585dc4e981ec070d.png

2.2对 item 中子 View 的监听事件处理

首先需要在adapter 中,注册子 View 的监听事件。

e2535d12e0b0d79e5f7804046848be9a.png

d1755f3340dd24981d434a3cc52adc9c.png

2.3 也可以通过viewHolder.getView(viewId)获取该控件,再设置监听。

5585b223efa9e9597ad294316822d1dd.png

网易云免费体验馆,0成本体验20+款云产品!

更多网易研发、产品、运营经验分享请访问网易云社区。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,下面是Kotlin实现的BRVAHRecyclerView实现无限循环滚动和可点击item的代码: 1. 首先在build.gradle中添加BRVAH依赖: ``` implementation 'com.github.CymChad:BaseRecyclerViewAdapterHelper:3.0.4' ``` 2. 在布局文件中添加RecyclerView: ``` <androidx.recyclerview.widget.RecyclerView android:id="@+id/recyclerView" android:layout_width="match_parent" android:layout_height="match_parent" /> ``` 3. 在Activity或Fragment中初始化RecyclerView: ``` val recyclerView = findViewById<RecyclerView>(R.id.recyclerView) val layoutManager = LinearLayoutManager(this) layoutManager.orientation = LinearLayoutManager.HORIZONTAL // 设置为横向滚动 recyclerView.layoutManager = layoutManager ``` 4. 创建Adapter并继承BaseQuickAdapter: ``` class MyAdapter(data: List<String>?) : BaseQuickAdapter<String, BaseViewHolder>(R.layout.item_layout, data) { override fun convert(holder: BaseViewHolder, item: String) { // 设置item的显示内容 holder.setText(R.id.tvItemName, item) } } ``` 5. 创建数据源并初始化Adapter: ``` val dataList = listOf("item1", "item2", "item3", "item4", "item5") val myAdapter = MyAdapter(dataList) recyclerView.adapter = myAdapter ``` 6. 实现无限循环滚动: ``` recyclerView.post { val layoutManager = recyclerView.layoutManager as LinearLayoutManager val firstItem = layoutManager.findFirstVisibleItemPosition() val lastItem = layoutManager.findLastVisibleItemPosition() val itemCount = layoutManager.itemCount // 如果当前第一个可见item是第0个item,则将RecyclerView滚动到最后一个item的位置 if (firstItem == 0) { recyclerView.scrollToPosition(itemCount - 1) } // 如果当前最后一个可见item是最后一个item,则将RecyclerView滚动到第一个item的位置 else if (lastItem == itemCount - 1) { recyclerView.scrollToPosition(0) } } ``` 7. 实现可点击item: ``` myAdapter.setOnItemClickListener { adapter, view, position -> // 处理item的点击事件 } ``` 以上就是BRVAHRecyclerView实现无限循环滚动和可点击item的Kotlin代码。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值