这篇文章主要介绍“android RecyclerView怎么添加footerview”,在日常操作中,相信很多人在android RecyclerView怎么添加footerview问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”android RecyclerView怎么添加footerview”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!
class FooterViewAdapter :RecyclerView.Adapter<RecyclerView.ViewHolder>() { companion object { const val TYPE_FOOTER: Int = 1 const val TYPE_NORMAL: Int = 0 } var isFooterView: Boolean = false fun setFooterView() { this.isFooterView = true notifyItemInserted(itemCount) } fun removeFooterView() { this.isFooterView = false } override fun getItemViewType(position: Int): Int { return if (isFooterView && position == itemCount - 1) TYPE_FOOTER else TYPE_NORMAL } override fun onCreateViewHolder(parent: ViewGroup, viewType: Int): RecyclerView.ViewHolder { if (viewType == TYPE_FOOTER) { val view = LayoutInflater.from(parent.context) .inflate(R.layout.focus_footer_view_no_line, parent, false) return BottomViewHolder(view) } return 设置的其他VIewHolder } override fun onBindViewHolder(holder: RecyclerView.ViewHolder, position: Int) { if (getItemViewType(position) == TYPE_FOOTER) return 你的绑定事件不用动 } class BottomViewHolder(view: View) : RecyclerView.ViewHolder(view) { } override fun getItemCount(): Int { return if (isFooterView && mData.size > 0) mData.size + 1 else mData.size } }
1.定义viewtype的类型,一个是正常的,一个是底部view
companion object { const val TYPE_FOOTER: Int = 1 const val TYPE_NORMAL: Int = 0 }
2.定义一个是否加FooterView的Boolean变量 (1)如果你的底部view是固定的,就不需要解析多次xml布局,直接在onCreateViewHolder方法里解析一次布局。 var isFooterView: Boolean = false (2)如果你的底部布局是变化的,那这里设置的就应该是 var isFooterView: View
3.FooterView相关方法
//设置FooterView fun setFooterView() { this.isFooterView = true notifyItemInserted(itemCount) //这个方法是通知Adapter有新的Item插入 } //移除FooterView fun removeFooterView() { this.isFooterView = false }
4.重写getItemViewType
根据isFooterView判断是否加FooterView&&item是不是最后一个来定位最后一个item,其他的ViewType都是TYPE_NORMAL
override fun getItemViewType(position: Int): Int { return if (isFooterView && position == itemCount - 1) TYPE_FOOTER else TYPE_NORMAL }
5.itemCount
这个方法很重要,是计算有多少个Item的,上面也用到了。
很简单,添加了FooterView,ItemCount加1
override fun getItemCount(): Int { return if (isFooterView && mData.size > 0) mData.size + 1 else mData.size }
6.接下来创建一个空ViewHolder,当然也可以复用其他已创建的ViewHolder
class BottomViewHolder(view: View) : RecyclerView.ViewHolder(view) { }
7.重写onCreateViewHolder,根据viewType来解析不同的布局。
override fun onCreateViewHolder(parent: ViewGroup, viewType: Int): RecyclerView.ViewHolder { if (viewType == TYPE_FOOTER) { val view = LayoutInflater.from(parent.context) .inflate(R.layout.focus_footer_view_no_line, parent, false) return BottomViewHolder(view) } return 设置的其他VIewHolder }
8.重写onBindViewHolder,如果viewType为TYPE_FOOTER就跳过
override fun onBindViewHolder(holder: RecyclerView.ViewHolder, position: Int) { if (getItemViewType(position) == TYPE_FOOTER) return 你的绑定事件不用动 }
9.最后说一下getAdapterPosition和getLayoutPosition
建议如下:
当你需要绑定数据的时候使用holder.getAdapterPosition();来实时获取
当你进行点击/滑动等监听事件用holder.getLayoutPosition();来获取位置
在绝大多数的时候holder.getAdapterPosition()和holder.getLayoutPosition()是没有任何区别的,因为两者数据的不同在16ms之内
到此,关于“android RecyclerView怎么添加footerview”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注亿速云网站,小编会继续努力为大家带来更多实用的文章!
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。