From 99a39bebc36acbe22a5ee2a502499d07f485040c Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?J=C3=BCrg=20Lehni?= Date: Fri, 2 Nov 2012 19:26:15 -0700 Subject: [PATCH] Clean up applyAttributeOrStyle(). Do not use style properties directly, but setters instead. --- src/svg/SvgImporter.js | 71 ++++++++++++++++-------------------------- 1 file changed, 27 insertions(+), 44 deletions(-) diff --git a/src/svg/SvgImporter.js b/src/svg/SvgImporter.js index dc68d12a..5aeee760 100644 --- a/src/svg/SvgImporter.js +++ b/src/svg/SvgImporter.js @@ -256,86 +256,69 @@ var SvgImporter = this.SvgImporter = new function() { * @param value the value of the SVG style */ function applyAttributeOrStyle(svg, item, name, value) { - if (!value) { + if (value == null) return; - } switch (name) { case 'id': - item.name = value; + item.setName(value); break; case 'fill': - if (value != 'none') { - item.fillColor = value; - } + if (value !== 'none') + item.setFillColor(value); break; case 'stroke': - if (value != 'none') { - item.strokeColor = value; - } + if (value !== 'none') + item.setStrokeColor(value); break; case 'stroke-width': - item.strokeWidth = parseFloat(value, 10); + item.setStrokeWidth(parseFloat(value, 10)); break; case 'stroke-linecap': - item.strokeCap = value; + item.setStrokeCap(value); break; case 'stroke-linejoin': - item.strokeJoin = value; + item.setStrokeJoin(value); break; case 'stroke-dasharray': - value = value.replace(/px/g, ''); - value = value.replace(/, /g, ','); - value = value.replace(/ /g, ','); - value = value.split(','); - for (var i in value) { + value = value.replace(/px/g, '').replace(/, /g, ',') + .replace(/ /g, ',').split(','); + for (var i = 0, l = value.length; i < l; i++) value[i] = parseFloat(value[i], 10); - } - item.dashArray = value; + item.setDashArray(value); break; case 'stroke-dashoffset': - item.dashOffset = parseFloat(value, 10); + item.setDashOffset(parseFloat(value, 10)); break; case 'stroke-miterlimit': - item.miterLimit = parseFloat(value, 10); + item.setMiterLimit(parseFloat(value, 10)); break; case 'transform': applyTransform(svg, item); break; case 'opacity': - item.opacity = parseFloat(value, 10); + item.setOpacity(parseFloat(value, 10)); break; case 'visibility': - item.visibility = (value == 'visible') ? true : false; + item.setVisibility(value === 'visible'); break; case 'font': + var text = document.createElement('span'); + text.style.font = value; + for (var i = 0; i < text.style.length; i++) { + var n = text.style[i]; + applyAttributeOrStyle(svg, item, n, text.style[n]); + } + break; case 'font-family': + item.setFont(value.split(',')[0].replace(/^\s+|\s+$/g, "")); + break; case 'font-size': - //Implemented in characterStyle below. + item.setFontSize(parseFloat(value, 10)); break; default: // Not supported yet. break; } - if (item.characterStyle) { - switch (name) { - case 'font': - var text = document.createElement('span'); - text.style.font = value; - for (var i = 0; i < text.style.length; i++) { - var n = text.style[i]; - applyAttributeOrStyle(svg, item, n, text.style[n]); - } - break; - case 'font-family': - var fonts = value.split(','); - fonts[0] = fonts[0].replace(/^\s+|\s+$/g, ""); - item.characterStyle.font = fonts[0]; - break; - case 'font-size': - item.characterStyle.fontSize = parseFloat(value, 10); - break; - } - } } /**