mirror of
https://github.com/scratchfoundation/paper.js.git
synced 2025-01-03 19:45:44 -05:00
More SVG code refactoring.
Follow coding conventions and fix some forgotten renamings.
This commit is contained in:
parent
160095d6e3
commit
d4a60fb62a
12 changed files with 378 additions and 381 deletions
|
@ -11,8 +11,8 @@
|
||||||
// strokeWidth: 2,
|
// strokeWidth: 2,
|
||||||
// strokeCap: 'round'
|
// strokeCap: 'round'
|
||||||
};
|
};
|
||||||
var isvg = new ImportSvg;
|
var isvg = new ImportSvg();
|
||||||
isvg.importSVG(document.getElementById('svg'));
|
isvg.importSvg(document.getElementById('svg'));
|
||||||
</script>
|
</script>
|
||||||
</head>
|
</head>
|
||||||
<body>
|
<body>
|
||||||
|
|
|
@ -11,8 +11,8 @@
|
||||||
// strokeWidth: 2,
|
// strokeWidth: 2,
|
||||||
// strokeCap: 'round'
|
// strokeCap: 'round'
|
||||||
};
|
};
|
||||||
var isvg = new ImportSvg;
|
var isvg = new ImportSvg();
|
||||||
isvg.importSVG(document.getElementById('svg'));
|
isvg.importSvg(document.getElementById('svg'));
|
||||||
</script>
|
</script>
|
||||||
</head>
|
</head>
|
||||||
<body>
|
<body>
|
||||||
|
|
|
@ -11,8 +11,8 @@
|
||||||
// strokeWidth: 2,
|
// strokeWidth: 2,
|
||||||
// strokeCap: 'round'
|
// strokeCap: 'round'
|
||||||
};
|
};
|
||||||
var isvg = new ImportSvg;
|
var isvg = new ImportSvg();
|
||||||
isvg.importSVG(document.getElementById('svg'));
|
isvg.importSvg(document.getElementById('svg'));
|
||||||
</script>
|
</script>
|
||||||
</head>
|
</head>
|
||||||
<body>
|
<body>
|
||||||
|
|
|
@ -11,8 +11,8 @@
|
||||||
// strokeWidth: 2,
|
// strokeWidth: 2,
|
||||||
// strokeCap: 'round'
|
// strokeCap: 'round'
|
||||||
};
|
};
|
||||||
var isvg = new ImportSvg;
|
var isvg = new ImportSvg();
|
||||||
isvg.importSVG(document.getElementById('svg'));
|
isvg.importSvg(document.getElementById('svg'));
|
||||||
</script>
|
</script>
|
||||||
</head>
|
</head>
|
||||||
<body>
|
<body>
|
||||||
|
|
|
@ -12,8 +12,8 @@
|
||||||
// strokeWidth: 2,
|
// strokeWidth: 2,
|
||||||
// strokeCap: 'round'
|
// strokeCap: 'round'
|
||||||
};
|
};
|
||||||
var isvg = new ImportSvg;
|
var isvg = new ImportSvg();
|
||||||
isvg.importSVG(document.getElementById('svg'));
|
isvg.importSvg(document.getElementById('svg'));
|
||||||
</script>
|
</script>
|
||||||
</head>
|
</head>
|
||||||
<body>
|
<body>
|
||||||
|
|
|
@ -11,8 +11,8 @@
|
||||||
// strokeWidth: 2,
|
// strokeWidth: 2,
|
||||||
// strokeCap: 'round'
|
// strokeCap: 'round'
|
||||||
};
|
};
|
||||||
var isvg = new ImportSvg;
|
var isvg = new ImportSvg();
|
||||||
isvg.importSVG(document.getElementById('svg'));
|
isvg.importSvg(document.getElementById('svg'));
|
||||||
</script>
|
</script>
|
||||||
</head>
|
</head>
|
||||||
<body>
|
<body>
|
||||||
|
|
|
@ -11,8 +11,8 @@
|
||||||
// strokeWidth: 2,
|
// strokeWidth: 2,
|
||||||
// strokeCap: 'round'
|
// strokeCap: 'round'
|
||||||
};
|
};
|
||||||
var isvg = new ImportSvg;
|
var isvg = new ImportSvg();
|
||||||
isvg.importSVG(document.getElementById('svg'));
|
isvg.importSvg(document.getElementById('svg'));
|
||||||
</script>
|
</script>
|
||||||
</head>
|
</head>
|
||||||
<body>
|
<body>
|
||||||
|
|
|
@ -11,8 +11,8 @@
|
||||||
// strokeWidth: 2,
|
// strokeWidth: 2,
|
||||||
// strokeCap: 'round'
|
// strokeCap: 'round'
|
||||||
};
|
};
|
||||||
var isvg = new ImportSvg;
|
var isvg = new ImportSvg();
|
||||||
isvg.importSVG(document.getElementById('svg'));
|
isvg.importSvg(document.getElementById('svg'));
|
||||||
</script>
|
</script>
|
||||||
</head>
|
</head>
|
||||||
<body>
|
<body>
|
||||||
|
|
|
@ -11,8 +11,8 @@
|
||||||
// strokeWidth: 2,
|
// strokeWidth: 2,
|
||||||
// strokeCap: 'round'
|
// strokeCap: 'round'
|
||||||
};
|
};
|
||||||
var isvg = new ImportSvg;
|
var isvg = new ImportSvg();
|
||||||
isvg.importSVG(document.getElementById('svg'));
|
isvg.importSvg(document.getElementById('svg'));
|
||||||
</script>
|
</script>
|
||||||
</head>
|
</head>
|
||||||
<body>
|
<body>
|
||||||
|
|
|
@ -111,123 +111,124 @@ var ExportSvg = this.ExportSvg = Base.extend(/** @Lends ExportSvg# */{
|
||||||
var pointArray;
|
var pointArray;
|
||||||
var handleInArray;
|
var handleInArray;
|
||||||
var handleOutArray;
|
var handleOutArray;
|
||||||
|
var type;
|
||||||
//finding the type of path to export
|
//finding the type of path to export
|
||||||
if(path.content) {
|
if (path.content) {
|
||||||
type = 'text';
|
type = 'text';
|
||||||
} else {
|
} else {
|
||||||
//Values are only defined if the path is not text because
|
//Values are only defined if the path is not text because
|
||||||
// text does not have these values
|
// text does not have these values
|
||||||
segArray = path.getSegments();
|
segArray = path.getSegments();
|
||||||
pointArray = new Array();
|
pointArray = [];
|
||||||
handleInArray = new Array();
|
handleInArray = [];
|
||||||
handleOutArray = new Array();
|
handleOutArray = [];
|
||||||
for (i = 0; i < segArray.length; i++) {
|
for (i = 0; i < segArray.length; i++) {
|
||||||
pointArray[i] = segArray[i].getPoint();
|
pointArray[i] = segArray[i].getPoint();
|
||||||
handleInArray[i] = segArray[i].getHandleIn();
|
handleInArray[i] = segArray[i].getHandleIn();
|
||||||
handleOutArray[i] = segArray[i].getHandleOut();
|
handleOutArray[i] = segArray[i].getHandleOut();
|
||||||
}
|
}
|
||||||
var exp = this;
|
var exp = this;
|
||||||
var type = exp._determineType(path, segArray, pointArray, handleInArray, handleOutArray);
|
type = exp._determineType(path, segArray, pointArray, handleInArray, handleOutArray);
|
||||||
}
|
}
|
||||||
//switch statement that determines what type of SVG element to add to the SVG Object
|
//switch statement that determines what type of SVG element to add to the SVG Object
|
||||||
switch (type) {
|
switch (type) {
|
||||||
case 'rect':
|
case 'rect':
|
||||||
var width = pointArray[0].getDistance(pointArray[3], false);
|
var width = pointArray[0].getDistance(pointArray[3], false);
|
||||||
var height = pointArray[0].getDistance(pointArray[1], false);
|
var height = pointArray[0].getDistance(pointArray[1], false);
|
||||||
svgEle = document.createElementNS(this.NS, 'rect');
|
svgEle = document.createElementNS(this.NS, 'rect');
|
||||||
svgEle.setAttribute('x', path.bounds.topLeft.getX());
|
svgEle.setAttribute('x', path.bounds.topLeft.getX());
|
||||||
svgEle.setAttribute('y', path.bounds.topLeft.getY());
|
svgEle.setAttribute('y', path.bounds.topLeft.getY());
|
||||||
svgEle.setAttribute('width', width);
|
svgEle.setAttribute('width', width);
|
||||||
svgEle.setAttribute('height', height);
|
svgEle.setAttribute('height', height);
|
||||||
break;
|
break;
|
||||||
case 'roundRect':
|
case 'roundRect':
|
||||||
//d variables and point are used to determine the rounded corners for the rounded rectangle
|
//d variables and point are used to determine the rounded corners for the rounded rectangle
|
||||||
var dx1 = pointArray[1].getDistance(pointArray[6], false);
|
var dx1 = pointArray[1].getDistance(pointArray[6], false);
|
||||||
var dx2 = pointArray[0].getDistance(pointArray[7], false);
|
var dx2 = pointArray[0].getDistance(pointArray[7], false);
|
||||||
var dx3 = (dx1 - dx2) / 2;
|
var dx3 = (dx1 - dx2) / 2;
|
||||||
var dy1 = pointArray[0].getDistance(pointArray[3], false);
|
var dy1 = pointArray[0].getDistance(pointArray[3], false);
|
||||||
var dy2 = pointArray[1].getDistance(pointArray[2], false);
|
var dy2 = pointArray[1].getDistance(pointArray[2], false);
|
||||||
var dy3 = (dy1 - dy2) / 2;
|
var dy3 = (dy1 - dy2) / 2;
|
||||||
var point = new Point((pointArray[3].getX() - dx3), (pointArray[2].getY() - dy3));
|
var point = new Point((pointArray[3].getX() - dx3), (pointArray[2].getY() - dy3));
|
||||||
var width = Math.round(dx1);
|
var width = Math.round(dx1);
|
||||||
var height = Math.round(dy1);
|
var height = Math.round(dy1);
|
||||||
var rx = pointArray[3].getX() - point.x;
|
var rx = pointArray[3].getX() - point.x;
|
||||||
var ry = pointArray[2].getY() - point.y;
|
var ry = pointArray[2].getY() - point.y;
|
||||||
svgEle = document.createElementNS(this.NS, 'rect');
|
svgEle = document.createElementNS(this.NS, 'rect');
|
||||||
svgEle.setAttribute('x', path.bounds.topLeft.getX());
|
svgEle.setAttribute('x', path.bounds.topLeft.getX());
|
||||||
svgEle.setAttribute('y', path.bounds.topLeft.getY());
|
svgEle.setAttribute('y', path.bounds.topLeft.getY());
|
||||||
svgEle.setAttribute('rx', rx);
|
svgEle.setAttribute('rx', rx);
|
||||||
svgEle.setAttribute('ry', ry);
|
svgEle.setAttribute('ry', ry);
|
||||||
svgEle.setAttribute('width', width);
|
svgEle.setAttribute('width', width);
|
||||||
svgEle.setAttribute('height', height);
|
svgEle.setAttribute('height', height);
|
||||||
break;
|
break;
|
||||||
case'line':
|
case'line':
|
||||||
svgEle = document.createElementNS(this.NS, 'line');
|
svgEle = document.createElementNS(this.NS, 'line');
|
||||||
svgEle.setAttribute('x1', pointArray[0].getX());
|
svgEle.setAttribute('x1', pointArray[0].getX());
|
||||||
svgEle.setAttribute('y1', pointArray[0].getY());
|
svgEle.setAttribute('y1', pointArray[0].getY());
|
||||||
svgEle.setAttribute('x2', pointArray[pointArray.length - 1].getX());
|
svgEle.setAttribute('x2', pointArray[pointArray.length - 1].getX());
|
||||||
svgEle.setAttribute('y2', pointArray[pointArray.length - 1].getY());
|
svgEle.setAttribute('y2', pointArray[pointArray.length - 1].getY());
|
||||||
break;
|
break;
|
||||||
case 'circle':
|
case 'circle':
|
||||||
svgEle = document.createElementNS(this.NS, 'circle');
|
svgEle = document.createElementNS(this.NS, 'circle');
|
||||||
var radius = (pointArray[0].getDistance(pointArray[2], false)) /2;
|
var radius = (pointArray[0].getDistance(pointArray[2], false)) /2;
|
||||||
svgEle.setAttribute('cx', path.bounds.center.x);
|
svgEle.setAttribute('cx', path.bounds.center.x);
|
||||||
svgEle.setAttribute('cy', path.bounds.center.y);
|
svgEle.setAttribute('cy', path.bounds.center.y);
|
||||||
svgEle.setAttribute('r', radius);
|
svgEle.setAttribute('r', radius);
|
||||||
break;
|
break;
|
||||||
case 'ellipse':
|
case 'ellipse':
|
||||||
svgEle = document.createElementNS(this.NS, 'ellipse');
|
svgEle = document.createElementNS(this.NS, 'ellipse');
|
||||||
var radiusX = (pointArray[2].getDistance(pointArray[0], false)) / 2;
|
var radiusX = (pointArray[2].getDistance(pointArray[0], false)) / 2;
|
||||||
var radiusY = (pointArray[3].getDistance(pointArray[1], false)) /2;
|
var radiusY = (pointArray[3].getDistance(pointArray[1], false)) /2;
|
||||||
svgEle.setAttribute('cx', path.bounds.center.x);
|
svgEle.setAttribute('cx', path.bounds.center.x);
|
||||||
svgEle.setAttribute('cy', path.bounds.center.y);
|
svgEle.setAttribute('cy', path.bounds.center.y);
|
||||||
svgEle.setAttribute('rx', radiusX);
|
svgEle.setAttribute('rx', radiusX);
|
||||||
svgEle.setAttribute('ry', radiusY);
|
svgEle.setAttribute('ry', radiusY);
|
||||||
break;
|
break;
|
||||||
case 'polyline':
|
case 'polyline':
|
||||||
svgEle = document.createElementNS(this.NS, 'polyline');
|
svgEle = document.createElementNS(this.NS, 'polyline');
|
||||||
var pointString = '';
|
var pointString = '';
|
||||||
for(i = 0; i < pointArray.length; ++i) {
|
for(i = 0; i < pointArray.length; ++i) {
|
||||||
pointString += pointArray[i].getX() + ',' + pointArray[i].getY() + ' ';
|
pointString += pointArray[i].getX() + ',' + pointArray[i].getY() + ' ';
|
||||||
}
|
}
|
||||||
svgEle.setAttribute('points', pointString);
|
svgEle.setAttribute('points', pointString);
|
||||||
break;
|
break;
|
||||||
case 'polygon':
|
case 'polygon':
|
||||||
svgEle = document.createElementNS(this.NS, 'polygon');
|
svgEle = document.createElementNS(this.NS, 'polygon');
|
||||||
var pointString = '';
|
var pointString = '';
|
||||||
for(i = 0; i < pointArray.length; ++i) {
|
for(i = 0; i < pointArray.length; ++i) {
|
||||||
pointString += pointArray[i].getX() + ',' + pointArray[i].getY() + ' ';
|
pointString += pointArray[i].getX() + ',' + pointArray[i].getY() + ' ';
|
||||||
}
|
}
|
||||||
svgEle.setAttribute('points', pointString);
|
svgEle.setAttribute('points', pointString);
|
||||||
break;
|
break;
|
||||||
case 'text':
|
case 'text':
|
||||||
svgEle = document.createElementNS(this.NS, 'text');
|
svgEle = document.createElementNS(this.NS, 'text');
|
||||||
svgEle.setAttribute('x', path.getPoint().getX());
|
svgEle.setAttribute('x', path.getPoint().getX());
|
||||||
svgEle.setAttribute('y', path.getPoint().getY());
|
svgEle.setAttribute('y', path.getPoint().getY());
|
||||||
if(path.style.font != undefined) {
|
if (path.style.font != undefined) {
|
||||||
svgEle.setAttribute('font', path.style.font);
|
svgEle.setAttribute('font', path.style.font);
|
||||||
}
|
}
|
||||||
if(path.characterStyle.font != undefined) {
|
if (path.characterStyle.font != undefined) {
|
||||||
svgEle.setAttribute('font-family', path.characterStyle.font);
|
svgEle.setAttribute('font-family', path.characterStyle.font);
|
||||||
}
|
}
|
||||||
if(path.characterStyle.fontSize != undefined) {
|
if (path.characterStyle.fontSize != undefined) {
|
||||||
svgEle.setAttribute('font-size',path.characterStyle.fontSize);
|
svgEle.setAttribute('font-size',path.characterStyle.fontSize);
|
||||||
}
|
}
|
||||||
svgEle.textContent = path.getContent();
|
svgEle.textContent = path.getContent();
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
svgEle = document.createElementNS(this.NS, 'path');
|
svgEle = document.createElementNS(this.NS, 'path');
|
||||||
svgEle = this.pathSetup(path, pointArray, handleInArray, handleOutArray);
|
svgEle = this.pathSetup(path, pointArray, handleInArray, handleOutArray);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
//If the object is a circle, ellipse, rectangle, or rounded rectangle, it will find the angle
|
//If the object is a circle, ellipse, rectangle, or rounded rectangle, it will find the angle
|
||||||
//found by the determineIfTransformed method and make a path that accommodates for the transformed object
|
//found by the determineIfTransformed method and make a path that accommodates for the transformed object
|
||||||
if(type != 'text' && type != undefined && type != 'polygon' && type != 'polyline' && type != 'line') {
|
if (type != 'text' && type != undefined && type != 'polygon' && type != 'polyline' && type != 'line') {
|
||||||
//TODO: Need to implement exported transforms for circle, ellipse, and rectangles instead of
|
//TODO: Need to implement exported transforms for circle, ellipse, and rectangles instead of
|
||||||
//making them paths
|
//making them paths
|
||||||
var angle = this._determineIfTransformed(path, pointArray, type) + 90;
|
var angle = this._determineIfTransformed(path, pointArray, type) + 90;
|
||||||
if(angle != 0) {
|
if (angle != 0) {
|
||||||
if(type == 'rect' || type == 'roundRect') {
|
if (type == 'rect' || type == 'roundRect') {
|
||||||
svgEle = document.createElementNS(this.NS, 'path');
|
svgEle = document.createElementNS(this.NS, 'path');
|
||||||
svgEle = this.pathSetup(path, pointArray, handleInArray, handleOutArray);
|
svgEle = this.pathSetup(path, pointArray, handleInArray, handleOutArray);
|
||||||
} else {
|
} else {
|
||||||
|
@ -236,10 +237,10 @@ var ExportSvg = this.ExportSvg = Base.extend(/** @Lends ExportSvg# */{
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if(type == 'text') {
|
if (type == 'text') {
|
||||||
svgEle.setAttribute('transform','rotate(' + path.matrix.getRotation() + ',' + path.getPoint().getX() + ',' +path.getPoint().getY() +')');
|
svgEle.setAttribute('transform','rotate(' + path.matrix.getRotation() + ',' + path.getPoint().getX() + ',' +path.getPoint().getY() +')');
|
||||||
}
|
}
|
||||||
if(path.id != undefined) {
|
if (path.id != undefined) {
|
||||||
svgEle.setAttribute('id', path.id);
|
svgEle.setAttribute('id', path.id);
|
||||||
}
|
}
|
||||||
//checks if there is a stroke color in the passed in path
|
//checks if there is a stroke color in the passed in path
|
||||||
|
@ -254,30 +255,30 @@ var ExportSvg = this.ExportSvg = Base.extend(/** @Lends ExportSvg# */{
|
||||||
svgEle.setAttribute('fill', 'rgba(0,0,0,0)');
|
svgEle.setAttribute('fill', 'rgba(0,0,0,0)');
|
||||||
}
|
}
|
||||||
//same thing as stroke color except with stroke width
|
//same thing as stroke color except with stroke width
|
||||||
if(path.strokeWidth != undefined){
|
if (path.strokeWidth != undefined) {
|
||||||
svgEle.setAttribute('stroke-width', path.strokeWidth);
|
svgEle.setAttribute('stroke-width', path.strokeWidth);
|
||||||
}
|
}
|
||||||
//same thing as stroke color except with the path name
|
//same thing as stroke color except with the path name
|
||||||
if(path.name != undefined) {
|
if (path.name != undefined) {
|
||||||
svgEle.setAttribute('name', path.name);
|
svgEle.setAttribute('name', path.name);
|
||||||
}
|
}
|
||||||
//same thing as stroke color except with the strokeCap
|
//same thing as stroke color except with the strokeCap
|
||||||
if(path.strokeCap != undefined) {
|
if (path.strokeCap != undefined) {
|
||||||
svgEle.setAttribute('stroke-linecap', path.strokeCap);
|
svgEle.setAttribute('stroke-linecap', path.strokeCap);
|
||||||
}
|
}
|
||||||
//same thing as stroke color except with the strokeJoin
|
//same thing as stroke color except with the strokeJoin
|
||||||
if(path.strokeJoin != undefined) {
|
if (path.strokeJoin != undefined) {
|
||||||
svgEle.setAttribute('stroke-linejoin', path.strokeJoin);
|
svgEle.setAttribute('stroke-linejoin', path.strokeJoin);
|
||||||
}
|
}
|
||||||
//same thing as stroke color except with the opacity
|
//same thing as stroke color except with the opacity
|
||||||
if(path.opacity != undefined) {
|
if (path.opacity != undefined) {
|
||||||
svgEle.setAttribute('opacity', path.opacity);
|
svgEle.setAttribute('opacity', path.opacity);
|
||||||
}
|
}
|
||||||
//checks to see if there the dashArray is set, then adds the attribute if there is.
|
//checks to see if there the dashArray is set, then adds the attribute if there is.
|
||||||
if(path.dashArray[0] != undefined) {
|
if (path.dashArray[0] != undefined) {
|
||||||
var dashVals = '';
|
var dashVals = '';
|
||||||
for (var i in path.dashArray) {
|
for (var i in path.dashArray) {
|
||||||
if(i != path.dashArray.length -1) {
|
if (i != path.dashArray.length -1) {
|
||||||
dashVals += path.dashArray[i] + ", ";
|
dashVals += path.dashArray[i] + ", ";
|
||||||
} else {
|
} else {
|
||||||
dashVals += path.dashArray[i];
|
dashVals += path.dashArray[i];
|
||||||
|
@ -286,17 +287,17 @@ var ExportSvg = this.ExportSvg = Base.extend(/** @Lends ExportSvg# */{
|
||||||
svgEle.setAttribute('stroke-dasharray', dashVals);
|
svgEle.setAttribute('stroke-dasharray', dashVals);
|
||||||
}
|
}
|
||||||
//same thing as stroke color except with the dash offset
|
//same thing as stroke color except with the dash offset
|
||||||
if(path.dashOffset != undefined) {
|
if (path.dashOffset != undefined) {
|
||||||
svgEle.setAttribute('stroke-dashoffset', path.dashOffset);
|
svgEle.setAttribute('stroke-dashoffset', path.dashOffset);
|
||||||
}
|
}
|
||||||
//same thing as stroke color except with the miter limit
|
//same thing as stroke color except with the miter limit
|
||||||
if(path.miterLimit != undefined) {
|
if (path.miterLimit != undefined) {
|
||||||
svgEle.setAttribute('stroke-miterlimit', path.miterLimit);
|
svgEle.setAttribute('stroke-miterlimit', path.miterLimit);
|
||||||
}
|
}
|
||||||
//same thing as stroke color except with the visibility
|
//same thing as stroke color except with the visibility
|
||||||
if(path.visibility != undefined) {
|
if (path.visibility != undefined) {
|
||||||
var visString = '';
|
var visString = '';
|
||||||
if(path.visibility) {
|
if (path.visibility) {
|
||||||
visString = 'visible';
|
visString = 'visible';
|
||||||
} else {
|
} else {
|
||||||
visString = 'hidden';
|
visString = 'hidden';
|
||||||
|
@ -316,25 +317,25 @@ var ExportSvg = this.ExportSvg = Base.extend(/** @Lends ExportSvg# */{
|
||||||
var topMidPathy;
|
var topMidPathy;
|
||||||
var topMidPath;
|
var topMidPath;
|
||||||
switch (type) {
|
switch (type) {
|
||||||
case 'rect':
|
case 'rect':
|
||||||
topMidPathx = (pointArray[1].getX() + pointArray[2].getX() )/2;
|
topMidPathx = (pointArray[1].getX() + pointArray[2].getX() )/2;
|
||||||
topMidPathy = (pointArray[1].getY() + pointArray[2].getY() )/2;
|
topMidPathy = (pointArray[1].getY() + pointArray[2].getY() )/2;
|
||||||
topMidPath = new Point(topMidPathx, topMidPathy);
|
topMidPath = new Point(topMidPathx, topMidPathy);
|
||||||
break;
|
break;
|
||||||
case 'ellipse':
|
case 'ellipse':
|
||||||
topMidPath = new Point(pointArray[1].getX(), pointArray[1].getY());
|
topMidPath = new Point(pointArray[1].getX(), pointArray[1].getY());
|
||||||
break;
|
break;
|
||||||
case 'circle':
|
case 'circle':
|
||||||
topMidPath = new Point(pointArray[1].getX(), pointArray[1].getY());
|
topMidPath = new Point(pointArray[1].getX(), pointArray[1].getY());
|
||||||
break;
|
break;
|
||||||
case 'roundRect':
|
case 'roundRect':
|
||||||
topMidPathx = (pointArray[3].getX() + pointArray[4].getX())/2;
|
topMidPathx = (pointArray[3].getX() + pointArray[4].getX())/2;
|
||||||
topMidPathy = (pointArray[3].getY() + pointArray[4].getY())/2;
|
topMidPathy = (pointArray[3].getY() + pointArray[4].getY())/2;
|
||||||
topMidPath = new Point(topMidPathx, topMidPathy);
|
topMidPath = new Point(topMidPathx, topMidPathy);
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
//Nothing happens here
|
//Nothing happens here
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
var deltaY = topMidPath.y - centerPoint.getY();
|
var deltaY = topMidPath.y - centerPoint.getY();
|
||||||
var deltaX = topMidPath.x - centerPoint.getX();
|
var deltaX = topMidPath.x - centerPoint.getX();
|
||||||
|
@ -362,7 +363,7 @@ var ExportSvg = this.ExportSvg = Base.extend(/** @Lends ExportSvg# */{
|
||||||
y2 = pointArray[i + 1].getY();
|
y2 = pointArray[i + 1].getY();
|
||||||
handleOut1 = hOArray[i];
|
handleOut1 = hOArray[i];
|
||||||
handleIn2 = hIArray[i+1];
|
handleIn2 = hIArray[i+1];
|
||||||
if(handleOut1.getX() == 0 && handleOut1.getY() == 0 && handleIn2.getX() == 0 && handleIn2.getY() ==0) {
|
if (handleOut1.getX() == 0 && handleOut1.getY() == 0 && handleIn2.getX() == 0 && handleIn2.getY() ==0) {
|
||||||
//L is lineto, moving to a point with drawing
|
//L is lineto, moving to a point with drawing
|
||||||
pointString+= 'L' + x2 + ',' + y2 + ' ';
|
pointString+= 'L' + x2 + ',' + y2 + ' ';
|
||||||
} else {
|
} else {
|
||||||
|
@ -410,7 +411,7 @@ var ExportSvg = this.ExportSvg = Base.extend(/** @Lends ExportSvg# */{
|
||||||
var curves = false;
|
var curves = false;
|
||||||
var segHandleIn;
|
var segHandleIn;
|
||||||
var segHandleOut;
|
var segHandleOut;
|
||||||
for( var i in segArray){
|
for( var i in segArray) {
|
||||||
//Checks for any curves (if the handles have values). Differentiates between straight objects(line, polyline, rect, and polygon) and
|
//Checks for any curves (if the handles have values). Differentiates between straight objects(line, polyline, rect, and polygon) and
|
||||||
//and objects with curves(circle, ellipse, roundedRectangle).
|
//and objects with curves(circle, ellipse, roundedRectangle).
|
||||||
segHandleIn = segArray[i].getHandleIn();
|
segHandleIn = segArray[i].getHandleIn();
|
||||||
|
@ -421,46 +422,46 @@ var ExportSvg = this.ExportSvg = Base.extend(/** @Lends ExportSvg# */{
|
||||||
//Checks for curves in the passed in segments
|
//Checks for curves in the passed in segments
|
||||||
//Checks if the type of the passed in path is a rounded rectangle, an ellipse, a circle, or if it's simply a path
|
//Checks if the type of the passed in path is a rounded rectangle, an ellipse, a circle, or if it's simply a path
|
||||||
//If there aren't any curves (if curves = false), then it checks if the type is a rectangle, a polygon, a polyline, or simply a line.
|
//If there aren't any curves (if curves = false), then it checks if the type is a rectangle, a polygon, a polyline, or simply a line.
|
||||||
if(curves){
|
if (curves) {
|
||||||
if(segArray.length == 8) {
|
if (segArray.length == 8) {
|
||||||
//if the distance between (point0 and point3) and (point7 and point4) are equal then it is a roundedRectangle
|
//if the distance between (point0 and point3) and (point7 and point4) are equal then it is a roundedRectangle
|
||||||
dPoint12 = Math.round(pointArray[0].getDistance(pointArray[3], false));
|
dPoint12 = Math.round(pointArray[0].getDistance(pointArray[3], false));
|
||||||
dPoint34 = Math.round(pointArray[7].getDistance(pointArray[4], false));
|
dPoint34 = Math.round(pointArray[7].getDistance(pointArray[4], false));
|
||||||
if(dPoint12 == dPoint34) {
|
if (dPoint12 == dPoint34) {
|
||||||
type = 'roundRect';
|
type = 'roundRect';
|
||||||
}
|
}
|
||||||
} else if(segArray.length == 4) {
|
} else if (segArray.length == 4) {
|
||||||
//checks if the values of the point have values similar to circles and ellipses
|
//checks if the values of the point have values similar to circles and ellipses
|
||||||
var checkPointValues = true;
|
var checkPointValues = true;
|
||||||
for(i = 0; i < pointArray.length && checkPointValues == true; i++) {
|
for(i = 0; i < pointArray.length && checkPointValues == true; i++) {
|
||||||
if(handleInArray[i].getX() != 0 || handleInArray[i].getY() != 0 && Math.round(Math.abs(handleInArray[i].getX())) === Math.round(Math.abs(handleOutArray[i].getX())) && Math.round(Math.abs(handleInArray[i].getY())) === Math.round(Math.abs(handleOutArray[i].getY()))) {
|
if (handleInArray[i].getX() != 0 || handleInArray[i].getY() != 0 && Math.round(Math.abs(handleInArray[i].getX())) === Math.round(Math.abs(handleOutArray[i].getX())) && Math.round(Math.abs(handleInArray[i].getY())) === Math.round(Math.abs(handleOutArray[i].getY()))) {
|
||||||
checkPointValues = true;
|
checkPointValues = true;
|
||||||
} else {
|
} else {
|
||||||
checkPointValues = false;
|
checkPointValues = false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if(checkPointValues == true) {
|
if (checkPointValues == true) {
|
||||||
//if the distance between (point0 and point2) and (point1 and point3) are equal, then it is a circle
|
//if the distance between (point0 and point2) and (point1 and point3) are equal, then it is a circle
|
||||||
var d1 = Math.round(pointArray[0].getDistance(pointArray[2], false));
|
var d1 = Math.round(pointArray[0].getDistance(pointArray[2], false));
|
||||||
var d2 = Math.round(pointArray[1].getDistance(pointArray[3], false));
|
var d2 = Math.round(pointArray[1].getDistance(pointArray[3], false));
|
||||||
if(d1 == d2) {
|
if (d1 == d2) {
|
||||||
type = 'circle';
|
type = 'circle';
|
||||||
} else {
|
} else {
|
||||||
type = 'ellipse';
|
type = 'ellipse';
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else if(!curves) {
|
} else if (!curves) {
|
||||||
if(segArray.length == 4) {
|
if (segArray.length == 4) {
|
||||||
//if the distance between (point0 and point1) and (point2 and point3) are equal, then it is a rectangle
|
//if the distance between (point0 and point1) and (point2 and point3) are equal, then it is a rectangle
|
||||||
dPoint12 = Math.round(pointArray[0].getDistance(pointArray[1], false));
|
dPoint12 = Math.round(pointArray[0].getDistance(pointArray[1], false));
|
||||||
dPoint34 = Math.round(pointArray[3].getDistance(pointArray[2], false));
|
dPoint34 = Math.round(pointArray[3].getDistance(pointArray[2], false));
|
||||||
if(dPoint12 == dPoint34) {
|
if (dPoint12 == dPoint34) {
|
||||||
type = 'rect';
|
type = 'rect';
|
||||||
}
|
}
|
||||||
} else if(segArray.length >= 3) {
|
} else if (segArray.length >= 3) {
|
||||||
//If it is an object with more than 3 segments and the path is closed, it is a polygon
|
//If it is an object with more than 3 segments and the path is closed, it is a polygon
|
||||||
if(path.getClosed()) {
|
if (path.getClosed()) {
|
||||||
type = 'polygon';
|
type = 'polygon';
|
||||||
} else {
|
} else {
|
||||||
type = 'polyline';
|
type = 'polyline';
|
||||||
|
|
|
@ -39,48 +39,47 @@ var ImportSvg = this.ImportSvg = Base.extend(/** @Lends ImportSvg# */{
|
||||||
* @param {SVG DOM} svg An SVG DOM object with parameters
|
* @param {SVG DOM} svg An SVG DOM object with parameters
|
||||||
* @return {item} A Paper.js layer
|
* @return {item} A Paper.js layer
|
||||||
*/
|
*/
|
||||||
importSVG: function(svg) {
|
importSvg: function(svg) {
|
||||||
var item;
|
var item;
|
||||||
var symbol;
|
var symbol;
|
||||||
switch (svg.nodeName.toLowerCase()) {
|
switch (svg.nodeName.toLowerCase()) {
|
||||||
case 'line':
|
case 'line':
|
||||||
item = this._importLine(svg);
|
item = this._importLine(svg);
|
||||||
break;
|
break;
|
||||||
case 'rect':
|
case 'rect':
|
||||||
item = this._importRectangle(svg);
|
item = this._importRectangle(svg);
|
||||||
break;
|
break;
|
||||||
case 'circle':
|
case 'circle':
|
||||||
item = this._importCircle(svg);
|
item = this._importCircle(svg);
|
||||||
break;
|
break;
|
||||||
case 'ellipse':
|
case 'ellipse':
|
||||||
item = this._importOval(svg);
|
item = this._importOval(svg);
|
||||||
break;
|
break;
|
||||||
case 'g':
|
case 'g':
|
||||||
case 'svg':
|
case 'svg':
|
||||||
item = this._importGroup(svg);
|
item = this._importGroup(svg);
|
||||||
break;
|
break;
|
||||||
case 'text':
|
case 'text':
|
||||||
item = this._importText(svg);
|
item = this._importText(svg);
|
||||||
break;
|
break;
|
||||||
case 'path':
|
case 'path':
|
||||||
item = this._importPath(svg);
|
item = this._importPath(svg);
|
||||||
break;
|
break;
|
||||||
case 'polygon':
|
case 'polygon':
|
||||||
case 'polyline':
|
case 'polyline':
|
||||||
item = this._importPoly(svg);
|
item = this._importPoly(svg);
|
||||||
break;
|
break;
|
||||||
case 'symbol':
|
case 'symbol':
|
||||||
item = this._importGroup(svg);
|
item = this._importGroup(svg);
|
||||||
this._importAttributesAndStyles(svg, item);
|
this._importAttributesAndStyles(svg, item);
|
||||||
symbol = new Symbol(item);
|
symbol = new Symbol(item);
|
||||||
item = null;
|
item = null;
|
||||||
default:
|
default:
|
||||||
//Not supported yet.
|
// Not supported yet.
|
||||||
}
|
}
|
||||||
|
|
||||||
if (item) {
|
if (item)
|
||||||
this._importAttributesAndStyles(svg, item);
|
this._importAttributesAndStyles(svg, item);
|
||||||
}
|
|
||||||
|
|
||||||
return item;
|
return item;
|
||||||
},
|
},
|
||||||
|
@ -101,13 +100,11 @@ var ImportSvg = this.ImportSvg = Base.extend(/** @Lends ImportSvg# */{
|
||||||
var child;
|
var child;
|
||||||
for (var i in svg.childNodes) {
|
for (var i in svg.childNodes) {
|
||||||
child = svg.childNodes[i];
|
child = svg.childNodes[i];
|
||||||
if (child.nodeType != 1) {
|
if (child.nodeType != 1)
|
||||||
continue;
|
continue;
|
||||||
}
|
item = this.importSvg(child);
|
||||||
item = this.importSVG(child);
|
if (item)
|
||||||
if (item) {
|
|
||||||
group.addChild(item);
|
group.addChild(item);
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return group;
|
return group;
|
||||||
|
@ -282,7 +279,7 @@ var ImportSvg = this.ImportSvg = Base.extend(/** @Lends ImportSvg# */{
|
||||||
var controlPoint;
|
var controlPoint;
|
||||||
var prevCommand;
|
var prevCommand;
|
||||||
var segmentTo;
|
var segmentTo;
|
||||||
for (var i = 0; i < segments.numberOfItems; ++i){
|
for (var i = 0; i < segments.numberOfItems; ++i) {
|
||||||
segment = segments.getItem(i);
|
segment = segments.getItem(i);
|
||||||
if (segment.pathSegType == SVGPathSeg.PATHSEG_UNKNOWN) {
|
if (segment.pathSegType == SVGPathSeg.PATHSEG_UNKNOWN) {
|
||||||
continue;
|
continue;
|
||||||
|
@ -295,75 +292,75 @@ var ImportSvg = this.ImportSvg = Base.extend(/** @Lends ImportSvg# */{
|
||||||
segmentTo = new Point(segment.x, segment.y);
|
segmentTo = new Point(segment.x, segment.y);
|
||||||
segmentTo = segmentTo.add(relativeToPoint);
|
segmentTo = segmentTo.add(relativeToPoint);
|
||||||
switch (segment.pathSegType) {
|
switch (segment.pathSegType) {
|
||||||
case SVGPathSeg.PATHSEG_CLOSEPATH:
|
case SVGPathSeg.PATHSEG_CLOSEPATH:
|
||||||
path.closePath();
|
path.closePath();
|
||||||
break;
|
break;
|
||||||
case SVGPathSeg.PATHSEG_MOVETO_ABS:
|
case SVGPathSeg.PATHSEG_MOVETO_ABS:
|
||||||
case SVGPathSeg.PATHSEG_MOVETO_REL:
|
case SVGPathSeg.PATHSEG_MOVETO_REL:
|
||||||
path.moveTo(segmentTo);
|
path.moveTo(segmentTo);
|
||||||
break;
|
break;
|
||||||
case SVGPathSeg.PATHSEG_LINETO_ABS:
|
case SVGPathSeg.PATHSEG_LINETO_ABS:
|
||||||
case SVGPathSeg.PATHSEG_LINETO_HORIZONTAL_ABS:
|
case SVGPathSeg.PATHSEG_LINETO_HORIZONTAL_ABS:
|
||||||
case SVGPathSeg.PATHSEG_LINETO_VERTICAL_ABS:
|
case SVGPathSeg.PATHSEG_LINETO_VERTICAL_ABS:
|
||||||
case SVGPathSeg.PATHSEG_LINETO_REL:
|
case SVGPathSeg.PATHSEG_LINETO_REL:
|
||||||
case SVGPathSeg.PATHSEG_LINETO_HORIZONTAL_REL:
|
case SVGPathSeg.PATHSEG_LINETO_HORIZONTAL_REL:
|
||||||
case SVGPathSeg.PATHSEG_LINETO_VERTICAL_REL:
|
case SVGPathSeg.PATHSEG_LINETO_VERTICAL_REL:
|
||||||
path.lineTo(segmentTo);
|
path.lineTo(segmentTo);
|
||||||
break;
|
break;
|
||||||
case SVGPathSeg.PATHSEG_CURVETO_CUBIC_ABS:
|
case SVGPathSeg.PATHSEG_CURVETO_CUBIC_ABS:
|
||||||
case SVGPathSeg.PATHSEG_CURVETO_CUBIC_REL:
|
case SVGPathSeg.PATHSEG_CURVETO_CUBIC_REL:
|
||||||
path.cubicCurveTo(
|
path.cubicCurveTo(
|
||||||
relativeToPoint.add([segment.x1, segment.y1]),
|
relativeToPoint.add([segment.x1, segment.y1]),
|
||||||
relativeToPoint.add([segment.x2, segment.y2]),
|
relativeToPoint.add([segment.x2, segment.y2]),
|
||||||
segmentTo
|
segmentTo
|
||||||
);
|
);
|
||||||
break;
|
break;
|
||||||
case SVGPathSeg.PATHSEG_CURVETO_QUADRATIC_ABS:
|
case SVGPathSeg.PATHSEG_CURVETO_QUADRATIC_ABS:
|
||||||
case SVGPathSeg.PATHSEG_CURVETO_QUADRATIC_REL:
|
case SVGPathSeg.PATHSEG_CURVETO_QUADRATIC_REL:
|
||||||
path.quadraticCurveTo(
|
path.quadraticCurveTo(
|
||||||
relativeToPoint.add([segment.x1, segment.y1]),
|
relativeToPoint.add([segment.x1, segment.y1]),
|
||||||
segmentTo
|
segmentTo
|
||||||
);
|
);
|
||||||
break;
|
break;
|
||||||
case SVGPathSeg.PATHSEG_ARC_ABS:
|
case SVGPathSeg.PATHSEG_ARC_ABS:
|
||||||
case SVGPathSeg.PATHSEG_ARC_REL:
|
case SVGPathSeg.PATHSEG_ARC_REL:
|
||||||
//TODO: Implement Arcs.
|
//TODO: Implement Arcs.
|
||||||
//TODO: Requires changes in Paper.js's Path to do.
|
//TODO: Requires changes in Paper.js's Path to do.
|
||||||
//TODO: http://www.w3.org/TR/SVG/implnote.html
|
//TODO: http://www.w3.org/TR/SVG/implnote.html
|
||||||
break;
|
break;
|
||||||
case SVGPathSeg.PATHSEG_CURVETO_CUBIC_SMOOTH_ABS:
|
case SVGPathSeg.PATHSEG_CURVETO_CUBIC_SMOOTH_ABS:
|
||||||
case SVGPathSeg.PATHSEG_CURVETO_CUBIC_SMOOTH_REL:
|
case SVGPathSeg.PATHSEG_CURVETO_CUBIC_SMOOTH_REL:
|
||||||
prevCommand = segments.getItem(i - 1);
|
prevCommand = segments.getItem(i - 1);
|
||||||
controlPoint = new Point(prevCommand.x2, prevCommand.y2);
|
controlPoint = new Point(prevCommand.x2, prevCommand.y2);
|
||||||
controlPoint = controlPoint.subtract([prevCommand.x, prevCommand.y]);
|
controlPoint = controlPoint.subtract([prevCommand.x, prevCommand.y]);
|
||||||
controlPoint = controlPoint.add(path.lastSegment.point);
|
controlPoint = controlPoint.add(path.lastSegment.point);
|
||||||
controlPoint = path.lastSegment.point.subtract(controlPoint);
|
controlPoint = path.lastSegment.point.subtract(controlPoint);
|
||||||
controlPoint = path.lastSegment.point.add(controlPoint);
|
controlPoint = path.lastSegment.point.add(controlPoint);
|
||||||
path.cubicCurveTo(
|
path.cubicCurveTo(
|
||||||
controlPoint,
|
controlPoint,
|
||||||
relativeToPoint.add([segment.x2, segment.y2]),
|
relativeToPoint.add([segment.x2, segment.y2]),
|
||||||
segmentTo
|
segmentTo
|
||||||
);
|
);
|
||||||
break;
|
break;
|
||||||
case SVGPathSeg.PATHSEG_CURVETO_QUADRATIC_SMOOTH_ABS:
|
case SVGPathSeg.PATHSEG_CURVETO_QUADRATIC_SMOOTH_ABS:
|
||||||
case SVGPathSeg.PATHSEG_CURVETO_QUADRATIC_SMOOTH_REL:
|
case SVGPathSeg.PATHSEG_CURVETO_QUADRATIC_SMOOTH_REL:
|
||||||
for (j = i; j >= 0; --j) {
|
for (j = i; j >= 0; --j) {
|
||||||
prevCommand = segments.getItem(j);
|
prevCommand = segments.getItem(j);
|
||||||
if (prevCommand.pathSegType == SVGPathSeg.PATHSEG_CURVETO_QUADRATIC_ABS ||
|
if (prevCommand.pathSegType == SVGPathSeg.PATHSEG_CURVETO_QUADRATIC_ABS ||
|
||||||
prevCommand.pathSegType == SVGPathSeg.PATHSEG_CURVETO_QUADRATIC_REL
|
prevCommand.pathSegType == SVGPathSeg.PATHSEG_CURVETO_QUADRATIC_REL
|
||||||
) {
|
) {
|
||||||
controlPoint = new Point(prevCommand.x1, prevCommand.y1);
|
controlPoint = new Point(prevCommand.x1, prevCommand.y1);
|
||||||
controlPoint = controlPoint.subtract([prevCommand.x, prevCommand.y]);
|
controlPoint = controlPoint.subtract([prevCommand.x, prevCommand.y]);
|
||||||
controlPoint = controlPoint.add(path.segments[j].point);
|
controlPoint = controlPoint.add(path.segments[j].point);
|
||||||
break;
|
break;
|
||||||
}
|
|
||||||
}
|
}
|
||||||
for (j; j < i; ++j) {
|
}
|
||||||
controlPoint = path.segments[j].point.subtract(controlPoint);
|
for (j; j < i; ++j) {
|
||||||
controlPoint = path.segments[j].point.add(controlPoint);
|
controlPoint = path.segments[j].point.subtract(controlPoint);
|
||||||
}
|
controlPoint = path.segments[j].point.add(controlPoint);
|
||||||
path.quadraticCurveTo(controlPoint, segmentTo);
|
}
|
||||||
break;
|
path.quadraticCurveTo(controlPoint, segmentTo);
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -445,79 +442,79 @@ var ImportSvg = this.ImportSvg = Base.extend(/** @Lends ImportSvg# */{
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
switch (name) {
|
switch (name) {
|
||||||
case 'id':
|
case 'id':
|
||||||
item.name = value;
|
item.name = value;
|
||||||
break;
|
break;
|
||||||
case 'fill':
|
case 'fill':
|
||||||
if (value != 'none') {
|
if (value != 'none') {
|
||||||
item.fillColor = value;
|
item.fillColor = value;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 'stroke':
|
case 'stroke':
|
||||||
if (value != 'none') {
|
if (value != 'none') {
|
||||||
item.strokeColor = value;
|
item.strokeColor = value;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 'stroke-width':
|
case 'stroke-width':
|
||||||
item.strokeWidth = parseFloat(value, 10);
|
item.strokeWidth = parseFloat(value, 10);
|
||||||
break;
|
break;
|
||||||
case 'stroke-linecap':
|
case 'stroke-linecap':
|
||||||
item.strokeCap = value;
|
item.strokeCap = value;
|
||||||
break;
|
break;
|
||||||
case 'stroke-linejoin':
|
case 'stroke-linejoin':
|
||||||
item.strokeJoin = value;
|
item.strokeJoin = value;
|
||||||
break;
|
break;
|
||||||
case 'stroke-dasharray':
|
case 'stroke-dasharray':
|
||||||
value = value.replace(/px/g, '');
|
value = value.replace(/px/g, '');
|
||||||
value = value.replace(/, /g, ',');
|
value = value.replace(/, /g, ',');
|
||||||
value = value.replace(/ /g, ',');
|
value = value.replace(/ /g, ',');
|
||||||
value = value.split(',');
|
value = value.split(',');
|
||||||
for (var i in value) {
|
for (var i in value) {
|
||||||
value[i] = parseFloat(value[i], 10);
|
value[i] = parseFloat(value[i], 10);
|
||||||
}
|
}
|
||||||
item.dashArray = value;
|
item.dashArray = value;
|
||||||
break;
|
break;
|
||||||
case 'stroke-dashoffset':
|
case 'stroke-dashoffset':
|
||||||
item.dashOffset = parseFloat(value, 10);
|
item.dashOffset = parseFloat(value, 10);
|
||||||
break;
|
break;
|
||||||
case 'stroke-miterlimit':
|
case 'stroke-miterlimit':
|
||||||
item.miterLimit = parseFloat(value, 10);
|
item.miterLimit = parseFloat(value, 10);
|
||||||
break;
|
break;
|
||||||
case 'transform':
|
case 'transform':
|
||||||
this._applyTransform(item, svg);
|
this._applyTransform(item, svg);
|
||||||
case 'opacity':
|
case 'opacity':
|
||||||
item.opacity = parseFloat(value, 10);
|
item.opacity = parseFloat(value, 10);
|
||||||
case 'visibility':
|
case 'visibility':
|
||||||
item.visibility = (value == 'visible') ? true : false;
|
item.visibility = (value == 'visible') ? true : false;
|
||||||
break;
|
break;
|
||||||
case 'font':
|
case 'font':
|
||||||
case 'font-family':
|
case 'font-family':
|
||||||
case 'font-size':
|
case 'font-size':
|
||||||
//Implemented in characterStyle below.
|
//Implemented in characterStyle below.
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
// Not supported yet.
|
// Not supported yet.
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
if (item.characterStyle) {
|
if (item.characterStyle) {
|
||||||
switch (name) {
|
switch (name) {
|
||||||
case 'font':
|
case 'font':
|
||||||
var text = document.createElement('span');
|
var text = document.createElement('span');
|
||||||
text.style.font = value;
|
text.style.font = value;
|
||||||
for (var i = 0; i < text.style.length; ++i) {
|
for (var i = 0; i < text.style.length; ++i) {
|
||||||
var n = text.style[i];
|
var n = text.style[i];
|
||||||
this._applyAttributeOrStyle(n, text.style[n], item, svg);
|
this._applyAttributeOrStyle(n, text.style[n], item, svg);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 'font-family':
|
case 'font-family':
|
||||||
var fonts = value.split(',');
|
var fonts = value.split(',');
|
||||||
fonts[0] = fonts[0].replace(/^\s+|\s+$/g, "");
|
fonts[0] = fonts[0].replace(/^\s+|\s+$/g, "");
|
||||||
item.characterStyle.font = fonts[0];
|
item.characterStyle.font = fonts[0];
|
||||||
break;
|
break;
|
||||||
case 'font-size':
|
case 'font-size':
|
||||||
item.characterStyle.fontSize = parseFloat(value, 10);
|
item.characterStyle.fontSize = parseFloat(value, 10);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
|
@ -550,29 +547,28 @@ var ImportSvg = this.ImportSvg = Base.extend(/** @Lends ImportSvg# */{
|
||||||
transform.matrix.f
|
transform.matrix.f
|
||||||
);
|
);
|
||||||
switch (transform.type) {
|
switch (transform.type) {
|
||||||
case SVGTransform.SVG_TRANSFORM_TRANSLATE:
|
case SVGTransform.SVG_TRANSFORM_TRANSLATE:
|
||||||
break;
|
break;
|
||||||
case SVGTransform.SVG_TRANSFORM_SCALE:
|
case SVGTransform.SVG_TRANSFORM_SCALE:
|
||||||
break;
|
break;
|
||||||
|
//Compensate for SVG's theta rotation going the opposite direction
|
||||||
//Compensate for SVG's theta rotation going the opposite direction
|
case SVGTransform.SVG_TRANSFORM_MATRIX:
|
||||||
case SVGTransform.SVG_TRANSFORM_MATRIX:
|
var temp = transformMatrix.getShearX();
|
||||||
var temp = transformMatrix.getShearX();
|
transformMatrix.setShearX(transformMatrix.getShearY());
|
||||||
transformMatrix.setShearX(transformMatrix.getShearY());
|
transformMatrix.setShearY(temp);
|
||||||
transformMatrix.setShearY(temp);
|
break;
|
||||||
break;
|
case SVGTransform.SVG_TRANSFORM_SKEWX:
|
||||||
case SVGTransform.SVG_TRANSFORM_SKEWX:
|
transformMatrix.setShearX(transformMatrix.getShearY());
|
||||||
transformMatrix.setShearX(transformMatrix.getShearY());
|
transformMatrix.setShearY(0);
|
||||||
transformMatrix.setShearY(0);
|
break;
|
||||||
break;
|
case SVGTransform.SVG_TRANSFORM_SKEWY:
|
||||||
case SVGTransform.SVG_TRANSFORM_SKEWY:
|
transformMatrix.setShearY(transformMatrix.getShearX());
|
||||||
transformMatrix.setShearY(transformMatrix.getShearX());
|
transformMatrix.setShearX(0);
|
||||||
transformMatrix.setShearX(0);
|
break;
|
||||||
break;
|
case SVGTransform.SVG_TRANSFORM_ROTATE:
|
||||||
case SVGTransform.SVG_TRANSFORM_ROTATE:
|
transformMatrix.setShearX(transformMatrix.getShearX() * -1);
|
||||||
transformMatrix.setShearX(transformMatrix.getShearX() * -1);
|
transformMatrix.setShearY(transformMatrix.getShearY() * -1);
|
||||||
transformMatrix.setShearY(transformMatrix.getShearY() * -1);
|
break;
|
||||||
break;
|
|
||||||
}
|
}
|
||||||
matrix.concatenate(transformMatrix);
|
matrix.concatenate(transformMatrix);
|
||||||
}
|
}
|
||||||
|
|
|
@ -31,7 +31,7 @@ test('make an svg line', function() {
|
||||||
shape.setAttribute('y2', y2);
|
shape.setAttribute('y2', y2);
|
||||||
|
|
||||||
var isvg = new ImportSvg();
|
var isvg = new ImportSvg();
|
||||||
var importedLine = isvg.importSVG(shape);
|
var importedLine = isvg.importSvg(shape);
|
||||||
|
|
||||||
var line = new Path.Line([x1, y1], [x2, y2]);
|
var line = new Path.Line([x1, y1], [x2, y2]);
|
||||||
|
|
||||||
|
@ -47,7 +47,7 @@ test('make an svg line with invalid values', function() {
|
||||||
shape.setAttribute('y2', null);
|
shape.setAttribute('y2', null);
|
||||||
|
|
||||||
var isvg = new ImportSvg();
|
var isvg = new ImportSvg();
|
||||||
var importedLine = isvg.importSVG(shape);
|
var importedLine = isvg.importSvg(shape);
|
||||||
|
|
||||||
var line = new Path.Line([0, 0], [0, 0]);
|
var line = new Path.Line([0, 0], [0, 0]);
|
||||||
|
|
||||||
|
@ -68,7 +68,7 @@ test('compare rectangle values', function() {
|
||||||
shape.setAttribute('height', height);
|
shape.setAttribute('height', height);
|
||||||
|
|
||||||
var isvg = new ImportSvg();
|
var isvg = new ImportSvg();
|
||||||
var importedRectangle = isvg.importSVG(shape);
|
var importedRectangle = isvg.importSvg(shape);
|
||||||
|
|
||||||
var topLeft = new Point(x, y);
|
var topLeft = new Point(x, y);
|
||||||
var size = new Size(width, height);
|
var size = new Size(width, height);
|
||||||
|
@ -92,7 +92,7 @@ test('compare negative rectangle values', function() {
|
||||||
shape.setAttribute('height', height);
|
shape.setAttribute('height', height);
|
||||||
|
|
||||||
var isvg = new ImportSvg();
|
var isvg = new ImportSvg();
|
||||||
var importedRectangle = isvg.importSVG(shape);
|
var importedRectangle = isvg.importSvg(shape);
|
||||||
var topLeft = new Point(x, y);
|
var topLeft = new Point(x, y);
|
||||||
var size = new Size(width, height);
|
var size = new Size(width, height);
|
||||||
var rectangle = new Rectangle(topLeft, size);
|
var rectangle = new Rectangle(topLeft, size);
|
||||||
|
@ -112,7 +112,7 @@ test('compare invalid rectangle values', function() {
|
||||||
shape.setAttribute('height', null);
|
shape.setAttribute('height', null);
|
||||||
|
|
||||||
var isvg = new ImportSvg();
|
var isvg = new ImportSvg();
|
||||||
var importedRectangle = isvg.importSVG(shape);
|
var importedRectangle = isvg.importSvg(shape);
|
||||||
|
|
||||||
var topLeft = new Point(0, 0);
|
var topLeft = new Point(0, 0);
|
||||||
var size = new Size(0, 0);
|
var size = new Size(0, 0);
|
||||||
|
@ -139,7 +139,7 @@ test('compare round rectangle values', function() {
|
||||||
shape.setAttribute('height', height);
|
shape.setAttribute('height', height);
|
||||||
|
|
||||||
var isvg = new ImportSvg();
|
var isvg = new ImportSvg();
|
||||||
var importedRectangle = isvg.importSVG(shape);
|
var importedRectangle = isvg.importSvg(shape);
|
||||||
|
|
||||||
var topLeft = new Point(x, y);
|
var topLeft = new Point(x, y);
|
||||||
var size = new Size(width, height);
|
var size = new Size(width, height);
|
||||||
|
@ -167,7 +167,7 @@ test('compare negative round rectangle values', function() {
|
||||||
shape.setAttribute('height', height);
|
shape.setAttribute('height', height);
|
||||||
|
|
||||||
var isvg = new ImportSvg();
|
var isvg = new ImportSvg();
|
||||||
var importedRectangle = isvg.importSVG(shape);
|
var importedRectangle = isvg.importSvg(shape);
|
||||||
|
|
||||||
var topLeft = new Point(x, y);
|
var topLeft = new Point(x, y);
|
||||||
var size = new Size(width, height);
|
var size = new Size(width, height);
|
||||||
|
@ -195,7 +195,7 @@ test('compare invalid round rectangle values', function() {
|
||||||
shape.setAttribute('height', height);
|
shape.setAttribute('height', height);
|
||||||
|
|
||||||
var isvg = new ImportSvg();
|
var isvg = new ImportSvg();
|
||||||
var importedRectangle = isvg.importSVG(shape);
|
var importedRectangle = isvg.importSvg(shape);
|
||||||
|
|
||||||
var topLeft = new Point(x, y);
|
var topLeft = new Point(x, y);
|
||||||
var size = new Size(width, height);
|
var size = new Size(width, height);
|
||||||
|
@ -219,7 +219,7 @@ test('compare oval values', function() {
|
||||||
shape.setAttribute('ry', ry);
|
shape.setAttribute('ry', ry);
|
||||||
|
|
||||||
var isvg = new ImportSvg();
|
var isvg = new ImportSvg();
|
||||||
var importedOval = isvg.importSVG(shape);
|
var importedOval = isvg.importSvg(shape);
|
||||||
|
|
||||||
var center = new Point(cx, cy);
|
var center = new Point(cx, cy);
|
||||||
var offset = new Point(rx, ry);
|
var offset = new Point(rx, ry);
|
||||||
|
@ -247,7 +247,7 @@ test('compare negative oval values', function() {
|
||||||
shape.setAttribute('ry', ry);
|
shape.setAttribute('ry', ry);
|
||||||
|
|
||||||
var isvg = new ImportSvg();
|
var isvg = new ImportSvg();
|
||||||
var importedOval = isvg.importSVG(shape);
|
var importedOval = isvg.importSvg(shape);
|
||||||
|
|
||||||
var center = new Point(cx, cy);
|
var center = new Point(cx, cy);
|
||||||
var offset = new Point(rx, ry);
|
var offset = new Point(rx, ry);
|
||||||
|
@ -270,7 +270,7 @@ test('compare invalid oval values', function() {
|
||||||
shape.setAttribute('ry', null);
|
shape.setAttribute('ry', null);
|
||||||
|
|
||||||
var isvg = new ImportSvg();
|
var isvg = new ImportSvg();
|
||||||
var importedOval = isvg.importSVG(shape);
|
var importedOval = isvg.importSvg(shape);
|
||||||
|
|
||||||
var center = new Point(0, 0);
|
var center = new Point(0, 0);
|
||||||
var offset = new Point(0, 0);
|
var offset = new Point(0, 0);
|
||||||
|
@ -295,7 +295,7 @@ test('compare circle values', function() {
|
||||||
shape.setAttribute('r', r);
|
shape.setAttribute('r', r);
|
||||||
|
|
||||||
var isvg = new ImportSvg();
|
var isvg = new ImportSvg();
|
||||||
var importedCircle = isvg.importSVG(shape);
|
var importedCircle = isvg.importSvg(shape);
|
||||||
|
|
||||||
var center = new Point(cx, cy);
|
var center = new Point(cx, cy);
|
||||||
var circle = new Path.Circle(center, r);
|
var circle = new Path.Circle(center, r);
|
||||||
|
@ -315,7 +315,7 @@ test('compare negative circle values', function() {
|
||||||
shape.setAttribute('r', r);
|
shape.setAttribute('r', r);
|
||||||
|
|
||||||
var isvg = new ImportSvg();
|
var isvg = new ImportSvg();
|
||||||
var importedCircle = isvg.importSVG(shape);
|
var importedCircle = isvg.importSvg(shape);
|
||||||
|
|
||||||
var center = new Point(cx, cy);
|
var center = new Point(cx, cy);
|
||||||
var circle = new Path.Circle(center, r);
|
var circle = new Path.Circle(center, r);
|
||||||
|
@ -333,7 +333,7 @@ test('compare invalid circle values', function() {
|
||||||
shape.setAttribute('r', null);
|
shape.setAttribute('r', null);
|
||||||
|
|
||||||
var isvg = new ImportSvg();
|
var isvg = new ImportSvg();
|
||||||
var importedCircle = isvg.importSVG(shape);
|
var importedCircle = isvg.importSvg(shape);
|
||||||
|
|
||||||
var center = new Point(0, 0);
|
var center = new Point(0, 0);
|
||||||
var circle = new Path.Circle(center, 0);
|
var circle = new Path.Circle(center, 0);
|
||||||
|
@ -349,7 +349,7 @@ test('compare polygon values', function() {
|
||||||
shape.setAttribute('points', svgpoints);
|
shape.setAttribute('points', svgpoints);
|
||||||
|
|
||||||
var isvg = new ImportSvg();
|
var isvg = new ImportSvg();
|
||||||
var importedPolygon = isvg.importSVG(shape);
|
var importedPolygon = isvg.importSvg(shape);
|
||||||
|
|
||||||
var poly = new Path();
|
var poly = new Path();
|
||||||
var points = shape.points;
|
var points = shape.points;
|
||||||
|
@ -376,7 +376,7 @@ test('compare negative polygon values', function() {
|
||||||
shape.setAttribute('points', svgpoints);
|
shape.setAttribute('points', svgpoints);
|
||||||
|
|
||||||
var isvg = new ImportSvg();
|
var isvg = new ImportSvg();
|
||||||
var importedPolygon = isvg.importSVG(shape);
|
var importedPolygon = isvg.importSvg(shape);
|
||||||
|
|
||||||
var poly = new Path();
|
var poly = new Path();
|
||||||
var points = shape.points;
|
var points = shape.points;
|
||||||
|
@ -403,7 +403,7 @@ test('compare polyline values', function() {
|
||||||
shape.setAttribute('points', svgpoints);
|
shape.setAttribute('points', svgpoints);
|
||||||
|
|
||||||
var isvg = new ImportSvg();
|
var isvg = new ImportSvg();
|
||||||
var importedPolyline = isvg.importSVG(shape);
|
var importedPolyline = isvg.importSvg(shape);
|
||||||
|
|
||||||
var poly = new Path();
|
var poly = new Path();
|
||||||
var points = shape.points;
|
var points = shape.points;
|
||||||
|
@ -430,7 +430,7 @@ test('compare polyline values', function() {
|
||||||
shape.setAttribute('points', svgpoints);
|
shape.setAttribute('points', svgpoints);
|
||||||
|
|
||||||
var isvg = new ImportSvg();
|
var isvg = new ImportSvg();
|
||||||
var importedPolyline = isvg.importSVG(shape);
|
var importedPolyline = isvg.importSvg(shape);
|
||||||
|
|
||||||
var poly = new Path();
|
var poly = new Path();
|
||||||
var points = shape.points;
|
var points = shape.points;
|
||||||
|
|
Loading…
Reference in a new issue