Android, как EditText работает как автозаполнение
Я хочу, чтобы мой EditText
работал как AutoComplete
, для этого я пишу в XML файл
android:inputType="textAutoComplete|textAutoCorrect"
но это не работает.
Я работаю с API v2.2, и моя активность расширяет MapActivity
, там я поместил простой EditText
и кнопку с именем "Поиск". поэтому, если мы введем название местоположения в EditText
и нажмем кнопку поиска, значит, оно должно перейти к этому местоположению на карте. Поэтому я хочу, чтобы EditText
работал как AutoComplete
. Как я могу это сделать?
Ответы
Ответ 1
Просто используйте AutoCompleteTextView
вместо обычного EditText
.
Привет-автозаполнение будет полезно.
РЕДАКТИРОВАТЬ: ссылка выше, похоже, истек. Новая страница находится здесь: https://developer.android.com/training/keyboard-input/style#AutoComplete
Ответ 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 + " ";
}
}
}