Android

Cambiar color de Spinner en Android

Los Spinners en Android son un dropdown o una lista desplegable que muestra una lista de opciones que el usuario puede seleccionar.

En este post voy a explicar cómo cambiar el color de un Spinner, es decir, cambiar el color de:

  • Elemento seleccionado
  • Elementos de la lista
  • Flecha o triángulo que aparece

Para personalizar el Spinner vamos a definir algunos archivos XML e indicar que los vamos a usar en nuestro adaptador.

Nota: si no sabes llenar un Spinner mira este post.

Cambiar color del elemento seleccionado

En la carpeta res/layout hay que agregar un archivo que vamos a usar en el Spinner:

See the gist on github.

Como puedes ver, es un simple TextView. Ponle el color que quieras y personalízalo. En este caso tiene el color blanco, pero puedes ponerle otro, al igual que puedes modificar el tamaño.

Cambiar color de elementos de la lista

Personalizar color de elementos de Spinner en Android

Si quieres cambiar el color de los elementos que se muestran en la lista, crea un CheckedTextView personalizado, dentro de un XML ubicado en la carpeta res/layout:

See the gist on github.

El color está definido por el atributo textColor.

Cambiar el color del triángulo o flecha

Para ello hay que modificar el backgroundTint del Spinner. Si tu nivel de API es mayor o igual a la 21, especifica el atributo android:backgroundTint así:

See the gist on github.

Si, en cambio, tu app usa APIs antiguas o menores, cambia el elemento Spinner por un android.support.v7.widget.AppCompatSpinner y especifica el atributo app:backgroundTint.

See the gist on github.

backgroundTint para cambiar color de elemento y flecha en Spinner Android

Especificando archivos XML

Ya definimos los diseños, ahora vamos a usarlos.

En el Spinner tienes un adaptador, cuando hagas el adaptador utiliza R.layout.elemento_spinner_personalizado como layout, en lugar del elemento por defecto

Después, invoca al método setDropDownViewResource de tu adaptador, y pásale tu archivo en donde personalizas la lista de los elementos:

arrayAdapter.setDropDownViewResource(R.layout.elemento_lista_spinner_personalizado);

Recuerda que el color del triángulo o flecha se especifica con backgroundTint.

Yo estoy trabajando con Kotlin pero igualmente funciona con Java, solo dejaré un ejemplo de mi código:

See the gist on github.

Encantado de ayudarte


Estoy disponible para trabajar en tu proyecto, modificar el programa del post o realizar tu tarea pendiente, no dudes en ponerte en contacto conmigo.

No te pierdas ninguno de mis posts

Suscríbete a mi canal de Telegram para recibir una notificación cuando escriba un nuevo tutorial de programación.
parzibyte

Programador freelancer listo para trabajar contigo. Aplicaciones web, móviles y de escritorio. PHP, Java, Go, Python, JavaScript, Kotlin y más :) https://parzibyte.me/blog/software-creado-por-parzibyte/

Ver comentarios

Compartir
Publicado por
parzibyte

Entradas recientes

Imprimir PDF con Bot de Telegram

La impresión de un PDF en cualquier impresora se puede automatizar con un bot de…

9 horas hace

Enviar mensaje con bot de Telegram usando JavaScript (lado del cliente)

Hoy te enseñaré cómo enviar un mensaje a un usuario desde un bot de Telegram…

1 día hace

PHP: incrustar imagen en base64

El día de hoy te enseñaré algo muy sencillo pero útil al programar con PHP:…

1 día hace

Plugin ESC POS – Actualización 3.4.0: imprimir HTML

El plugin para imprimir en impresoras térmicas alcanza hoy su versión 3.4.0 agregando soporte para…

2 días hace

JavaScript (lado del cliente): leer pixeles de imagen

En ocasiones es necesario leer los pixeles y colores de una imagen con JavaScript del…

1 semana hace

PHP y JavaScript: llenar select con AJAX

Siguiendo con los tutoriales de listas desplegables o select con JavaScript, vamos a ver cómo…

1 semana hace

Esta web usa cookies.