mirror of
https://github.com/scratchfoundation/paper.js.git
synced 2025-01-22 23:39:59 -05:00
Handle all the calls to Base.read() differently, by checking result for null and bailing out if it is.
This commit is contained in:
parent
261fa819d7
commit
dd9340d522
6 changed files with 126 additions and 105 deletions
|
@ -139,8 +139,7 @@ var Matrix = this.Matrix = Base.extend({
|
||||||
* @return {Matrix} This affine transform.
|
* @return {Matrix} This affine transform.
|
||||||
*/
|
*/
|
||||||
translate: function(point) {
|
translate: function(point) {
|
||||||
point = Point.read(arguments);
|
if (point = Point.read(arguments)) {
|
||||||
if (point) {
|
|
||||||
var x = point.x, y = point.y;
|
var x = point.x, y = point.y;
|
||||||
this._m02 += x * this._m00 + y * this._m01;
|
this._m02 += x * this._m00 + y * this._m01;
|
||||||
this._m12 += x * this._m10 + y * this._m11;
|
this._m12 += x * this._m10 + y * this._m11;
|
||||||
|
@ -418,8 +417,7 @@ var Matrix = this.Matrix = Base.extend({
|
||||||
* @return {Matrix} This affine transform.
|
* @return {Matrix} This affine transform.
|
||||||
*/
|
*/
|
||||||
setToTranslation: function(delta) {
|
setToTranslation: function(delta) {
|
||||||
delta = Point.read(arguments);
|
if (delta = Point.read(arguments)) {
|
||||||
if (delta) {
|
|
||||||
this.set(1, 0, 0, 1, delta.x, delta.y);
|
this.set(1, 0, 0, 1, delta.x, delta.y);
|
||||||
}
|
}
|
||||||
return this;
|
return this;
|
||||||
|
@ -445,8 +443,7 @@ var Matrix = this.Matrix = Base.extend({
|
||||||
* @return {Matrix} This affine transform.
|
* @return {Matrix} This affine transform.
|
||||||
*/
|
*/
|
||||||
setToRotation: function(angle, center) {
|
setToRotation: function(angle, center) {
|
||||||
center = Point.read(arguments, 1);
|
if (center = Point.read(arguments, 1)) {
|
||||||
if (center) {
|
|
||||||
angle = angle * Math.PI / 180.0;
|
angle = angle * Math.PI / 180.0;
|
||||||
var x = center.x,
|
var x = center.x,
|
||||||
y = center.y,
|
y = center.y,
|
||||||
|
|
|
@ -77,38 +77,43 @@ var Point = this.Point = Base.extend({
|
||||||
return Point.create(this.x, this.y);
|
return Point.create(this.x, this.y);
|
||||||
},
|
},
|
||||||
|
|
||||||
add: function() {
|
add: function(point) {
|
||||||
var point = Point.read(arguments);
|
return (point = Point.read(arguments))
|
||||||
return Point.create(this.x + point.x, this.y + point.y);
|
? Point.create(this.x + point.x, this.y + point.y)
|
||||||
|
: null;
|
||||||
},
|
},
|
||||||
|
|
||||||
subtract: function() {
|
subtract: function(point) {
|
||||||
var point = Point.read(arguments);
|
return (point = Point.read(arguments))
|
||||||
return Point.create(this.x - point.x, this.y - point.y);
|
? Point.create(this.x - point.x, this.y - point.y)
|
||||||
|
: null;
|
||||||
},
|
},
|
||||||
|
|
||||||
multiply: function() {
|
multiply: function(point) {
|
||||||
var point = Point.read(arguments);
|
return (point = Point.read(arguments))
|
||||||
return Point.create(this.x * point.x, this.y * point.y);
|
? Point.create(this.x * point.x, this.y * point.y)
|
||||||
|
: null;
|
||||||
},
|
},
|
||||||
|
|
||||||
divide: function() {
|
divide: function(point) {
|
||||||
var point = Point.read(arguments);
|
return (point = Point.read(arguments))
|
||||||
return Point.create(this.x / point.x, this.y / point.y);
|
? Point.create(this.x / point.x, this.y / point.y)
|
||||||
|
: null;
|
||||||
},
|
},
|
||||||
|
|
||||||
modulo: function() {
|
modulo: function(point) {
|
||||||
var point = Point.read(arguments);
|
return (point = Point.read(arguments))
|
||||||
return Point.create(this.x % point.x, this.y % point.y);
|
? Point.create(this.x % point.x, this.y % point.y)
|
||||||
|
: null;
|
||||||
},
|
},
|
||||||
|
|
||||||
negate: function() {
|
negate: function() {
|
||||||
return Point.create(-this.x, -this.y);
|
return Point.create(-this.x, -this.y);
|
||||||
},
|
},
|
||||||
|
|
||||||
equals: function() {
|
equals: function(point) {
|
||||||
var point = Point.read(arguments);
|
return (point = Point.read(arguments))
|
||||||
return this.x == point.x && this.y == point.y;
|
&& this.x == point.x && this.y == point.y;
|
||||||
},
|
},
|
||||||
|
|
||||||
transform: function(matrix) {
|
transform: function(matrix) {
|
||||||
|
@ -131,15 +136,17 @@ var Point = this.Point = Base.extend({
|
||||||
* @param px
|
* @param px
|
||||||
* @param py
|
* @param py
|
||||||
*/
|
*/
|
||||||
getDistance: function() {
|
getDistance: function(point) {
|
||||||
var point = Point.read(arguments);
|
if (!(point = Point.read(arguments)))
|
||||||
|
return null;
|
||||||
var px = point.x - this.x;
|
var px = point.x - this.x;
|
||||||
var py = point.y - this.y;
|
var py = point.y - this.y;
|
||||||
return Math.sqrt(px * px + py * py);
|
return Math.sqrt(px * px + py * py);
|
||||||
},
|
},
|
||||||
|
|
||||||
getDistanceSquared: function() {
|
getDistanceSquared: function(point) {
|
||||||
var point = Point.read(arguments);
|
if (!(point = Point.read(arguments)))
|
||||||
|
return null;
|
||||||
var px = point.x - this.x;
|
var px = point.x - this.x;
|
||||||
var py = point.y - this.y;
|
var py = point.y - this.y;
|
||||||
return px * px + py * py;
|
return px * px + py * py;
|
||||||
|
@ -152,7 +159,6 @@ var Point = this.Point = Base.extend({
|
||||||
* Setting the length changes the location but keeps the vector's angle.
|
* Setting the length changes the location but keeps the vector's angle.
|
||||||
*/
|
*/
|
||||||
getLength: function() {
|
getLength: function() {
|
||||||
var point = Point.read(arguments);
|
|
||||||
return Math.sqrt(this.x * this.x + this.y * this.y);
|
return Math.sqrt(this.x * this.x + this.y * this.y);
|
||||||
},
|
},
|
||||||
|
|
||||||
|
@ -264,8 +270,9 @@ var Point = this.Point = Base.extend({
|
||||||
*
|
*
|
||||||
* @param point
|
* @param point
|
||||||
*/
|
*/
|
||||||
getDirectedAngle: function() {
|
getDirectedAngle: function(point) {
|
||||||
var point = Point.read(arguments);
|
if (!(point = Point.read(arguments)))
|
||||||
|
return null;
|
||||||
var angle = this.getAngle() - point.getAngle();
|
var angle = this.getAngle() - point.getAngle();
|
||||||
var bounds = 180;
|
var bounds = 180;
|
||||||
if (angle < - bounds) {
|
if (angle < - bounds) {
|
||||||
|
@ -442,9 +449,10 @@ var Point = this.Point = Base.extend({
|
||||||
* @param point
|
* @param point
|
||||||
* @return the dot product of the two points
|
* @return the dot product of the two points
|
||||||
*/
|
*/
|
||||||
dot: function() {
|
dot: function(point) {
|
||||||
var point = Point.read(arguments);
|
return (point = Point.read(arguments))
|
||||||
return this.x * point.x + this.y * point.y;
|
? this.x * point.x + this.y * point.y
|
||||||
|
: null;
|
||||||
},
|
},
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -452,9 +460,10 @@ var Point = this.Point = Base.extend({
|
||||||
* @param point
|
* @param point
|
||||||
* @return the cross product of the two points
|
* @return the cross product of the two points
|
||||||
*/
|
*/
|
||||||
cross: function() {
|
cross: function(point) {
|
||||||
var point = Point.read(arguments);
|
return (point = Point.read(arguments))
|
||||||
return this.x * point.y - this.y * point.x;
|
? this.x * point.y - this.y * point.x
|
||||||
|
: null;
|
||||||
},
|
},
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -464,8 +473,9 @@ var Point = this.Point = Base.extend({
|
||||||
* @param point
|
* @param point
|
||||||
* @return the project of the point on another point
|
* @return the project of the point on another point
|
||||||
*/
|
*/
|
||||||
project: function() {
|
project: function(point) {
|
||||||
var point = Point.read(arguments);
|
if (!(point = Point.read(arguments)))
|
||||||
|
return null;
|
||||||
if (point.isZero()) {
|
if (point.isZero()) {
|
||||||
return Point.create(0, 0);
|
return Point.create(0, 0);
|
||||||
} else {
|
} else {
|
||||||
|
|
|
@ -74,8 +74,9 @@ var Rectangle = this.Rectangle = Base.extend({
|
||||||
return Point.create(this.x, this.y);
|
return Point.create(this.x, this.y);
|
||||||
},
|
},
|
||||||
|
|
||||||
setPoint: function() {
|
setPoint: function(point) {
|
||||||
var point = Point.read(arguments);
|
if (!(point = Point.read(arguments)))
|
||||||
|
return this;
|
||||||
this.x = point.x;
|
this.x = point.x;
|
||||||
this.y = point.y;
|
this.y = point.y;
|
||||||
return this;
|
return this;
|
||||||
|
@ -85,8 +86,9 @@ var Rectangle = this.Rectangle = Base.extend({
|
||||||
return Size.create(this.width, this.height);
|
return Size.create(this.width, this.height);
|
||||||
},
|
},
|
||||||
|
|
||||||
setSize: function() {
|
setSize: function(size) {
|
||||||
var size = Size.read(arguments);
|
if (!(size = Size.read(arguments)))
|
||||||
|
return this;
|
||||||
this.width = size.width;
|
this.width = size.width;
|
||||||
this.height = size.height;
|
this.height = size.height;
|
||||||
return this;
|
return this;
|
||||||
|
@ -153,18 +155,19 @@ var Rectangle = this.Rectangle = Base.extend({
|
||||||
return Point.create(this.getCenterX(), this.getCenterY());
|
return Point.create(this.getCenterX(), this.getCenterY());
|
||||||
},
|
},
|
||||||
|
|
||||||
setCenter: function() {
|
setCenter: function(point) {
|
||||||
var pt = Point.read(arguments);
|
if (!(point = Point.read(arguments)))
|
||||||
return this.setCenterX(pt.x).setCenterY(pt.y);
|
return this;
|
||||||
|
return this.setCenterX(point.x).setCenterY(point.y);
|
||||||
},
|
},
|
||||||
|
|
||||||
clone: function() {
|
clone: function() {
|
||||||
return new Rectangle(this);
|
return new Rectangle(this);
|
||||||
},
|
},
|
||||||
|
|
||||||
equals: function() {
|
equals: function(rect) {
|
||||||
var rect = Rectangle.read(arguments);
|
rect = Rectangle.read(arguments);
|
||||||
return this.x == rect.x && this.y == rect.y
|
return rect && this.x == rect.x && this.y == rect.y
|
||||||
&& this.width == rect.width && this.height == rect.height;
|
&& this.width == rect.width && this.height == rect.height;
|
||||||
},
|
},
|
||||||
|
|
||||||
|
@ -185,35 +188,38 @@ var Rectangle = this.Rectangle = Base.extend({
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
intersects: function() {
|
intersects: function(rect) {
|
||||||
var rect = Rectangle.read(arguments);
|
rect = Rectangle.read(arguments);
|
||||||
return rect.x + rect.width > this.x
|
return rect && rect.x + rect.width > this.x
|
||||||
&& rect.y + rect.height > this.y
|
&& rect.y + rect.height > this.y
|
||||||
&& rect.x < this.x + this.width
|
&& rect.x < this.x + this.width
|
||||||
&& rect.y < this.y + this.height;
|
&& rect.y < this.y + this.height;
|
||||||
},
|
},
|
||||||
|
|
||||||
intersect: function() {
|
intersect: function(rect) {
|
||||||
var rect = Rectangle.read(arguments);
|
if (!(rect = Rectangle.read(arguments)))
|
||||||
x1 = Math.max(this.x, rect.x),
|
return null;
|
||||||
|
var x1 = Math.max(this.x, rect.x),
|
||||||
y1 = Math.max(this.y, rect.y),
|
y1 = Math.max(this.y, rect.y),
|
||||||
x2 = Math.min(this.x + this.width, rect.x + rect.width),
|
x2 = Math.min(this.x + this.width, rect.x + rect.width),
|
||||||
y2 = Math.min(this.y + this.height, rect.y + rect.height);
|
y2 = Math.min(this.y + this.height, rect.y + rect.height);
|
||||||
return Rectangle.create(x1, y1, x2 - x1, y2 - y1);
|
return Rectangle.create(x1, y1, x2 - x1, y2 - y1);
|
||||||
},
|
},
|
||||||
|
|
||||||
unite: function() {
|
unite: function(rect) {
|
||||||
var rect = Rectangle.read(arguments),
|
if (!(rect = Rectangle.read(arguments)))
|
||||||
x1 = Math.min(this.x, rect.x),
|
return null;
|
||||||
|
var x1 = Math.min(this.x, rect.x),
|
||||||
y1 = Math.min(this.y, rect.y),
|
y1 = Math.min(this.y, rect.y),
|
||||||
x2 = Math.max(this.x + this.width, rect.x + rect.width),
|
x2 = Math.max(this.x + this.width, rect.x + rect.width),
|
||||||
y2 = Math.max(this.y + this.height, rect.y + rect.height);
|
y2 = Math.max(this.y + this.height, rect.y + rect.height);
|
||||||
return Rectangle.create(x1, y1, x2 - x1, y2 - y1);
|
return Rectangle.create(x1, y1, x2 - x1, y2 - y1);
|
||||||
},
|
},
|
||||||
|
|
||||||
include: function() {
|
include: function(point) {
|
||||||
var point = Point.read(arguments),
|
if (!(point = Point.read(arguments)))
|
||||||
x1 = Math.min(this.x, point.x),
|
return null;
|
||||||
|
var x1 = Math.min(this.x, point.x),
|
||||||
y1 = Math.min(this.y, point.y),
|
y1 = Math.min(this.y, point.y),
|
||||||
x2 = Math.max(this.x + this.width, point.x),
|
x2 = Math.max(this.x + this.width, point.x),
|
||||||
y2 = Math.max(this.y + this.height, point.y);
|
y2 = Math.max(this.y + this.height, point.y);
|
||||||
|
@ -235,14 +241,12 @@ var Rectangle = this.Rectangle = Base.extend({
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}, new function() {
|
}, new function() {
|
||||||
var keys = [
|
return Base.each([
|
||||||
['Top', 'Left'], ['Top', 'Right'],
|
['Top', 'Left'], ['Top', 'Right'],
|
||||||
['Bottom', 'Left'], ['Bottom', 'Right'],
|
['Bottom', 'Left'], ['Bottom', 'Right'],
|
||||||
['Left', 'Center'], ['Top', 'Center'],
|
['Left', 'Center'], ['Top', 'Center'],
|
||||||
['Right', 'Center'], ['Bottom', 'Center']
|
['Right', 'Center'], ['Bottom', 'Center']
|
||||||
];
|
],
|
||||||
|
|
||||||
return Base.each(keys,
|
|
||||||
function(parts, index) {
|
function(parts, index) {
|
||||||
var key = parts.join('');
|
var key = parts.join('');
|
||||||
// find out if the first of the pair is an x or y property,
|
// find out if the first of the pair is an x or y property,
|
||||||
|
@ -260,9 +264,10 @@ var Rectangle = this.Rectangle = Base.extend({
|
||||||
this['get' + key] = function() {
|
this['get' + key] = function() {
|
||||||
return Point.create(this[getX](), this[getY]());
|
return Point.create(this[getX](), this[getY]());
|
||||||
};
|
};
|
||||||
this['set' + key] = function(value) {
|
this['set' + key] = function(point) {
|
||||||
var pt = Point.read(arguments);
|
if (!(point = Point.read(arguments)))
|
||||||
return this[setX](pt.x)[setY](pt.y); // Note: chaining here!
|
return this;
|
||||||
|
return this[setX](point.x)[setY](point.y); // Note: call chaining!
|
||||||
};
|
};
|
||||||
}, { beans: true });
|
}, { beans: true });
|
||||||
});
|
});
|
||||||
|
|
|
@ -48,28 +48,34 @@ var Size = this.Size = Base.extend({
|
||||||
},
|
},
|
||||||
|
|
||||||
add: function() {
|
add: function() {
|
||||||
var size = Size.read(arguments);
|
return (size = Size.read(arguments))
|
||||||
return Size.create(this.width + size.width, this.height + size.height);
|
? Size.create(this.width + size.width, this.height + size.height)
|
||||||
|
: null;
|
||||||
},
|
},
|
||||||
|
|
||||||
subtract: function() {
|
subtract: function() {
|
||||||
var size = Size.read(arguments);
|
return (size = Size.read(arguments))
|
||||||
return Size.create(this.width - size.width, this.height - size.height);
|
? Size.create(this.width - size.width, this.height - size.height)
|
||||||
|
: null;
|
||||||
|
;
|
||||||
},
|
},
|
||||||
|
|
||||||
multiply: function() {
|
multiply: function() {
|
||||||
var size = Size.read(arguments);
|
return (size = Size.read(arguments))
|
||||||
return Size.create(this.width * size.width, this.height * size.height);
|
? Size.create(this.width * size.width, this.height * size.height)
|
||||||
|
: null;
|
||||||
},
|
},
|
||||||
|
|
||||||
divide: function() {
|
divide: function() {
|
||||||
var size = Size.read(arguments);
|
return (size = Size.read(arguments))
|
||||||
return Size.create(this.width / size.width, this.height / size.height);
|
? Size.create(this.width / size.width, this.height / size.height)
|
||||||
|
: null;
|
||||||
},
|
},
|
||||||
|
|
||||||
modulo: function() {
|
modulo: function() {
|
||||||
var size = Size.read(arguments);
|
return (size = Size.read(arguments))
|
||||||
return Size.create(this.width % size.width, this.height % size.height);
|
? Size.create(this.width % size.width, this.height % size.height)
|
||||||
|
: null;
|
||||||
},
|
},
|
||||||
|
|
||||||
negate: function() {
|
negate: function() {
|
||||||
|
@ -77,8 +83,8 @@ var Size = this.Size = Base.extend({
|
||||||
},
|
},
|
||||||
|
|
||||||
equals: function() {
|
equals: function() {
|
||||||
var size = Size.read(arguments);
|
return (size = Size.read(arguments))
|
||||||
return this.width == size.width && this.height == size.height;
|
&& this.width == size.width && this.height == size.height;
|
||||||
},
|
},
|
||||||
|
|
||||||
isNaN: function() {
|
isNaN: function() {
|
||||||
|
@ -101,11 +107,6 @@ var Size = this.Size = Base.extend({
|
||||||
return Size.create(Math.abs(this.width), Math.abs(this.height));
|
return Size.create(Math.abs(this.width), Math.abs(this.height));
|
||||||
},
|
},
|
||||||
|
|
||||||
dot: function() {
|
|
||||||
var size = Size.read(arguments);
|
|
||||||
return this.width * size.width + this.height * size.height;
|
|
||||||
},
|
|
||||||
|
|
||||||
toString: function() {
|
toString: function() {
|
||||||
return '{ x: ' + this.width + ', y: ' + this.height + ' }';
|
return '{ x: ' + this.width + ', y: ' + this.height + ' }';
|
||||||
},
|
},
|
||||||
|
|
|
@ -29,34 +29,42 @@ var GradientColor = this.GradientColor = Color.extend({
|
||||||
return this._origin;
|
return this._origin;
|
||||||
},
|
},
|
||||||
|
|
||||||
setOrigin: function() {
|
setOrigin: function(origin) {
|
||||||
this._origin = Point.read(arguments);
|
if (origin = Point.read(arguments)) {
|
||||||
if (this._destination)
|
this._origin = origin;
|
||||||
this._radius = this._destination.getDistance(this._origin);
|
if (this._destination)
|
||||||
|
this._radius = this._destination.getDistance(this._origin);
|
||||||
|
}
|
||||||
|
return this;
|
||||||
},
|
},
|
||||||
|
|
||||||
getDestination: function() {
|
getDestination: function() {
|
||||||
return this._destination;
|
return this._destination;
|
||||||
},
|
},
|
||||||
|
|
||||||
setDestination: function() {
|
setDestination: function(destination) {
|
||||||
this._destination = Point.read(arguments);
|
if (destination = Point.read(arguments)) {
|
||||||
this._radius = this._destination.getDistance(this._origin);
|
this._destination = destination;
|
||||||
|
this._radius = this._destination.getDistance(this._origin);
|
||||||
|
}
|
||||||
|
return this;
|
||||||
},
|
},
|
||||||
|
|
||||||
getHilite: function() {
|
getHilite: function() {
|
||||||
return this._hilite;
|
return this._hilite;
|
||||||
},
|
},
|
||||||
|
|
||||||
setHilite: function() {
|
setHilite: function(hilite) {
|
||||||
var hilite = Point.read(arguments);
|
if (hilite = Point.read(arguments)) {
|
||||||
var vector = hilite.subtract(this._origin);
|
var vector = hilite.subtract(this._origin);
|
||||||
if (vector.getLength() > this._radius) {
|
if (vector.getLength() > this._radius) {
|
||||||
this._hilite = this._origin.add(vector.normalize(
|
this._hilite = this._origin.add(vector.normalize(
|
||||||
this._radius - 0.1));
|
this._radius - 0.1));
|
||||||
} else {
|
} else {
|
||||||
this._hilite = hilite;
|
this._hilite = hilite;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
return this;
|
||||||
},
|
},
|
||||||
|
|
||||||
getCanvasStyle: function(ctx) {
|
getCanvasStyle: function(ctx) {
|
||||||
|
|
|
@ -35,7 +35,7 @@ var GradientStop = this.GradientStop = Base.extend({
|
||||||
return this._color;
|
return this._color;
|
||||||
},
|
},
|
||||||
|
|
||||||
setColor: function() {
|
setColor: function(color) {
|
||||||
this._color = Color.read(arguments);
|
this._color = Color.read(arguments);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
Loading…
Reference in a new issue