css властивість animation-timing-function
Властивість animation-timing-function визначає криву швидкості анімації кожного циклу між ключовими кадрами. В якості значень для властивості використовуються часові функції додані в CSS3.
Вона являє собою математичну функцію, яка показує, як швидко з часом змінюється значення властивості. Початкова точка має координати 0.0, 0.0, кінцева - 1.0, 1.0, при цьому функція по осі ординат може перевищувати ці значення в більшу чи меншу сторону.
На відмінну від @keyframe ця властивість впливає лише на демонстрацію циклів між ключовими кадрами, а не на анімацію цілком!
Наприклад, використовуючи часову функцію ease-in-out анімація буде повільно починатися, пришвидшуватися та повільно закінчуватися. І так кожен цикл демонстрації. Якщо animation-timing-function задана тільки для блоку @keyframe, то й впливає вона лише на цей ключовий кадр. В протилежному випадку властивість визначає криву швидкості всіх кадрів анімації.
На цьому прикладі ми бачимо два елементи. Для одного задана крива швидкості Безьє, для другого - залишено значення без задання linear, тобто однакову швидкість протягом кожного циклу:

| Нотатка: | Рекомендується використовувати універсальну властивість |
Синтаксис
animation-timing-function: linear|ease|ease-in|ease-out|ease-in-out|step-start|step-end|steps(int,start|end)|cubic-bezier(n,n,n,n)|initial|inherit;
Властивість animation-timing-function може отримувати 11 значень:
linearОднакова швидкість від початку і до кінця
easeАнімація починається повільно, потім прискорюється і до кінця руху знову сповільнюється. Аналогічно
cubic-bezier (0.25,0.1,0.25,1)ease-inАнімація повільно починається, до кінця прискорюється. Аналогічно
cubic-bezier (0.42,0,1,1)ease-outАнімація починається швидко, до кінця сповільнюється. Аналогічно
cubic-bezier (0,0,0.58,1)ease-in-outАнімація починається і закінчується повільно. Аналогічно
cubic-bezier (0.42,0,0.58,1)step-endЯк такої анімації немає. Стильові властивості відразу ж приймають кінцеве значення
step-startЯк такої анімації немає. Стильові властивості знаходяться в початковому значенні заданий час, потім відразу ж приймають кінцеве значення
steps(int,start|end)Ступінчаста функція, що має задане число кроків.
animation-timing-function: steps(<число>, start | end)- <число> - ціле число більше нуля;
- start - задає напівбезперервна знизу функцію;
- end - задає напівбезперервна зверху функцію
cubic-bezier(n,n,n,n)Задає функцію руху у вигляді кривої Безьє
initialВстановлює властивість у значення без задання
inheritВказує на спадковість властивості від свого батьківського елемента
| Значення без задання: | ease |
|---|---|
| Наслідує: | Ні |
| Анімується: | Ні |
| JavaScript синтаксис: | object.style.animationTimingFunction="linear" |
Переглядачі
| Переглядач | ||||||
|---|---|---|---|---|---|---|
| animation-timing-function | 43.0 |
10.0 |
16.0 |
9.0 |
12.10 |
12.0 |
| Переглядач | |||
|---|---|---|---|
| animation-timing-function | 2.0 -webkit- |
16.0 |
9.2 |
Мобільних переглядачів ще не додано.
Приклади
Демонстрації різних значень властивості
Простий приклад дії анімації
Вказує, що анімація буде тривати з одною швідкістю
div {
-webkit-animation-timing-function: linear; /* Chrome, Safari, Opera */
animation-timing-function: linear;
}
