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.
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.
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:
Hoy te voy a presentar un creador de credenciales que acabo de programar y que…
Ya te enseñé cómo convertir una aplicación web de Vue 3 en una PWA. Al…
En este artículo voy a documentar la arquitectura que yo utilizo al trabajar con WebAssembly…
En un artículo anterior te enseñé a crear un PWA. Al final, cualquier aplicación que…
Al usar Comlink para trabajar con los workers usando JavaScript me han aparecido algunos errores…
En este artículo te voy a enseñar cómo usar un "top level await" esperando a…
Esta web usa cookies.