svg-path-morph
v1.0.5
Published
Small library for morphing bewtween multiple SVG paths.
Downloads
7,355
Maintainers
Readme
svg-path-morph
A simple library for morphing between variations of SVG paths.
Use svg-path-morph
to smoothly morph between X variations of the same SVG path (i.e. same commands, different values).
Installation
npm install svg-path-morph
Demo
A live demo is also available on my website.
https://user-images.githubusercontent.com/8108085/172227481-1e1e1e9b-6868-41f9-81e0-dfb52ec32e3d.mp4
See demo.html and src/demo.js for the implementation of the above demonstration
Usage
import { compile, morph } from 'svg-path-morph'
// Get the d attributes of the <path> elements you want to morph between
const happy = document.getElemenyById('happy').getAttribute('d')
const angry = document.getElemenyById('angry').getAttribute('d')
// Compile the morph base (average path embedding)
const compiled = compile([
happy,
angry
])
// Morph between the happy/angry faces
const slightlyAngry = morph(
compiled,
[
0.80, // 80% happy
0.20 // 20% angry
]
)
// Use the face is the d attribute of a <path> element
document.getElementById('the-face').setAttribute('d', slightlyAngry)