Sticky Header的另一种实现方法

使用Sticky Header的list单个item一般情况下使用的数据结构是
{data:"what's inside", category:"section name"}
这样存储其实是浪费了很多的空间,因为category的名字被存储的多次。在移动环境中,传输这种多余信息是不文明的。
由此可以演化出两种数据结构,一个是树形的{category0:[data...data],...};另一种是线性的[category0,data0-from-c0...,category1,data0-from-c1,...]。如果把广为流传的Section Indexer用在这两种数据上,需要进行数据转换,数据很多可能有性能问题。
使用第二种格式的数据,可以用简单的思路实现一个Sticky Header:
- 为数据创建一个基类,category和data均继承自此,放入一个list中;
- 为每一个类型创建独立的layout和ViewHolder,ViewHolder以Fragment的形式,提供统一的对外接口,实现所有的对应项逻辑(类似于RecyclerView);
- 设置ListView的ScrollListener,在OnScroll中监听两个事件:
- 当category是第二个可见元素时,进行推挤Indexer的操作;
- 当category是第一个可见元素时,将Indexer复位,覆盖category对应的Item。
这种方案似乎比现有的方法显示效率高一些,因为不需要改变第一个data item中占位符的可见性,减少了绘制次数。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值