mirror of
https://github.com/scratchfoundation/paper.js.git
synced 2025-01-22 23:39:59 -05:00
Introduce private getDistance() function for shorter code.
This commit is contained in:
parent
7511511ec7
commit
5a061da4e3
1 changed files with 20 additions and 15 deletions
|
@ -47,6 +47,10 @@ var SvgExporter = this.SvgExporter = new function() {
|
||||||
return svg;
|
return svg;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function getDistance(segments, index1, index2) {
|
||||||
|
return segments[index1]._point.getDistance(segments[index2]._point);
|
||||||
|
}
|
||||||
|
|
||||||
function exportItem(path) {
|
function exportItem(path) {
|
||||||
var svg;
|
var svg;
|
||||||
//Getting all of the segments(a point, a HandleIn and a HandleOut) in the path
|
//Getting all of the segments(a point, a HandleIn and a HandleOut) in the path
|
||||||
|
@ -61,11 +65,12 @@ var SvgExporter = this.SvgExporter = new function() {
|
||||||
segments = path.getSegments();
|
segments = path.getSegments();
|
||||||
type = determineType(path, segments);
|
type = determineType(path, segments);
|
||||||
}
|
}
|
||||||
|
|
||||||
//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 = segments[0]._point.getDistance(segments[3]._point);
|
var width = getDistance(segments, 0, 3);
|
||||||
var height = segments[0]._point.getDistance(segments[1]._point);
|
var height = getDistance(segments, 0, 1);
|
||||||
svg = createElement('rect');
|
svg = createElement('rect');
|
||||||
svg.setAttribute('x', path.bounds.topLeft._x);
|
svg.setAttribute('x', path.bounds.topLeft._x);
|
||||||
svg.setAttribute('y', path.bounds.topLeft._y);
|
svg.setAttribute('y', path.bounds.topLeft._y);
|
||||||
|
@ -74,11 +79,11 @@ var SvgExporter = this.SvgExporter = new function() {
|
||||||
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 = segments[1]._point.getDistance(segments[6]._point);
|
var dx1 = getDistance(segments, 1, 6);
|
||||||
var dx2 = segments[0]._point.getDistance(segments[7]._point);
|
var dx2 = getDistance(segments, 0, 7);
|
||||||
var dx3 = (dx1 - dx2) / 2;
|
var dx3 = (dx1 - dx2) / 2;
|
||||||
var dy1 = segments[0]._point.getDistance(segments[3]._point);
|
var dy1 = getDistance(segments, 0, 3);
|
||||||
var dy2 = segments[1]._point.getDistance(segments[2]._point);
|
var dy2 = getDistance(segments, 1, 2);
|
||||||
var dy3 = (dy1 - dy2) / 2;
|
var dy3 = (dy1 - dy2) / 2;
|
||||||
var point = new Point((segments[3]._point._x - dx3), (segments[2]._point._y - dy3));
|
var point = new Point((segments[3]._point._x - dx3), (segments[2]._point._y - dy3));
|
||||||
var width = Math.round(dx1);
|
var width = Math.round(dx1);
|
||||||
|
@ -102,15 +107,15 @@ var SvgExporter = this.SvgExporter = new function() {
|
||||||
break;
|
break;
|
||||||
case 'circle':
|
case 'circle':
|
||||||
svg = createElement('circle');
|
svg = createElement('circle');
|
||||||
var radius = (segments[0]._point.getDistance(segments[2]._point)) /2;
|
var radius = (getDistance(segments, 0, 2)) /2;
|
||||||
svg.setAttribute('cx', path.bounds.center.x);
|
svg.setAttribute('cx', path.bounds.center.x);
|
||||||
svg.setAttribute('cy', path.bounds.center.y);
|
svg.setAttribute('cy', path.bounds.center.y);
|
||||||
svg.setAttribute('r', radius);
|
svg.setAttribute('r', radius);
|
||||||
break;
|
break;
|
||||||
case 'ellipse':
|
case 'ellipse':
|
||||||
svg = createElement('ellipse');
|
svg = createElement('ellipse');
|
||||||
var radiusX = segments[2]._point.getDistance(segments[0]._point) / 2;
|
var radiusX = getDistance(segments, 2, 0) / 2;
|
||||||
var radiusY = segments[3]._point.getDistance(segments[1]._point) /2;
|
var radiusY = getDistance(segments, 3, 1) /2;
|
||||||
svg.setAttribute('cx', path.bounds.center.x);
|
svg.setAttribute('cx', path.bounds.center.x);
|
||||||
svg.setAttribute('cy', path.bounds.center.y);
|
svg.setAttribute('cy', path.bounds.center.y);
|
||||||
svg.setAttribute('rx', radiusX);
|
svg.setAttribute('rx', radiusX);
|
||||||
|
@ -263,8 +268,8 @@ var SvgExporter = this.SvgExporter = new function() {
|
||||||
if (segments.length == 4) {
|
if (segments.length == 4) {
|
||||||
// If the distance between (point0 and point1) and (point2 and
|
// If the distance between (point0 and point1) and (point2 and
|
||||||
// point3) are equal, then it is a rectangle
|
// point3) are equal, then it is a rectangle
|
||||||
dPoint12 = Math.round(segments[0]._point.getDistance(segments[1]._point));
|
dPoint12 = Math.round(getDistance(segments, 0, 1));
|
||||||
dPoint34 = Math.round(segments[3]._point.getDistance(segments[2]._point));
|
dPoint34 = Math.round(getDistance(segments, 3, 2));
|
||||||
if (dPoint12 == dPoint34) {
|
if (dPoint12 == dPoint34) {
|
||||||
type = 'rect';
|
type = 'rect';
|
||||||
}
|
}
|
||||||
|
@ -283,8 +288,8 @@ var SvgExporter = this.SvgExporter = new function() {
|
||||||
if (segments.length == 8) {
|
if (segments.length == 8) {
|
||||||
// If the distance between (point0 and point3) and (point7 and
|
// If the distance between (point0 and point3) and (point7 and
|
||||||
// point4) are equal then it is a roundedRectangle
|
// point4) are equal then it is a roundedRectangle
|
||||||
dPoint12 = Math.round(segments[0]._point.getDistance(segments[3]._point));
|
dPoint12 = Math.round(getDistance(segments, 0, 3));
|
||||||
dPoint34 = Math.round(segments[7]._point.getDistance(segments[4]._point));
|
dPoint34 = Math.round(getDistance(segments, 7, 4));
|
||||||
if (dPoint12 == dPoint34) {
|
if (dPoint12 == dPoint34) {
|
||||||
type = 'roundrect';
|
type = 'roundrect';
|
||||||
}
|
}
|
||||||
|
@ -304,8 +309,8 @@ var SvgExporter = this.SvgExporter = new function() {
|
||||||
if (checkPointValues) {
|
if (checkPointValues) {
|
||||||
// If the distance between (point0 and point2) and (point1
|
// If the distance between (point0 and point2) and (point1
|
||||||
// and point3) are equal, then it is a circle
|
// and point3) are equal, then it is a circle
|
||||||
var d1 = Math.round(segments[0]._point.getDistance(segments[2]._point));
|
var d1 = Math.round(getDistance(segments, 0, 2));
|
||||||
var d2 = Math.round(segments[1]._point.getDistance(segments[3]._point));
|
var d2 = Math.round(getDistance(segments, 1, 3));
|
||||||
if (d1 == d2) {
|
if (d1 == d2) {
|
||||||
type = 'circle';
|
type = 'circle';
|
||||||
} else {
|
} else {
|
||||||
|
|
Loading…
Reference in a new issue