Подтвердить что ты не робот

Android, как EditText работает как автозаполнение

Я хочу, чтобы мой EditText работал как AutoComplete, для этого я пишу в XML файл

android:inputType="textAutoComplete|textAutoCorrect"

но это не работает.

Я работаю с API v2.2, и моя активность расширяет MapActivity, там я поместил простой EditText и кнопку с именем "Поиск". поэтому, если мы введем название местоположения в EditText и нажмем кнопку поиска, значит, оно должно перейти к этому местоположению на карте. Поэтому я хочу, чтобы EditText работал как AutoComplete. Как я могу это сделать?

4b9b3361

Ответ 2

Сначала преобразуйте ваш EditText->AutoCompleteTextView

Затем свяжите ваш XML файл с AutoCompleteTextView используя ArrayAdapter

Предположим, что созданный вами string-array XML называется list_of_countries после чего он может быть связан с вашим AutoCompleteTextView следующим образом:

String[] countries = getResources().getStringArray(R.array.list_of_countries);
ArrayAdapter<String> adapter = new ArrayAdapter<String>(this,android.R.layout.simple_list_item_1,countries);
actv.setAdapter(adapter);

Ответ 3

Я использую этот код:

enter image description here

1) На AndroidManifest.xml

<uses-permission android:name="android.permission.GET_ACCOUNTS"></uses-permission>

2) В макете XML вы должны использовать AutoCompleteTextView вместо EditText.

<AutoCompleteTextView
    android:id="@+id/autoCompleteTextView1"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:ems="10"
    android:text="AutoCompleteTextView" />

3) Используйте это в файле активности

private ArrayAdapter<String> getEmailAddressAdapter(Context context) {
    Account[] accounts = AccountManager.get(context).getAccounts();
    String[] addresses = new String[accounts.length];
    for (int i = 0; i < accounts.length; i++) { 
        addresses[i] = accounts[i].name;
    }
    return new ArrayAdapter<String>(context, android.R.layout.simple_dropdown_item_1line, addresses);
}

4) О создании деятельности:

AutoCompleteTextView autoCompleteTextView1 = (AutoCompleteTextView) findViewById(R.id.autoCompleteTextView1);
autoCompleteTextView1.setAdapter(getEmailAddressAdapter(this));

Ответ 4

По умолчанию ArrayAdapter фильтрует только первые символы. Если вы хотите увидеть также слова, которые содержат ключевое слово поиска, вам нужно использовать настраиваемый ArrayAdapter и переопределить его методы getView и getFilter. Взгляните на полное решение, которое я представил в другом вопросе StackOverflow: fooobar.com/questions/224283/...

Ответ 5

Этот код для настроек изменения MultiAutoCompleteTextView

ArrayAdapter<String> adapter = new ArrayAdapter<String>(this,android.R.layout.simple_list_item_1,codeKeyWords);
MultiAutoCompleteTextView autoCompleteTextView1 = (MultiAutoCompleteTextView) findViewById(R.id.autoCompleteTextView1);
autoCompleteTextView1.setAdapter(adapter);
autoCompleteTextView1.setThreshold(1);
autoCompleteTextView1.setTokenizer(new this.CommaTokenizer());

И ниже этого кода для создания разделяющих слов с помощью пробела char и \n charactes.. (Почему нам нужен этот код? Потому что Normal multiAutoComplete.setTokenizer(new MultiAutoCompleteTextView.CommaTokenizer()); нравится и он делает разделение слов символом ,, но наш код поможет вам сделать это разделение на эти символы '' и '\n')

/**
         * This simple Tokenizer can be used for lists where the items are
         * separated by a comma and one or more spaces.
         */
    public static class CommaTokenizer implements Tokenizer {
        public int findTokenStart(CharSequence text, int cursor) {
            int i = cursor;

            while (i > 0 && text.charAt(i - 1) != ' ') {
                i--;
            }
            while (i < cursor && text.charAt(i) == '\n') {
                i++;
            }

            return i;
        }

        public int findTokenEnd(CharSequence text, int cursor) {
            int i = cursor;
            int len = text.length();

            while (i < len) {
                if (text.charAt(i) == '\n') {
                    return i;
                } else {
                    i++;
                }
            }

            return len;
        }

        public CharSequence terminateToken(CharSequence text) {
            int i = text.length();

            while (i > 0 && text.charAt(i - 1) == ' ') {
                i--;
            }

            if (i > 0 && text.charAt(i - 1) == ' ') {
                return text;
            } else {
                if (text instanceof Spanned) {
                    SpannableString sp = new SpannableString(text + "\n");
                    TextUtils.copySpansFrom((Spanned) text, 0, text.length(),
                                            Object.class, sp, 0);
                    return sp;
                } else {
                    return text + " ";
                }
            }
        }