Поместите текстовое поле на панель приложений во Flutter

Я хочу реализовать панель приложений, как показано ниже, где есть текстовое поле и несколько значков:

Поместите текстовое поле на панель приложений во Flutter

Значки можно легко добавить в действие, но как добавить текстовое поле и добавить к нему действие поиска. Доступно множество плагинов панели поиска, но все они занимают всю панель приложения, и нет возможности упомянуть подсказки. Может ли кто-нибудь дать некоторую идею, это будет большим подспорьем для меня.

добавить то, что вы сделали до сих пор

primo 28.05.2019 13:15
Стоит ли изучать PHP в 2023-2024 годах?
Стоит ли изучать PHP в 2023-2024 годах?
Привет всем, сегодня я хочу высказать свои соображения по поводу вопроса, который я уже много раз получал в своем сообществе: "Стоит ли изучать PHP в...
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
В JavaScript одним из самых запутанных понятий является поведение ключевого слова "this" в стрелочной и обычной функциях.
Приемы CSS-макетирования - floats и Flexbox
Приемы CSS-макетирования - floats и Flexbox
Здравствуйте, друзья-студенты! Готовы совершенствовать свои навыки веб-дизайна? Сегодня в нашем путешествии мы рассмотрим приемы CSS-верстки - в...
Тестирование функциональных ngrx-эффектов в Angular 16 с помощью Jest
В системе управления состояниями ngrx, совместимой с Angular 16, появились функциональные эффекты. Это здорово и делает код определенно легче для...
Концепция локализации и ее применение в приложениях React ⚡️
Концепция локализации и ее применение в приложениях React ⚡️
Локализация - это процесс адаптации приложения к различным языкам и культурным требованиям. Это позволяет пользователям получить опыт, соответствующий...
Пользовательский скаляр GraphQL
Пользовательский скаляр GraphQL
Листовые узлы системы типов GraphQL называются скалярами. Достигнув скалярного типа, невозможно спуститься дальше по иерархии типов. Скалярный тип...
1
1
2 848
1
Перейти к ответу Данный вопрос помечен как решенный

Ответы 1

Ответ принят как подходящий

В собственности заголовка, внутри AppBar, вы можете передать виджет, что означает, что вы можете добавить любой компонент, который хотите, например TextField. см. пример ниже:

appBar: AppBar(
        title: TextField(
          decoration: InputDecoration(
            hintText: 'Search',
            prefixIcon: Icon(Icons.search)
          ),
        ),
      ),

Я предлагаю вам обернуть это TextField в GestureDetector, отключить TextField с свойством, называемым enable (установленным в false), и в методе onTap внутри GestureDetector вы можете вызвать метод showSearch().

Чтобы вызвать это showSearch(), вам нужно передать context и searchDelegate, которые являются компонентом, расширяющим класс, проверьте этот пример:

class CustomSearchDelegate extends SearchDelegate {
  @override
  List<Widget> buildActions(BuildContext context) {
    // TODO: implement buildActions
    return null;
  }

  @override
  Widget buildLeading(BuildContext context) {
    // TODO: implement buildLeading
    return null;
  }

  @override
  Widget buildResults(BuildContext context) {
    // TODO: implement buildResults
    return null;
  }

  @override
  Widget buildSuggestions(BuildContext context) {
    // TODO: implement buildSuggestions
    return null;
  }
}

Источник: Реализация поиска во Flutter

Теперь вы можете сделать это:

GestureDetector:
  onTap: () => showSearch(context: context, delegate: CustomSearchScreen()),
  child: ....

Спасибо. Это большая помощь.

dev_android 28.05.2019 15:04

Идея преобразования текстового поля в панель поиска с делегатом поиска. отличная идея. Спасибо

Yash 08.08.2020 22:22

Другие вопросы по теме