Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/alexk111/SVG-Morpheus
JavaScript library enabling SVG icons to morph from one to the other. It implements Material Design's Delightful Details transitions. (THIS PROJECT IS NOT MAINTAINED ANYMORE)
https://github.com/alexk111/SVG-Morpheus
Last synced: 2 months ago
JSON representation
JavaScript library enabling SVG icons to morph from one to the other. It implements Material Design's Delightful Details transitions. (THIS PROJECT IS NOT MAINTAINED ANYMORE)
- Host: GitHub
- URL: https://github.com/alexk111/SVG-Morpheus
- Owner: alexk111
- License: mit
- Created: 2014-11-24T07:14:03.000Z (about 10 years ago)
- Default Branch: master
- Last Pushed: 2017-07-21T12:53:57.000Z (over 7 years ago)
- Last Synced: 2024-10-29T15:34:45.185Z (3 months ago)
- Language: JavaScript
- Homepage:
- Size: 88.9 KB
- Stars: 2,700
- Watchers: 120
- Forks: 241
- Open Issues: 11
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-material - SVG-Morpheus
README
# SVG Morpheus
## WARNING
THIS PROJECT IS NOT MAINTAINED ANYMORE. You are free to fork it and start a new project.
## Overview
JavaScript library enabling SVG icons to morph from one to the other. It implements Material Design's [Delightful Details](http://www.google.com/design/spec/animation/delightful-details.html) transitions.
## Live demo
[Launch Live Demo](http://alexk111.github.io/SVG-Morpheus/)
## Installing
### Using SVG Morpheus with a CDN
CDN provided by [cdnjs](https://cdnjs.com/libraries/SVG-Morpheus)
``````
### Download
You have the following options to install the library:
- [Download SVG Morpheus](https://github.com/alexk111/SVG-Morpheus/archive/master.zip) from GitHub.
- Use NPM `npm install svg-morpheus`.
- Use Bower `bower install svg-morpheus`.### Add Script
Simply add the svg-morpheus.js script to your website/application. No other scripts are needed. Both the minified and uncompressed (for development) versions are in the /compile folder.
```html
```
## Usage
1. Add an icon set SVG to the HTML file where you want to show the morphing icon.
2. Create a SVG Morpheus instance for the icon set by calling `new SVGMorpheus(element)`. *Object/IFrame/Inline SVG element containing the icon set. Can be a DOM element or a CSS query selector.*. For example:```javascript
var myIcons = new SVGMorpheus('#myIconSet');
```3. After initializing, you get a SVGMorpheus object having `to(ID)` function. *ID is an id of Icon in the icon set*. Use it to morph the icon to another icon in the icon set.
```javascript
myIcons.to('icon1');
```## Functions
### SVGMorpheus Constructor
Creates a SVGMorpheus instance.
```javascript
var myIcons = new SVGMorpheus(element, options, callback);
```**element** - Object/IFrame/SVG element containing an icon set. Can be a DOM element or a CSS query selector.
**options** - *Optional*. Object specifying default options.
**options.iconId** - *Optional*. Id of an icon shown after initialization. Default: last icon in the icon set.
**options.duration** - *Optional*. Set a default duration for transition animations, in msec. Default: 750.
**options.easing** - *Optional*. Set a default easing for transition animations. Default: quad-in-out.
**options.rotation** - *Optional*. Set a default rotation for icon shapes. `clock` = clockwise, `counterclock` = counterclockwise, `random` = randomly set clock/counterclock, `none` = no rotation. Default: clock.
**callback** - *Optional*. Set a default callback function to call at the animation end.
### SVGMorpheus.to()
Morphs the icon to another one.
```javascript
myIcons.to(iconId, options, callback);
```**iconId** - Id of an icon to transition to.
**options** - *Optional*. Object specifying the animation options.
**options.duration** - *Optional*. Set a duration for the animation, in msec.
**options.easing** - *Optional*. Set an easing for the animation.
**options.rotation** - *Optional*. Set a rotation for icon shapes. `clock` = clockwise, `counterclock` = counterclockwise, `random` = randomly set clock/counterclock, `none` = no rotation.
**callback** - *Optional*. Set a callback function to call at the animation end.
### SVGMorpheus.registerEasing()
Registers a custom easing function. SVGMorpheus has a set of predefined easing functions for the morph animation (goes below). If you want to use your own easing, use this function to do that.
```javascript
myIcons.registerEasing(name, fn);
```**name** - Name of an easing function you want to register.
**fn** - Easing function. ```function easing(timing)``` gets a float ```0<=timing<=1``` argument as an input, and outputs float ```0<=progress<=1```.
## Predefined easing functions
`circ-in`, `circ-out`, `circ-in-out`, `cubic-in`, `cubic-out`, `cubic-in-out`, `elastic-in`, `elastic-out`, `elastic-in-out`, `expo-in`, `expo-out`, `expo-in-out`, `linear`, `quad-in`, `quad-out`, `quad-in-out`, `quart-in`, `quart-out`, `quart-in-out`, `quint-in`, `quint-out`, `quint-in-out`, `sine-in`, `sine-out`, `sine-in-out`
## Icon Set structure
SVG should have the following structure to be a valid icon set:
- 1st tier nodes are `` elements having 'id' attribute. They define icons in the icon set.
- 2nd tier nodes are shape elements (``, `circle`, `rect`, `ellipse`, `polygon`, `line`). They define the icon graphics.```xml
Shape elements
Shape elements
```
## Example code
Check the Demos directory for examples.
## Supported browsers
Chrome
Firefox
IE >= 10
Safari
Opera
iOS Safari
Android Browser >= 4.4
Chrome for Android## License
See the [LICENSE](https://github.com/alexk111/SVG-Morpheus/blob/master/LICENSE) file.