Cambiar color de Spinner en Android

Publicado por parzibyte en

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:

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:

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í:

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.

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:


parzibyte

He trabajado por más de 4 años en el desarrollo de software con experiencia en Java, PHP, JavaScript, HTML, Node.JS, Python, Android y Go. También he trabajado con bases de datos SQL como MySQL y SQLite, así como con bases de datos NoSQL usando MongoDB.Soy bueno utilizando algunos frameworks y herramientas como Firebase, jQuery, AngularJS, VueJS, CodeIgniter, Laravel, BulmaCSS, Bootstrap y Electron.Otros términos que conozco son: Arduino, GraphQL, API's, REST, AJAX, PouchDB, CouchDB, Experiencia de usuario, buenas prácticas de programación, Webpack, NPM, Administración de servidores y programación de scriptsLa plataforma en la que tengo más experiencia es la web, pero en mis ratos libres realizo unos pequeños ejercicios en C# y C.Estoy aquí para ayudarte a resolver tus problemas de programación y depuración :-)

1 Comment

Spinner en Android: escuchar cambio de elemento seleccionado - Parzibyte's blog · julio 4, 2019 a las 5:41 pm

[…] Tal vez ahora quieras cambiarle el color a tu spinner. […]

Deja un comentario

Tu dirección de correo electrónico no será publicada. Los campos obligatorios están marcados con *

This site uses Akismet to reduce spam. Learn how your comment data is processed.

A %d blogueros les gusta esto: