Веб-анимации в деталях

Front-End Friday

Всем Салют!

Меня зовут Алексей

Я веселый Front-end разработчик

Я верстаю сайты

и преподаю в

  1. Зачем анимировать веб
  2. Как работает анимация в браузере:
    заглянем под капот
  3. Методы анимации в вебе: CSS, JS, SVG
  4. Какой метод анимации выбрать
  5. Как правильно анимировать

О чем поговорим

Зачем нам анимировать ВЕБ?

ФАКТЫ

ФАКТ 1

Красота сайта равна его удобству, реальной или потенциальной пользе для посетителя.

 

Стоит рассмотреть интересный частный случай. Сайт с необычным дизайном кажется красивым, хотя очевидной пользы посетителю может не нести. У человека есть шаблон — за необычной обложкой находится необычное содержание. Мы ждем что-то новое. Новизна информации повышает ее потенциальную пользу для нас.

ФАКТ 2

Работа мозга требует значительных ресурсов организма. Люди стремятся свести к минимуму мыслительный процесс. Лучше найти закономерности и сложить их в шаблон. Нам очень приятно, когда кто-то подумал за нас, а мы используем результат.

ФАКТ 3

Интернет интегрирован в повседневную жизнь.

Мы ориентируемся на сайтах не хуже, чем в реальном мире.

Особенности виртуальности стали очевидными, как-будто так было всегда.

ЗАЧЕМ ЭТО НУЖНО?

  1. Мы живем в реальном мире
  2. Природность использования веба
  3. Анимация - это часть хорошего UI
  4. Запоминаемость вашего сайта
  5. Это весело! ( не забываем про веселье :)

Анимация как часть интерфейса

Сравните эти два примера

Резкие изменения сложны для понимания пользователя.

Движение создает понимание

Но "напихав" кучу анимации, все не будет хорошо  

Заглянем "под капот"

или

"В поисках утраченных FPS"

ЛАГ
(Jank)

Встречайте

(плохой парень)

60

frames per second

16.7

ms per frame

Jank («лаг»)

Что делает браузер "за кулисами"

LOADING    RENDERING    PAINTING    DISPLAYING

LOADING 

RENDERING

RENDERING

Layout - компоновка

  • высчитывается геометрия
  • width/height, position и др

PAINTING

RENDERER PROCESS

 MAIN THREAD

 RASTER THREADS

COMPOSITOR THREAD

GPU PROCESS

 GPU THREAD

DISPLAYING

УСПЕХ! *

Хорошая новость

LOADING    RENDERING    PAINTING    DISPLAYING

    RENDERING    PAINTING    DISPLAYING

Меньше работы браузера 

больше FPS

REFLOWS

  • width
  • height
  • margin
  • padding
  • top
  • bottom
  • left
  • right
  • font-size
  • and more...

вызывается при

изменении геометрии

REPAINTS

  • color
  • background-color
  • box-shadow
  • background-position
  • border-radius 
  • and more...

принуждают пиксели

перерисовываться

GPU ACCELERATED

transform       filter*       opacity

*за исключением blur и drop-shadow

IT'S DEMO TIME!

IT'S DEMO TIME!

РЫБНАЯ ВЕЧЕРИНКА!

x 1000

Это все можно глянуть на мобильном

Инструменты для профилирования

  • chrome://inspect (подключение мобильных)
  • Сhrome dev tools
    • frame layer (просмотр слоев)
    • paint debugger (процесс растеризации)
    • animations (контроль анимаций)
    • easing editor (редактирование типа анимации)

Как анимировать ВЕБ

CSS Animation

  1. CSS transitions
  2. CSS animation (keyframes)
  1. Просты
  2. Свободны от основного потока *
  3. Синхронизируются с частотой обновления экрана
  1. Неконтролируемые: только пауза и запуск

JavaScript Animations

  1. Полный контроль
  2. Синхронизируются с частотой обновления экрана*
    (при использовании requestAnimationFrame())
  1. Забивают основной поток

JavaScript Animations: GreenSock (GSAP)

Для полного контроля над анимацией

  • pause()
  • play()
  • seek()
  • reverse()
  • ratio()
  • callback paradise (start, update, finish etc)
  • tween, timeline
  • plugins: css, svg, canvas

Что еще?

Web Animations

  • Собственный поток (как в CSS)
  • Полный контроль (как в JS)

SVG Animation

SVG + GSAP = 

Scroll Animations: ScrollMagic

Какой метод выбрать

Нужен контроль?

Анимация на скролле,
переход в конкретную точку и др.

ДА

JS

Широкая поддержка
браузеров?

ДА

GSAP

НЕТ

CSS

Сложная анимация?

Больше двух состояний, нужна остановка

Keyframes

Transitions

ДА

НЕТ

НЕТ

Web Animations

Как правильно анимировать

Хорошие вопросы

  1. Кто должен думать за анимацию?
  2. Есть ли какие-то принципы/правила/инструкции?
     

Front-end Developer

Designer

или

Front-end Developer

Designer

Принципы анимации

Motion design guidelines

  1. Какая должна быть продолжительность анимации
  2. Какое направление
  3. Easing functions

Вдохновение

Примеры

Loading animations

Homepage animations

Page Transition

Hover animations

Hover animations examples

Navigation and menus

Fixed navigation and menus

Menu links hover

Morphing

Morphing

Story-telling animations

Совсем не "попсовый" параллакс

Анимация элементов форм

Более выразительная обратная связьи взаимодействие

Анимация плейсхолдеров

Анимация плейсхолдеров

Эластичность Добавляет Иллюзию реалистичного движения

Эластичность (SVG)

Эффекты "Motion blur" (SVG фильтры)

и напоследок...

Это Анимации

Анимируйте

Делайте ваши сайты живыми

Спасибо за внимание!

Front-End Friday - Веб-анимации в деталях

By Alexey Kalyuzhnyi

Front-End Friday - Веб-анимации в деталях

“Движение создает понимание”: сегодня анимация является важной частью хорошего UI, а также все больше и больше растущим трендом, поэтому эту тему нужно рассмотреть в деталях.

  • 1,046