返回顶部
首页 > 资讯 > 移动开发 >androidRecyclerView添加footerview详解
  • 382
分享到

androidRecyclerView添加footerview详解

2024-04-02 19:04:59 382人浏览 薄情痞子
摘要

class FooterViewAdapter :RecyclerView.Adapter<RecyclerView.ViewHolder>() { compa

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详解的文章就介绍到这了,更多相关RecyclerView添加footerview内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

--结束END--

本文标题: androidRecyclerView添加footerview详解

本文链接: https://lsjlt.com/news/162654.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作