2011-03-06 19:50:44 -05:00
|
|
|
/*
|
2013-01-28 21:03:27 -05:00
|
|
|
* Paper.js - The Swiss Army Knife of Vector Graphics Scripting.
|
2011-03-07 20:41:50 -05:00
|
|
|
* http://paperjs.org/
|
2011-06-30 06:01:51 -04:00
|
|
|
*
|
2013-01-28 21:03:27 -05:00
|
|
|
* Copyright (c) 2011 - 2013, Juerg Lehni & Jonathan Puckey
|
2011-03-06 19:50:44 -05:00
|
|
|
* http://lehni.org/ & http://jonathanpuckey.com/
|
2011-06-30 06:01:51 -04:00
|
|
|
*
|
2011-07-01 06:17:45 -04:00
|
|
|
* Distributed under the MIT license. See LICENSE file for details.
|
|
|
|
*
|
2011-03-07 20:41:50 -05:00
|
|
|
* All rights reserved.
|
2011-03-06 19:50:44 -05:00
|
|
|
*/
|
|
|
|
|
2011-02-17 15:04:02 -05:00
|
|
|
Path.inject({ statics: new function() {
|
2012-11-06 14:37:00 -05:00
|
|
|
|
2013-03-05 03:28:10 -05:00
|
|
|
function createPath(args) {
|
2013-07-21 18:45:22 -04:00
|
|
|
return new Path(Base.getNamed(args));
|
2013-03-05 03:28:10 -05:00
|
|
|
}
|
|
|
|
|
2013-10-16 07:26:08 -04:00
|
|
|
var kappa = Numerical.KAPPA,
|
|
|
|
halfKappa = kappa / 2,
|
|
|
|
ellipseSegments = [
|
|
|
|
new Segment([0, 0.5], [0, halfKappa ], [0, -halfKappa]),
|
|
|
|
new Segment([0.5, 0], [-halfKappa, 0], [halfKappa, 0 ]),
|
|
|
|
new Segment([1, 0.5], [0, -halfKappa], [0, halfKappa ]),
|
|
|
|
new Segment([0.5, 1], [halfKappa, 0 ], [-halfKappa, 0])
|
|
|
|
];
|
2012-11-06 14:37:00 -05:00
|
|
|
|
2011-06-22 18:58:50 -04:00
|
|
|
return /** @lends Path */{
|
2011-05-23 08:33:22 -04:00
|
|
|
/**
|
2011-05-30 11:13:19 -04:00
|
|
|
* {@grouptitle Shaped Paths}
|
2011-06-27 06:31:39 -04:00
|
|
|
*
|
2013-06-27 21:03:03 -04:00
|
|
|
* Creates a Path item with two anchor points forming a line.
|
2011-06-30 06:01:51 -04:00
|
|
|
*
|
2013-03-10 14:09:09 -04:00
|
|
|
* @name Path.Line
|
2012-12-30 12:24:33 -05:00
|
|
|
* @param {Point} from the first anchor point of the path
|
|
|
|
* @param {Point} to the second anchor point of the path
|
2011-05-23 08:33:22 -04:00
|
|
|
* @return {Path} the newly created path
|
2011-06-30 06:01:51 -04:00
|
|
|
*
|
2013-03-03 12:34:39 -05:00
|
|
|
* @example {@paperscript}
|
2011-05-30 11:13:19 -04:00
|
|
|
* var from = new Point(20, 20);
|
2013-03-03 12:34:39 -05:00
|
|
|
* var to = new Point(80, 80);
|
2011-05-30 11:13:19 -04:00
|
|
|
* var path = new Path.Line(from, to);
|
|
|
|
* path.strokeColor = 'black';
|
2013-03-03 12:34:39 -05:00
|
|
|
*
|
2013-04-21 07:58:22 -04:00
|
|
|
* @example {@paperscript} // Using object notation
|
2013-03-03 12:34:39 -05:00
|
|
|
* var path = new Path.Line({
|
2013-03-10 14:09:09 -04:00
|
|
|
* from: [20, 20],
|
|
|
|
* to: [80, 80],
|
2013-03-03 12:34:39 -05:00
|
|
|
* strokeColor: 'black'
|
|
|
|
* });
|
2011-05-23 08:33:22 -04:00
|
|
|
*/
|
2012-12-30 12:33:46 -05:00
|
|
|
Line: function(/* from, to */) {
|
2011-03-13 13:31:00 -04:00
|
|
|
return new Path(
|
2012-12-30 12:24:33 -05:00
|
|
|
Point.readNamed(arguments, 'from'),
|
|
|
|
Point.readNamed(arguments, 'to')
|
2013-03-01 17:06:04 -05:00
|
|
|
).set(Base.getNamed(arguments));
|
2011-02-17 09:55:26 -05:00
|
|
|
},
|
|
|
|
|
2013-06-27 20:54:00 -04:00
|
|
|
/**
|
2013-06-27 21:03:03 -04:00
|
|
|
* Creates a circle shaped Path item.
|
2013-06-27 20:54:00 -04:00
|
|
|
*
|
|
|
|
* @param {Point} center the center point of the circle
|
|
|
|
* @param {Number} radius the radius of the circle
|
|
|
|
* @return {Path} the newly created path
|
|
|
|
*
|
|
|
|
* @example {@paperscript}
|
|
|
|
* var path = new Path.Circle(new Point(80, 50), 30);
|
|
|
|
* path.strokeColor = 'black';
|
|
|
|
*
|
|
|
|
* @example {@paperscript} // Using object notation
|
|
|
|
* var path = new Path.Circle({
|
|
|
|
* center: [80, 50],
|
|
|
|
* radius: 30,
|
|
|
|
* strokeColor: 'black'
|
|
|
|
* });
|
|
|
|
*/
|
|
|
|
Circle: function(/* center, radius */) {
|
|
|
|
var center = Point.readNamed(arguments, 'center'),
|
|
|
|
radius = Base.readNamed(arguments, 'radius');
|
2013-10-16 07:26:08 -04:00
|
|
|
// No need for new, since that's happening inside Path.Ellipse
|
|
|
|
return Path.Ellipse(new Rectangle(center.subtract(radius),
|
2013-06-27 20:54:00 -04:00
|
|
|
new Size(radius * 2, radius * 2)))
|
|
|
|
.set(Base.getNamed(arguments));
|
|
|
|
},
|
|
|
|
|
2011-05-23 08:33:22 -04:00
|
|
|
/**
|
2013-06-27 21:03:03 -04:00
|
|
|
* Creates a rectangle shaped Path item from the passed point and size.
|
2011-06-30 06:01:51 -04:00
|
|
|
*
|
2011-05-27 20:17:35 -04:00
|
|
|
* @name Path.Rectangle
|
2011-05-23 08:33:22 -04:00
|
|
|
* @param {Point} point
|
|
|
|
* @param {Size} size
|
|
|
|
* @return {Path} the newly created path
|
2011-06-30 06:01:51 -04:00
|
|
|
*
|
2013-03-03 12:34:39 -05:00
|
|
|
* @example {@paperscript}
|
|
|
|
* var point = new Point(20, 20);
|
|
|
|
* var size = new Size(60, 60);
|
2013-03-10 14:09:09 -04:00
|
|
|
* var path = new Path.Rectangle(point, size);
|
2011-05-30 11:13:19 -04:00
|
|
|
* path.strokeColor = 'black';
|
2013-03-10 14:09:09 -04:00
|
|
|
*
|
2013-04-21 07:58:22 -04:00
|
|
|
* @example {@paperscript} // Using object notation
|
2013-03-10 14:09:09 -04:00
|
|
|
* var path = new Path.Rectangle({
|
|
|
|
* point: [20, 20],
|
|
|
|
* size: [60, 60],
|
|
|
|
* strokeColor: 'black'
|
|
|
|
* });
|
2011-05-23 08:33:22 -04:00
|
|
|
*/
|
|
|
|
/**
|
2013-06-27 21:03:03 -04:00
|
|
|
* Creates a rectangle shaped Path item from the passed points. These do
|
|
|
|
* not necessarily need to be the top left and bottom right corners, the
|
2011-05-23 08:33:22 -04:00
|
|
|
* constructor figures out how to fit a rectangle between them.
|
2011-06-30 06:01:51 -04:00
|
|
|
*
|
2011-05-27 20:17:35 -04:00
|
|
|
* @name Path.Rectangle
|
2012-12-30 12:24:33 -05:00
|
|
|
* @param {Point} from The first point defining the rectangle
|
|
|
|
* @param {Point} to The second point defining the rectangle
|
2011-05-23 08:33:22 -04:00
|
|
|
* @return {Path} the newly created path
|
2011-06-30 06:01:51 -04:00
|
|
|
*
|
2013-03-03 12:34:39 -05:00
|
|
|
* @example {@paperscript}
|
|
|
|
* var from = new Point(20, 20);
|
|
|
|
* var to = new Point(80, 80);
|
|
|
|
* var path = new Path.Rectangle(from, to);
|
2011-05-30 11:13:19 -04:00
|
|
|
* path.strokeColor = 'black';
|
2013-03-10 14:09:09 -04:00
|
|
|
*
|
2013-04-21 07:58:22 -04:00
|
|
|
* @example {@paperscript} // Using object notation
|
2013-03-10 14:09:09 -04:00
|
|
|
* var path = new Path.Rectangle({
|
|
|
|
* from: [20, 20],
|
|
|
|
* to: [80, 80],
|
|
|
|
* strokeColor: 'black'
|
|
|
|
* });
|
2011-05-23 08:33:22 -04:00
|
|
|
*/
|
|
|
|
/**
|
2013-06-27 21:03:03 -04:00
|
|
|
* Creates a rectangle shaped Path item from the passed abstract
|
2011-05-23 08:33:22 -04:00
|
|
|
* {@link Rectangle}.
|
2011-06-30 06:01:51 -04:00
|
|
|
*
|
2013-04-19 15:36:49 -04:00
|
|
|
* @name Path.Rectangle
|
2012-12-30 12:24:33 -05:00
|
|
|
* @param {Rectangle} rectangle
|
2011-05-30 11:13:19 -04:00
|
|
|
* @return {Path} the newly created path
|
2011-06-30 06:01:51 -04:00
|
|
|
*
|
2013-03-03 12:34:39 -05:00
|
|
|
* @example {@paperscript}
|
|
|
|
* var rectangle = new Rectangle({
|
|
|
|
* point: new Point(20, 20),
|
|
|
|
* size: new Size(60, 60)
|
|
|
|
* });
|
2011-05-23 08:33:22 -04:00
|
|
|
* var path = new Path.Rectangle(rectangle);
|
|
|
|
* path.strokeColor = 'black';
|
2013-03-10 14:09:09 -04:00
|
|
|
*
|
|
|
|
* @example {@paperscript}
|
|
|
|
* var rectangle = new Rectangle({
|
|
|
|
* point: [20, 20],
|
|
|
|
* size: [60, 60]
|
|
|
|
* });
|
|
|
|
*
|
|
|
|
* var path = new Path.Rectangle({
|
|
|
|
* rectangle: rectangle,
|
|
|
|
* strokeColor: 'black'
|
|
|
|
* });
|
2011-05-23 08:33:22 -04:00
|
|
|
*/
|
|
|
|
/**
|
2013-06-27 21:03:03 -04:00
|
|
|
* Creates a rectangular Path item with rounded corners.
|
2011-06-30 06:01:51 -04:00
|
|
|
*
|
2013-04-19 15:36:49 -04:00
|
|
|
* @name Path.Rectangle
|
2012-12-30 12:24:33 -05:00
|
|
|
* @param {Rectangle} rectangle
|
|
|
|
* @param {Size} radius the size of the rounded corners
|
2011-05-23 08:33:22 -04:00
|
|
|
* @return {Path} the newly created path
|
2011-06-30 06:01:51 -04:00
|
|
|
*
|
2013-03-03 12:34:39 -05:00
|
|
|
* @example {@paperscript}
|
|
|
|
* var rectangle = new Rectangle({
|
|
|
|
* point: new Point(20, 20),
|
|
|
|
* size: new Size(60, 60)
|
|
|
|
* });
|
|
|
|
* var cornerSize = new Size(10, 10);
|
2013-04-19 15:36:49 -04:00
|
|
|
* var path = new Path.Rectangle(rectangle, cornerSize);
|
2013-03-03 12:34:39 -05:00
|
|
|
* path.strokeColor = 'black';
|
2013-03-10 14:09:09 -04:00
|
|
|
*
|
2013-04-21 07:58:22 -04:00
|
|
|
* @example {@paperscript} // Using object notation
|
2013-04-19 15:36:49 -04:00
|
|
|
* var path = new Path.Rectangle({
|
2013-03-10 14:09:09 -04:00
|
|
|
* rectangle: {
|
|
|
|
* point: [20, 20],
|
|
|
|
* size: [60, 60]
|
|
|
|
* },
|
|
|
|
* radius: 10,
|
|
|
|
* strokeColor: 'black'
|
|
|
|
* });
|
2011-05-23 08:33:22 -04:00
|
|
|
*/
|
2013-10-16 07:26:08 -04:00
|
|
|
Rectangle: function(/* rectangle */) {
|
|
|
|
var rect = Rectangle.readNamed(arguments, 'rectangle'),
|
|
|
|
radius = Size.readNamed(arguments, 'radius', 0, 0,
|
|
|
|
{ readNull: true }),
|
|
|
|
bl = rect.getBottomLeft(true),
|
|
|
|
tl = rect.getTopLeft(true),
|
|
|
|
tr = rect.getTopRight(true),
|
|
|
|
br = rect.getBottomRight(true),
|
|
|
|
path = createPath(arguments);
|
|
|
|
if (!radius || radius.isZero()) {
|
|
|
|
path._add([
|
|
|
|
new Segment(bl),
|
|
|
|
new Segment(tl),
|
|
|
|
new Segment(tr),
|
|
|
|
new Segment(br)
|
|
|
|
]);
|
|
|
|
} else {
|
|
|
|
radius = Size.min(radius, rect.getSize(true).divide(2));
|
|
|
|
var rx = radius.width,
|
|
|
|
ry = radius.height,
|
|
|
|
hx = rx * kappa,
|
|
|
|
hy = ry * kappa;
|
|
|
|
path._add([
|
|
|
|
new Segment(bl.add(rx, 0), null, [-hx, 0]),
|
|
|
|
new Segment(bl.subtract(0, ry), [0, hy]),
|
|
|
|
new Segment(tl.add(0, ry), null, [0, -hy]),
|
|
|
|
new Segment(tl.add(rx, 0), [-hx, 0], null),
|
|
|
|
new Segment(tr.subtract(rx, 0), null, [hx, 0]),
|
|
|
|
new Segment(tr.add(0, ry), [0, -hy], null),
|
|
|
|
new Segment(br.subtract(0, ry), null, [0, hy]),
|
|
|
|
new Segment(br.subtract(rx, 0), [hx, 0])
|
|
|
|
]);
|
|
|
|
}
|
|
|
|
// No need to use setter for _closed since _add() called _changed().
|
|
|
|
path._closed = true;
|
|
|
|
return path;
|
|
|
|
},
|
2011-02-17 09:55:26 -05:00
|
|
|
|
2013-04-19 15:36:49 -04:00
|
|
|
/**
|
|
|
|
* @deprecated use {@link #Path.Rectangle(rectangle, size)} instead.
|
|
|
|
*/
|
2013-10-16 07:26:08 -04:00
|
|
|
RoundRectangle: '#Rectangle',
|
2011-02-17 09:55:26 -05:00
|
|
|
|
2011-05-23 08:33:22 -04:00
|
|
|
/**
|
2013-06-27 21:03:03 -04:00
|
|
|
* Creates an ellipse shaped Path item.
|
2011-06-30 06:01:51 -04:00
|
|
|
*
|
2012-12-30 12:24:33 -05:00
|
|
|
* @param {Rectangle} rectangle
|
2011-05-31 08:28:42 -04:00
|
|
|
* @param {Boolean} [circumscribed=false] when set to {@code true} the
|
2012-11-06 14:37:00 -05:00
|
|
|
* ellipse shaped path will be created so the rectangle fits into
|
|
|
|
* it. When set to {@code false} the ellipse path will fit within
|
2011-05-31 08:28:42 -04:00
|
|
|
* the rectangle.
|
2011-05-23 08:33:22 -04:00
|
|
|
* @return {Path} the newly created path
|
2011-06-30 06:01:51 -04:00
|
|
|
*
|
2013-03-03 12:34:39 -05:00
|
|
|
* @example {@paperscript}
|
|
|
|
* var rectangle = new Rectangle({
|
2013-03-04 06:09:58 -05:00
|
|
|
* point: [20, 20],
|
|
|
|
* size: [180, 60]
|
2013-03-03 12:34:39 -05:00
|
|
|
* });
|
2012-11-06 14:37:00 -05:00
|
|
|
* var path = new Path.Ellipse(rectangle);
|
2011-05-30 11:13:19 -04:00
|
|
|
* path.fillColor = 'black';
|
2013-03-10 14:09:09 -04:00
|
|
|
*
|
2013-04-21 07:58:22 -04:00
|
|
|
* @example {@paperscript} // Using object notation
|
2013-03-10 14:09:09 -04:00
|
|
|
* var path = new Path.Ellipse({
|
|
|
|
* point: [20, 20],
|
|
|
|
* size: [180, 60],
|
|
|
|
* fillColor: 'black'
|
|
|
|
* });
|
2011-05-23 08:33:22 -04:00
|
|
|
*/
|
2013-10-16 07:26:08 -04:00
|
|
|
Ellipse: function(/* rectangle */) {
|
|
|
|
var rect = Rectangle.readNamed(arguments, 'rectangle'),
|
|
|
|
path = createPath(arguments),
|
|
|
|
point = rect.getPoint(true),
|
|
|
|
size = rect.getSize(true),
|
|
|
|
segments = new Array(4);
|
|
|
|
for (var i = 0; i < 4; i++) {
|
|
|
|
var segment = ellipseSegments[i];
|
|
|
|
segments[i] = new Segment(
|
|
|
|
segment._point.multiply(size).add(point),
|
|
|
|
segment._handleIn.multiply(size),
|
|
|
|
segment._handleOut.multiply(size)
|
|
|
|
);
|
|
|
|
}
|
|
|
|
path._add(segments);
|
|
|
|
path._closed = true;
|
|
|
|
return path;
|
|
|
|
},
|
2012-11-06 14:37:00 -05:00
|
|
|
|
|
|
|
/**
|
2013-04-19 15:36:49 -04:00
|
|
|
* @deprecated use {@link #Path.Ellipse(rectangle)} instead.
|
2012-11-06 14:37:00 -05:00
|
|
|
*/
|
2013-10-16 07:26:08 -04:00
|
|
|
Oval: '#Ellipse',
|
2011-02-17 09:55:26 -05:00
|
|
|
|
2011-05-23 08:33:22 -04:00
|
|
|
/**
|
2013-06-27 21:03:03 -04:00
|
|
|
* Creates a circular arc shaped Path item.
|
2011-06-30 06:01:51 -04:00
|
|
|
*
|
2011-05-23 08:33:22 -04:00
|
|
|
* @param {Point} from the starting point of the circular arc
|
|
|
|
* @param {Point} through the point the arc passes through
|
|
|
|
* @param {Point} to the end point of the arc
|
|
|
|
* @return {Path} the newly created path
|
2011-06-30 06:01:51 -04:00
|
|
|
*
|
2013-03-03 12:34:39 -05:00
|
|
|
* @example {@paperscript}
|
|
|
|
* var from = new Point(20, 20);
|
|
|
|
* var through = new Point(60, 20);
|
|
|
|
* var to = new Point(80, 80);
|
|
|
|
* var path = new Path.Arc(from, through, to);
|
2011-05-30 11:13:19 -04:00
|
|
|
* path.strokeColor = 'black';
|
2013-03-10 14:09:09 -04:00
|
|
|
*
|
2013-04-21 07:58:22 -04:00
|
|
|
* @example {@paperscript} // Using object notation
|
2013-03-10 14:09:09 -04:00
|
|
|
* var path = new Path.Arc({
|
|
|
|
* from: [20, 20],
|
|
|
|
* through: [60, 20],
|
|
|
|
* to: [80, 80],
|
|
|
|
* strokeColor: 'black'
|
|
|
|
* });
|
2011-05-23 08:33:22 -04:00
|
|
|
*/
|
2012-12-30 12:33:46 -05:00
|
|
|
Arc: function(/* from, through, to */) {
|
|
|
|
var from = Point.readNamed(arguments, 'from'),
|
|
|
|
through = Point.readNamed(arguments, 'through'),
|
|
|
|
to = Point.readNamed(arguments, 'to'),
|
2013-03-05 03:28:10 -05:00
|
|
|
path = createPath(arguments);
|
2012-12-30 12:33:46 -05:00
|
|
|
path.moveTo(from);
|
|
|
|
path.arcTo(through, to);
|
2011-02-17 09:55:26 -05:00
|
|
|
return path;
|
2011-02-26 13:19:02 -05:00
|
|
|
},
|
2011-03-03 17:45:17 -05:00
|
|
|
|
2011-05-23 08:33:22 -04:00
|
|
|
/**
|
2013-06-27 21:03:03 -04:00
|
|
|
* Creates a regular polygon shaped Path item.
|
2011-06-30 06:01:51 -04:00
|
|
|
*
|
2011-05-23 08:33:22 -04:00
|
|
|
* @param {Point} center the center point of the polygon
|
2013-03-10 13:02:16 -04:00
|
|
|
* @param {Number} sides the number of sides of the polygon
|
2011-05-27 15:21:49 -04:00
|
|
|
* @param {Number} radius the radius of the polygon
|
2011-05-23 08:33:22 -04:00
|
|
|
* @return {Path} the newly created path
|
2011-06-30 06:01:51 -04:00
|
|
|
*
|
2013-03-03 12:34:39 -05:00
|
|
|
* @example {@paperscript}
|
|
|
|
* var center = new Point(50, 50);
|
2011-05-30 11:13:19 -04:00
|
|
|
* var sides = 3;
|
2013-03-03 12:34:39 -05:00
|
|
|
* var radius = 40;
|
2011-05-30 11:13:19 -04:00
|
|
|
* var triangle = new Path.RegularPolygon(center, sides, radius);
|
|
|
|
* triangle.fillColor = 'black';
|
2011-06-30 06:01:51 -04:00
|
|
|
*
|
2013-04-21 07:58:22 -04:00
|
|
|
* @example {@paperscript} // Using object notation
|
2013-03-10 14:09:09 -04:00
|
|
|
* var triangle = new Path.RegularPolygon({
|
|
|
|
* center: [50, 50],
|
|
|
|
* sides: 10,
|
|
|
|
* radius: 40,
|
|
|
|
* fillColor: 'black'
|
|
|
|
* });
|
2011-05-23 08:33:22 -04:00
|
|
|
*/
|
2013-03-10 13:02:16 -04:00
|
|
|
RegularPolygon: function(/* center, sides, radius */) {
|
2012-12-30 12:33:46 -05:00
|
|
|
var center = Point.readNamed(arguments, 'center'),
|
2013-03-10 13:02:16 -04:00
|
|
|
sides = Base.readNamed(arguments, 'sides'),
|
2012-12-30 12:33:46 -05:00
|
|
|
radius = Base.readNamed(arguments, 'radius'),
|
2013-03-05 03:28:10 -05:00
|
|
|
path = createPath(arguments),
|
2013-03-10 13:02:16 -04:00
|
|
|
step = 360 / sides,
|
|
|
|
three = !(sides % 3),
|
2012-12-30 12:33:46 -05:00
|
|
|
vector = new Point(0, three ? -radius : radius),
|
2011-05-04 13:42:40 -04:00
|
|
|
offset = three ? -1 : 0.5,
|
2013-03-10 13:02:16 -04:00
|
|
|
segments = new Array(sides);
|
|
|
|
for (var i = 0; i < sides; i++) {
|
2012-12-30 12:33:46 -05:00
|
|
|
segments[i] = new Segment(center.add(
|
2011-05-04 13:42:40 -04:00
|
|
|
vector.rotate((i + offset) * step)));
|
2011-02-26 13:19:02 -05:00
|
|
|
}
|
2011-05-04 13:42:40 -04:00
|
|
|
path._add(segments);
|
|
|
|
path._closed = true;
|
2011-02-26 13:19:02 -05:00
|
|
|
return path;
|
2011-04-12 08:18:00 -04:00
|
|
|
},
|
2011-05-23 08:33:22 -04:00
|
|
|
|
|
|
|
/**
|
2013-06-27 21:03:03 -04:00
|
|
|
* Creates a star shaped Path item.
|
2011-06-30 06:01:51 -04:00
|
|
|
*
|
2011-05-23 08:33:22 -04:00
|
|
|
* The largest of {@code radius1} and {@code radius2} will be the outer
|
|
|
|
* radius of the star. The smallest of radius1 and radius2 will be the
|
|
|
|
* inner radius.
|
2011-06-30 06:01:51 -04:00
|
|
|
*
|
2011-05-23 08:33:22 -04:00
|
|
|
* @param {Point} center the center point of the star
|
2013-03-10 13:09:05 -04:00
|
|
|
* @param {Number} points the number of points of the star
|
2011-05-27 15:21:49 -04:00
|
|
|
* @param {Number} radius1
|
|
|
|
* @param {Number} radius2
|
2011-05-23 08:33:22 -04:00
|
|
|
* @return {Path} the newly created path
|
2011-06-30 06:01:51 -04:00
|
|
|
*
|
2013-03-03 12:34:39 -05:00
|
|
|
* @example {@paperscript}
|
|
|
|
* var center = new Point(50, 50);
|
|
|
|
* var points = 12;
|
|
|
|
* var radius1 = 25;
|
|
|
|
* var radius2 = 40;
|
2011-05-30 11:13:19 -04:00
|
|
|
* var path = new Path.Star(center, points, radius1, radius2);
|
|
|
|
* path.fillColor = 'black';
|
2013-03-10 14:09:09 -04:00
|
|
|
*
|
2013-04-21 07:58:22 -04:00
|
|
|
* @example {@paperscript} // Using object notation
|
2013-03-10 14:09:09 -04:00
|
|
|
* var path = new Path.Star({
|
|
|
|
* center: [50, 50],
|
|
|
|
* points: 12,
|
|
|
|
* radius1: 25,
|
|
|
|
* radius2: 40,
|
|
|
|
* fillColor: 'black'
|
|
|
|
* });
|
2011-06-30 06:01:51 -04:00
|
|
|
*/
|
2013-03-10 13:09:05 -04:00
|
|
|
Star: function(/* center, points, radius1, radius2 */) {
|
2012-12-30 12:33:46 -05:00
|
|
|
var center = Point.readNamed(arguments, 'center'),
|
2013-03-10 13:09:05 -04:00
|
|
|
points = Base.readNamed(arguments, 'points') * 2,
|
2012-12-30 12:33:46 -05:00
|
|
|
radius1 = Base.readNamed(arguments, 'radius1'),
|
|
|
|
radius2 = Base.readNamed(arguments, 'radius2'),
|
2013-03-05 03:28:10 -05:00
|
|
|
path = createPath(arguments),
|
2013-03-10 13:09:05 -04:00
|
|
|
step = 360 / points,
|
2011-05-04 13:42:40 -04:00
|
|
|
vector = new Point(0, -1),
|
2013-03-10 13:09:05 -04:00
|
|
|
segments = new Array(points);
|
|
|
|
for (var i = 0; i < points; i++) {
|
2012-12-30 12:33:46 -05:00
|
|
|
segments[i] = new Segment(center.add(
|
|
|
|
vector.rotate(step * i).multiply(i % 2 ? radius2 : radius1)));
|
2011-04-12 08:18:00 -04:00
|
|
|
}
|
2011-05-04 13:42:40 -04:00
|
|
|
path._add(segments);
|
|
|
|
path._closed = true;
|
2011-04-12 08:18:00 -04:00
|
|
|
return path;
|
2011-02-17 09:55:26 -05:00
|
|
|
}
|
|
|
|
};
|
2011-02-17 15:04:02 -05:00
|
|
|
}});
|