Android, как EditText работает как автозаполнение - PullRequest
35 голосов
/ 27 июня 2011

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

android:inputType="textAutoComplete|textAutoCorrect"

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

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

Ответы [ 5 ]

50 голосов
/ 27 июня 2011

Просто используйте AutoCompleteTextView вместо обычного EditText.

hello-autocomplete будет полезно.

РЕДАКТИРОВАТЬ: ссылка выше, похоже, истек. Новая страница здесь: https://developer.android.com/training/keyboard-input/style#AutoComplete

15 голосов
/ 07 июня 2015

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

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

. Предположим, что созданный вами XML string-array назван 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);
9 голосов
/ 12 октября 2016

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

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) Для действия onCreate:

AutoCompleteTextView autoCompleteTextView1 = (AutoCompleteTextView) findViewById(R.id.autoCompleteTextView1);
autoCompleteTextView1.setAdapter(getEmailAddressAdapter(this));
2 голосов
/ 18 мая 2016

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

0 голосов
/ 22 марта 2017

Этот код для изменения настроек 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());

И ниже этого кода для разделения слов на пробел и \ n символов .. (Почемунам нужен этот код? Потому что 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 + " ";
                }
            }
        }
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...