Blog para desarrollo de aplicaciones en Android, aprende paso a paso como crear aplicaciones.

Usamos cookies propias y de terceros que entre otras cosas recogen datos sobre sus hábitos de navegación para mostrarle publicidad personalizada y realizar análisis de uso de nuestro sitio.
Si continúa navegando consideramos que acepta su uso. OK Más información | Y más

Como crear un Spinner List en Android

Android Spinner Dropdown List

Hola amigos.

Vamos a crear un proyecto en Android Studio (Aquí).

Comenzaremos con este tutorial crearemos un Spinner con un poco mas de opciones.


El Spinner es similar a un Dropdownlist que es una lista desplegable de elementos. Es muy útil utilizar el Spinner en Android. Y les mostrare las diferentes opciones en que lo pueden utilizar.

Comenzaremos creando el diseño de nuestro proyecto.

Android Studio - Spinner Dropdown List
El código seria así.

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
xmlns:app="http://schemas.android.com/apk/res-auto" 
android:layout_width="match_parent"
android:layout_height="match_parent" 
android:paddingLeft="@dimen/activity_horizontal_margin"
android:paddingRight="@dimen/activity_horizontal_margin"
android:paddingTop="@dimen/activity_vertical_margin"
android:paddingBottom="@dimen/activity_vertical_margin"
app:layout_behavior="@string/appbar_scrolling_view_behavior"
tools:showIn="@layout/activity_main" tools:context=".MainActivity">
<!-- Text Label -->
<TextView
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:layout_marginTop="10dip"
android:text="Category:"
android:layout_marginBottom="5dp"
android:id="@+id/category"
/>

<!-- Spinner Elementos -->
<Spinner
android:id="@+id/spinner"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:layout_below="@+id/category"
/>

</RelativeLayout>

Para poder utilizar este elemento en la clase. Se utiliza el siguiente fragmento de código.


Spinner spinner = (Spinner) findViewById(R.id.spinner);

Para continuar con este elemento agregaremos un botón para crear una nueva opción utilizando varios controles en este caso el Android Button.

Diseño Android Spinner

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
 xmlns:tools="http://schemas.android.com/tools"
 xmlns:app="http://schemas.android.com/apk/res-auto" android:layout_width="match_parent"
 android:layout_height="match_parent" android:paddingLeft="@dimen/activity_horizontal_margin"
 android:paddingRight="@dimen/activity_horizontal_margin"
 android:paddingTop="@dimen/activity_vertical_margin"
 android:paddingBottom="@dimen/activity_vertical_margin"
 app:layout_behavior="@string/appbar_scrolling_view_behavior"
 tools:showIn="@layout/activity_main" tools:context=".MainActivity">
 <LinearLayout
 android:orientation="vertical"
 android:padding="10dip"
 android:id="@+id/linear_layout"
 android:layout_width="fill_parent"
 android:layout_height="wrap_content">

 <!-- Text Label -->
 <TextView
 android:layout_width="match_parent"
 android:layout_height="wrap_content"
 android:layout_marginTop="10dip"
 android:text="Category:"
 android:layout_marginBottom="5dp"
 android:id="@+id/category"
 />

 <!-- Spinner Elemento -->
 <Spinner
 android:id="@+id/spinner"
 android:layout_width="match_parent"
 android:layout_height="wrap_content"
 android:layout_below="@+id/category"
 />
 </LinearLayout>

 <Button
 android:layout_width="match_parent"
 android:layout_height="wrap_content"
 android:text="Continuar"
 android:id="@+id/button"
 android:layout_alignParentBottom="true"
 android:layout_centerHorizontal="true"
 android:layout_marginBottom="137dp" />

</RelativeLayout>

Continuaremos agregando un segundo Activity.

Android Studio - Spinner Dropdown List
Al cual le agregaremso un TextView para mostrar un mensaje.

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
 xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent"
 android:layout_height="match_parent" android:paddingLeft="@dimen/activity_horizontal_margin"
 android:paddingRight="@dimen/activity_horizontal_margin"
 android:paddingTop="@dimen/activity_vertical_margin"
 android:paddingBottom="@dimen/activity_vertical_margin"
 tools:context="com.example.blackjack.myapplication.Main2Activity">
 <TextView
 android:layout_width="wrap_content"
 android:layout_height="wrap_content"
 android:textAppearance="?android:attr/textAppearanceMedium"
 android:text="Mensaje"
 android:id="@+id/txt_bundle"
 android:layout_alignParentTop="true"
 android:layout_centerHorizontal="true"
 android:layout_marginTop="103dp" />
