mirror of
https://github.com/scratchfoundation/paper.js.git
synced 2025-01-19 14:10:14 -05:00
Clean up SVGExport tests.
This commit is contained in:
parent
5604dd7a30
commit
3816407ee7
4 changed files with 111 additions and 523 deletions
|
@ -67,6 +67,28 @@ var comparators = {
|
||||||
QUnit.push(Base.equals(actual, expected), actual, expected, message);
|
QUnit.push(Base.equals(actual, expected), actual, expected, message);
|
||||||
},
|
},
|
||||||
|
|
||||||
|
Element: function(actual, expected, message, options) {
|
||||||
|
// Convention: Loop through the attribute lists of both actual and
|
||||||
|
// expected element, and compare values even if they may be inherited.
|
||||||
|
// This is to handle styling values on SVGElements more flexibly.
|
||||||
|
equals(actual && actual.tagName, expected.tagName,
|
||||||
|
(message || '') + '.tagName', options);
|
||||||
|
for (var i = 0; i < expected.attributes.length; i++) {
|
||||||
|
var attr = expected.attributes[i];
|
||||||
|
if (attr.specified) {
|
||||||
|
equals(actual && actual.getAttribute(attr.name), attr.value,
|
||||||
|
(message || '') + '.' + attr.name, options);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
for (var i = 0; i < actual && actual.attributes.length; i++) {
|
||||||
|
var attr = actual.attributes[i];
|
||||||
|
if (attr.specified) {
|
||||||
|
equals(attr.value, expected.getAttribute(attr.name)
|
||||||
|
(message || '') + '.' + attr.name, options);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
Base: function(actual, expected, message, options) {
|
Base: function(actual, expected, message, options) {
|
||||||
comparators.Object(actual, expected, message, options);
|
comparators.Object(actual, expected, message, options);
|
||||||
},
|
},
|
||||||
|
@ -228,14 +250,12 @@ function equals(actual, expected, message, options) {
|
||||||
|| type === 'boolean' && 'Boolean'
|
|| type === 'boolean' && 'Boolean'
|
||||||
|| type === 'undefined' && 'Undefined'
|
|| type === 'undefined' && 'Undefined'
|
||||||
|| Array.isArray(expected) && 'Array'
|
|| Array.isArray(expected) && 'Array'
|
||||||
|| (cls = expected && expected._class)
|
|| expected instanceof Element && 'Element' // handle DOM Elements
|
||||||
|| type === 'object' && 'Object';
|
|| (cls = expected && expected._class) // check _class 2nd last
|
||||||
|
|| type === 'object' && 'Object'; // Object as catch-all
|
||||||
var comparator = type && comparators[type];
|
var comparator = type && comparators[type];
|
||||||
if (!message) {
|
if (!message)
|
||||||
message = type
|
message = type ? type.toLowerCase() : 'value';
|
||||||
? type.charAt(0).toLowerCase() + type.substring(1)
|
|
||||||
: 'value';
|
|
||||||
}
|
|
||||||
if (comparator) {
|
if (comparator) {
|
||||||
comparator(actual, expected, message, options);
|
comparator(actual, expected, message, options);
|
||||||
} else if (expected && expected.equals) {
|
} else if (expected && expected.equals) {
|
||||||
|
|
|
@ -12,527 +12,94 @@
|
||||||
|
|
||||||
module('SVGExport');
|
module('SVGExport');
|
||||||
|
|
||||||
// TODO: Implement proper tests and clean up testing code
|
test('Export SVG line', function() {
|
||||||
|
var attrs = {
|
||||||
test('compare line path functions', function() {
|
x1: 5,
|
||||||
var svgns = 'http://www.w3.org/2000/svg';
|
x2: 45,
|
||||||
var shape = document.createElementNS(svgns, 'line');
|
y1: 5,
|
||||||
var x1 = 5,
|
y2: 45
|
||||||
x2 = 45,
|
};
|
||||||
y1 = 5,
|
var path = new Path.Line([attrs.x1, attrs.y1], [attrs.x2, attrs.y2]);
|
||||||
y2 = 45;
|
equals(path.exportSVG(), createSVG('line', attrs));
|
||||||
shape.setAttribute('x1', x1);
|
|
||||||
shape.setAttribute('y1', y1);
|
|
||||||
shape.setAttribute('x2', x2);
|
|
||||||
shape.setAttribute('y2', y2);
|
|
||||||
|
|
||||||
var line = new Path.Line([x1, y1], [x2, y2]);
|
|
||||||
|
|
||||||
var exportedLine = line.exportSVG();
|
|
||||||
|
|
||||||
var shapex1 = shape.getAttribute('x1');
|
|
||||||
var shapey1 = shape.getAttribute('y1');
|
|
||||||
var shapex2 = shape.getAttribute('x2');
|
|
||||||
var shapey2 = shape.getAttribute('y2');
|
|
||||||
|
|
||||||
var exportedx1 = exportedLine.getAttribute('x1');
|
|
||||||
var exportedy1 = exportedLine.getAttribute('y1');
|
|
||||||
var exportedx2 = exportedLine.getAttribute('x2');
|
|
||||||
var exportedy2 = exportedLine.getAttribute('y2');
|
|
||||||
|
|
||||||
equals(shapex1, exportedx1);
|
|
||||||
equals(shapey1, exportedy1);
|
|
||||||
equals(shapex2, exportedx2);
|
|
||||||
equals(shapey2, exportedy2);
|
|
||||||
|
|
||||||
});
|
});
|
||||||
|
|
||||||
test('compare negative line path functions', function() {
|
test('Export SVG rect', function() {
|
||||||
var svgns = 'http://www.w3.org/2000/svg';
|
var attrs = {
|
||||||
var shape = document.createElementNS(svgns, 'line');
|
x: 25,
|
||||||
var x1 = -5,
|
y: 25,
|
||||||
x2 = -45,
|
width: 100,
|
||||||
y1 = -5,
|
height: 100
|
||||||
y2 = -45;
|
};
|
||||||
shape.setAttribute('x1', x1);
|
var path = new Path.Rectangle(attrs);
|
||||||
shape.setAttribute('y1', y1);
|
equals(path.exportSVG({ matchShapes: true }), createSVG('rect', attrs));
|
||||||
shape.setAttribute('x2', x2);
|
|
||||||
shape.setAttribute('y2', y2);
|
|
||||||
|
|
||||||
var line = new Path.Line([x1, y1], [x2, y2]);
|
|
||||||
|
|
||||||
var exportedLine = line.exportSVG();
|
|
||||||
|
|
||||||
var shapex1 = shape.getAttribute('x1');
|
|
||||||
var shapey1 = shape.getAttribute('y1');
|
|
||||||
var shapex2 = shape.getAttribute('x2');
|
|
||||||
var shapey2 = shape.getAttribute('y2');
|
|
||||||
|
|
||||||
var exportedx1 = exportedLine.getAttribute('x1');
|
|
||||||
var exportedy1 = exportedLine.getAttribute('y1');
|
|
||||||
var exportedx2 = exportedLine.getAttribute('x2');
|
|
||||||
var exportedy2 = exportedLine.getAttribute('y2');
|
|
||||||
|
|
||||||
equals(shapex1, exportedx1);
|
|
||||||
equals(shapey1, exportedy1);
|
|
||||||
equals(shapex2, exportedx2);
|
|
||||||
equals(shapey2, exportedy2);
|
|
||||||
|
|
||||||
});
|
});
|
||||||
|
|
||||||
test('compare invalid line path functions', function() {
|
test('Export SVG round rect', function() {
|
||||||
var svgns = 'http://www.w3.org/2000/svg';
|
var attrs = {
|
||||||
var shape = document.createElementNS(svgns, 'line');
|
x: 25,
|
||||||
var x1 = null,
|
y: 25,
|
||||||
x2 = null,
|
rx: 50,
|
||||||
y1 = null,
|
ry: 50,
|
||||||
y2 = null;
|
width: 100,
|
||||||
shape.setAttribute('x1', x1);
|
height: 100
|
||||||
shape.setAttribute('y1', y1);
|
};
|
||||||
shape.setAttribute('x2', x2);
|
var path = new Path.Rectangle(new Rectangle(attrs),
|
||||||
shape.setAttribute('y2', y2);
|
new Size(attrs.rx, attrs.ry));
|
||||||
|
equals(path.exportSVG({ matchShapes: true }), createSVG('rect', attrs));
|
||||||
var line = new Path.Line([x1, y1], [x2, y2]);
|
|
||||||
|
|
||||||
var exportedLine = line.exportSVG();
|
|
||||||
|
|
||||||
var shapex1 = shape.getAttribute('x1');
|
|
||||||
var shapey1 = shape.getAttribute('y1');
|
|
||||||
var shapex2 = shape.getAttribute('x2');
|
|
||||||
var shapey2 = shape.getAttribute('y2');
|
|
||||||
|
|
||||||
var exportedx1 = exportedLine.getAttribute('x1');
|
|
||||||
var exportedy1 = exportedLine.getAttribute('y1');
|
|
||||||
var exportedx2 = exportedLine.getAttribute('x2');
|
|
||||||
var exportedy2 = exportedLine.getAttribute('y2');
|
|
||||||
|
|
||||||
equals(shapex1, exportedx1);
|
|
||||||
equals(shapey1, exportedy1);
|
|
||||||
equals(shapex2, exportedx2);
|
|
||||||
equals(shapey2, exportedy2);
|
|
||||||
|
|
||||||
});
|
});
|
||||||
|
|
||||||
/*
|
test('Export SVG ellipse', function() {
|
||||||
test('compare rectangle values', function() {
|
var attrs = {
|
||||||
var svgns = 'http://www.w3.org/2000/svg';
|
cx: 300,
|
||||||
var shape = document.createElementNS(svgns, 'rect');
|
cy: 80,
|
||||||
var x = 25,
|
rx: 100,
|
||||||
y = 25,
|
ry: 50
|
||||||
width = 100,
|
|
||||||
height = 100;
|
|
||||||
shape.setAttribute('x', x);
|
|
||||||
shape.setAttribute('y', y);
|
|
||||||
shape.setAttribute('width', width);
|
|
||||||
shape.setAttribute('height', height);
|
|
||||||
|
|
||||||
var point = new Point(100, 100);
|
|
||||||
var size = new Size(100, 100);
|
|
||||||
var path = new Path.Rectangle(point, size);
|
|
||||||
|
|
||||||
var exportedRectangle = path.exportSVG();
|
|
||||||
|
|
||||||
var shapex1 = shape.getAttribute('x');
|
|
||||||
var shapey1 = shape.getAttribute('y1');
|
|
||||||
var shapewidth = shape.getAttribute('width');
|
|
||||||
var shapeheight = shape.getAttribute('height');
|
|
||||||
|
|
||||||
var exportedx = exportedRectangle.getAttribute('x1');
|
|
||||||
var exportedy = exportedRectangle.getAttribute('y1');
|
|
||||||
|
|
||||||
var exportedwidth = exportedRectangle.getAttribute('width');
|
|
||||||
var exportedheight = exportedRectangle.getAttribute('height');
|
|
||||||
|
|
||||||
equals(shapex, exportedx);
|
|
||||||
equals(shapey, exportedy);
|
|
||||||
equals(shapewidth, exportedwidth);
|
|
||||||
equals(shapeheight, exportedheight);
|
|
||||||
});
|
|
||||||
|
|
||||||
test('compare negative rectangle values', function() {
|
|
||||||
var svgns = 'http://www.w3.org/2000/svg';
|
|
||||||
var shape = document.createElementNS(svgns, 'rect');
|
|
||||||
var x = -25,
|
|
||||||
y = -25,
|
|
||||||
width = -100,
|
|
||||||
height = -100;
|
|
||||||
shape.setAttribute('x', x);
|
|
||||||
shape.setAttribute('y', y);
|
|
||||||
shape.setAttribute('width', width);
|
|
||||||
shape.setAttribute('height', height);
|
|
||||||
|
|
||||||
var topLeft = new Point(x, y);
|
|
||||||
var size = new Size(width, height);
|
|
||||||
var rect = new Rectangle(topLeft, size);
|
|
||||||
|
|
||||||
var exportedRectangle = rect.exportSVG();
|
|
||||||
|
|
||||||
var shapex = shape.getAttribute('x');
|
|
||||||
var shapey = shape.getAttribute('y');
|
|
||||||
var shapewidth = shape.getAttribute('width');
|
|
||||||
var shapeheight = shape.getAttribute('height');
|
|
||||||
|
|
||||||
var exportedx = exportedRectangle.getAttribute('x');
|
|
||||||
var exportedy = exportedRectangle.getAttribute('y');
|
|
||||||
var exportedwidth = exportedRectangle.getAttribute('width');
|
|
||||||
var exportedheight = exportedRectangle.getAttribute('height');
|
|
||||||
|
|
||||||
equals(shapex, exportedx);
|
|
||||||
equals(shapey, exportedy);
|
|
||||||
equals(shapewidth, exportedwidth);
|
|
||||||
equals(shapeheight, exportedheight);
|
|
||||||
});
|
|
||||||
|
|
||||||
test('compare invalid rectangle values', function() {
|
|
||||||
var svgns = 'http://www.w3.org/2000/svg';
|
|
||||||
var shape = document.createElementNS(svgns, 'rect');
|
|
||||||
var x = null,
|
|
||||||
y = null,
|
|
||||||
width = null,
|
|
||||||
height = 100;
|
|
||||||
shape.setAttribute('x', x);
|
|
||||||
shape.setAttribute('y', y);
|
|
||||||
shape.setAttribute('width', width);
|
|
||||||
shape.setAttribute('height', height);
|
|
||||||
|
|
||||||
var topLeft = new Point(x, y);
|
|
||||||
var size = new Size(width, height);
|
|
||||||
var rect = new Rectangle(topLeft, size);
|
|
||||||
|
|
||||||
var exportedRectangle = rect.exportSVG();
|
|
||||||
|
|
||||||
var shapex = shape.getAttribute('x');
|
|
||||||
var shapey = shape.getAttribute('y');
|
|
||||||
var shapewidth = shape.getAttribute('width');
|
|
||||||
var shapeheight = shape.getAttribute('height');
|
|
||||||
|
|
||||||
var exportedx = exportedRectangle.getAttribute('x');
|
|
||||||
var exportedy = exportedRectangle.getAttribute('y');
|
|
||||||
var exportedwidth = exportedRectangle.getAttribute('width');
|
|
||||||
var exportedheight = exportedRectangle.getAttribute('height');
|
|
||||||
|
|
||||||
equals(shapex, exportedx);
|
|
||||||
equals(shapey, exportedy);
|
|
||||||
equals(shapewidth, exportedwidth);
|
|
||||||
equals(shapeheight, exportedheight);
|
|
||||||
});
|
|
||||||
|
|
||||||
test('compare rounded rectangle values', function() {
|
|
||||||
var svgns = 'http://www.w3.org/2000/svg';
|
|
||||||
var shape = document.createElementNS(svgns, 'rect');
|
|
||||||
var x = 25,
|
|
||||||
y = 25,
|
|
||||||
rx = 50,
|
|
||||||
ry = 50,
|
|
||||||
width = 100,
|
|
||||||
height = 100;
|
|
||||||
shape.setAttribute('x', x);
|
|
||||||
shape.setAttribute('y', y);
|
|
||||||
shape.setAttribute('rx', rx);
|
|
||||||
shape.setAttribute('ry', ry);
|
|
||||||
shape.setAttribute('width', width);
|
|
||||||
shape.setAttribute('height', height);
|
|
||||||
|
|
||||||
var topLeft = new Point(x, y);
|
|
||||||
var size = new Size(width, height);
|
|
||||||
var cornerSize = new Size(rx, ry);
|
|
||||||
var rect = new Rectangle(topLeft, size);
|
|
||||||
var roundRect = new Path.Rectangle(rect, cornerSize);
|
|
||||||
|
|
||||||
var exportedRectangle = rect.exportSVG();
|
|
||||||
|
|
||||||
var shapex = shape.getAttribute('x');
|
|
||||||
var shapey = shape.getAttribute('y');
|
|
||||||
var shapecx = shape.getAttribute('rx');
|
|
||||||
var shapecy = shape.getAttribute('ry');
|
|
||||||
var shapewidth = shape.getAttribute('width');
|
|
||||||
var shapeheight = shape.getAttribute('height');
|
|
||||||
|
|
||||||
var exportedx = exportedRectangle.getAttribute('x');
|
|
||||||
var exportedy = exportedRectangle.getAttribute('y');
|
|
||||||
var exportedcx = exportedRectangle.getAttribute('rx');
|
|
||||||
var exportedcy = exportedRectangle.getAttribute('ry');
|
|
||||||
var exportedwidth = exportedRectangle.getAttribute('width');
|
|
||||||
var exportedheight = exportedRectangle.getAttribute('height');
|
|
||||||
|
|
||||||
equals(shapex, exportedx);
|
|
||||||
equals(shapey, exportedy);
|
|
||||||
equals(shapewidth, exportedwidth);
|
|
||||||
equals(shapeheight, exportedheight);
|
|
||||||
});
|
|
||||||
|
|
||||||
test('compare negative rounded rectangle values', function() {
|
|
||||||
var svgns = 'http://www.w3.org/2000/svg';
|
|
||||||
var shape = document.createElementNS(svgns, 'rect');
|
|
||||||
var x = -25,
|
|
||||||
y = -25,
|
|
||||||
rx = -50,
|
|
||||||
ry = -50,
|
|
||||||
width = -100,
|
|
||||||
height = -100;
|
|
||||||
shape.setAttribute('x', x);
|
|
||||||
shape.setAttribute('y', y);
|
|
||||||
shape.setAttribute('rx', rx);
|
|
||||||
shape.setAttribute('ry', ry);
|
|
||||||
shape.setAttribute('width', width);
|
|
||||||
shape.setAttribute('height', height);
|
|
||||||
|
|
||||||
var topLeft = new Point(x, y);
|
|
||||||
var size = new Size(width, height);
|
|
||||||
var cornerSize = new Size(rx, ry);
|
|
||||||
var rect = new Rectangle(topLeft, size);
|
|
||||||
var roundRect = new Path.Rectangle(rect, cornerSize);
|
|
||||||
|
|
||||||
var exportedRectangle = rect.exportSVG();
|
|
||||||
|
|
||||||
var shapex = shape.getAttribute('x');
|
|
||||||
var shapey = shape.getAttribute('y');
|
|
||||||
var shapecx = shape.getAttribute('rx');
|
|
||||||
var shapecy = shape.getAttribute('ry');
|
|
||||||
var shapewidth = shape.getAttribute('width');
|
|
||||||
var shapeheight = shape.getAttribute('height');
|
|
||||||
|
|
||||||
var exportedx = exportedRectangle.getAttribute('x');
|
|
||||||
var exportedy = exportedRectangle.getAttribute('y');
|
|
||||||
var exportedcx = exportedRectangle.getAttribute('rx');
|
|
||||||
var exportedcy = exportedRectangle.getAttribute('ry');
|
|
||||||
var exportedwidth = exportedRectangle.getAttribute('width');
|
|
||||||
var exportedheight = exportedRectangle.getAttribute('height');
|
|
||||||
|
|
||||||
equals(shapex, exportedx);
|
|
||||||
equals(shapey, exportedy);
|
|
||||||
equals(shapewidth, exportedwidth);
|
|
||||||
equals(shapeheight, exportedheight);
|
|
||||||
});
|
|
||||||
|
|
||||||
test('compare invalid rounded rectangle values', function() {
|
|
||||||
var svgns = 'http://www.w3.org/2000/svg';
|
|
||||||
var shape = document.createElementNS(svgns, 'rect');
|
|
||||||
var x = null,
|
|
||||||
y = null,
|
|
||||||
rx = null,
|
|
||||||
ry = null,
|
|
||||||
width = null,
|
|
||||||
height = null;
|
|
||||||
shape.setAttribute('x', x);
|
|
||||||
shape.setAttribute('y', y);
|
|
||||||
shape.setAttribute('rx', rx);
|
|
||||||
shape.setAttribute('ry', ry);
|
|
||||||
shape.setAttribute('width', width);
|
|
||||||
shape.setAttribute('height', height);
|
|
||||||
|
|
||||||
var topLeft = new Point(x, y);
|
|
||||||
var size = new Size(width, height);
|
|
||||||
var cornerSize = new Size(rx, ry);
|
|
||||||
var rect = new Rectangle(topLeft, size);
|
|
||||||
var roundRect = new Path.Rectangle(rect, cornerSize);
|
|
||||||
|
|
||||||
var exportedRectangle = rect.exportSVG();
|
|
||||||
|
|
||||||
var shapex = shape.getAttribute('x');
|
|
||||||
var shapey = shape.getAttribute('y');
|
|
||||||
var shapecx = shape.getAttribute('rx');
|
|
||||||
var shapecy = shape.getAttribute('ry');
|
|
||||||
var shapewidth = shape.getAttribute('width');
|
|
||||||
var shapeheight = shape.getAttribute('height');
|
|
||||||
|
|
||||||
var exportedx = exportedRectangle.getAttribute('x');
|
|
||||||
var exportedy = exportedRectangle.getAttribute('y');
|
|
||||||
var exportedcx = exportedRectangle.getAttribute('rx');
|
|
||||||
var exportedcy = exportedRectangle.getAttribute('ry');
|
|
||||||
var exportedwidth = exportedRectangle.getAttribute('width');
|
|
||||||
var exportedheight = exportedRectangle.getAttribute('height');
|
|
||||||
|
|
||||||
equals(shapex, exportedx);
|
|
||||||
equals(shapey, exportedy);
|
|
||||||
equals(shapewidth, exportedwidth);
|
|
||||||
equals(shapeheight, exportedheight);
|
|
||||||
});*/
|
|
||||||
|
|
||||||
test('compare ellipse values', function() {
|
|
||||||
var svgns = 'http://www.w3.org/2000/svg';
|
|
||||||
var shape = document.createElementNS(svgns, 'ellipse');
|
|
||||||
var cx = 100,
|
|
||||||
cy = 80,
|
|
||||||
rx = 50,
|
|
||||||
ry = 30;
|
|
||||||
shape.setAttribute('cx', cx);
|
|
||||||
shape.setAttribute('cy', cy);
|
|
||||||
shape.setAttribute('rx', rx);
|
|
||||||
shape.setAttribute('ry', ry);
|
|
||||||
|
|
||||||
var center = new Point(cx, cy);
|
|
||||||
var offset = new Point(rx, ry);
|
|
||||||
var topLeft = center.subtract(offset);
|
|
||||||
var bottomRight = center.add(offset);
|
|
||||||
|
|
||||||
var rect = new Rectangle(topLeft, bottomRight);
|
|
||||||
var ellipse = new Shape.Ellipse(rect);
|
|
||||||
|
|
||||||
var exportedEllipse = ellipse.exportSVG();
|
|
||||||
|
|
||||||
var shapecx = shape.getAttribute('cx');
|
|
||||||
var shapecy = shape.getAttribute('cy');
|
|
||||||
var shaperx = shape.getAttribute('rx');
|
|
||||||
var shapery = shape.getAttribute('ry');
|
|
||||||
|
|
||||||
var exportedcx = exportedEllipse.getAttribute('cx');
|
|
||||||
var exportedcy = exportedEllipse.getAttribute('cy');
|
|
||||||
var exportedrx = exportedEllipse.getAttribute('rx');
|
|
||||||
var exportedry = exportedEllipse.getAttribute('ry');
|
|
||||||
|
|
||||||
equals(shapecx, exportedcx);
|
|
||||||
equals(shapecy, exportedcy);
|
|
||||||
equals(shaperx, exportedrx);
|
|
||||||
equals(shapery, exportedry);
|
|
||||||
|
|
||||||
});
|
|
||||||
|
|
||||||
test('compare circle values', function() {
|
|
||||||
var svgns = 'http://www.w3.org/2000/svg';
|
|
||||||
var shape = document.createElementNS(svgns, 'circle');
|
|
||||||
var cx = 100,
|
|
||||||
cy = 80,
|
|
||||||
r = 50;
|
|
||||||
shape.setAttribute('cx', cx);
|
|
||||||
shape.setAttribute('cy', cy);
|
|
||||||
shape.setAttribute('r', r);
|
|
||||||
|
|
||||||
var center = new Point(cx, cy);
|
|
||||||
var circle = new Shape.Circle(center, r);
|
|
||||||
|
|
||||||
var exportedCircle = circle.exportSVG();
|
|
||||||
|
|
||||||
var shapecx = shape.getAttribute('cx');
|
|
||||||
var shapecy = shape.getAttribute('cy');
|
|
||||||
var shaper = shape.getAttribute('r');
|
|
||||||
|
|
||||||
var exportedcx = exportedCircle.getAttribute('cx');
|
|
||||||
var exportedcy = exportedCircle.getAttribute('cy');
|
|
||||||
var exportedr = exportedCircle.getAttribute('r');
|
|
||||||
|
|
||||||
equals(shapecx, exportedcx);
|
|
||||||
equals(shapecy, exportedcy);
|
|
||||||
equals(shaper, exportedr);
|
|
||||||
|
|
||||||
});
|
|
||||||
|
|
||||||
test('compare polygon values', function() {
|
|
||||||
var svgns = 'http://www.w3.org/2000/svg';
|
|
||||||
var shape = document.createElementNS(svgns, 'polygon');
|
|
||||||
var svgpoints = "100,10 40,180 190,60 10,60 160,180";
|
|
||||||
shape.setAttribute('points', svgpoints);
|
|
||||||
|
|
||||||
var poly = new Path();
|
|
||||||
var points = shape.points;
|
|
||||||
var start = points.getItem(0);
|
|
||||||
var point;
|
|
||||||
poly.moveTo([start.x, start.y]);
|
|
||||||
|
|
||||||
for (var i = 1; i < points.length; i++) {
|
|
||||||
point = points.getItem(i);
|
|
||||||
poly.lineTo([point.x, point.y]);
|
|
||||||
}
|
}
|
||||||
if (shape.nodeName.toLowerCase() == 'polygon') {
|
var path = new Path.Ellipse({
|
||||||
poly.closePath();
|
center: new Point(attrs.cx, attrs.cy),
|
||||||
|
radius: new Point(attrs.rx, attrs.ry)
|
||||||
|
});
|
||||||
|
equals(path.exportSVG({ matchShapes: true }), createSVG('ellipse', attrs));
|
||||||
|
});
|
||||||
|
|
||||||
|
test('Export SVG circle', function() {
|
||||||
|
var attrs = {
|
||||||
|
cx: 100,
|
||||||
|
cy: 80,
|
||||||
|
r: 50
|
||||||
|
}
|
||||||
|
var path = new Path.Circle({
|
||||||
|
center: new Point(attrs.cx, attrs.cy),
|
||||||
|
radius: attrs.r
|
||||||
|
});
|
||||||
|
equals(path.exportSVG({ matchShapes: true }), createSVG('circle', attrs));
|
||||||
|
});
|
||||||
|
|
||||||
|
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;
|
||||||
}
|
}
|
||||||
|
|
||||||
var exportedPolygon = poly.exportSVG();
|
test('Export SVG polygon', function() {
|
||||||
|
var points = '100,10 40,180 190,60 10,60 160,180';
|
||||||
var svgPoints = shape.getAttribute('points');
|
var path = createPolyPath(points);
|
||||||
|
path.closePath();
|
||||||
var exportedPoints = shape.getAttribute('points');
|
equals(path.exportSVG({ matchShapes: true }), createSVG('polygon', {
|
||||||
|
points: points
|
||||||
equals(svgPoints, exportedPoints);
|
}));
|
||||||
|
|
||||||
});
|
});
|
||||||
|
|
||||||
test('compare negative polygon values', function() {
|
test('Export SVG polyline', function() {
|
||||||
var svgns = 'http://www.w3.org/2000/svg';
|
var points = '5,5 45,45 5,45 45,5';
|
||||||
var shape = document.createElementNS(svgns, 'polygon');
|
var path = createPolyPath(points);
|
||||||
var svgpoints = "-100,-10 -40,-180 -190,-60 -10,-60 -160,-180";
|
equals(path.exportSVG({ matchShapes: true }), createSVG('polyline', {
|
||||||
shape.setAttribute('points', svgpoints);
|
points: points
|
||||||
|
}));
|
||||||
var poly = new Path();
|
|
||||||
var points = shape.points;
|
|
||||||
var start = points.getItem(0);
|
|
||||||
var point;
|
|
||||||
poly.moveTo([start.x, start.y]);
|
|
||||||
|
|
||||||
for (var i = 1; i < points.length; i++) {
|
|
||||||
point = points.getItem(i);
|
|
||||||
poly.lineTo([point.x, point.y]);
|
|
||||||
}
|
|
||||||
if (shape.nodeName.toLowerCase() == 'polygon') {
|
|
||||||
poly.closePath();
|
|
||||||
}
|
|
||||||
|
|
||||||
var exportedPolygon = poly.exportSVG();
|
|
||||||
|
|
||||||
var svgPoints = shape.getAttribute('points');
|
|
||||||
|
|
||||||
var exportedPoints = shape.getAttribute('points');
|
|
||||||
|
|
||||||
equals(svgPoints, exportedPoints);
|
|
||||||
|
|
||||||
});
|
});
|
||||||
|
|
||||||
test('compare polyline values', function() {
|
|
||||||
var svgns = 'http://www.w3.org/2000/svg';
|
|
||||||
var shape = document.createElementNS(svgns, 'polyline');
|
|
||||||
var svgpoints = "5,5 45,45 5,45 45,5";
|
|
||||||
shape.setAttribute('points', svgpoints);
|
|
||||||
|
|
||||||
var poly = new Path();
|
|
||||||
var points = shape.points;
|
|
||||||
var start = points.getItem(0);
|
|
||||||
var point;
|
|
||||||
poly.moveTo([start.x, start.y]);
|
|
||||||
|
|
||||||
for (var i = 1; i < points.length; i++) {
|
|
||||||
point = points.getItem(i);
|
|
||||||
poly.lineTo([point.x, point.y]);
|
|
||||||
}
|
|
||||||
if (shape.nodeName.toLowerCase() == 'polygon') {
|
|
||||||
poly.closePath();
|
|
||||||
}
|
|
||||||
|
|
||||||
var exportedPolygon = poly.exportSVG();
|
|
||||||
|
|
||||||
var svgPoints = shape.getAttribute('points');
|
|
||||||
|
|
||||||
var exportedPoints = shape.getAttribute('points');
|
|
||||||
|
|
||||||
equals(svgPoints, exportedPoints);
|
|
||||||
|
|
||||||
});
|
|
||||||
|
|
||||||
test('compare negative polyline values', function() {
|
|
||||||
var svgns = 'http://www.w3.org/2000/svg';
|
|
||||||
var shape = document.createElementNS(svgns, 'polyline');
|
|
||||||
var svgpoints = "-5,-5 -45,-45 -5,-45 -45,-5";
|
|
||||||
shape.setAttribute('points', svgpoints);
|
|
||||||
|
|
||||||
var poly = new Path();
|
|
||||||
var points = shape.points;
|
|
||||||
var start = points.getItem(0);
|
|
||||||
var point;
|
|
||||||
poly.moveTo([start.x, start.y]);
|
|
||||||
|
|
||||||
for (var i = 1; i < points.length; i++) {
|
|
||||||
point = points.getItem(i);
|
|
||||||
poly.lineTo([point.x, point.y]);
|
|
||||||
}
|
|
||||||
if (shape.nodeName.toLowerCase() == 'polygon') {
|
|
||||||
poly.closePath();
|
|
||||||
}
|
|
||||||
|
|
||||||
var exportedPolygon = poly.exportSVG();
|
|
||||||
|
|
||||||
var svgPoints = shape.getAttribute('points');
|
|
||||||
|
|
||||||
var exportedPoints = shape.getAttribute('points');
|
|
||||||
|
|
||||||
equals(svgPoints, exportedPoints);
|
|
||||||
|
|
||||||
});
|
|
||||||
|
|
|
@ -12,12 +12,6 @@
|
||||||
|
|
||||||
module('SVGImport');
|
module('SVGImport');
|
||||||
|
|
||||||
test('Import complex CompoundPath and clone', function() {
|
|
||||||
var svg = createSVG('<path id="path" fill="red" d="M4,14h20v-2H4V14z M15,26h7v-2h-7V26z M15,22h9v-2h-9V22z M15,18h9v-2h-9V18z M4,26h9V16H4V26z M28,10V6H0v22c0,0,0,4,4,4 h25c0,0,3-0.062,3-4V10H28z M4,30c-2,0-2-2-2-2V8h24v20c0,0.921,0.284,1.558,0.676,2H4z"/>;');
|
|
||||||
var item = paper.project.importSVG(svg.getElementById('path'));
|
|
||||||
equals(item, item.clone(), null, { cloned: true });
|
|
||||||
});
|
|
||||||
|
|
||||||
test('Import SVG line', function() {
|
test('Import SVG line', function() {
|
||||||
var attrs = {
|
var attrs = {
|
||||||
x1: 5,
|
x1: 5,
|
||||||
|
@ -112,10 +106,16 @@ test('Import SVG polygon', function() {
|
||||||
});
|
});
|
||||||
|
|
||||||
test('Import SVG polyline', function() {
|
test('Import SVG polyline', function() {
|
||||||
var points = "5,5 45,45 5,45 45,5";
|
var points = '5,5 45,45 5,45 45,5';
|
||||||
var imported = paper.project.importSVG(createSVG('polyline', {
|
var imported = paper.project.importSVG(createSVG('polyline', {
|
||||||
points: points
|
points: points
|
||||||
}));
|
}));
|
||||||
var path = createPolyPath(points);
|
var path = createPolyPath(points);
|
||||||
equals(imported, path);
|
equals(imported, path);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
test('Import complex CompoundPath and clone', function() {
|
||||||
|
var svg = createSVG('<path id="path" fill="red" d="M4,14h20v-2H4V14z M15,26h7v-2h-7V26z M15,22h9v-2h-9V22z M15,18h9v-2h-9V18z M4,26h9V16H4V26z M28,10V6H0v22c0,0,0,4,4,4 h25c0,0,3-0.062,3-4V10H28z M4,30c-2,0-2-2-2-2V8h24v20c0,0.921,0.284,1.558,0.676,2H4z"/>;');
|
||||||
|
var item = paper.project.importSVG(svg.getElementById('path'));
|
||||||
|
equals(item, item.clone(), null, { cloned: true });
|
||||||
|
});
|
||||||
|
|
|
@ -59,6 +59,7 @@
|
||||||
|
|
||||||
/*#*/ include('HitResult.js');
|
/*#*/ include('HitResult.js');
|
||||||
|
|
||||||
|
/*#*/ include('JSON.js');
|
||||||
|
|
||||||
/*#*/ include('SVGImport.js');
|
/*#*/ include('SVGImport.js');
|
||||||
/*#*/ include('SVGExport.js');
|
/*#*/ include('SVGExport.js');
|
||||||
/*#*/ include('JSON.js');
|
|
||||||
|
|
Loading…
Reference in a new issue