Refactorizar mi class de espectadores en kotlin

Tengo una list de recicladores que contiene muchos types diferentes de vistas de artículos. Es bastante fácil usar databinding sin necesidad de declarar el layout y la asignación en el visualizador, sin embargo, termino con muchos códigos de biloplate para simplemente crear los diferentes visualizadores con databinding, ¿hay alguna forma de deshacerse de ellos?

class ViewHolder1 private constructor( val binding: ViewHolder1LayoutBinding ): RecyclerView.ViewHolder(binding.root) { companion object { fun create(parent: ViewGroup): RecyclerView.ViewHolder { val inflater = LayoutInflater.from(parent.context) val binding = ViewHolder1LayoutBinding.inflate(inflater, parent, false) return ViewHolder1(binding) } } fun bind(viewModel: ViewHolder1ViewModel) { binding.viewModel = viewModel binding.executePendingBindings() } } 

kotlin admite vinculación de vista, por lo que no es necesario hacer otras cosas para la vista binding. Simplemente siga los pasos y podrá acceder a la vista por su id definido en el layout xml.

En gradle de nivel de aplicación, agregue lo siguiente

 apply plugin: 'kotlin-android-extensions' 

Vista de import

 import kotlinx.android.synthetic.main.<layout_file>.view.* 

Solo revisa esta class para ver una demostración

 class NotificationHolder(itemView: View?, listener: NotificationItemListener) : RecyclerView.ViewHolder(itemView) { init { itemView?.setOnClickListener { listener.onNotificationItemClicked(adapterPosition) } } fun bind(notificationModel: NotificationModel) { val titleArray = notificationModel.title.split("#".toRegex()).dropLastWhile { it.isEmpty() }.toTypedArray() itemView.tvNotificationTitle.text = titleArray[0] itemView.tvNotificationDetails.text = notificationModel.message itemView.tvNotificationTime.text = notificationModel.formattedTime Glide.with(itemView.context).load(ServiceHandler.BASE_URL + notificationModel.icon).dontAnimate().diskCacheStrategy(DiskCacheStrategy.SOURCE).error(R.drawable.user_default_logo).into(itemView.imageView) if (CommonUtils.lastNotificationTime < notificationModel.date) { itemView.card.setCardBackgroundColor(Color.parseColor("#ffffff")) } else { itemView.card.setCardBackgroundColor(Color.parseColor("#f2f2f2")) } } } 

En el adaptador puede anular

 override fun onCreateViewHolder(parent: ViewGroup?, viewType: Int): RecyclerView.ViewHolder { return if (viewType == 0 || viewType == 3) { NotificationHolder(LayoutInflater.from(parent?.context).inflate(R.layout.item_notification, parent, false), this) } else { NotificationListHeaderHolder(LayoutInflater.from(parent?.context).inflate(R.layout.item_notification_header, parent, false)) } } override fun onBindViewHolder(holder: RecyclerView.ViewHolder?, position: Int) { (holder as? NotificationHolder)?.bind(notificationList[position]) (holder as? NotificationListHeaderHolder)?.bind(notificationList[position]) } 
  • kodein, inyecta datos a la class simple
  • ¿Cómo comparar dos matrices en Kotlin?
  • Solo las dependencies se copyn cuando se implementan plugins intellij
  • Tamaño de file grande al convertir bitmap a PDF
  • Kotlin: ¿cómo pasar una function como parámetro a otra?
  • Cómo get la class de parámetro genérico en Kotlin
  • Live Template no funciona en Kotlin
  • ¿Por qué recibo una ArrayIndexOutOfBoundsException ejecutando este paso particular de Cucumber en Kotlin?
  • Usar un Flux en lugar de un bucle for, ¿algún beneficio?
  • ¿Por qué la cadena json es nula cuando paso un object interno a Gson (). ToJson (object) en Kotlin?
  • Referencia al setter de properties de la class Kotlin como function