- AutoCompieteTextview и MultiAutoCompleteTextView
- AutoCompleteTextView
- Пример для Kotlin
- Стилизация
- Место вывода выпадающего списка
- Динамический подбор
- Собственный адаптер для выпадающего списка подсказок
- MultiAutoCompleteTextView
- Библиотеки
- Android AutoCompleteTextView с подсказками из веб-сервиса
- Шаг 1 – реализация кастомного адаптера для AutoCompleteTextView
- Шаг 2 – создание XML-разметки для строки подсказки
- Шаг 3 – добавление задержки перед отправкой запроса на сервер
- Шаг 4 – добавление анимированного прогресса к полю ввода
- Шаг 5 – соединение компонентов
- Android AutoCompleteTextView with MVVM and Databinding in Kotlin
- AutoCompleteTextView in Kotlin
- Different attributes of AutoCompleteText widget –
- Add the AutoCompleteTextView in activity_main.xml
- Dynamic AutoCompleteTextView in Kotlin
- Use LinearLayout in activity_main.xml file
AutoCompieteTextview и MultiAutoCompleteTextView
AutoCompleteTextView
Компонент AutoCompleteTextView — это текстовое поле с автозаполнением и возможностью редактирования вводимого текста. Использование компонента удобно в том случае, когда требуется ускорить процесс ввода текста.
На панели инструментов элемент можно найти в разделе Texts.
AutoCompleteTextView является подклассом EditText, поэтому доступны все возможности форматирования и редактирования текста родительского класса.
Дополнительно, у AutoCompleteTextView есть свойство completionThreshold для указания минимального числа символов, которое должен ввести пользователь, чтобы включилась функция автозаполнения. Для связывания с данными необходимо задействовать адаптер, содержащий список значений через метод setAdapter().
Для упрощения создадим статический массив строк с именами котов и свяжем его через адаптер с нашим элементом в Java-коде. В реальных приложениях лучше использовать строковые ресурсы.
Запустите пример и начинайте вводить имена. Если вы напечатаете два символа му, то появится выпадающий список с вариантами слов для продолжения. Дальше текст можно не набирать, а просто коснуться нужного варианта и готовый текст сразу вставится в текстовое поле. Вот так все просто и работает.
Пример с строковыми ресурсами (res/values/string.xml).
Получаем массив из ресурсов и используем в адаптере.
Пример для Kotlin
Напишем аналогичный пример на Kotlin и добавим несколько новых слушателей.
Стилизация
Подготовим тему в styles.xml:
Подключим тему к компоненту.
Место вывода выпадающего списка
По умолчанию выпадающий список подсказок выводится сразу под текстовым полем. Но можно переопределить это поведение через атрибут android:dropDownAnchor, указав нужный идентификатор компонента.
Добавим кнопку под текстовым полем и будем выводить выпадающий список под кнопкой.
Динамический подбор
В примере используется готовый набор слов для подстановки. Можно модифицировать программу, чтобы список слов был динамическим. Когда пользователь напечатает новое слово и нажмёт ОК, то проверяем наличие данного слова в массиве. Если такого слова нет, то добавляем в массив. Для решения данной задачи обычный строковый массив нам не подойдёт, будем использовать List .
Собственный адаптер для выпадающего списка подсказок
Можно настроить свой адаптер для вывода подсказок, используя интерфейсы Filterable и ListAdapter. Можно наследоваться от ArrayAdapter, который уже имеет эти интерфейсы.
Попробуйте реализовать пример самостоятельно и пришлите его мне.
MultiAutoCompleteTextView
На панели инструментов компонент можно найти в том же разделе Texts.
Использование компонента удобно в том случае, когда требуется ускорить процесс ввода текста.
MultiAutoCompleteTextView — это текстовое поле с автозаполнением и возможностью редактирования вводимого текста, расширяющее функциональность AutoCompieteTextview, который может показывать автозаполнение для каждой из подстрок текста, разделенных знаком пунктуации. Разделитель задается явно вызовом метода setTokenizer().
MultiAutoCompleteTextView является подклассом EditText и AutoCompleteTextView, поэтому доступны все возможности форматирования и редактирования текста родительских классов, описанных выше.
Пример практически не будет отличаться от предыдущего. Главная особенность — можно задать строковый массив в виде строк, разделенных запятой, например, так:
Теперь, при наборе первых букв, будет выводиться не одно слово, а сразу пара слов.
Библиотеки
EmailAutoCompleteTextView — данные берутся из списка контактов вашего телефона
Источник
Android AutoCompleteTextView с подсказками из веб-сервиса
Для одного из своих Android-приложений Book Tracker я реализовал кастомный AutoCompleteTextView с подсказками для названий книг, которые динамически подгружаются с Google Books по мере ввода названия книги.
Задача перед компонентом стояла следующая:
- Загрузка данных должна осуществляться в отдельном потоке, чтобы не блокировать UI-поток;
- Загрузка подсказок должна начинаться только, если пользователь приостанавливает набор (чтобы предотвратить отправку множества запросов к серверу после каждого введенного символа);
- Подсказки должны загружаться, если пользователь ввел строку некоторой минимальной длины (нет смысла начинать загрузку данных для строки из двух или трех символов);
- При запросе к серверу в правой части поля должен быть показан анимированный прогресс, чтобы информировать пользователя о загрузке.
Финальный результат:
Шаг 1 – реализация кастомного адаптера для AutoCompleteTextView
Адаптер для AutoCompleteTextView – это ключевой компонент, в котором происходит загрузка и хранение подсказок. BookAutoCompleteAdapter реализовывает интерфейс Filterable, чтобы перехватывать ввод пользователя из AutoCompleteTextView и передавать его в качестве поискового запроса в веб-сервис. Единственный метод интерфейса Filterable – это getFilter(), который должен возвращать экземпляр класса Filter, осуществляющий загрузку и публикацию данных. Наследники класса Filter должны реализовать два метода: performFiltering(CharSequence constraint) и publishResults(CharSequence constraint, Filter.FilterResults results).
Метод performFiltering будет вызван в отдельном потоке автоматически, поэтому нет необходимости создавать и запускать новый поток вручную. Это уже сделано за разработчика в классе Filter. Метод publishResults же вызывается в UI-потоке, чтобы опубликовать результаты на экране.
BookAutoCompleteAdapter.java
Шаг 2 – создание XML-разметки для строки подсказки
Когда подсказки загружены, будет показан выпадающий список с результатами. Каждая строка состоит из двух элементов: названия книги и имени автора.
simple_dropdown_item_2line.xml
Шаг 3 – добавление задержки перед отправкой запроса на сервер
При использовании стандартного AutoCompleteTextView запрос инициируется после каждого введенного символа. Если пользователь набирает текст без остановки, подсказки, полученные для предыдущего запроса, могут оказаться неактуальными при вводе каждого последующего символа. Это порождает ненужные и ресурсоемкие обращения к серверу, появляется шанс превышения лимитов API, которые может иметь веб-сервис, а также возвращаются устаревшие результаты, загруженные для предыдущего состояния строки запроса.
Для того, чтобы избежать вышеописанных проблем, необходимо добавить небольшую задержку между вводом символа и отправкой запроса на сервер. Если во время этой задержки человек вводит следующий символ, запрос для предыдущей строки отменяется и переносится вперед на время задержки. Если же пользователь не изменяет строку на протяжении этого времени, запрос отправляется на сервер.
Чтобы реализовать вышеописанное поведение, нужно создать кастомную реализацию AutoCompleteTextView и переопределить метод performFiltering(CharSequence text, int keyCode). Поле mAutoCompleteDelay определяет время в миллисекундах, после которого запрос будет отправлен на сервер, если пользователь не ввел новых символов.
DelayAutoCompleteTextView.java
Шаг 4 – добавление анимированного прогресса к полю ввода
Очень важно обеспечить обратную связь, когда пользователь набирает текст. Необходимо показать анимированный прогресс в поле ввода названия книги. Прогресс нужен для того, чтобы проинформировать человека о том, что подсказки загружаются и будут скоро отображены. Таким образом пользователь будет осведомлен и сможет подождать пока они не появятся. Без такой обратной связи человек может даже не подозревать о том, что поле может показывать подсказки.
Элементы ProgressBar и DelayAutoCompleteTextView необходимо поместить во FrameLayout и выровнять ProgressBar по правой стороне родительской группы. Также необходимо изначально скрыть прогресс с помощью установки атрибута android:visibility=«gone».
ProgressBar подключается к DelayAutoCompleteTextView с помощью метода setLoadingIndicator(ProgressBar view) последнего. Видимость элемента прогресса устанавливается в View.VISIBLE, когда происходит загрузка подсказок и в View.GONE, когда загрузка завершена.
Шаг 5 – соединение компонентов
Теперь, когда все части готовы, необходимо соединить их вместе:
bookTitle.setThreshold(4) определяет минимальное количество символов, которые должен ввести пользователь, чтобы были показаны подсказки.
bookTitle.setLoadingIndicator((ProgressBar) findViewById(R.id.progress_bar)) соединяет ProgressBar с DelayAutoCompleteTextView.
Важно установить OnItemClickListener для DelayAutoCompleteTextView и присвоить правильное значение полю ввода. Если этого не сделать, результат вызова метода toString() выбранного объекта будет вставлен в поле вместо названия книги.
Источник
Android AutoCompleteTextView with MVVM and Databinding in Kotlin
Our code example for today is about a very useful Android widget called AutocompleteTextView. Specifically, we’ll code an Android AutocompleteTextView with API data as drop-down suggestions.
If you’re not yet familiar with AutocompleteTextView, this widget looks like an EditText but shows completion suggestions automatically while the user is typing. The list of suggestions is displayed in a drop-down menu from which the user can choose an item to replace the content of the edit box.
Let’s start from app build.gradle. Add below dependencies in app build.gradle.
And in android block enable data binding.
Add AutoCompleteTextView in your layout file.
Now let’s build our ViewModel. We will add MutableLiveData and MediatorLiveData to an observer the changes of AutoCompleteTextView. I used the GitHub API to search the user.
Now let’s set up our API service using Retrofit.
And now the last step is to setup the adapter to AutoCompleteTextView.
That’s it. Now here is the result.
You can download code from the GitHub repository.
If you liked this post, kindly give me some claps and follow me for more posts like this one. Be sure to leave a comment if you have any thoughts or questions.
Источник
AutoCompleteTextView in Kotlin
Android AutoCompleteTextView is an editable text view which shows a list of suggestions when user starts typing text. When a user starts typing, a dropdown menu will be there based on the entered characters, defined in the threshold limit and the user can choose an item from the list to replace the text.
The AutoCompleteTextView is a subclass of EditText class so we can easily inherit all the properties of EditText as per our requirements.
The dropdown list will be obtained using the data adaptor and these suggestions will be appeared only after entering the minimum number of characters defined in the Threshold limit. The Threshold limit is used to define the minimum number of characters the user must type to see the dropdown list of suggestions.
In android, we can create an AutoCompleteTextView control in two ways either manually in an XML file or create it in the Activity file programmatically.
First we create a new project by following the below steps:
- Click on File, then New =>New Project.
- After that include the Kotlin support and click on next.
- Select the minimum SDK as per convenience and click next button.
- Then select the Empty activity =>next =>finish.
Different attributes of AutoCompleteText widget –
XML Attributes | Description |
---|---|
android:id | Used to uniquely identify the control. |
android:gravity | Used to specify how to align the text like left, right, center, top, etc. |
android:text | Used to set the text. |
android:textSize | Used to set the size of the text. |
android:textStyle | Used to set the style of the text like bold, italic. |
android:background | Used to set background color of the Text View. |
android:hint | Used to set display hint text in the Text View. |
android:maxHeight | Used to set maximum height of the Text view. |
android:maxWidth | Used to set maximum width of the Text view. |
android:padding | Used to set the padding from left, right, top and bottom. |
Add the AutoCompleteTextView in activity_main.xml
In this file, we will add the AutoCompleteTextView and Button widget and set their attributes so that it can be accessed in the kotlin file.
Источник
Dynamic AutoCompleteTextView in Kotlin
Android AutoCompleteTextView is an editable text view which shows a list of suggestions when user starts typing text. When a user starts typing, a dropdown menu will be there based on the entered characters, defined in threshold limit and user can choose an item from list to replace the text.
The AutoCompleteTextView is a subclass of EditText class so we can easily inherit all the properties of EditText as per our requirements.
The dropdown list will be obtained suing data adaptor and these suggestions will be appeared only after entering the minimum number characters defined in the Threshold limit. The Threshold limit is used to define the minimum number of characters the user must type to see the dropdown list of suggestions.
In android, we can create a AutoCompleteTextView control in two ways either manually in XML file or create it in Activity file programmatically.
First we create a new project by following the below steps:
- Click on File, then New =>New Project.
- After that include the Kotlin support and click on next.
- Select the minimum SDK as per convenience and click next button.
- Then select the Empty activity =>next =>finish.
Use LinearLayout in activity_main.xml file
In this file, we only use the LinearLayout and set it attributes.
Источник