2013-01-28 21:03:27 -05:00
|
|
|
/*
|
|
|
|
* Paper.js - The Swiss Army Knife of Vector Graphics Scripting.
|
2012-11-06 16:07:18 -05:00
|
|
|
* http://paperjs.org/
|
|
|
|
*
|
2018-12-27 02:13:01 -05:00
|
|
|
* Copyright (c) 2011 - 2019, Juerg Lehni & Jonathan Puckey
|
2018-11-10 02:19:34 -05:00
|
|
|
* http://scratchdisk.com/ & https://puckey.studio/
|
2012-11-06 16:07:18 -05:00
|
|
|
*
|
|
|
|
* Distributed under the MIT license. See LICENSE file for details.
|
|
|
|
*
|
|
|
|
* All rights reserved.
|
|
|
|
*/
|
|
|
|
|
2016-02-01 06:50:22 -05:00
|
|
|
QUnit.module('SvgExport');
|
2012-09-30 17:51:50 -04:00
|
|
|
|
2015-07-27 05:42:41 -04:00
|
|
|
test('Export SVG line', function() {
|
|
|
|
var attrs = {
|
|
|
|
x1: 5,
|
|
|
|
x2: 45,
|
|
|
|
y1: 5,
|
|
|
|
y2: 45
|
|
|
|
};
|
|
|
|
var path = new Path.Line([attrs.x1, attrs.y1], [attrs.x2, attrs.y2]);
|
2015-08-17 08:18:22 -04:00
|
|
|
equals(path.exportSVG({ matchShapes: true }), createSVG('line', attrs));
|
2012-09-30 17:51:50 -04:00
|
|
|
});
|
|
|
|
|
2015-07-27 05:42:41 -04:00
|
|
|
test('Export SVG rect', function() {
|
|
|
|
var attrs = {
|
|
|
|
x: 25,
|
|
|
|
y: 25,
|
|
|
|
width: 100,
|
|
|
|
height: 100
|
|
|
|
};
|
|
|
|
var path = new Path.Rectangle(attrs);
|
|
|
|
equals(path.exportSVG({ matchShapes: true }), createSVG('rect', attrs));
|
2012-09-30 17:51:50 -04:00
|
|
|
});
|
|
|
|
|
2015-07-27 05:42:41 -04:00
|
|
|
test('Export SVG round rect', function() {
|
|
|
|
var attrs = {
|
|
|
|
x: 25,
|
|
|
|
y: 25,
|
|
|
|
rx: 50,
|
|
|
|
ry: 50,
|
|
|
|
width: 100,
|
|
|
|
height: 100
|
|
|
|
};
|
|
|
|
var path = new Path.Rectangle(new Rectangle(attrs),
|
|
|
|
new Size(attrs.rx, attrs.ry));
|
|
|
|
equals(path.exportSVG({ matchShapes: true }), createSVG('rect', attrs));
|
2012-09-30 17:51:50 -04:00
|
|
|
});
|
|
|
|
|
2015-07-27 05:42:41 -04:00
|
|
|
test('Export SVG ellipse', function() {
|
|
|
|
var attrs = {
|
|
|
|
cx: 300,
|
|
|
|
cy: 80,
|
|
|
|
rx: 100,
|
|
|
|
ry: 50
|
2016-02-11 05:06:09 -05:00
|
|
|
};
|
2015-07-27 05:42:41 -04:00
|
|
|
var path = new Path.Ellipse({
|
|
|
|
center: new Point(attrs.cx, attrs.cy),
|
|
|
|
radius: new Point(attrs.rx, attrs.ry)
|
|
|
|
});
|
|
|
|
equals(path.exportSVG({ matchShapes: true }), createSVG('ellipse', attrs));
|
2012-09-30 17:51:50 -04:00
|
|
|
});
|
|
|
|
|
2015-07-27 05:42:41 -04:00
|
|
|
test('Export SVG circle', function() {
|
|
|
|
var attrs = {
|
|
|
|
cx: 100,
|
|
|
|
cy: 80,
|
|
|
|
r: 50
|
2016-02-11 05:06:09 -05:00
|
|
|
};
|
2015-07-27 05:42:41 -04:00
|
|
|
var path = new Path.Circle({
|
|
|
|
center: new Point(attrs.cx, attrs.cy),
|
|
|
|
radius: attrs.r
|
|
|
|
});
|
|
|
|
equals(path.exportSVG({ matchShapes: true }), createSVG('circle', attrs));
|
2012-09-30 17:51:50 -04:00
|
|
|
});
|
|
|
|
|
2015-07-27 05:42:41 -04:00
|
|
|
function createPolyPath(str) {
|
|
|
|
var points = str.split(' ').map(function(point) {
|
|
|
|
return point.split(',').map(parseFloat);
|
|
|
|
});
|
|
|
|
var path = new Path();
|
|
|
|
path.moveTo(points[0]);
|
|
|
|
for (var i = 1; i < points.length; i++)
|
|
|
|
path.lineTo(points[i]);
|
|
|
|
return path;
|
|
|
|
}
|
|
|
|
|
|
|
|
test('Export SVG polygon', function() {
|
|
|
|
var points = '100,10 40,180 190,60 10,60 160,180';
|
|
|
|
var path = createPolyPath(points);
|
|
|
|
path.closePath();
|
|
|
|
equals(path.exportSVG({ matchShapes: true }), createSVG('polygon', {
|
|
|
|
points: points
|
|
|
|
}));
|
2012-09-30 17:51:50 -04:00
|
|
|
});
|
|
|
|
|
2015-07-27 05:42:41 -04:00
|
|
|
test('Export SVG polyline', function() {
|
|
|
|
var points = '5,5 45,45 5,45 45,5';
|
|
|
|
var path = createPolyPath(points);
|
|
|
|
equals(path.exportSVG({ matchShapes: true }), createSVG('polyline', {
|
|
|
|
points: points
|
|
|
|
}));
|
2012-09-30 17:51:50 -04:00
|
|
|
});
|
2015-07-27 05:42:41 -04:00
|
|
|
|
2015-10-27 18:33:09 -04:00
|
|
|
test('Export SVG path defaults to precision 5', function() {
|
|
|
|
var path = new Path('M0.123456789,1.9l0.8,1.1');
|
|
|
|
equals(path.exportSVG({}).getAttribute('d'), 'M0.12346,1.9l0.8,1.1');
|
|
|
|
});
|
|
|
|
|
|
|
|
test('Export SVG path at precision 0', function() {
|
|
|
|
var path = new Path('M0.123456789,1.9l0.8,1.1');
|
|
|
|
equals(path.exportSVG({ precision: 0 }).getAttribute('d'), 'M0,2l1,1');
|
|
|
|
});
|
2016-02-14 18:13:38 -05:00
|
|
|
|
2016-02-15 03:21:11 -05:00
|
|
|
if (!isNode) {
|
|
|
|
// JSDom does not have SVG rendering, so we can't test there.
|
|
|
|
test('Export transformed shapes', function(assert) {
|
|
|
|
var rect = new Shape.Rectangle({
|
|
|
|
point: [200, 100],
|
|
|
|
size: [200, 300],
|
|
|
|
fillColor: 'red'
|
|
|
|
});
|
|
|
|
rect.rotate(40);
|
2016-02-14 18:13:38 -05:00
|
|
|
|
2016-02-15 03:21:11 -05:00
|
|
|
var circle = new Shape.Circle({
|
|
|
|
center: [200, 300],
|
|
|
|
radius: 100,
|
|
|
|
fillColor: 'green'
|
|
|
|
});
|
|
|
|
circle.scale(0.5, 1);
|
|
|
|
circle.rotate(40);
|
2016-02-14 18:13:38 -05:00
|
|
|
|
2016-02-15 03:21:11 -05:00
|
|
|
var ellipse = new Shape.Ellipse({
|
|
|
|
point: [300, 300],
|
|
|
|
size: [100, 200],
|
|
|
|
fillColor: 'blue'
|
|
|
|
});
|
|
|
|
ellipse.rotate(-40);
|
2016-02-14 18:13:38 -05:00
|
|
|
|
2016-02-15 03:21:11 -05:00
|
|
|
var rect = new Shape.Rectangle({
|
|
|
|
point: [250, 20],
|
|
|
|
size: [200, 300],
|
|
|
|
radius: [40, 20],
|
|
|
|
fillColor: 'yellow'
|
|
|
|
});
|
|
|
|
rect.rotate(-20);
|
|
|
|
var svg = project.exportSVG({ bounds: 'content', asString: true });
|
|
|
|
compareSVG(assert.async(), svg, project.activeLayer);
|
2016-02-14 18:13:38 -05:00
|
|
|
});
|
2016-04-06 23:05:32 -04:00
|
|
|
|
|
|
|
test('Export gradients', function(assert) {
|
|
|
|
var bounds = new Rectangle(new Size(300, 600));
|
|
|
|
var stops = [new Color(1, 1, 0, 0), 'red', 'black'];
|
|
|
|
|
|
|
|
var radius = bounds.width * 0.4,
|
|
|
|
from = new Point(bounds.center.x),
|
2016-05-27 05:37:59 -04:00
|
|
|
to = from.add(radius, 0);
|
2016-04-06 23:05:32 -04:00
|
|
|
|
|
|
|
var circle = new Path.Circle({
|
|
|
|
center: from,
|
|
|
|
radius: radius,
|
|
|
|
fillColor: {
|
|
|
|
stops: stops,
|
|
|
|
radial: true,
|
|
|
|
origin: from,
|
|
|
|
destination: to
|
|
|
|
},
|
|
|
|
strokeColor: 'black'
|
|
|
|
});
|
|
|
|
|
|
|
|
var from = bounds.leftCenter,
|
|
|
|
to = bounds.bottomRight;
|
|
|
|
|
|
|
|
var rect = new Path.Rectangle({
|
|
|
|
from: from,
|
|
|
|
to: to,
|
|
|
|
fillColor: {
|
|
|
|
stops: stops,
|
|
|
|
radial: false,
|
|
|
|
origin: from,
|
|
|
|
destination: to
|
|
|
|
},
|
|
|
|
strokeColor: 'black'
|
|
|
|
});
|
|
|
|
|
|
|
|
rect.rotate(45).scale(0.7);
|
|
|
|
|
|
|
|
var svg = project.exportSVG({ bounds: 'content', asString: true });
|
2016-04-13 17:08:52 -04:00
|
|
|
compareSVG(assert.async(), svg, project.activeLayer, null, {
|
2016-04-13 17:37:13 -04:00
|
|
|
tolerance: 1e-2
|
2016-04-13 17:08:52 -04:00
|
|
|
});
|
2016-04-06 23:05:32 -04:00
|
|
|
});
|
2016-11-20 20:53:41 -05:00
|
|
|
|
|
|
|
test('Export SVG with clipping defs', function(assert) {
|
|
|
|
var group = new Group({
|
|
|
|
children: [
|
|
|
|
new Path.Circle({
|
|
|
|
center: [150, 150],
|
|
|
|
radius: 50
|
|
|
|
}),
|
|
|
|
new Path.Rectangle({
|
|
|
|
point: [100, 100],
|
|
|
|
size: [100, 100],
|
|
|
|
fillColor: 'green'
|
|
|
|
})
|
|
|
|
],
|
|
|
|
clipped: true
|
|
|
|
});
|
|
|
|
var svg = project.exportSVG({ bounds: 'content', asString: true });
|
|
|
|
compareSVG(assert.async(), svg, project.activeLayer, null, {
|
|
|
|
tolerance: 1e-2
|
|
|
|
});
|
|
|
|
});
|
2016-02-15 03:21:11 -05:00
|
|
|
}
|