mirror of
https://github.com/scratchfoundation/paper.js.git
synced 2025-01-22 07:19:57 -05:00
Make drawCurve() a private function of drawPath().
This commit is contained in:
parent
3c14b3042b
commit
40390f8309
1 changed files with 22 additions and 21 deletions
|
@ -179,37 +179,38 @@ var SvgExporter = this.SvgExporter = new function() {
|
||||||
function drawPath(path, segments) {
|
function drawPath(path, segments) {
|
||||||
var parts = [],
|
var parts = [],
|
||||||
style = path._style;
|
style = path._style;
|
||||||
|
|
||||||
|
function drawCurve(seg1, seg2, skipLine) {
|
||||||
|
var point1 = seg1._point,
|
||||||
|
point2 = seg2._point,
|
||||||
|
handle1 = seg1._handleOut,
|
||||||
|
handle2 = seg2._handleIn;
|
||||||
|
if (handle1.isZero() && handle2.isZero()) {
|
||||||
|
if (!skipLine) {
|
||||||
|
// L = lineto: moving to a point with drawing
|
||||||
|
parts.push('L' + formatPoint(point2));
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
// c = relative curveto: handle1, handle2 + end - start, end - start
|
||||||
|
var end = point2.subtract(point1);
|
||||||
|
parts.push('c' + formatPoint(handle1),
|
||||||
|
formatPoint(end.add(handle2)),
|
||||||
|
formatPoint(end));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
parts.push('M' + formatPoint(segments[0]._point));
|
parts.push('M' + formatPoint(segments[0]._point));
|
||||||
for (i = 0; i < segments.length - 1; i++)
|
for (i = 0; i < segments.length - 1; i++)
|
||||||
drawCurve(parts, segments[i], segments[i + 1], false);
|
drawCurve(segments[i], segments[i + 1], false);
|
||||||
// We only need to draw the connecting curve if it is not a line, and if
|
// We only need to draw the connecting curve if it is not a line, and if
|
||||||
// the path is cosed and has a stroke color, or if it is filled.
|
// the path is cosed and has a stroke color, or if it is filled.
|
||||||
if (path._closed && style._strokeColor || style._fillColor)
|
if (path._closed && style._strokeColor || style._fillColor)
|
||||||
drawCurve(parts, segments[segments.length - 1], segments[0], true);
|
drawCurve(segments[segments.length - 1], segments[0], true);
|
||||||
if (path._closed)
|
if (path._closed)
|
||||||
parts.push('z');
|
parts.push('z');
|
||||||
return parts.join(' ');
|
return parts.join(' ');
|
||||||
}
|
}
|
||||||
|
|
||||||
function drawCurve(parts, seg1, seg2, skipLine) {
|
|
||||||
var point1 = seg1._point,
|
|
||||||
point2 = seg2._point,
|
|
||||||
handle1 = seg1._handleOut,
|
|
||||||
handle2 = seg2._handleIn;
|
|
||||||
if (handle1.isZero() && handle2.isZero()) {
|
|
||||||
if (!skipLine) {
|
|
||||||
// L = lineto: moving to a point with drawing
|
|
||||||
parts.push('L' + formatPoint(point2));
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
// c = relative curveto: handle1, handle2 + end - start, end - start
|
|
||||||
var end = point2.subtract(point1);
|
|
||||||
parts.push('c' + formatPoint(handle1),
|
|
||||||
formatPoint(end.add(handle2)),
|
|
||||||
formatPoint(end));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
function determineAngle(path, segments, type) {
|
function determineAngle(path, segments, type) {
|
||||||
// If the object is a circle, ellipse, rectangle, or rounded rectangle,
|
// If the object is a circle, ellipse, rectangle, or rounded rectangle,
|
||||||
// see if they are placed at an angle.
|
// see if they are placed at an angle.
|
||||||
|
|
Loading…
Reference in a new issue