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]) } 
  • maven-source-plugin no funciona para kotlin
  • La aplicación Kotlin no muestra mi matriz json
  • extracción de resources de string para kotlin en android studio?
  • En Kotlin, ¿cómo se modifican los contenidos de una list mientras se itera
  • Complemento de estudio Android con id: 'kotlin-android-extensions'
  • Repetir una alarma para disparar exacta en el momento específico no funciona correctamente
  • ¿Por qué Kotlin Array <T> no implementa Iterable <T>
  • Criterio multicriterio de Kotlin no comstackndo
  • ¿Cuál es la forma correcta de crear y publicar la biblioteca de Kotlin para evitar el problema de múltiples times de ejecución?
  • Kotlin detecta el time de espera a petición del server
  • ¿Cómo configurar la versión de Kotlin en Android Studio?