🧩Hero
Что такое Hero
HeroHero — это виджет, который позволяет создать плавный анимационный переход между экранами при навигации, когда один и тот же элемент (например, изображение, текст, кнопка) встречается на обоих экранах. При переходе из одного экрана в другой элемент будет плавно перемещаться и изменять размеры, создавая эффект "перелета" или "перехода", что делает навигацию более естественной и интерактивной.
Пример использования
В этом примере у нас есть изображение на главном экране, и при нажатии на него оно плавно увеличивается и перемещается на новый экран.

Как работает код
Создание тега
Hero— вFirstScreenмы оборачиваем изображение в виджетHeroи даем ему уникальныйtag(в нашем примере это'imageHero'). Этот жеtagиспользуется наSecondScreen.Переход между экранами — при нажатии на изображение на первом экране выполняется переход на второй экран.
Heroавтоматически создает анимацию, которая перемещает изображение из одной позиции в другую, плавно изменяя его размеры.Уникальный
tag— важно, чтобы у обоих виджетовHero(на обоих экранах) был один и тот жеtag, иначе Flutter не сможет связать их и показать анимацию.
Все настройки Hero
tag
Описание: Уникальный идентификатор, который связывает
Heroэлементы между двумя экранами.Пример:
Применение: Без этого тега анимация не сработает. Теги должны совпадать на обоих экранах.
child
Описание: Виджет, который будет анимирован при переходе.
Пример:
Применение: Это элемент, который перемещается между экранами.
flightShuttleBuilder
Описание: Функция, которая позволяет настроить внешний вид
Heroво время анимации перехода.Пример:
Применение: Позволяет изменить внешний вид анимированного объекта (например, сделать его прозрачным или заменить на другой виджет).
placeholderBuilder
Описание: Функция, возвращающая виджет-заполнитель для
Heroна экране, пока выполняется переход.Пример:
Применение: Показывает элемент-заполнитель, пока основной виджет еще не появился на экране.
transitionOnUserGestures
Описание: Позволяет использовать анимацию
Hero, когда пользователь вручную перетаскивает экран (например, свайпом назад на iOS).Пример:
Применение: Полезно для устройств с жестами навигации, чтобы позволить анимации работать плавно при свайпе.
Итог
Hero — это виджет для создания впечатляющих анимационных переходов между экранами с минимальной настройкой. Он делает переходы между экранами более естественными и привлекательными для пользователя, добавляя глубину и визуальный интерес к вашему приложению.
Last updated