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
根據(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,當然也可以復用其他已創(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 設置的其他VIewHolder }
8.重寫onBindViewHolder,如果viewType為TYPE_FOOTER就跳過
override fun onBindViewHolder(holder: RecyclerView.ViewHolder, position: Int) { if (getItemViewType(position) == TYPE_FOOTER) return 你的綁定事件不用動 }
9.最后說一下getAdapterPosition和getLayoutPosition
建議如下:
當你需要綁定數(shù)據(jù)的時候使用holder.getAdapterPosition();來實時獲取
當你進行點擊/滑動等監(jiān)聽事件用holder.getLayoutPosition();來獲取位置
在絕大多數(shù)的時候holder.getAdapterPosition()和holder.getLayoutPosition()是沒有任何區(qū)別的,因為兩者數(shù)據(jù)的不同在16ms之內(nèi)
總結
到此這篇關于android RecyclerView添加footerview詳解的文章就介紹到這了,更多相關RecyclerView添加footerview內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
Flutter實現(xiàn)單選,復選和開關組件的示例代碼
在App開發(fā)過程中,選擇交互是非常常見的,今天主要介紹下關于選擇的三個組件的使用:開關、單選和復選,感興趣的小伙伴可以了解一下2022-04-04Android實現(xiàn)錄音監(jiān)聽動畫的示例代碼
在很多app種內(nèi)置了語音助手,也存在各種動畫,這篇文章主要為大家詳細介紹了Android實現(xiàn)錄音監(jiān)聽動畫的示例代碼,感興趣的小伙伴可以跟隨小編一起學習一下2023-12-12Android ViewPager自定義輪播圖并解決播放沖突
這篇文章主要為大家詳細介紹了Android ViewPager自定義輪播圖并解決播放沖突,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2021-09-09Android中的android:layout_weight使用詳解
layout_weight的作用是設置子空間在LinearLayout的重要度(控件的大小比重)。layout_weight的值越低,則控件越重要,下面為大家介紹下具體的使用方法2013-06-06