</RelativeLayout>

Código MaintActivity

Ahora nos dirigimos al MainActivity. Para escribir nuestro código.


import android.app.Activity;
import android.content.Intent;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.Menu;
import android.view.MenuItem;
import android.view.View;
import android.widget.AdapterView;
import android.widget.ArrayAdapter;
import android.widget.Button;
import android.widget.Spinner;
import android.widget.Toast;

import java.util.ArrayList;
import java.util.List;

public class MainActivity extends Activity implements AdapterView.OnItemSelectedListener {
 @Override
 public void onCreate(Bundle savedInstanceState) {
 super.onCreate(savedInstanceState);
 setContentView(R.layout.activity_main);

 // Declaramos el Spinner y el Button
 final Spinner spinner = (Spinner) findViewById(R.id.spinner);
 Button button = (Button)findViewById(R.id.button);

 // Evento en espera de recibir Click del Spinner
 spinner.setOnItemSelectedListener(this);

 // Elementos que mostrar el Spinner
 List<String> categories = new ArrayList<String>();
 categories.add("Google");
 categories.add("Microsoft");
 categories.add("Yahoo");
 categories.add("Android");
 categories.add("IOS");
 categories.add("Linux");

 // Crear el Adapter para el Spinner
 ArrayAdapter<String> dataAdapter = new ArrayAdapter<String>(this, android.R.layout.simple_spinner_item, categories);

 // Estilo de diseño desplegable: vista de lista con el botón de opción
 dataAdapter.setDropDownViewResource(android.R.layout.simple_spinner_dropdown_item);

 // Conectar el adaptador de datos para el Spinner
 spinner.setAdapter(dataAdapter);
 
 // Evento del Botón que captura el dato del Spinner que fue seleccionado
 button.setOnClickListener(new View.OnClickListener() {
 @Override
 public void onClick(View v) {
 // Segundo activity
 Intent intent= new Intent(MainActivity.this,Main2Activity.class);
 // Enviar el dato seleccionado en el Spinner get SelectedItem
 intent.putExtra("Seleccion",String.valueOf(spinner.getSelectedItem()));
 // Ejecutar el Intent
 startActivity(intent);
 }
 });
 }

 @Override
 public void onItemSelected(AdapterView<?> parent, View view, int position, long id) {
 
 }

 @Override
 public void onNothingSelected(AdapterView<?> parent) {

 }
}

Y ahora abrimos el segundo Activity.


import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;

public class Main2Activity extends AppCompatActivity {

 protected void onCreate(Bundle savedInstanceState) {
 super.onCreate(savedInstanceState);
 setContentView(R.layout.activity_main2);
 // Declaramos el elemento TextView
 TextView textView=(TextView) findViewById(R.id.txt_bundle);
// Declaramos la variable Bundle para obtener el valor recuperado
 Bundle bundle=getIntent().getExtras();
// Asignamos el valor a nuestra variable
 String data=bundle.get("Seleccion").toString();
// Colocamos el valor en nuestra TextView
 textView.setText(data);
 }
}


Crear Emulador AVD

Con esto quedaría listo nuestro ejemplo. Creamos un emulador (Aquí) para ver nuestro ejemplo en ejecución.

Android Studio - Spinner Dropdown List
El siguiente Activity.
Android Studio - Spinner Dropdown List
Y esto seria todo. Si tienes alguna duda por favor déjanos tu comentario.

Gracias!

Descargar: Aquí.

Hazlo simple: tan simple como sea posible, pero no más. 
- Albert Einstein

No hay comentarios:

Publicar un comentario

x

Registrate!

Curso Android Español

Curso Kotlin Español

eBook Free Android Studio

Noticias y Eventos

¡Directamente a tu INBOX!

Le enviaremos nuestros recursos gratis. Para obtener nuestro contenido nuevo, únase a nuestra comunidad. No te molestaremos enviando información inútil. ¡No te pierdas ninguna actualización, mantente conectado! Recuerda verificar tu correo electronico.

Ingrese su dirección de correo electrónico:

Entregado por FeedBurner