@hellouxpavel/cssanimation
Version:
A Powerful CSS Animation Library for Advanced Motion Design.
80 lines (66 loc) • 1.66 kB
CSS
/*!
* Module: glitchSliceYank Animation
* Usage: <div class="cssanimation ca__fx-glitchSliceYank">Your Content</div>
*/
/* stylelint-disable */
:root {
--cssanimation-duration: 1s;
--cssanimation-fill-mode: both;
--cssanimation-infinite: infinite;
--cssanimation-backface-visibility: hidden;
--cssanimation-transform-style: preserve-3d;
--cssanimation-will-change: transform, opacity;
--cssanimation-display: inline-block;
--move-distance: -800px;
}
.cssanimation {
animation-duration: var(--cssanimation-duration, 1s);
animation-fill-mode: var(--cssanimation-fill-mode, both);
}
.cssanimation span {
display: var(--cssanimation-display, inline-block);
}
.infinite {
animation-iteration-count: var(--cssanimation-infinite, infinite) ;
}
@media (prefers-reduced-motion: reduce) {
.cssanimation,
.cssanimation span {
animation: none ;
transition: none ;
}
}
/* stylelint-enable */
.ca__fx-glitchSliceYank {
animation: glitchSliceYank 1s infinite steps(2, end);
}
@keyframes glitchSliceYank {
0% {
clip-path: inset(0 0 0 0);
transform: translate(0, 0);
}
15% {
clip-path: inset(10% 0 80% 0);
transform: translateX(-5px);
}
30% {
clip-path: inset(60% 0 25% 0);
transform: translateX(4px);
}
45% {
clip-path: inset(40% 0 50% 0);
transform: translateX(-3px);
}
60% {
clip-path: inset(20% 0 70% 0);
transform: translateX(3px);
}
75% {
clip-path: inset(50% 0 30% 0);
transform: translateX(-2px);
}
100% {
clip-path: inset(0 0 0 0);
transform: translate(0, 0);
}
}