日本免费高清视频-国产福利视频导航-黄色在线播放国产-天天操天天操天天操天天操|www.shdianci.com

學(xué)無先后,達者為師

網(wǎng)站首頁 編程語言 正文

android?RecyclerView添加footerview詳解_Android

作者:橘子先生z ? 更新時間: 2022-03-30 編程語言
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 設(shè)置的其他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)如果你的底部布局是變化的,那這里設(shè)置的就應(yīng)該是
var isFooterView: View

3.FooterView相關(guān)方法

//設(shè)置FooterView
fun setFooterView() {
        this.isFooterView = true
        notifyItemInserted(itemCount)
       //這個方法是通知Adapter有新的Item插入
    }

//移除FooterView
    fun removeFooterView() {
        this.isFooterView = false
    }

4.重寫getItemViewType
根據(jù)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.接下來創(chuàng)建一個空ViewHolder,當(dāng)然也可以復(fù)用其他已創(chuàng)建的ViewHolder

 class BottomViewHolder(view: View) : RecyclerView.ViewHolder(view) {
    }

7.重寫onCreateViewHolder,根據(jù)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 設(shè)置的其他VIewHolder
    }

8.重寫onBindViewHolder,如果viewType為TYPE_FOOTER就跳過

 override fun onBindViewHolder(holder: RecyclerView.ViewHolder, position: Int) {
        if (getItemViewType(position) == TYPE_FOOTER) return
        你的綁定事件不用動
    }

9.最后說一下getAdapterPosition和getLayoutPosition
建議如下:

當(dāng)你需要綁定數(shù)據(jù)的時候使用holder.getAdapterPosition();來實時獲取

當(dāng)你進行點擊/滑動等監(jiān)聽事件用holder.getLayoutPosition();來獲取位置

在絕大多數(shù)的時候holder.getAdapterPosition()和holder.getLayoutPosition()是沒有任何區(qū)別的,因為兩者數(shù)據(jù)的不同在16ms之內(nèi)

總結(jié)

原文鏈接:https://blog.csdn.net/DASHBB/article/details/122513764

欄目分類
最近更新