Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/gre/bezier-easing
cubic-bezier implementation for your JavaScript animation easings – MIT License
https://github.com/gre/bezier-easing
animation bezier cubic-bezier easing
Last synced: 5 days ago
JSON representation
cubic-bezier implementation for your JavaScript animation easings – MIT License
- Host: GitHub
- URL: https://github.com/gre/bezier-easing
- Owner: gre
- License: mit
- Created: 2013-12-18T17:07:14.000Z (about 11 years ago)
- Default Branch: master
- Last Pushed: 2023-07-12T02:39:01.000Z (over 1 year ago)
- Last Synced: 2024-10-29T15:05:27.056Z (3 months ago)
- Topics: animation, bezier, cubic-bezier, easing
- Language: JavaScript
- Homepage: http://greweb.me/bezier-easing-editor/example/
- Size: 328 KB
- Stars: 1,738
- Watchers: 31
- Forks: 137
- Open Issues: 5
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-github-star - bezier-easing - bezier implementation for your JavaScript animation easings – MIT License | gre | 1662 | (JavaScript)
- awesome-list - bezier-easing - bezier implementation for your JavaScript animation easings – MIT License | gre | 1400 | (JavaScript)
- awesome-web-animation - Bezier easing - Cubic-bezier implementation for your JavaScript animation easings. (Common)
README
bezier-easing [![Build Status](https://img.shields.io/travis/gre/bezier-easing.svg)](https://travis-ci.org/gre/bezier-easing)
===BezierEasing provides **Cubic Bezier** Curve easing which generalizes easing functions (ease-in, ease-out, ease-in-out, ...any other custom curve) exactly like in CSS Transitions.
Implementing efficient lookup is not easy because it implies projecting
the X coordinate to a Bezier Curve.
This micro library uses fast heuristics (involving dichotomic search, newton-raphson, sampling) to focus on **performance** and **precision**.> It is heavily based on implementations available in Firefox and Chrome (for the CSS transition-timing-function property).
Usage
-------```javascript
var easing = BezierEasing(0, 0, 1, 0.5);
// easing allows to project x in [0.0,1.0] range onto the bezier-curve defined by the 4 points (see schema below).
console.log(easing(0.0)); // 0.0
console.log(easing(0.5)); // 0.3125
console.log(easing(1.0)); // 1.0
```(this schema is from the CSS spec)
[![TimingFunction.png](https://www.w3.org/TR/css-timing-1/cubic-bezier-timing-curve.svg)](http://www.w3.org/TR/css3-transitions/#transition-timing-function-property)
> `BezierEasing(P1.x, P1.y, P2.x, P2.y)`
Install
-------[![npm install bezier-easing](https://nodei.co/npm/bezier-easing.png)](http://npmjs.org/package/bezier-easing)
It is the equivalent to [CSS Transitions' `transition-timing-function`](http://www.w3.org/TR/css-easing-1/#cubic-bezier-easing-functions).
In the same way you can define in CSS `cubic-bezier(0.42, 0, 0.58, 1)`,
with BezierEasing, you can define it using `BezierEasing(0.42, 0, 0.58, 1)` which have the `` function taking an X and computing the Y interpolated easing value (see schema).License
-------MIT License.
Tests
---[![Build Status](https://img.shields.io/travis/gre/bezier-easing.svg)](https://travis-ci.org/gre/bezier-easing)
```
npm test
```See also
===- [https://github.com/gre/bezier-easing-editor/](https://github.com/gre/bezier-easing-editor/)
Who use it?
===- [React Native](https://github.com/facebook/react-native/blob/master/Libraries/Animated/src/bezier.js)
- [Apple®](http://images.apple.com/v/mac-pro/home/b/scripts/overview.js) :)
- [Velocity.js](https://github.com/julianshapiro/velocity)
- [GLSL.io](http://glsl.io/) and [Diaporama Maker](https://github.com/gre/diaporama-maker)
- [ipo](https://github.com/gre/ipo)More informations
-----------------Implementation based on this [article](http://greweb.me/2012/02/bezier-curve-based-easing-functions-from-concept-to-implementation/).
Contributing
------------You need a `node` installed.
Install the deps:
```
npm install
```The library is in `index.js`.
Ensure any modication will:
- keep validating the tests (run `npm test`)
- not bring performance regression (compare with `npm run benchmark` – don't rely 100% on its precision but it still helps to notice big gaps)
- Run the visual example: `npm run visual`