Rectangle = Base.extend({ initialize: function() { if(arguments.length == 1) { var rect = arguments[0]; this.x = rect.x; this.y = rect.y; this.width = rect.width; this.height = rect.height; } else if(arguments.length == 2) { if(arguments[1].x !== undefined) { // new Rectangle(point1, point2) var point1 = new Point(arguments[0]); var point2 = new Point(arguments[1]); this.x = point1.x; this.y = point1.y; this.width = point2.x - point1.x; this.height = point2.y - point1.y; if(this.width < 0) { this.x = point2.x; this.width = -this.width; } if(this.height < 0) { this.y = point2.y; this.height = -this.height; } } else { // new Rectangle(point, size) var point = new Point(arguments[0]); var size = new Size(arguments[1]); this.x = point.x; this.y = point.y; this.width = size.width; this.height = size.height; } } else if(arguments.length == 4) { // new Rectangle(x, y, width, height) this.x = arguments[0]; this.y = arguments[1]; this.width = arguments[2]; this.height = arguments[3]; } else { // new Rectangle() this.x = this.y = this.width = this.height = 0; } }, getPoint: function() { return new Point(this.x, this.y); }, setPoint: function() { var point = Point.read(arguments); this.x = point.x; this.y = point.y; }, getSize: function() { return new Size(this.width, this.height); }, setSize: function() { var size = Size.read(arguments); this.width = size.width; this.height = size.height; }, getLeft: function() { return this.x; }, setLeft: function(left) { // right should not move this.width -= left - this.x; this.x = left; }, getTop: function() { return this.y; }, setTop: function(top) { this.height -= top - this.y; this.y = top; }, getRight: function() { return this.x + this.width; }, setRight: function(right) { this.width = right - this.x; }, getBottom: function() { return this.y + this.height; }, setBottom: function(bottom) { this.height = bottom - this.y; }, getCenterX: function() { return this.x + this.width * 0.5; }, setCenterX: function(x) { this.x = x - this.width * 0.5; }, getCenterY: function() { return this.y + this.height * 0.5; }, setCenterY: function(y) { this.y = y - this.height * 0.5; }, getCenter: function() { return new Point(this.x - this.width / 2, this.y - this.height / 2); }, setCenter: function() { var center = Point.read(arguments); this.x = center.x - this.width / 2; this.y = center.y - this.height / 2; }, getTopLeft: function() { return new Point(this.getLeft(), this.getTop()); }, setTopLeft: function() { var topLeft = Point.read(arguments); this.setLeft(topLeft.x); this.setTop(topLeft.y); }, getTopRight: function() { return new Point(this.getRight(), this.getTop()); }, setTopRight: function() { var topRight = Point.read(arguments); this.setRight(topRight.x); this.setTop(topRight.y); }, getBottomLeft: function() { return new Point(this.getLeft(), this.getBottom()); }, setBottomLeft: function() { var bottomLeft = Point.read(arguments); this.setLeft(bottomLeft.x); this.setBottom(bottomLeft.y); }, getBottomRight: function() { return new Point(this.getRight(), this.getBottom()); }, setBottomRight: function() { var bottomRight = Point.read(arguments); this.setBottom(bottomRight.y); this.setRight(bottomRight.x); }, getLeftCenter: function() { return new Point(this.getLeft(), this.getCenterY()); }, setLeftCenter: function() { var leftCenter = Point.read(arguments); this.setLeft(leftCenter.x); this.setCenterY(leftCenter.y); }, getTopCenter: function() { return new Point(this.getCenterX(), this.getTop()); }, setTopCenter: function() { var topCenter = Point.read(arguments); this.setCenterX(topCenter.x); this.setTop(topCenter.y); }, getRightCenter: function() { return new Point(this.getRight(), this.getCenterY()); }, setRightCenter: function() { var rightCenter = Point.read(arguments); this.setRight(rightCenter.x); this.setCenterY(rightCenter.y); }, getBottomCenter: function() { return new Point(this.getCenterX(), this.getBottom()); }, setBottomCenter: function() { var bottomCenter = Point.read(arguments); this.setBottom(bottomCenter.y); this.setCenterX(bottomCenter.x); }, clone: function() { return new Rectangle(this); }, equals: function() { var rect = Rectangle.read(arguments); return this.x == rect.x && this.y == rect.y && this.width == rect.width && this.height == rect.height; }, isEmpty: function() { return this.width == 0 || this.height == 0; }, contains: function(rect) { if(rect.width !== undefined) { return rect.x >= this.x && rect.y >= this.y && rect.x + rect.width <= this.x + this.width && rect.y + rect.height <= this.y + this.height; } else { var point = Point.read(arguments); return point.x >= this.x && point.y >= this.y && point.x <= this.x + this.width && point.y <= this.y + this.height; } }, intersects: function() { var rect = Rectangle.read(arguments); return rect.x + rect.width > this.x && rect.y + rect.height > this.y && rect.x < this.x + this.width && rect.y < this.y + this.height; }, intersect: function() { var rect = Rectangle.read(arguments); var x1 = Math.max(this.x, rect.x); var y1 = Math.max(this.y, rect.y); var x2 = Math.min(this.x + this.width, rect.x + rect.width); var y2 = Math.min(this.y + this.height, rect.y + rect.height); return new Rectangle(x1, y1, x2 - x1, y2 - y1); }, unite: function() { var rect = Rectangle.read(arguments); var x1 = Math.min(this.x, rect.x); var y1 = Math.min(this.y, rect.y); var x2 = Math.max(this.x + this.width, rect.x + rect.width); var y2 = Math.max(this.y + this.height, rect.y + rect.height); return new Rectangle(x1, y1, x2 - x1, y2 - y1); }, include: function() { var point = Point.read(arguments); var x1 = Math.min(this.x, point.x); var y1 = Math.min(this.y, point.y); var x2 = Math.max(this.x + this.width, point.x); var y2 = Math.max(this.y + this.height, point.y); return new Rectangle(x1, y1, x2 - x1, y2 - y1); }, toString: function() { return '{ x: ' + this.x + ', y: ' + this.y + ', width: ' + this.width + ', height: ' + this.height + ' }'; }, statics: { read: function(args) { if(args.length) { var rect = new Rectangle(); rect.initialize.apply(rect, args); return rect; } } } });