Jak dodawać elementy do spinu w Androidzie?


Odpowiedzi:


144

Plik XML:

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

Plik 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);
    }
}

Zobacz przykład przędzarki .


7
Chociaż może to teoretycznie odpowiedzieć na pytanie, lepiej byłoby zawrzeć tutaj zasadnicze części odpowiedzi i podać link do odniesienia.
Bill the Lizard

użyj tego android.R.layout.simple_spinner_dropdown_item zamiast tego android.R.layout.simple_spinner_item wygląda o wiele lepiej
sai Gorantla

Co to jest array_spinner? nazwa tablicy to arraySpinner. czy to błąd w pisowni, czy tylko tak musi być>
SurajS

1
Rozważ dodanie adapter.setDropDownViewResource(android.R.layout.simple_spinner_dropdown_item);(wcześniej, s.setAdapter(adapter);aby menu wyglądało lepiej.
zakaz geoinżynierii

1
@StephenM zmienił link
pankajagarwal

99

Znalazłem inną opcję: definicja przędzarki w pliku układu

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

Definicja pozycji w pliku array.xml:

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

Link do pełnego źródła kodu


Wypróbowałem wszystkie powyższe metody i kilka innych samouczków, ale ten jest jedynym, który działał dla mnie. Dziękuję bardzo!
snapplex,

Cieszę się, że mogę Ci pomóc @snapplex;)
maxivis

1
To powinna być najlepsza odpowiedź. Czysty.

30

Wypróbuj ten kod:

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
        }
    });

Możesz również dodać wartość elementu przędzarki za pomocą pliku xml tablicy String.

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

W 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

Aby dodać element w Spinner, możesz zrobić jedną rzecz, spróbować utworzyć adapter, a następnie dodać / usunąć elementy do adaptera, a następnie możesz łatwo powiązać ten adapter z kołpakiem za pomocą setAdapter()metody.

Oto przykład:

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

Dzięki za odpowiedź ur Mam rozwiązanie również teraz mam do czynienia z jednym problemem.

Chcę pobrać wybraną pozycję przędzarki, tj. Jej pozycję, jak dalej chcę przekazać ją do innej metody, zobacz, co zrobiłem ... dataspin.setOnItemSelectedListener (nowy myitemlistener ());

dataspin to mój obiekt Spinner

@Override public void onItemSelected (AdapterView <?> Nadrzędny, widok widoku, pozycja int, długi id) {// TODO Metoda generowana automatycznie stub String p = parent.getItemAtPosition (pozycja) .toString (); int pos = (int) parent.getItemIdAtPosition (pozycja); System.out.println ("pozycja przędzarki ..." + poz); setSearchView (pos); }

jeśli to zrobię, element spinner nie jest wyświetlany

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

W swoim układzie:

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

ale w jaki sposób otrzymujesz wybrany przedmiot?
Zdemotywowany

1
Pierwszy TypeCast w pliku Java. Następnie użyj przędzarki Spinner; spinner = findViewById (R.id.spinner); spinner.setOnItemClickListener (new AdapterView.OnItemClickListener () {@Override public void onItemClick (AdapterView <?> element nadrzędny, widok widoku, pozycja int, długi identyfikator) {}});
ZIA ANSARI

5

Ten kod w zasadzie odczytuje obiekt tablicy JSON i konwertuje każdy wiersz na opcję w pokrętle, która jest przekazywana jako parametr:

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

Dodaj pokrętło do układu XML, a następnie dodaj ten kod do pliku 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

Dodaj ten kod po zaktualizowaniu listy

Przypuszczać:

Nazwa zmiennej ArrayAdapter <String> to dataAdapter , a nazwa zmiennej List to keys .

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

1

Aby dodać jeszcze jeden przedmiot do Spinnera , możesz:

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

myAdapter.add(myValue);

myAdapter.notifyDataSetChanged();


0

Wystarczy wyczyścić adapter, dodać wszystkie elementy i powiadomić o zmianie, jak poniżej:

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

0

Łatwiejszym sposobem jest użycie biblioteki spinnerów materiałów: https://github.com/jaredrummler/MaterialSpinner

najpierw dodaj do swojego projektu:

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

i użyj w ten sposób:

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

i kod java, dzięki któremu możesz dodawać elementy w java tak łatwo:

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();
  }
});
Korzystając z naszej strony potwierdzasz, że przeczytałeś(-aś) i rozumiesz nasze zasady używania plików cookie i zasady ochrony prywatności.
Licensed under cc by-sa 3.0 with attribution required.