0.2.1 • Published 12 years ago
svg-path v0.2.1
svg-path
Parse and manipulate SVG <path>s.
Usage example
Parsing
var svgPath = require('svg-path')
var pathData = 'm100,1e2C125,100 130,110 150,150l-25-75z'
var path = svgPath(pathData) // creates a new svgPath.Path
console.log(path.content)
/*
[
{ type: 'M', relative: false, x: 100, y: 100 },
{ type: 'C', relative: false,
x1: 125, y1: 100, x2: 130, y2: 110, x: 150, y: 150 },
{ type: 'L', relative: true, x: -25, y: -75 },
{ type: 'Z' }
]
*/Applying transformations
var path = svgPath(pathData)
path.abs()
path.matrix(1, 0, 0, 1, 100, 50) // same as translate(100, 50)Transformations are applied in-place. To retain the original, create a copy first:
var newPath = path.copy()Available transformations are abs, translate, scale, rotate, skewX and skewY and convertArcs. The latter converts all A (arc) commands to C (curveto) commands. All transformations expect #abs() start by calling #convertArcs.
Running the tests
$ git clone https://github.com/PPvG/svg-path
$ cd svg-path
$ npm install
$ npm testCode coverage report
$ npm run coverThen open ./cov/report.html in your browser.

