2012-11-02 20:47:14 -04:00
|
|
|
/*
|
2012-09-30 17:51:50 -04:00
|
|
|
* Paper.js
|
|
|
|
*
|
|
|
|
* This file is part of Paper.js, a JavaScript Vector Graphics Library,
|
|
|
|
* based on Scriptographer.org and designed to be largely API compatible.
|
|
|
|
* http://paperjs.org/
|
|
|
|
* http://scriptographer.org/
|
|
|
|
*
|
|
|
|
* Copyright (c) 2011, Juerg Lehni & Jonathan Puckey
|
|
|
|
* http://lehni.org/ & http://jonathanpuckey.com/
|
|
|
|
*
|
|
|
|
* Distributed under the MIT license. See LICENSE file for details.
|
|
|
|
*
|
|
|
|
* All rights reserved.
|
|
|
|
*
|
2012-11-02 21:14:20 -04:00
|
|
|
* The base for this code was donated by Stetson-Team-Alpha.
|
2012-09-13 20:45:27 -04:00
|
|
|
*/
|
|
|
|
|
2012-11-04 02:04:15 -05:00
|
|
|
/**
|
|
|
|
* @name SvgExporter
|
|
|
|
*
|
|
|
|
* @class The SvgExporter object holds all the functionality to convert a
|
|
|
|
* Paper.js DOM to a SVG DOM.
|
|
|
|
*/
|
2012-09-30 17:51:50 -04:00
|
|
|
|
2012-11-04 01:43:45 -05:00
|
|
|
var SvgExporter = this.SvgExporter = new function() {
|
2012-10-24 23:21:59 -04:00
|
|
|
|
2012-11-04 01:43:45 -05:00
|
|
|
function createElement(tag) {
|
2012-10-24 23:21:59 -04:00
|
|
|
return document.createElementNS('http://www.w3.org/2000/svg', tag);
|
2012-11-04 01:43:45 -05:00
|
|
|
}
|
2012-09-30 17:51:50 -04:00
|
|
|
|
2012-11-04 12:01:11 -05:00
|
|
|
function setAttributes(svg, attrs) {
|
2012-11-05 22:03:42 -05:00
|
|
|
for (var key in attrs)
|
2012-11-04 12:01:11 -05:00
|
|
|
svg.setAttribute(key, attrs[key]);
|
|
|
|
}
|
|
|
|
|
2012-11-04 01:43:45 -05:00
|
|
|
function exportGroup(group) {
|
|
|
|
var svg = createElement('g'),
|
2012-11-02 19:51:42 -04:00
|
|
|
children = group._children;
|
2012-11-04 01:43:45 -05:00
|
|
|
for (var i = 0, l = children.length; i < l; i++)
|
|
|
|
svg.appendChild(SvgExporter.exportItem(children[i]));
|
2012-11-05 22:03:42 -05:00
|
|
|
// Override default SVG style on groups, then apply style.
|
|
|
|
setAttributes(svg, {
|
|
|
|
fill: 'none'
|
|
|
|
});
|
2012-11-05 12:05:32 -05:00
|
|
|
applyStyle(group, svg);
|
2012-11-02 19:51:42 -04:00
|
|
|
return svg;
|
2012-11-04 01:43:45 -05:00
|
|
|
}
|
|
|
|
|
2012-11-05 23:10:31 -05:00
|
|
|
function getDistance(segments, index1, index2) {
|
|
|
|
return segments[index1]._point.getDistance(segments[index2]._point);
|
|
|
|
}
|
|
|
|
|
2012-11-04 01:43:45 -05:00
|
|
|
function exportItem(path) {
|
2012-11-02 19:51:42 -04:00
|
|
|
var svg;
|
2012-09-30 17:51:50 -04:00
|
|
|
//Getting all of the segments(a point, a HandleIn and a HandleOut) in the path
|
2012-11-05 22:44:23 -05:00
|
|
|
var segments;
|
2012-10-22 19:31:08 -04:00
|
|
|
var type;
|
2012-09-30 17:51:50 -04:00
|
|
|
//finding the type of path to export
|
2012-10-22 19:31:08 -04:00
|
|
|
if (path.content) {
|
2012-09-30 17:51:50 -04:00
|
|
|
type = 'text';
|
|
|
|
} else {
|
|
|
|
//Values are only defined if the path is not text because
|
|
|
|
// text does not have these values
|
2012-11-05 22:44:23 -05:00
|
|
|
segments = path.getSegments();
|
|
|
|
type = determineType(path, segments);
|
2012-09-30 17:51:50 -04:00
|
|
|
}
|
2012-11-05 23:10:31 -05:00
|
|
|
|
2012-09-30 17:51:50 -04:00
|
|
|
//switch statement that determines what type of SVG element to add to the SVG Object
|
|
|
|
switch (type) {
|
2012-10-22 19:31:08 -04:00
|
|
|
case 'rect':
|
2012-11-05 23:10:31 -05:00
|
|
|
var width = getDistance(segments, 0, 3);
|
|
|
|
var height = getDistance(segments, 0, 1);
|
2012-11-04 01:43:45 -05:00
|
|
|
svg = createElement('rect');
|
2012-11-05 22:45:18 -05:00
|
|
|
svg.setAttribute('x', path.bounds.topLeft._x);
|
|
|
|
svg.setAttribute('y', path.bounds.topLeft._y);
|
2012-11-02 19:51:42 -04:00
|
|
|
svg.setAttribute('width', width);
|
|
|
|
svg.setAttribute('height', height);
|
2012-10-22 19:31:08 -04:00
|
|
|
break;
|
2012-11-02 21:23:23 -04:00
|
|
|
case 'roundrect':
|
2012-10-22 19:31:08 -04:00
|
|
|
//d variables and point are used to determine the rounded corners for the rounded rectangle
|
2012-11-05 23:10:31 -05:00
|
|
|
var dx1 = getDistance(segments, 1, 6);
|
|
|
|
var dx2 = getDistance(segments, 0, 7);
|
2012-10-22 19:31:08 -04:00
|
|
|
var dx3 = (dx1 - dx2) / 2;
|
2012-11-05 23:10:31 -05:00
|
|
|
var dy1 = getDistance(segments, 0, 3);
|
|
|
|
var dy2 = getDistance(segments, 1, 2);
|
2012-10-22 19:31:08 -04:00
|
|
|
var dy3 = (dy1 - dy2) / 2;
|
2012-11-05 22:45:18 -05:00
|
|
|
var point = new Point((segments[3]._point._x - dx3), (segments[2]._point._y - dy3));
|
2012-10-22 19:31:08 -04:00
|
|
|
var width = Math.round(dx1);
|
|
|
|
var height = Math.round(dy1);
|
2012-11-05 22:45:18 -05:00
|
|
|
var rx = segments[3]._point._x - point.x;
|
|
|
|
var ry = segments[2]._point._y - point.y;
|
2012-11-04 01:43:45 -05:00
|
|
|
svg = createElement('rect');
|
2012-11-05 22:45:18 -05:00
|
|
|
svg.setAttribute('x', path.bounds.topLeft._x);
|
|
|
|
svg.setAttribute('y', path.bounds.topLeft._y);
|
2012-11-02 19:51:42 -04:00
|
|
|
svg.setAttribute('rx', rx);
|
|
|
|
svg.setAttribute('ry', ry);
|
|
|
|
svg.setAttribute('width', width);
|
|
|
|
svg.setAttribute('height', height);
|
2012-10-22 19:31:08 -04:00
|
|
|
break;
|
|
|
|
case'line':
|
2012-11-04 01:43:45 -05:00
|
|
|
svg = createElement('line');
|
2012-11-05 22:45:18 -05:00
|
|
|
svg.setAttribute('x1', segments[0]._point._x);
|
|
|
|
svg.setAttribute('y1', segments[0]._point._y);
|
|
|
|
svg.setAttribute('x2', segments[segments.length - 1]._point._x);
|
|
|
|
svg.setAttribute('y2', segments[segments.length - 1]._point._y);
|
2012-10-22 19:31:08 -04:00
|
|
|
break;
|
|
|
|
case 'circle':
|
2012-11-04 01:43:45 -05:00
|
|
|
svg = createElement('circle');
|
2012-11-05 23:10:31 -05:00
|
|
|
var radius = (getDistance(segments, 0, 2)) /2;
|
2012-11-02 19:51:42 -04:00
|
|
|
svg.setAttribute('cx', path.bounds.center.x);
|
|
|
|
svg.setAttribute('cy', path.bounds.center.y);
|
|
|
|
svg.setAttribute('r', radius);
|
2012-10-22 19:31:08 -04:00
|
|
|
break;
|
|
|
|
case 'ellipse':
|
2012-11-04 01:43:45 -05:00
|
|
|
svg = createElement('ellipse');
|
2012-11-05 23:10:31 -05:00
|
|
|
var radiusX = getDistance(segments, 2, 0) / 2;
|
|
|
|
var radiusY = getDistance(segments, 3, 1) /2;
|
2012-11-02 19:51:42 -04:00
|
|
|
svg.setAttribute('cx', path.bounds.center.x);
|
|
|
|
svg.setAttribute('cy', path.bounds.center.y);
|
|
|
|
svg.setAttribute('rx', radiusX);
|
|
|
|
svg.setAttribute('ry', radiusY);
|
2012-10-22 19:31:08 -04:00
|
|
|
break;
|
|
|
|
case 'polyline':
|
|
|
|
case 'polygon':
|
2012-11-05 22:47:47 -05:00
|
|
|
svg = createElement(type);
|
2012-11-05 22:56:49 -05:00
|
|
|
var parts = [];
|
2012-11-05 22:44:23 -05:00
|
|
|
for(i = 0; i < segments.length; i++) {
|
2012-11-05 22:56:49 -05:00
|
|
|
parts.push(segments[i]._point._x + ',' + segments[i]._point._y);
|
2012-10-22 19:31:08 -04:00
|
|
|
}
|
2012-11-05 22:56:49 -05:00
|
|
|
svg.setAttribute('points', parts.join(' '));
|
2012-10-22 19:31:08 -04:00
|
|
|
break;
|
|
|
|
case 'text':
|
2012-11-04 01:43:45 -05:00
|
|
|
svg = createElement('text');
|
2012-11-05 22:45:18 -05:00
|
|
|
svg.setAttribute('x', path.getPoint()._x);
|
|
|
|
svg.setAttribute('y', path.getPoint()._y);
|
2012-10-22 19:31:08 -04:00
|
|
|
if (path.characterStyle.font != undefined) {
|
2012-11-02 19:51:42 -04:00
|
|
|
svg.setAttribute('font-family', path.characterStyle.font);
|
2012-10-22 19:31:08 -04:00
|
|
|
}
|
|
|
|
if (path.characterStyle.fontSize != undefined) {
|
2012-11-02 19:51:42 -04:00
|
|
|
svg.setAttribute('font-size',path.characterStyle.fontSize);
|
2012-10-22 19:31:08 -04:00
|
|
|
}
|
2012-11-02 19:51:42 -04:00
|
|
|
svg.textContent = path.getContent();
|
2012-10-22 19:31:08 -04:00
|
|
|
break;
|
|
|
|
default:
|
2012-11-05 22:44:23 -05:00
|
|
|
svg = pathSetup(path, segments);
|
2012-10-22 19:31:08 -04:00
|
|
|
break;
|
2012-09-30 17:51:50 -04:00
|
|
|
}
|
|
|
|
//If the object is a circle, ellipse, rectangle, or rounded rectangle, it will find the angle
|
2012-09-30 21:11:00 -04:00
|
|
|
//found by the determineIfTransformed method and make a path that accommodates for the transformed object
|
2012-10-22 19:31:08 -04:00
|
|
|
if (type != 'text' && type != undefined && type != 'polygon' && type != 'polyline' && type != 'line') {
|
2012-09-30 18:05:21 -04:00
|
|
|
//TODO: Need to implement exported transforms for circle, ellipse, and rectangles instead of
|
|
|
|
//making them paths
|
2012-11-05 22:44:23 -05:00
|
|
|
var angle = determineIfTransformed(path, segments, type) + 90;
|
2012-10-22 19:31:08 -04:00
|
|
|
if (angle != 0) {
|
2012-11-02 21:23:23 -04:00
|
|
|
if (type == 'rect' || type == 'roundrect') {
|
2012-11-05 22:44:23 -05:00
|
|
|
svg = pathSetup(path, segments);
|
2012-09-30 17:51:50 -04:00
|
|
|
} else {
|
2012-11-05 22:44:23 -05:00
|
|
|
svg = pathSetup(path, segments);
|
2012-09-30 17:51:50 -04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2012-10-22 19:31:08 -04:00
|
|
|
if (type == 'text') {
|
2012-11-05 22:45:18 -05:00
|
|
|
svg.setAttribute('transform','rotate(' + path.matrix.getRotation() + ',' + path.getPoint()._x + ',' +path.getPoint()._y +')');
|
2012-09-30 17:51:50 -04:00
|
|
|
}
|
2012-11-04 12:01:11 -05:00
|
|
|
applyStyle(path, svg);
|
2012-11-02 19:51:42 -04:00
|
|
|
return svg;
|
2012-11-04 01:43:45 -05:00
|
|
|
}
|
|
|
|
var exporters = {
|
|
|
|
group: exportGroup,
|
|
|
|
layer: exportGroup,
|
|
|
|
path: exportItem,
|
|
|
|
pointtext: exportItem
|
|
|
|
// TODO:
|
|
|
|
// raster:
|
|
|
|
// placedsymbol:
|
|
|
|
// compoundpath:
|
|
|
|
};
|
2012-09-13 20:45:27 -04:00
|
|
|
|
2012-11-04 01:43:45 -05:00
|
|
|
// Determines whether the object has been transformed or not through finding the angle
|
2012-11-05 22:44:23 -05:00
|
|
|
function determineIfTransformed(path, segments, type) {
|
2012-11-05 22:47:47 -05:00
|
|
|
var topMidBoundx = (path.bounds.topRight._x + path.bounds.topLeft._x) / 2;
|
|
|
|
var topMidBoundy = (path.bounds.topRight._y + path.bounds.topLeft._y) / 2;
|
2012-09-30 17:51:50 -04:00
|
|
|
var topMidBound = new Point(topMidBoundx, topMidBoundy);
|
|
|
|
var centerPoint = path.getPosition();
|
|
|
|
var topMidPathx;
|
|
|
|
var topMidPathy;
|
|
|
|
var topMidPath;
|
|
|
|
switch (type) {
|
2012-10-22 19:31:08 -04:00
|
|
|
case 'rect':
|
2012-11-05 22:47:47 -05:00
|
|
|
topMidPathx = (segments[1]._point._x + segments[2]._point._x) / 2;
|
|
|
|
topMidPathy = (segments[1]._point._y + segments[2]._point._y) / 2;
|
2012-10-22 19:31:08 -04:00
|
|
|
topMidPath = new Point(topMidPathx, topMidPathy);
|
|
|
|
break;
|
|
|
|
case 'ellipse':
|
2012-11-05 22:45:18 -05:00
|
|
|
topMidPath = new Point(segments[1]._point._x, segments[1]._point._y);
|
2012-10-22 19:31:08 -04:00
|
|
|
break;
|
|
|
|
case 'circle':
|
2012-11-05 22:45:18 -05:00
|
|
|
topMidPath = new Point(segments[1]._point._x, segments[1]._point._y);
|
2012-10-22 19:31:08 -04:00
|
|
|
break;
|
2012-11-02 21:23:23 -04:00
|
|
|
case 'roundrect':
|
2012-11-05 22:47:47 -05:00
|
|
|
topMidPathx = (segments[3]._point._x + segments[4]._point._x) / 2;
|
|
|
|
topMidPathy = (segments[3]._point._y + segments[4]._point._y) / 2;
|
2012-10-22 19:31:08 -04:00
|
|
|
topMidPath = new Point(topMidPathx, topMidPathy);
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
//Nothing happens here
|
|
|
|
break;
|
2012-09-30 17:51:50 -04:00
|
|
|
}
|
2012-11-05 22:45:18 -05:00
|
|
|
var deltaY = topMidPath.y - centerPoint._y;
|
|
|
|
var deltaX = topMidPath.x - centerPoint._x;
|
2012-09-30 17:51:50 -04:00
|
|
|
var angleInDegrees = Math.atan2(deltaY, deltaX) * 180 / Math.PI;
|
|
|
|
return angleInDegrees;
|
2012-11-04 01:43:45 -05:00
|
|
|
}
|
2012-09-30 17:51:50 -04:00
|
|
|
|
2012-11-05 22:44:23 -05:00
|
|
|
function pathSetup(path, segments) {
|
2012-11-04 01:43:45 -05:00
|
|
|
var svgPath = createElement('path');
|
2012-11-05 22:56:49 -05:00
|
|
|
var parts = [];
|
|
|
|
parts.push('M' + segments[0]._point._x + ',' + segments[0]._point._y);
|
2012-11-05 23:06:54 -05:00
|
|
|
function drawCurve(seg1, seg2, skipLine) {
|
2012-11-05 23:03:03 -05:00
|
|
|
var point1 = seg1._point,
|
|
|
|
point2 = seg2._point,
|
|
|
|
x1 = point1._x,
|
|
|
|
y1 = point1._y,
|
|
|
|
x2 = point2._x,
|
|
|
|
y2 = point2._y,
|
|
|
|
handle1 = seg1._handleOut,
|
|
|
|
handle2 = seg2._handleIn;
|
|
|
|
if (handle1.isZero() && handle2.isZero()) {
|
2012-11-05 23:06:54 -05:00
|
|
|
if (!skipLine) {
|
2012-11-02 21:23:37 -04:00
|
|
|
// L is lineto, moving to a point with drawing
|
2012-11-05 22:56:49 -05:00
|
|
|
parts.push('L' + x2 + ',' + y2 + ' ');
|
2012-11-05 23:06:54 -05:00
|
|
|
}
|
2012-09-30 17:51:50 -04:00
|
|
|
} else {
|
2012-11-05 23:03:03 -05:00
|
|
|
// c is curveto, relative: handle1, handle2 + end - start, end - start
|
|
|
|
x2 -= x1;
|
|
|
|
y2 -= y1;
|
|
|
|
parts.push(
|
|
|
|
'c' + handle1._x + ',' + handle1._y,
|
|
|
|
(x2 + handle2._x) + ',' + (y2 + handle2._y),
|
|
|
|
x2 + ',' + y2
|
|
|
|
);
|
2012-09-30 17:51:50 -04:00
|
|
|
}
|
|
|
|
}
|
2012-11-05 22:56:49 -05:00
|
|
|
for (i = 0; i < segments.length - 1; i++)
|
2012-11-05 23:06:54 -05:00
|
|
|
drawCurve(segments[i], segments[i + 1], false);
|
2012-11-05 23:03:03 -05:00
|
|
|
// We only need to draw the connecting curve if the path is cosed and
|
|
|
|
// has a stroke color, or if it's filled.
|
2012-11-05 23:06:54 -05:00
|
|
|
if (path._closed && path._style._strokeColor || path._style._fillColor)
|
|
|
|
drawCurve(segments[segments.length - 1], segments[0], true);
|
2012-11-05 23:03:03 -05:00
|
|
|
if (path._closed)
|
2012-11-05 22:56:49 -05:00
|
|
|
parts.push('z');
|
|
|
|
svgPath.setAttribute('d', parts.join(' '));
|
2012-09-30 17:51:50 -04:00
|
|
|
return svgPath;
|
2012-11-04 01:43:45 -05:00
|
|
|
}
|
2012-09-30 17:51:50 -04:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Checks the type SVG object created by converting from Paper.js
|
|
|
|
*/
|
2012-11-05 22:44:23 -05:00
|
|
|
function determineType(path, segments) {
|
2012-09-30 17:51:50 -04:00
|
|
|
var type;
|
|
|
|
var dPoint12;
|
|
|
|
var dPoint34;
|
2012-11-02 21:22:01 -04:00
|
|
|
// See if actually have any curves in the path. Differentiate
|
|
|
|
// between straight objects (line, polyline, rect, and polygon) and
|
|
|
|
// objects with curves(circle, ellipse, roundedRectangle).
|
2012-11-04 02:04:15 -05:00
|
|
|
if (path.isPolygon()) {
|
2012-11-05 22:44:23 -05:00
|
|
|
if (segments.length == 4) {
|
2012-11-02 21:22:01 -04:00
|
|
|
// If the distance between (point0 and point1) and (point2 and
|
|
|
|
// point3) are equal, then it is a rectangle
|
2012-11-05 23:10:31 -05:00
|
|
|
dPoint12 = Math.round(getDistance(segments, 0, 1));
|
|
|
|
dPoint34 = Math.round(getDistance(segments, 3, 2));
|
2012-11-02 21:22:01 -04:00
|
|
|
if (dPoint12 == dPoint34) {
|
|
|
|
type = 'rect';
|
|
|
|
}
|
2012-11-05 22:44:23 -05:00
|
|
|
} else if (segments.length >= 3) {
|
2012-11-02 21:22:01 -04:00
|
|
|
//If it is an object with more than 3 segments and the path is closed, it is a polygon
|
|
|
|
if (path.getClosed()) {
|
|
|
|
type = 'polygon';
|
|
|
|
} else {
|
|
|
|
type = 'polyline';
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
//if all of the handle values are == 0 and there are only 2 segments, it is a line
|
|
|
|
type = 'line';
|
|
|
|
}
|
|
|
|
} else {
|
2012-11-05 22:44:23 -05:00
|
|
|
if (segments.length == 8) {
|
2012-11-02 21:22:01 -04:00
|
|
|
// If the distance between (point0 and point3) and (point7 and
|
|
|
|
// point4) are equal then it is a roundedRectangle
|
2012-11-05 23:10:31 -05:00
|
|
|
dPoint12 = Math.round(getDistance(segments, 0, 3));
|
|
|
|
dPoint34 = Math.round(getDistance(segments, 7, 4));
|
2012-10-22 19:31:08 -04:00
|
|
|
if (dPoint12 == dPoint34) {
|
2012-11-02 21:22:01 -04:00
|
|
|
type = 'roundrect';
|
2012-09-30 17:51:50 -04:00
|
|
|
}
|
2012-11-05 22:44:23 -05:00
|
|
|
} else if (segments.length == 4) {
|
2012-11-02 21:22:01 -04:00
|
|
|
// Check if the values of the point have values similar to
|
|
|
|
// circles and ellipses.
|
2012-09-30 17:51:50 -04:00
|
|
|
var checkPointValues = true;
|
2012-11-05 22:44:23 -05:00
|
|
|
for (i = 0; i < segments.length && checkPointValues; i++) {
|
2012-11-05 22:45:18 -05:00
|
|
|
if (segments[i]._handleIn._x != 0 || segments[i]._handleIn._y != 0
|
|
|
|
&& Math.round(Math.abs(segments[i]._handleIn._x)) === Math.round(Math.abs(segments[i]._handleOut._x))
|
|
|
|
&& Math.round(Math.abs(segments[i]._handleIn._y)) === Math.round(Math.abs(segments[i]._handleOut._y))) {
|
2012-09-30 17:51:50 -04:00
|
|
|
checkPointValues = true;
|
|
|
|
} else {
|
|
|
|
checkPointValues = false;
|
|
|
|
}
|
|
|
|
}
|
2012-11-02 21:22:01 -04:00
|
|
|
if (checkPointValues) {
|
|
|
|
// If the distance between (point0 and point2) and (point1
|
|
|
|
// and point3) are equal, then it is a circle
|
2012-11-05 23:10:31 -05:00
|
|
|
var d1 = Math.round(getDistance(segments, 0, 2));
|
|
|
|
var d2 = Math.round(getDistance(segments, 1, 3));
|
2012-10-22 19:31:08 -04:00
|
|
|
if (d1 == d2) {
|
2012-09-30 17:51:50 -04:00
|
|
|
type = 'circle';
|
|
|
|
} else {
|
|
|
|
type = 'ellipse';
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return type;
|
|
|
|
}
|
2012-11-04 01:43:45 -05:00
|
|
|
|
2012-11-04 12:01:11 -05:00
|
|
|
function applyStyle(item, svg) {
|
|
|
|
var attrs = {},
|
|
|
|
style = item._style,
|
2012-11-05 12:05:32 -05:00
|
|
|
parent = item.getParent(),
|
2012-11-05 21:58:16 -05:00
|
|
|
parentStyle = parent && parent._style;
|
2012-11-04 12:01:11 -05:00
|
|
|
|
|
|
|
if (item._name != null)
|
2012-11-05 22:26:54 -05:00
|
|
|
attrs.id = item._name;
|
2012-11-04 12:01:11 -05:00
|
|
|
|
2012-11-05 21:58:16 -05:00
|
|
|
Base.each(SvgStyles.properties, function(entry) {
|
2012-11-04 12:01:11 -05:00
|
|
|
// Get a given style only if it differs from the value on the parent
|
|
|
|
// (A layer or group which can have style values in SVG).
|
2012-11-05 22:03:42 -05:00
|
|
|
var value = style[entry.get]();
|
2012-11-05 12:05:32 -05:00
|
|
|
if (value != null && (!parentStyle
|
2012-11-05 22:03:42 -05:00
|
|
|
|| !Base.equals(parentStyle[entry.get](), value))) {
|
2012-11-05 21:58:16 -05:00
|
|
|
attrs[entry.attribute] = entry.type === 'color'
|
2012-11-04 12:01:11 -05:00
|
|
|
? value.toCssString()
|
2012-11-05 21:58:16 -05:00
|
|
|
: entry.type === 'array'
|
2012-11-04 12:01:11 -05:00
|
|
|
? value.join(',')
|
|
|
|
: value;
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
if (item._opacity != null)
|
|
|
|
attrs.opacity = item._opacity;
|
|
|
|
|
|
|
|
if (item._visibility != null)
|
|
|
|
attrs._visibility = item._visibility ? 'visible' : 'hidden';
|
|
|
|
|
|
|
|
setAttributes(svg, attrs);
|
|
|
|
}
|
|
|
|
|
2012-11-04 01:43:45 -05:00
|
|
|
return /** @Lends SvgExporter */{
|
|
|
|
/**
|
|
|
|
* Takes the selected Paper.js project and parses all of its layers and
|
|
|
|
* groups to be placed into SVG groups, converting the project into one
|
|
|
|
* SVG group.
|
|
|
|
*
|
|
|
|
* @function
|
|
|
|
* @param {Project} project a Paper.js project
|
|
|
|
* @return {SVGSVGElement} the imported project converted to an SVG project
|
|
|
|
*/
|
|
|
|
// TODO: Implement symbols and Gradients
|
|
|
|
exportProject: function(project) {
|
|
|
|
var svg = createElement('svg'),
|
|
|
|
layers = project.layers;
|
|
|
|
for (var i = 0, l = layers.length; i < l; i++) {
|
|
|
|
svg.appendChild(this.exportItem(layers[i]));
|
|
|
|
}
|
|
|
|
return svg;
|
|
|
|
},
|
|
|
|
|
|
|
|
exportItem: function(item) {
|
|
|
|
var exporter = exporters[item._type];
|
|
|
|
// TODO: exporter == null: Not supported yet.
|
|
|
|
var svg = exporter && exporter(item);
|
|
|
|
return svg;
|
|
|
|
}
|
|
|
|
};
|
2012-11-02 19:19:45 -04:00
|
|
|
};
|