mirror of
https://github.com/photonstorm/phaser
synced 2024-11-23 21:24:09 +00:00
170 lines
No EOL
4.5 KiB
TypeScript
170 lines
No EOL
4.5 KiB
TypeScript
/// <reference path="../Game.ts" />
|
|
|
|
/**
|
|
* Phaser - MicroPoint
|
|
*
|
|
* The MicroPoint object represents a location in a two-dimensional coordinate system,
|
|
* where x represents the horizontal axis and y represents the vertical axis.
|
|
* It is different to the Point class in that it doesn't contain any of the help methods like add/substract/distanceTo, etc.
|
|
* Use a MicroPoint when all you literally need is a solid container for x and y (such as in the Rectangle class).
|
|
*/
|
|
|
|
module Phaser {
|
|
|
|
export class MicroPoint {
|
|
|
|
/**
|
|
* Creates a new point. If you pass no parameters to this method, a point is created at (0,0).
|
|
* @class MicroPoint
|
|
* @constructor
|
|
* @param {Number} x The horizontal position of this point (default 0)
|
|
* @param {Number} y The vertical position of this point (default 0)
|
|
**/
|
|
constructor(x: number = 0, y: number = 0, parent?:any = null) {
|
|
|
|
this._x = x;
|
|
this._y = y;
|
|
this.parent = parent;
|
|
|
|
}
|
|
|
|
private _x: number;
|
|
private _y: number;
|
|
|
|
public parent: any;
|
|
|
|
/**
|
|
* The x coordinate of the top-left corner of the rectangle
|
|
* @property x
|
|
* @type Number
|
|
**/
|
|
public get x(): number {
|
|
|
|
return this._x;
|
|
|
|
}
|
|
|
|
/**
|
|
* The y coordinate of the top-left corner of the rectangle
|
|
* @property y
|
|
* @type Number
|
|
**/
|
|
public get y(): number {
|
|
|
|
return this._y;
|
|
|
|
}
|
|
|
|
/**
|
|
* The x coordinate of the top-left corner of the rectangle
|
|
* @property x
|
|
* @type Number
|
|
**/
|
|
public set x(value: number) {
|
|
|
|
this._x = value;
|
|
|
|
if (this.parent)
|
|
{
|
|
this.parent.updateBounds();
|
|
}
|
|
|
|
}
|
|
|
|
/**
|
|
* The y coordinate of the top-left corner of the rectangle
|
|
* @property y
|
|
* @type Number
|
|
**/
|
|
public set y(value:number) {
|
|
|
|
this._y = value;
|
|
|
|
if (this.parent)
|
|
{
|
|
this.parent.updateBounds();
|
|
}
|
|
|
|
}
|
|
|
|
/**
|
|
* Copies the x and y values from any given object to this MicroPoint.
|
|
* @method copyFrom
|
|
* @param {any} source - The object to copy from.
|
|
* @return {MicroPoint} This MicroPoint object. Useful for chaining method calls.
|
|
**/
|
|
public copyFrom(source: any): MicroPoint {
|
|
|
|
return this.setTo(source.x, source.y);
|
|
|
|
}
|
|
|
|
/**
|
|
* Copies the x and y values from this MicroPoint to any given object.
|
|
* @method copyTo
|
|
* @param {any} target - The object to copy to.
|
|
* @return {any} The target object.
|
|
**/
|
|
public copyTo(target: any): MicroPoint {
|
|
|
|
target.x = this._x;
|
|
target.y = this._y;
|
|
|
|
return target;
|
|
|
|
}
|
|
|
|
/**
|
|
* Sets the x and y values of this MicroPoint object to the given coordinates.
|
|
* @method setTo
|
|
* @param {Number} x - The horizontal position of this point.
|
|
* @param {Number} y - The vertical position of this point.
|
|
* @return {MicroPoint} This MicroPoint object. Useful for chaining method calls.
|
|
**/
|
|
public setTo(x: number, y: number, callParent?:bool = true): MicroPoint {
|
|
|
|
this._x = x;
|
|
this._y = y;
|
|
|
|
if (this.parent != null && callParent == true)
|
|
{
|
|
this.parent.updateBounds();
|
|
}
|
|
|
|
return this;
|
|
|
|
}
|
|
|
|
/**
|
|
* Determines whether this MicroPoint object and the given object are equal. They are equal if they have the same x and y values.
|
|
* @method equals
|
|
* @param {any} point - The object to compare against. Must have x and y properties.
|
|
* @return {Boolean} A value of true if the object is equal to this MicroPoin object; false if it is not equal.
|
|
**/
|
|
public equals(toCompare): bool {
|
|
|
|
if (this._x === toCompare.x && this._y === toCompare.y)
|
|
{
|
|
return true;
|
|
}
|
|
else
|
|
{
|
|
return false;
|
|
}
|
|
|
|
}
|
|
|
|
/**
|
|
* Returns a string representation of this object.
|
|
* @method toString
|
|
* @return {string} a string representation of the instance.
|
|
**/
|
|
public toString(): string {
|
|
|
|
return '[{MicroPoint (x=' + this._x + ' y=' + this._y + ')}]';
|
|
|
|
}
|
|
|
|
}
|
|
|
|
} |