Учебное пособие по примерам Android AutoCompleteTextView
AutocompleteTextView — это редактируемое текстовое представление, которое автоматически отображает предложения по завершению, пока пользователь печатает в приложениях для Android. В этом руководстве мы реализуем Android AutoCompleteTextView в нашем приложении, используя ArrayAdapter
для определения списка предложений.
Обзор Android AutoCompleteTextView
AutoCompleteTextView — это компонент, используемый для отображения предложений при написании в редактируемом текстовом поле. Список предложений отображается в раскрывающемся меню, из которого пользователь может выбрать нужный элемент. Список предложений получается от адаптера и появляется только после того количества символов, которое указано в пороге. Чтобы использовать поле AutoCompleteThreshold, его необходимо определить в макете xml следующим образом:
<AutoCompleteTextView
android:id="@+id/autoCompleteTextView"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignParentTop="true"
android:layout_centerHorizontal="true"
android:layout_marginTop="65dp"
android:ems="10" >
Примечание. android:ems или setEms(x) устанавливает ширину TextView, чтобы она соответствовала тексту, состоящему из x M букв, независимо от фактического расширения текста и размера текста. Некоторые важные методы списка автозаполнения приведены ниже:
- getAdapter(): этот метод возвращает фильтруемый адаптер списка, используемый для автоматического завершения.
- getCompletionHint(): этот метод возвращает необязательный текст подсказки, отображаемый в нижней части списка соответствия.
- getDropDownAnchor(): этот метод возвращает идентификатор представления, к которому прикреплен раскрывающийся список автозаполнения.
- getListSelection(): этот метод возвращает позицию выбора раскрывающегося списка, если таковая имеется.
- isPopupShowing(): этот метод указывает, отображается ли всплывающее меню.
- setText(CharSequence text, boolean filter): этот метод задает текст, но может отключить фильтрацию
- showDropDown(): этот метод отображает раскрывающийся список на экране.
Метод setAdapter используется для установки адаптера autoCompleteTextView. Давайте перейдем к части кодирования.
Структура проекта Android AutoCompleteTextView
Пример кода Android AutoCompleteTextView
Макет MainActivity определяется следующим образом. activity_main.xml
<RelativeLayout xmlns:android="https://schemas.android.com/apk/res/android"
xmlns:tools="https://schemas.android.com/tools" android:layout_width="match_parent"
android:layout_height="match_parent" android:paddingLeft="@dimen/activity_horizontal_margin"
android:paddingRight="@dimen/activity_horizontal_margin"
android:paddingTop="@dimen/activity_vertical_margin"
android:paddingBottom="@dimen/activity_vertical_margin" tools:context=".MainActivity">
<TextView
android:id="@+id/textView"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignParentLeft="true"
android:layout_alignParentTop="true"
android:layout_marginTop="15dp"
android:text="Name a fruit from (Apple Banana Cherry Date Grape Kiwi Mango Pear)" />
<AutoCompleteTextView
android:id="@+id/autoCompleteTextView"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignParentLeft="true"
android:layout_below="@+id/textView"
android:layout_marginLeft="36dp"
android:layout_marginTop="17dp"
android:ems="10"
android:text="">
<requestFocus />
</AutoCompleteTextView>
</RelativeLayout>
MainActivity.java определен ниже.
package com.journaldev.autocomplete;
import android.app.Activity;
import android.graphics.Color;
import android.os.Bundle;
import android.widget.ArrayAdapter;
import android.widget.AutoCompleteTextView;
public class MainActivity extends Activity {
String[] fruits = {"Apple", "Banana", "Cherry", "Date", "Grape", "Kiwi", "Mango", "Pear"};
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
//Creating the instance of ArrayAdapter containing list of fruit names
ArrayAdapter<String> adapter = new ArrayAdapter<String>
(this, android.R.layout.select_dialog_item, fruits);
//Getting the instance of AutoCompleteTextView
AutoCompleteTextView actv = (AutoCompleteTextView) findViewById(R.id.autoCompleteTextView);
actv.setThreshold(1);//will start working from first character
actv.setAdapter(adapter);//setting the adapter data into the AutoCompleteTextView
actv.setTextColor(Color.RED);
}
}
Скачать проект Android AutoCompleteTextView