ikonkov
@ikonkov

Как плавно увеличить скорость анимации?

Привет Хабр! Неожиданно столкнулся с проблемой, уже казалось что ничего неизведанного в CSS не осталось, однако...
Есть элемент который крутится по кругу с помощью CSS анимации
@keyframes rotation {
    from {
        transform: rotate(0deg);
    }
    to {
        transform: rotate(359deg);
    }
}

.circle {
        width: 188px;
        height: 188px;
        background: url(../imgs/youtube-circle.svg);
        animation-name: rotation;
        animation-timing-function: linear;
        animation-duration: 20s;
        animation-iteration-count: infinite;
        position: absolute;
        top: 0;
        left: 0;
        transition: all .3s ease;
}

.circle:hover {
    animation-duration: 5s;
}


Необходимо чтобы при наведении скорость увеличивалось, ускоряю уменьшением animation-duration. Но при наведении перед изменением скорости происходит скачок, как будто сбрасывается transform на исходное значение.
Вот как это происходит https://disk.yandex.ru/i/U9SwafVorEFhOw
Возможно ли как то плавно ускорить кручение избежав этого рывка
  • Вопрос задан
  • 244 просмотра
Решения вопроса 1
RAX7
@RAX7
Свойство animation-duration неанимируемое. И да, придется писать костыль на js
Ответ написан
Пригласить эксперта
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Похожие вопросы
22 нояб. 2024, в 06:06
1500 руб./в час
22 нояб. 2024, в 06:04
1 руб./за проект
22 нояб. 2024, в 03:54
1500 руб./за проект