mirror of
https://github.com/scratchfoundation/paper.js.git
synced 2025-01-03 19:45:44 -05:00
Cleanup Path constructors by using simple constructor functions instead of Base.extend() classes, use Path.Oval for Path.Circle and optimise Path.Oval through ovalSegments array with real segments (no use to call Segment.read each time).
This commit is contained in:
parent
12d82ece56
commit
a6e9ee56d4
1 changed files with 79 additions and 97 deletions
|
@ -1,11 +1,20 @@
|
||||||
Path = PathItem.extend({
|
Path = PathItem.extend(new function() {
|
||||||
|
var kappa = 2 / 3 * (Math.sqrt(2) - 1);
|
||||||
|
|
||||||
|
var ovalSegments = [
|
||||||
|
new Segment([0, 0.5], [0, kappa ], [0, -kappa]),
|
||||||
|
new Segment([0.5, 0], [-kappa, 0], [kappa, 0 ]),
|
||||||
|
new Segment([1, 0.5], [0, -kappa], [0, kappa ]),
|
||||||
|
new Segment([0.5, 1], [kappa, 0 ], [-kappa, 0])
|
||||||
|
];
|
||||||
|
|
||||||
|
return {
|
||||||
initialize: function() {
|
initialize: function() {
|
||||||
this.base.apply(this, arguments);
|
this.base.apply(this, arguments);
|
||||||
},
|
},
|
||||||
|
|
||||||
statics: {
|
statics: {
|
||||||
Line: Base.extend({
|
Line: function() {
|
||||||
initialize: function() {
|
|
||||||
var path = new Path();
|
var path = new Path();
|
||||||
if (arguments.length == 2) {
|
if (arguments.length == 2) {
|
||||||
path.addSegment(new Segment(arguments[0]));
|
path.addSegment(new Segment(arguments[0]));
|
||||||
|
@ -15,11 +24,9 @@ Path = PathItem.extend({
|
||||||
path.addSegment(Segment.read(arguments[2], arguments[3]));
|
path.addSegment(Segment.read(arguments[2], arguments[3]));
|
||||||
}
|
}
|
||||||
return path;
|
return path;
|
||||||
}
|
},
|
||||||
}),
|
|
||||||
|
|
||||||
Rectangle: Base.extend({
|
Rectangle: function() {
|
||||||
initialize: function() {
|
|
||||||
var path = new Path();
|
var path = new Path();
|
||||||
path.closed = true;
|
path.closed = true;
|
||||||
var rectangle = Rectangle.read(arguments);
|
var rectangle = Rectangle.read(arguments);
|
||||||
|
@ -28,13 +35,9 @@ Path = PathItem.extend({
|
||||||
path.add(rectangle[corners[i]]);
|
path.add(rectangle[corners[i]]);
|
||||||
}
|
}
|
||||||
return path;
|
return path;
|
||||||
}
|
},
|
||||||
}),
|
|
||||||
|
|
||||||
RoundRectangle: Base.extend(new function() {
|
RoundRectangle: function() {
|
||||||
var u = 4 / 3 * (Math.sqrt(2) - 1);
|
|
||||||
return {
|
|
||||||
initialize: function() {
|
|
||||||
var path = new Path();
|
var path = new Path();
|
||||||
var rect, size;
|
var rect, size;
|
||||||
if (arguments.length == 2) {
|
if (arguments.length == 2) {
|
||||||
|
@ -46,7 +49,7 @@ Path = PathItem.extend({
|
||||||
size = new Size(arguments[4], arguments[5]);
|
size = new Size(arguments[4], arguments[5]);
|
||||||
}
|
}
|
||||||
size = Size.min(size, rect.size.divide(2));
|
size = Size.min(size, rect.size.divide(2));
|
||||||
uSize = size.multiply(u);
|
uSize = size.multiply(kappa * 2);
|
||||||
|
|
||||||
var bl = rect.bottomLeft;
|
var bl = rect.bottomLeft;
|
||||||
path.add(bl.add(size.width, 0), null, [-uSize.width, 0]);
|
path.add(bl.add(size.width, 0), null, [-uSize.width, 0]);
|
||||||
|
@ -66,41 +69,28 @@ Path = PathItem.extend({
|
||||||
|
|
||||||
path.closed = true;
|
path.closed = true;
|
||||||
return path;
|
return path;
|
||||||
}
|
},
|
||||||
}
|
|
||||||
}),
|
|
||||||
|
|
||||||
Oval: Base.extend(new function() {
|
Oval: function() {
|
||||||
var u = 2 / 3 * (Math.sqrt(2) - 1);
|
|
||||||
var segments = [
|
|
||||||
{ handleOut: [0, -u], handleIn: [0, u], point: [ 0, 0.5] },
|
|
||||||
{ handleOut: [u, 0], handleIn: [-u, 0], point: [ 0.5, 0] },
|
|
||||||
{ handleOut: [0, u], handleIn: [0, -u], point: [ 1, 0.5] },
|
|
||||||
{ handleOut: [-u, 0], handleIn: [u, 0], point: [0.5, 1] }
|
|
||||||
];
|
|
||||||
return {
|
|
||||||
initialize: function() {
|
|
||||||
var path = new Path();
|
var path = new Path();
|
||||||
var rect = Rectangle.read(arguments);
|
var rect = Rectangle.read(arguments);
|
||||||
var topLeft = rect.topLeft;
|
var topLeft = rect.topLeft;
|
||||||
var size = new Size(rect.width, rect.height);
|
var size = new Size(rect.width, rect.height);
|
||||||
for (var i = 0; i < 4; i++) {
|
for (var i = 0; i < 4; i++) {
|
||||||
var segment = Segment.read([segments[i]]);
|
var segment = ovalSegments[i];
|
||||||
segment.handleIn = segment.handleIn.multiply(size);
|
path.addSegment(new Segment(
|
||||||
segment.handleOut = segment.handleOut.multiply(size);
|
segment.point.multiply(size).add(topLeft),
|
||||||
segment.point = segment.point.multiply(size).add(topLeft);
|
segment.handleIn.multiply(size),
|
||||||
path._segments.push(segment);
|
segment.handleOut.multiply(size)
|
||||||
|
));
|
||||||
}
|
}
|
||||||
path.closed = true;
|
path.closed = true;
|
||||||
return path;
|
return path;
|
||||||
}
|
},
|
||||||
}
|
|
||||||
}),
|
|
||||||
|
|
||||||
Circle: Base.extend({
|
Circle: function() {
|
||||||
initialize: function() {
|
|
||||||
var path = new Path();
|
|
||||||
var center, radius;
|
var center, radius;
|
||||||
|
// TODO: Have Point.read() return consumed index somehow?
|
||||||
if (arguments.length == 3) {
|
if (arguments.length == 3) {
|
||||||
center = new Point(arguments[0], arguments[1]);
|
center = new Point(arguments[0], arguments[1]);
|
||||||
radius = arguments[2];
|
radius = arguments[2];
|
||||||
|
@ -108,24 +98,16 @@ Path = PathItem.extend({
|
||||||
center = new Point(arguments[0]);
|
center = new Point(arguments[0]);
|
||||||
radius = arguments[1];
|
radius = arguments[1];
|
||||||
}
|
}
|
||||||
var left = center.subtract(radius, 0);
|
return Path.Oval(new Rectangle(center.subtract(radius),
|
||||||
path.moveTo(left);
|
new Size(radius * 2, radius * 2)));
|
||||||
path.arcTo(center.add(radius, 0), true);
|
},
|
||||||
path.arcTo(left, true);
|
|
||||||
var last = path._segments.pop();
|
|
||||||
path._segments[0].handleIn = last.handleIn;
|
|
||||||
path.closed = true;
|
|
||||||
return path;
|
|
||||||
}
|
|
||||||
}),
|
|
||||||
|
|
||||||
Arc: PathItem.extend({
|
Arc: function(from, through, to) {
|
||||||
initialize: function(from, through, to) {
|
|
||||||
var path = new Path();
|
var path = new Path();
|
||||||
path.moveTo(from);
|
path.moveTo(from);
|
||||||
path.arcTo(through, to);
|
path.arcTo(through, to);
|
||||||
return path;
|
return path;
|
||||||
}
|
}
|
||||||
})
|
}
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
Loading…
Reference in a new issue