Как добавить элементы в счетчик в 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
Хотя теоретически это может дать ответ на вопрос, было бы предпочтительнее включить сюда основные части ответа и предоставить ссылку для справки.
Bill the Lizard

используйте этот android.R.layout.simple_spinner_dropdown_item вместо этого android.R.layout.simple_spinner_item, он выглядит намного лучше,
сай Горантла

Что такое array_spinner? имя массива - arraySpinner. это орфографическая ошибка или это должно быть только так>
SurajS

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

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 07

Рад помочь вам @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-файл с массивом строк.

<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 (new myitemlistener ());

dataspin - это мой объект Spinner

@Override public void onItemSelected (AdapterView <?> Parent, View view, int position, long id) {// TODO Автоматически сгенерированная заглушка метода 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; spinner = findViewById (R.id.spinner); spinner.setOnItemClickListener (новый AdapterView.OnItemClickListener () {@Override public void onItemClick (AdapterView <?> parent, View view, int position, long id) {}});
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 , а имя переменной списка - keys .

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