Всем здравствуйте, я хочу спросить, могу ли я добавить к своим 3 представлениям повторного использования каждый интерфейс представления повторного использования имеет интерфейс для оптимизации моего кода. Я пытался добавить только 1 адаптер для представления 3 повторных циклов, как вы можете видеть мой код ниже, но я обнаружил, что застрял с этим адаптер, у кого-нибудь есть идеи, как добавить собственный адаптер для адаптации 3 Recycle View? Спасибо.
класс CustomAdapter (частный контекст: контекст): RecyclerView.Adapter<RecyclerView.ViewHolder>() { контекст частного значения: Context = contexte
inner class FolderViewHolder(itemView: View) : RecyclerView.ViewHolder(itemView) {
}
inner class PagesViewHolder(itemView: View) : RecyclerView.ViewHolder(itemView) {
}
inner class CorpusViewHolder(itemView: View) : RecyclerView.ViewHolder(itemView) {
}
override fun onCreateViewHolder(parent: ViewGroup, viewType: Int): RecyclerView.ViewHolder {
if (viewType == VIEW_TYPE_CORPUS)
return CorpusViewHolder(
LayoutInflater.from(parent.context)
.inflate(R.layout.corpus_item_layout, parent, false)
)
if (viewType == VIEW_TYPE_FOLDER)
return FolderViewHolder(
LayoutInflater.from(parent.context)
.inflate(R.layout.folder_item_layout, parent, false)
)
return PagesViewHolder(
LayoutInflater.from(parent.context).inflate(
R.layout.page_item_layout, parent, false
)
)
}
override fun onBindViewHolder(holder: RecyclerView.ViewHolder, position: Int) {
TODO("Not yet implemented")
}
override fun getItemCount(): Int {
return 20
}
companion object {
internal val VIEW_TYPE_CORPUS = 1
internal val VIEW_TYPE_FOLDER = 2
internal val VIEW_TYPE_PAGES = 2
}
Вместо этого я предлагаю вам использовать базовый класс, который принимает идентификатор макета и инициализирует с ним ваш общий адаптер.
open class AdapterItem(val layoutId: Int)
data class Corpus(val id: Int): AdapterItem(id)
затем инициализируйте свой адаптер, например
CustomAdapter<AdapterItem>(...)
в вашем адаптере переопределите getView
@Override
fun getView(position: Int, convertView: View, parent: ViewGroup): View {
val item = list[position]
return if (converView != null){
convertView
} else {
LayoutInflater.from(parent.context).inflate(item.layoutId, parent, false)
}
}