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