Add SvgImport example for Inkscape and fix issue with multiple SVG path commands.

Closes #203.
This commit is contained in:
Jürg Lehni 2013-04-20 14:54:21 -07:00
parent 3025c63179
commit bcb10a222f
2 changed files with 110 additions and 15 deletions

View file

@ -0,0 +1,88 @@
<!DOCTYPE html>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<title>Inkscape</title>
<link rel="stylesheet" href="../css/style.css">
<script type="text/javascript" src="../../dist/paper.js"></script>
<script type="text/paperscript" canvas="canvas">
var start = Date.now();
project.importSvg(document.getElementById('svg2'));
console.log(Date.now() - start);
// console.log(project.exportJson());
</script>
</head>
<body>
<svg
xmlns:dc="http://purl.org/dc/elements/1.1/"
xmlns:cc="http://creativecommons.org/ns#"
xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
xmlns:svg="http://www.w3.org/2000/svg"
xmlns="http://www.w3.org/2000/svg"
xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
width="400"
height="400"
id="svg2"
version="1.1"
inkscape:version="0.48.3.1 r9886"
sodipodi:docname="a.svg">
<defs
id="defs4" />
<sodipodi:namedview
id="base"
pagecolor="#ffffff"
bordercolor="#666666"
borderopacity="1.0"
inkscape:pageopacity="0.0"
inkscape:pageshadow="2"
inkscape:zoom="0.77875"
inkscape:cx="330.27138"
inkscape:cy="184.86687"
inkscape:document-units="px"
inkscape:current-layer="layer1"
showgrid="false"
width="400px"
inkscape:window-width="1280"
inkscape:window-height="776"
inkscape:window-x="0"
inkscape:window-y="24"
inkscape:window-maximized="1" />
<metadata
id="metadata7">
<rdf:RDF>
<cc:Work
rdf:about="">
<dc:format>image/svg+xml</dc:format>
<dc:type
rdf:resource="http://purl.org/dc/dcmitype/StillImage" />
<dc:title />
</cc:Work>
</rdf:RDF>
</metadata>
<g
inkscape:label="Calque 1"
inkscape:groupmode="layer"
id="layer1"
transform="translate(0,-652.3622)">
<rect
style="color:#000000;fill:#ffffff;fill-opacity:1;fill-rule:nonzero;stroke:#808080;stroke-width:5.44782829;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:10.89565646, 5.44782823;stroke-dashoffset:0;marker:none;visibility:visible;display:inline;overflow:visible;enable-background:accumulate"
id="rect2985"
width="394.55215"
height="394.55219"
x="2.7239141"
y="655.08612" />
<g
style="font-size:199.2015686px;font-style:normal;font-variant:normal;font-weight:bold;font-stretch:normal;text-align:end;line-height:110.00000238%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:end;fill:#000000;fill-opacity:1;stroke:none;font-family:Quicksand;-inkscape-font-specification:Quicksand Bold"
id="text3755">
<path
d="m 234.38449,911.25829 c 1.59361,4.38243 5.77685,6.97206 10.15928,6.97206 1.39441,0 2.78882,-0.19921 3.78483,-0.59761 5.77684,-2.19121 8.56566,-8.56567 6.57365,-14.34251 L 210.8787,785.96051 c -1.79281,-4.38243 -5.97605,-7.17126 -10.55768,-6.97206 -4.38243,-0.1992 -8.76487,2.58963 -10.55769,6.97206 l -44.02354,117.32972 c -1.99202,5.77684 0.79681,12.1513 6.57365,14.34251 1.19521,0.3984 2.39042,0.59761 3.78483,0.59761 4.38243,0 8.56567,-2.58963 10.35848,-6.97206 l 9.76088,-25.8962 48.40598,0 9.76088,25.8962 m -50.1988,-47.80837 16.13533,-42.82834 16.13532,42.82834 -32.27065,0"
style="fill:#ff0000;fill-opacity:1"
id="path3760" />
</g>
</g>
</svg>
<canvas id="canvas" width="400" height="400"></canvas>
</body>
</html>

View file

@ -117,42 +117,49 @@ var PathItem = this.PathItem = Item.extend(/** @lends PathItem# */{
// Use positive lookahead to include signs. // Use positive lookahead to include signs.
coords = part.slice(1).trim().split(/[\s,]+|(?=[+-])/); coords = part.slice(1).trim().split(/[\s,]+|(?=[+-])/);
relative = cmd === lower; relative = cmd === lower;
var length = coords.length;
switch (lower) { switch (lower) {
case 'm': case 'm':
case 'l': case 'l':
for (var j = 0; j < coords.length; j += 2) for (var j = 0; j < length; j += 2)
this[j === 0 && lower === 'm' ? 'moveTo' : 'lineTo']( this[j === 0 && lower === 'm' ? 'moveTo' : 'lineTo'](
getPoint(j, true)); getPoint(j, true));
break; break;
case 'h': case 'h':
case 'v': case 'v':
var coord = lower == 'h' ? 'x' : 'y'; var coord = lower == 'h' ? 'x' : 'y';
for (var j = 0; j < coords.length; j++) { for (var j = 0; j < length; j++) {
getCoord(j, coord, true); getCoord(j, coord, true);
this.lineTo(current); this.lineTo(current);
} }
break; break;
case 'c': case 'c':
this.cubicCurveTo( for (var j = 0; j < length; j += 6) {
getPoint(0), this.cubicCurveTo(
control = getPoint(2), getPoint(j),
getPoint(4, true)); control = getPoint(j + 2),
getPoint(j + 4, true));
}
break; break;
case 's': case 's':
// Shorthand cubic bezierCurveTo, absolute // Shorthand cubic bezierCurveTo, absolute
this.cubicCurveTo( for (var j = 0; j < length; j += 4) {
// Calculate reflection of previous control points this.cubicCurveTo(
current.multiply(2).subtract(control), // Calculate reflection of previous control points
control = getPoint(0), current.multiply(2).subtract(control),
getPoint(2, true)); control = getPoint(j),
getPoint(j + 2, true));
}
break; break;
case 'q': case 'q':
this.quadraticCurveTo( for (var j = 0; j < length; j += 4) {
control = getPoint(0), this.quadraticCurveTo(
getPoint(2, true)); control = getPoint(j),
getPoint(j + 2, true));
}
break; break;
case 't': case 't':
for (var j = 0; j < coords.length; j += 2) { for (var j = 0; j < length; j += 2) {
this.quadraticCurveTo( this.quadraticCurveTo(
// Calculate reflection of previous control points // Calculate reflection of previous control points
control = current.multiply(2).subtract(control), control = current.multiply(2).subtract(control),