Criei esta biblioteca numa época em que achava que o RecyclerView era novo e difícil. Escrever um adaptador que pudesse aumentar vários tipos de visualizações parecia uma tarefa difícil. Na realidade, RecyclerViewHeader
é apenas uma solução complexa para um problema simples. Em vez de usar esta biblioteca, aprenda como criar um RecyclerView.Adapter
multitipo. Isso lhe trará muito valor no longo prazo e não é nada difícil. Verifique a seção Migration
para obter o exemplo mais simples desse Adapter.
Nenhum novo desenvolvimento ocorrerá.
Obrigado por todo o apoio!
Se você ainda quiser usar esta biblioteca, verifique o antigo README.md.
Basta usar um RecyclerView.Adapter
que pode inflar vários tipos de itens.
Aqui está o mais simples que você pode usar:
class ExampleAdapter : RecyclerView . Adapter < RecyclerView . ViewHolder >() {
companion object {
private const val VIEW_TYPE_HEADER = 4815
private const val VIEW_TYPE_ITEM = 1623
}
private val itemDataSetSize : Int get() = TODO ( " provide the size of your `ITEM` dataset " )
override fun onCreateViewHolder ( parent : ViewGroup , viewType : Int ): RecyclerView . ViewHolder {
when (viewType) {
VIEW_TYPE_HEADER -> TODO ( " create your HEADER ViewHolder " )
VIEW_TYPE_ITEM -> TODO ( " create your ITEM ViewHolder " )
else -> error( " Unhandled viewType= $viewType " )
}
}
override fun onBindViewHolder ( holder : RecyclerView . ViewHolder , position : Int ) {
when ( val viewType = getItemViewType(position)) {
VIEW_TYPE_HEADER -> TODO ( " bind your HEADER ViewHolder " )
VIEW_TYPE_ITEM -> TODO ( " bind your ITEM ViewHolder " )
else -> error( " Unhandled viewType= $viewType " )
}
}
override fun getItemCount (): Int = itemDataSetSize + 1 // 1 for header
override fun getItemViewType ( position : Int ) = when (position) {
0 -> VIEW_TYPE_HEADER
else -> VIEW_TYPE_ITEM
}
}
Copyright 2015 Bartosz Lipiński
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.