Acabamos de ver cómo agregar un listener a un Spinner para saber cuándo se selecciona un elemento en Android, pero lo hicimos con Java.
Ahora voy a mostrarte cómo escuchar el cambio de un Spinner en Kotlin, para programar en Android.
Listener de Spinner con Kotlin
Obviamente debemos tener una referencia al Spinner, en mi caso esa referencia o variable se llama spinnerCategoriasReporteGastos
.
Hay que agregar un listener de tipo OnItemSelectedListener
de la siguiente manera:
spinnerCategoriasReporteGastos.onItemSelectedListener = object : AdapterView.OnItemSelectedListener {
override fun onNothingSelected(parent: AdapterView<*>?) {
Toast.makeText(context!!, "onNothingSelected", Toast.LENGTH_SHORT).show()
}
override fun onItemSelected(parent: AdapterView<*>?, view: View?, position: Int, id: Long) {
Toast.makeText(context!!, "onItemSelected position: $position. id: $id", Toast.LENGTH_SHORT).show()
}
}
El método importante aquí es onItemSelected
, pues recibimos la posición del elemento que fue seleccionado.
Lo único que hago es mostrar un simple toast para saber que un elemento fue seleccionado.
Llamada en la creación de la actividad
Este listener tiene un pequeño defecto, y es que también es invocado cuando la actividad o fragmento es creado.
Podemos agregar una bandera como vimos en el otro post. De esta manera, usando una variable booleana, podemos ignorar la primera llamada.
Declaramos la global:
class ReporteGastosFragment : Fragment() {
var banderaListener = false
// Aquí más código...
}
Y en el listener evitamos la primera vez:
spinnerCategoriasReporteGastos.onItemSelectedListener = object : AdapterView.OnItemSelectedListener {
override fun onNothingSelected(parent: AdapterView<*>?) {
Toast.makeText(context!!, "onNothingSelected", Toast.LENGTH_SHORT).show()
}
override fun onItemSelected(parent: AdapterView<*>?, view: View?, position: Int, id: Long) {
if (!banderaListener) {
banderaListener = true
return
}
// A partir de acá, podemos asumir que la llamada es genuina y generada por el usuario
Toast.makeText(context!!, "onItemSelected position: $position. id: $id", Toast.LENGTH_SHORT).show()
}
}
Así de simple es. Recuerda que para obtener el elemento puedes usar la variable position
como índice.
En mi caso funciona como un encanto: