¿Cómo agregar elementos a una ruleta en Android?


107

¿Cómo agregar elementos a una ruleta?


1
Si desea agregar elementos dinámicamente a su lista y llame a adapter.notifyDataSetChanged ()
asok Buzz

Respuestas:


144

Archivo XML:

<Spinner
    android:id="@+id/Spinner01"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"/>

Archivo Java:

public class SpinnerExample extends Activity {

    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);

        String[] arraySpinner = new String[] {
            "1", "2", "3", "4", "5", "6", "7"
        };
        Spinner s = (Spinner) findViewById(R.id.Spinner01);
        ArrayAdapter<String> adapter = new ArrayAdapter<String>(this,
                android.R.layout.simple_spinner_item, arraySpinner);
        adapter.setDropDownViewResource(android.R.layout.simple_spinner_dropdown_item);
        s.setAdapter(adapter);
    }
}

Ver ejemplo de ruleta .


7
Si bien esto puede responder teóricamente a la pregunta, sería preferible incluir aquí las partes esenciales de la respuesta y proporcionar el enlace como referencia.
Bill the Lizard

use este android.R.layout.simple_spinner_dropdown_item en lugar de este android.R.layout.simple_spinner_item se ve mucho mejor
sai Gorantla

¿Qué es array_spinner? el nombre de la matriz es arraySpinner. ¿Es un error de ortografía o tiene que ser así solo?>
SurajS

1
Considere agregar adapter.setDropDownViewResource(android.R.layout.simple_spinner_dropdown_item);(antes s.setAdapter(adapter);para que el menú desplegable se vea mejor.
ban-geoengineering

1
@StephenM cambió el enlace
pankajagarwal

99

Encontré otra opción: definición de ruleta en el archivo de diseño

<Spinner android:id="@+id/spinner"
    android:layout_width="fill_parent"
    android:drawSelectorOnTop="true"
    android:prompt="@string/spin"
    android:entries="@array/spinnerItems"
/>

Definición de elementos en el archivo array.xml:

<resources>
    <string-array name="spinnerItems">
        <item>item1</item>
        <item>item2</item>
        <item>item3</item>
        <item>item4</item>
    </string-array>
</resources>

Enlace a la fuente completa del código


Probé todos los métodos anteriores y algunos otros tutoriales, pero este es el único que funcionó para mí. Muchas gracias!
snapplex

Encantado de ayudarte @snapplex;)
maxivis

1
Esta debería ser la mejor respuesta. Limpiar.

30

Prueba este código:

final List<String> list = new ArrayList<String>();
list.add("Item 1");
list.add("Item 2");
list.add("Item 3");
list.add("Item 4");
list.add("Item 5");

final String[] str = {"Report 1", "Report 2", "Report 3", "Report 4", "Report 5"};

final Spinner sp1 = (Spinner) findViewById(R.id.spinner1);
final Spinner sp2 = (Spinner) findViewById(R.id.spinner2);

ArrayAdapter<String> adp1 = new ArrayAdapter<String>(this,
                              android.R.layout.simple_list_item_1, list);
adp1.setDropDownViewResource(android.R.layout.simple_spinner_dropdown_item);
sp1.setAdapter(adp1);

ArrayAdapter<String> adp2 = new ArrayAdapter<String>(this,
                                  android.R.layout.simple_spinner_item, str);
adp2.setDropDownViewResource(android.R.layout.simple_spinner_dropdown_item);
sp2.setAdapter(adp2);

sp1.setOnItemSelectedListener(new OnItemSelectedListener()
    {
        @Override
        public void onItemSelected(AdapterView<?> arg0, View arg1, int position, long id) {
            // TODO Auto-generated method stub
            Toast.makeText(getBaseContext(), list.get(position), Toast.LENGTH_SHORT).show();
        }

        @Override
        public void onNothingSelected(AdapterView<?> arg0) {
            // TODO Auto-generated method stub
        }
    });

sp2.setOnItemSelectedListener(new OnItemSelectedListener()
    {
        @Override
        public void onItemSelected(AdapterView<?> arg0, View arg1, int position, long id) {
            // TODO Auto-generated method stub
            Toast.makeText(getBaseContext(), str[position], Toast.LENGTH_SHORT).show();
        }

        @Override
        public void onNothingSelected(AdapterView<?> arg0) {
            // TODO Auto-generated method stub
        }
    });

También puede agregar el valor del elemento giratorio a través del archivo xml de matriz de cadenas.

<resources>
    <string name="app_name">Spinner_ex5</string>
    <string name="hello_world">Hello world!</string>
    <string name="menu_settings">Settings</string>
    <string name="title_activity_main">MainActivity</string>
    <string-array name="str2">
        <item>Data 1</item>
        <item>Data 2</item>
        <item>Data 3</item>
        <item>Data 4</item>
        <item>Data 5</item>
    </string-array>
</resources>

En mainActivity.java:

final Spinner sp3 = (Spinner) findViewById(R.id.spinner3);
ArrayAdapter<CharSequence> adp3 = ArrayAdapter.createFromResource(this,
                                    R.array.str2, android.R.layout.simple_list_item_1);

adp3.setDropDownViewResource(android.R.layout.simple_spinner_dropdown_item);
sp3.setAdapter(adp3);
sp3.setOnItemSelectedListener(new OnItemSelectedListener()
    {
        @Override
        public void onItemSelected(AdapterView<?> arg0, View arg1, int position, long id) {
            // TODO Auto-generated method stub
            String ss = sp3.getSelectedItem().toString();
            Toast.makeText(getBaseContext(), ss, Toast.LENGTH_SHORT).show();
        }

        @Override
        public void onNothingSelected(AdapterView<?> arg0) {
            // TODO Auto-generated method stub
        }
    });

9

Para agregar un elemento en Spinner, puede hacer una cosa, intentar crear un adaptador y luego agregar / quitar elementos en el adaptador, luego puede vincular fácilmente ese adaptador a Spinner usando el setAdapter()método.

Aquí hay un ejemplo:

spinner.setAdapter(adapter);
adapter.add(item1);
adapter.add(item2);
adapter.add(item3);
adapter.add(item4);
adapter.add(item5);
adapter.notifyDataSetChanged();
spinner.setAdapter(adapter);

Gracias por tu respuesta, obtuve la solución y ahora tengo un problema.

Quiero recuperar el elemento seleccionado de spinner, es decir, su posición, ya que además quiero pasarlo a otro método, mira lo que hice ... dataspin.setOnItemSelectedListener (new myitemlistener ());

dataspin es mi objeto Spinner

@Override public void onItemSelected (AdapterView <?> Parent, View view, int position, long id) {// TODO Método generado automáticamente stub String p = parent.getItemAtPosition (position) .toString (); int pos = (int) parent.getItemIdAtPosition (posición); System.out.println ("posición de la ruleta ..." + pos); setSearchView (pos); }

si hago esto, el elemento giratorio no se muestra

8
<string-array name="array_name">
<item>Array Item One</item>
<item>Array Item Two</item>
<item>Array Item Three</item>
</string-array>

En tu diseño:

<Spinner 
        android:id="@+id/spinner"
        android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        android:drawSelectorOnTop="true"
        android:entries="@array/array_name"
    />

pero entonces, ¿cómo se obtiene el artículo seleccionado?
Desmotivado el

1
Primer TypeCast en un archivo Java. Luego usa Spinner spinner; spinner = findViewById (R.id.spinner); spinner.setOnItemClickListener (nuevo AdapterView.OnItemClickListener () {@Override public void onItemClick (AdapterView <?> parent, View view, int position, long id) {}});
ZIA ANSARI

5

Este código básicamente lee un objeto de matriz JSON y convierte cada fila en una opción en la ruleta que se pasa como parámetro:

public ArrayAdapter<String> getArrayAdapterFromArrayListForSpinner(ArrayList<JSONObject> aArrayList, String aField)
{
    ArrayAdapter<String> aArrayAdapter = new ArrayAdapter<String>(context, android.R.layout.simple_spinner_item);
    aArrayAdapter.setDropDownViewResource(R.layout.multiline_spinner_dropdown_item); //android.R.layout.simple_spinner_dropdown_item
    try {
        for (int i = 0; i < aArrayList.size(); i++)
        {
            aArrayAdapter.add(aArrayList.get(i).getString(aField)); 
        }
    } catch (JSONException e) {
        e.printStackTrace();
        ShowMessage("Error while reading the JSON list");
    }
    return aArrayAdapter;       
}

2

Agregue una ruleta al diseño XML y luego agregue este código al archivo Java:

Spinner spinner;
spinner = (Spinner) findViewById(R.id.spinner1) ;
java.util.ArrayList<String> strings = new java.util.ArrayList<>();
strings.add("Mobile") ;
strings.add("Home");
strings.add("Work");
SpinnerAdapter spinnerAdapter = new SpinnerAdapter(AddMember.this, R.layout.support_simple_spinner_dropdown_item, strings);
spinner.setAdapter(spinnerAdapter);

1

Agregue este código después de actualizar la lista

Suponer:

El nombre de la variable ArrayAdapter <String> es dataAdapter y el nombre de la variable List es keys .

  • dataAdapter.addAll (claves);
  • dataAdapter.notifyDataSetChanged ();

1

Para agregar un elemento más a Spinner , puede:

ArrayAdapter myAdapter = 
  ((ArrayAdapter) mySpinner.getAdapter());

myAdapter.add(myValue);

myAdapter.notifyDataSetChanged();


0

Es solo para borrar el adaptador, agregar todos los itens y notificar el cambio como se muestra a continuación:

  public void show(List<Object> objLIst) {
    adapter.clear();
    adapter.addAll(objLIst);
    adapter.notifyDataSetChanged(); }

0

Una forma más sencilla es utilizar la biblioteca de material spinner: https://github.com/jaredrummler/MaterialSpinner

primero agregue a su proyecto:

compile 'com.jaredrummler:material-spinner:1.2.4'

y use así:

<com.jaredrummler.materialspinner.MaterialSpinner
    android:id="@+id/spinner"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"/>

y código java que puede agregar elementos en java tan fácil:

MaterialSpinner spinner = (MaterialSpinner) findViewById(R.id.spinner);
spinner.setItems("item 1", "item 2", "item 3", "item 4", "item 5");
spinner.setOnItemSelectedListener(new MaterialSpinner.OnItemSelectedListener<String>() {

  @Override public void onItemSelected(MaterialSpinner view, int position, long id, String item) {
    Snackbar.make(view, "Clicked " + item, Snackbar.LENGTH_LONG).show();
  }
});
Al usar nuestro sitio, usted reconoce que ha leído y comprende nuestra Política de Cookies y Política de Privacidad.
Licensed under cc by-sa 3.0 with attribution required.