Spaces:
Running
Running
# tween.js | |
JavaScript tweening engine for easy animations, incorporating optimised Robert Penner's equations. | |
[![NPM Version][npm-image]][npm-url] | |
[![NPM Downloads][downloads-image]][downloads-url] | |
[![Travis tests][travis-image]][travis-url] | |
[![Flattr this][flattr-image]][flattr-url] | |
[![CDNJS][cdnjs-image]][cdnjs-url] | |
```javascript | |
var box = document.createElement('div'); | |
box.style.setProperty('background-color', '#008800'); | |
box.style.setProperty('width', '100px'); | |
box.style.setProperty('height', '100px'); | |
document.body.appendChild(box); | |
// Setup the animation loop. | |
function animate(time) { | |
requestAnimationFrame(animate); | |
TWEEN.update(time); | |
} | |
requestAnimationFrame(animate); | |
var coords = { x: 0, y: 0 }; // Start at (0, 0) | |
var tween = new TWEEN.Tween(coords) // Create a new tween that modifies 'coords'. | |
.to({ x: 300, y: 200 }, 1000) // Move to (300, 200) in 1 second. | |
.easing(TWEEN.Easing.Quadratic.Out) // Use an easing function to make the animation smooth. | |
.onUpdate(function() { // Called after tween.js updates 'coords'. | |
// Move 'box' to the position described by 'coords' with a CSS translation. | |
box.style.setProperty('transform', 'translate(' + coords.x + 'px, ' + coords.y + 'px)'); | |
}) | |
.start(); // Start the tween immediately. | |
``` | |
[Test it with CodePen](https://codepen.io/mikebolt/pen/zzzvZg) | |
## Installation | |
Download the [library](https://raw.githubusercontent.com/tweenjs/tween.js/master/src/Tween.js) and include it in your code: | |
```html | |
<script src="js/Tween.js"></script> | |
``` | |
You can also reference a CDN-hosted version in your code, thanks to cdnjs. For example: | |
```html | |
<script src="https://cdnjs.cloudflare.com/ajax/libs/tween.js/16.3.5/Tween.min.js"></script> | |
``` | |
See [tween.js](https://cdnjs.com/libraries/tween.js/) for more versions. | |
### More advanced users might want to... | |
#### Use `npm` | |
```bash | |
npm install @tweenjs/tween.js | |
``` | |
Then include the Tween.js module with the standard node.js `require`: | |
```javascript | |
var TWEEN = require('@tweenjs/tween.js'); | |
``` | |
And you can use Tween.js as in all other examples--for example: | |
```javascript | |
var t = new TWEEN.Tween( /* etc */ ); | |
t.start(); | |
``` | |
You will need to use a tool such as `browserify` to convert code using this style into something that can be run in the browser (browsers don't know about `require`). | |
#### Use `bower` | |
```bash | |
bower install @tweenjs/tweenjs --save | |
``` | |
or install an specific tag. They are git tags, and you can run `git tag` in the command line for a list if you have cloned the repository locally, or you can also check out the list in the [tween.js tags page](https://github.com/tweenjs/tween.js/tags). For example, to install `v16.3.0`: | |
```bash | |
bower install @tweenjs/tweenjs#v16.3.0 | |
``` | |
Then reference the library source: | |
```html | |
<script src="bower_components/@tweenjs/tweenjs/src/Tween.js"></script> | |
``` | |
## Features | |
* Does one thing and one thing only: tween properties | |
* Doesn't take care of CSS units (e.g. appending `px`) | |
* Doesn't interpolate colours | |
* Easing functions are reusable outside of Tween | |
* Can also use custom easing functions | |
## Documentation | |
* [User guide](./docs/user_guide.md) | |
* [Contributor guide](./docs/contributor_guide.md) | |
* [Tutorial](http://learningthreejs.com/blog/2011/08/17/tweenjs-for-smooth-animation/) using tween.js with three.js | |
* Also: [libtween](https://github.com/jsm174/libtween), a port of tween.js to C by [jsm174](https://github.com/jsm174) | |
* Also: [es6-tween](https://github.com/tweenjs/es6-tween), a port of tween.js to ES6/Harmony by [dalisoft](https://github.com/dalisoft) | |
* [Understanding tween.js](https://mikebolt.me/article/understanding-tweenjs.html) | |
## Examples | |
<table> | |
<tr> | |
<td> | |
<a href="http://tweenjs.github.io/tween.js/examples/12_graphs_custom_functions.html"> | |
<img src="./assets/examples/03_graphs.png" alt="Custom functions" /> | |
</a> | |
</td> | |
<td> | |
Custom functions<br /> | |
(<a href="examples/12_graphs_custom_functions.html">source</a>) | |
</td> | |
<td> | |
<a href="http://tweenjs.github.io/tween.js/examples/11_stop_all_chained_tweens.html"> | |
<img src="./assets/examples/11_stop_all_chained_tweens.png" alt="Stop all chained tweens" /> | |
</a> | |
</td> | |
<td> | |
Stop all chained tweens<br /> | |
(<a href="examples/11_stop_all_chained_tweens.html">source</a>) | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="http://tweenjs.github.io/tween.js/examples/10_yoyo.html"> | |
<img src="./assets/examples/10_yoyo.png" alt="Yoyo" /> | |
</a> | |
</td> | |
<td> | |
Yoyo<br /> | |
(<a href="examples/10_yoyo.html">source</a>) | |
</td> | |
<td> | |
<a href="http://tweenjs.github.io/tween.js/examples/09_relative_values.html"> | |
<img src="./assets/examples/09_relative.png" alt="Relative values" /> | |
</a> | |
</td> | |
<td> | |
Relative values<br /> | |
(<a href="examples/09_relative_values.html">source</a>) | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="http://tweenjs.github.io/tween.js/examples/08_repeat.html"> | |
<img src="./assets/examples/08_repeat.png" alt="Repeat" /> | |
</a> | |
</td> | |
<td> | |
Repeat<br /> | |
(<a href="examples/08_repeat.html">source</a>) | |
</td> | |
<td> | |
<a href="http://tweenjs.github.io/tween.js/examples/07_dynamic_to.html"> | |
<img src="./assets/examples/07_dynamic_to.png" alt="Dynamic to" /> | |
</a> | |
</td> | |
<td> | |
Dynamic to<br /> | |
(<a href="examples/07_dynamic_to.html">source</a>) | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="http://tweenjs.github.io/tween.js/examples/06_array_interpolation.html"> | |
<img src="./assets/examples/03_graphs.png" alt="Array interpolation" /> | |
</a> | |
</td> | |
<td> | |
Array interpolation<br /> | |
(<a href="examples/06_array_interpolation.html">source</a>) | |
</td> | |
<td> | |
<a href="http://tweenjs.github.io/tween.js/examples/05_video_and_time.html"> | |
<img src="./assets/examples/06_video_and_time.png" alt="Video and time" /> | |
</a> | |
</td> | |
<td> | |
Video and time<br /> | |
(<a href="examples/05_video_and_time.html">source</a>) | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="http://tweenjs.github.io/tween.js/examples/04_simplest.html"> | |
<img src="./assets/examples/04_simplest.png" alt="Simplest possible example" /> | |
</a> | |
</td> | |
<td> | |
Simplest possible example<br /> | |
(<a href="examples/04_simplest.html">source</a>) | |
</td> | |
<td> | |
<a href="http://tweenjs.github.io/tween.js/examples/03_graphs.html"> | |
<img src="./assets/examples/03_graphs.png" alt="Graphs" /> | |
</a> | |
</td> | |
<td> | |
Graphs<br /> | |
(<a href="examples/03_graphs.html">source</a>) | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="http://tweenjs.github.io/tween.js/examples/02_black_and_red.html"> | |
<img src="./assets/examples/02_black_and_red.png" alt="Black and red" /> | |
</a> | |
</td> | |
<td> | |
Black and red<br /> | |
(<a href="examples/02_black_and_red.html">source</a>) | |
</td> | |
<td> | |
<a href="http://tweenjs.github.io/tween.js/examples/01_bars.html"> | |
<img src="./assets/examples/01_bars.png" alt="Bars" /> | |
</a> | |
</td> | |
<td> | |
Bars<br /> | |
(<a href="examples/01_bars.html">source</a>) | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="http://tweenjs.github.io/tween.js/examples/00_hello_world.html"> | |
<img src="./assets/examples/00_hello_world.png" alt="hello world" /> | |
</a> | |
</td> | |
<td> | |
hello world<br /> | |
(<a href="examples/00_hello_world.html">source</a>) | |
</td> | |
</tr> | |
</table> | |
## Tests | |
You need to install `npm` first--this comes with node.js, so install that one first. Then, cd to `tween.js`'s directory and run: | |
```bash | |
npm install | |
``` | |
if running the tests for the first time, to install additional dependencies for running tests, and then run | |
```bash | |
npm test | |
``` | |
every time you want to run the tests. | |
If you want to add any feature or change existing features, you *must* run the tests to make sure you didn't break anything else. If you send a pull request (PR) to add something new and it doesn't have tests, or the tests don't pass, the PR won't be accepted. See [contributing](CONTRIBUTING.md) for more information. | |
## People | |
Maintainers: [mikebolt](https://github.com/mikebolt), [sole](https://github.com/sole). | |
[All contributors](http://github.com/tweenjs/tween.js/contributors). | |
## Projects using tween.js | |
[![A-Frame VR](http://tweenjs.github.io/tween.js/assets/projects/10_aframe.png)](https://aframe.io) | |
[![MOMA Inventing Abstraction 1910-1925](http://tweenjs.github.io/tween.js/assets/projects/09_moma.png)](http://www.moma.org/interactives/exhibitions/2012/inventingabstraction/) | |
[![Web Lab](http://tweenjs.github.io/tween.js/assets/projects/08_web_lab.png)](http://www.chromeweblab.com/) | |
[![MACCHINA I](http://tweenjs.github.io/tween.js/assets/projects/07_macchina.png)](http://5013.es/toys/macchina) | |
[![Minesweeper 3D](http://tweenjs.github.io/tween.js/assets/projects/06_minesweeper3d.png)](http://egraether.com/mine3d/) | |
[![ROME](http://tweenjs.github.io/tween.js/assets/projects/05_rome.png)](http://ro.me) | |
[![WebGL Globe](http://tweenjs.github.io/tween.js/assets/projects/04_webgl_globe.png)](http://data-arts.appspot.com/globe) | |
[![Androidify](http://tweenjs.github.io/tween.js/assets/projects/03_androidify.png)](http://www.androidify.com/) | |
[![The Wilderness Downtown](http://tweenjs.github.io/tween.js/assets/projects/01_wilderness.png)](http://thewildernessdowntown.com/) | |
[![Linechart](http://tweenjs.github.io/tween.js/assets/projects/00_linechart.png)](http://dejavis.org/linechart) | |
[npm-image]: https://img.shields.io/npm/v/@tweenjs/tween.js.svg | |
[npm-url]: https://npmjs.org/package/@tweenjs/tween.js | |
[downloads-image]: https://img.shields.io/npm/dm/@tweenjs/tween.js.svg | |
[downloads-url]: https://npmjs.org/package/@tweenjs/tween.js | |
[travis-image]: https://travis-ci.org/tweenjs/tween.js.svg?branch=master | |
[travis-url]: https://travis-ci.org/tweenjs/tween.js | |
[flattr-image]: https://api.flattr.com/button/flattr-badge-large.png | |
[flattr-url]: https://flattr.com/thing/45014/tween-js | |
[cdnjs-image]: https://img.shields.io/cdnjs/v/tween.js.svg | |
[cdnjs-url]: https://cdnjs.com/libraries/tween.js | |