From 953bba4c7b6c0d589d71edcc073bb9fd112f861e Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?J=C3=BCrg=20Lehni?= Date: Wed, 16 Oct 2013 16:12:46 +0200 Subject: [PATCH] SVG: Use Shape instead of Path constructors for primitive shapes. --- src/svg/SVGImport.js | 27 ++++++++++----------------- 1 file changed, 10 insertions(+), 17 deletions(-) diff --git a/src/svg/SVGImport.js b/src/svg/SVGImport.js index 7cd85034..fa39b350 100644 --- a/src/svg/SVGImport.js +++ b/src/svg/SVGImport.js @@ -74,7 +74,7 @@ new function() { function importGroup(node, type) { var nodes = node.childNodes, clip = type === 'clippath', - item = clip ? new CompoundPath() : new Group(), + item = new Group(), project = item._project, currentStyle = project._currentStyle, children = []; @@ -94,19 +94,12 @@ new function() { for (var i = 0, l = nodes.length; i < l; i++) { var childNode = nodes[i], child; - if (childNode.nodeType === 1 && (child = importSVG(childNode))) { - // When adding CompoundPaths to other CompoundPaths, - // we need to "unbox" them first: - if (clip && child instanceof CompoundPath) { - children.push.apply(children, child.removeChildren()); - child.remove(); - } else if (!(child instanceof Symbol)) { - children.push(child); - } - } + if (childNode.nodeType === 1 && (child = importSVG(childNode)) + && !(child instanceof Symbol)) + children.push(child); } item.addChildren(children); - // clip paths are reduced (unboxed) and their attributes applied at the + // Clip paths are reduced (unboxed) and their attributes applied at the // end. if (clip) item = applyAttributes(item.reduce(), node); @@ -236,15 +229,15 @@ new function() { // http://www.w3.org/TR/SVG/shapes.html#InterfaceSVGCircleElement circle: function(node) { - return new Path.Circle(getPoint(node, 'cx', 'cy'), + return new Shape.Circle(getPoint(node, 'cx', 'cy'), getValue(node, 'r')); }, // http://www.w3.org/TR/SVG/shapes.html#InterfaceSVGEllipseElement ellipse: function(node) { // We only use object literal notation where the default one is not - // supported (e.g. center / radius fo Path.Ellipse). - return new Path.Ellipse({ + // supported (e.g. center / radius fo Shape.Ellipse). + return new Shape.Ellipse({ center: getPoint(node, 'cx', 'cy'), radius: getSize(node, 'rx', 'ry') }); @@ -255,7 +248,7 @@ new function() { var point = getPoint(node, 'x', 'y'), size = getSize(node, 'width', 'height'), radius = getSize(node, 'rx', 'ry'); - return new Path.Rectangle(new Rectangle(point, size), radius); + return new Shape.Rectangle(new Rectangle(point, size), radius); }, // http://www.w3.org/TR/SVG/shapes.html#LineElement @@ -425,7 +418,7 @@ new function() { group = item._definition; if (clip && !rect.contains(group.getBounds())) { // Add a clip path at the top of this symbol's group - clip = new Path.Rectangle(rect).transform(group._matrix); + clip = new Shape.Rectangle(rect).transform(group._matrix); clip.setClipMask(true); group.addChild(clip); }