Як додати елементи до спіннера в Android?


107

Як додати елементи до спінера?


1
Якщо ви хочете динамічно додати елементи до свого списку та зателефонувати на adapter.notifyDataSetChanged ()
Asok Buzz

Відповіді:


144

XML-файл:

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

Файл 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);
    }
}

Дивіться приклад спінера .


7
Хоча це теоретично може відповісти на питання, бажано було б сюди включити істотні частини відповіді та надати посилання для довідки.
Білл Ящірка

використовувати цей android.R.layout.simple_spinner_dropdown_item замість цього android.R.layout.simple_spinner_item це виглядає набагато краще
sai Gorantla

Що таке array_spinner? ім'я масиву - arraySpinner. це орфографічна помилка чи вона повинна бути такою лише>
SurajS

1
Подумайте про додавання adapter.setDropDownViewResource(android.R.layout.simple_spinner_dropdown_item);(раніше, s.setAdapter(adapter);щоб спадне меню виглядало краще.
заборона-геоінженерія

1
@StephenM змінив посилання
pankajagarwal

99

Я знайшов інший варіант: визначення спінера у файлі макета

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

Визначення елементів у файлі array.xml:

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

Посилання на повне джерело коду


Я спробував усі вищевказані методи та кілька інших навчальних посібників, але це я єдиний, який працював на мене. Дуже дякую!
snapplex

Радий допомогти вам @snapplex;)
maxivis

1
Це має бути головна відповідь. Чисто.

30

Спробуйте цей код:

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

Ви також можете додати значення елемента спінера через XML-файл 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>

В 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

Для додавання елемента в Spinner ви можете зробити одне, спробувати створити адаптер, а потім додати / вилучити елементи в адаптер, тож ви можете легко прив’язати цей адаптер до спінера, використовуючи setAdapter() методу.

Ось приклад:

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

ніж за відповідь ур я отримав рішення також тепер я зіткнувся з однією проблемою.

Я хочу взяти вибраний елемент спінера, тобто його положення, як далі, я хочу передати його іншому методу, побачити, що я зробив ... dataspin.setOnItemSelectedListener (новий myitemlistener ());

dataspin - мій об'єкт Spinner

@Override public void onItemSelected (AdapterView <?> Батьків, перегляд подання, int позиція, довгий ідентифікатор) {// TODO Автоматично створений метод stub String p = parent.getItemAtPosition (position) .toString (); int pos = (int) parent.getItemIdAtPosition (позиція); System.out.println ("положення спінера ..." + pos); setSearchView (pos); }

якщо я це зроблю, то предмет не

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

У вашому макеті:

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

але як тоді отримати вибраний товар?
Демотивовано

1
Перший TypeCast у файлі Java. Потім використовуйте спінер Spinner; spinner = findViewById (R.id.spinner); spinner.setOnItemClickListener (новий AdapterView.OnItemClickListener () {@Override public void onItemClick (AdapterView <?> батьківський, вид подання, позиція int, довгий ідентифікатор) {}});
ZIA ANSARI

5

Цей код здебільшого читає об'єкт масиву JSON і перетворює кожну рядок у параметр у спінері, який передається як параметр:

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

Додайте спінер до макета XML, а потім додайте цей код у файл 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

Додайте цей код після оновлення списку

Припустимо:

Ім'я змінної ArrayAdapter <String> - це dataAdapter , а назва змінної List - ключі .

  • dataAdapter.addAll (клавіші);
  • dataAdapter.notifyDataSetChanged ();

1

Щоб додати ще один елемент до Spinner, ви можете:

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

myAdapter.add(myValue);

myAdapter.notifyDataSetChanged();


0

Просто очистити адаптер, додати всі курси та повідомити про зміни, як показано нижче:

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

0

Найпростіший спосіб - це використання бібліотеки прядильних матеріалів: https://github.com/jaredrummler/MaterialSpinner

спочатку додайте до свого проекту:

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

і використовувати так:

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

і код java, що ви можете легко додавати елементи в java:

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();
  }
});
Використовуючи наш веб-сайт, ви визнаєте, що прочитали та зрозуміли наші Політику щодо файлів cookie та Політику конфіденційності.
Licensed under cc by-sa 3.0 with attribution required.