2013-04-18 13:16:18 +00:00
|
|
|
/// <reference path="../Game.ts" />
|
2013-04-12 16:19:56 +00:00
|
|
|
|
|
|
|
/**
|
2013-04-18 15:49:08 +00:00
|
|
|
* Phaser - Tile
|
|
|
|
*
|
2013-04-25 00:55:56 +00:00
|
|
|
* A Tile is a single representation of a tile within a Tilemap
|
2013-04-18 13:16:18 +00:00
|
|
|
*/
|
|
|
|
|
|
|
|
module Phaser {
|
|
|
|
|
2013-04-25 00:55:56 +00:00
|
|
|
export class Tile {
|
2013-04-18 13:16:18 +00:00
|
|
|
|
2013-05-03 11:32:39 +00:00
|
|
|
/**
|
|
|
|
* Tile constructor
|
|
|
|
* Create a new <code>Tile</code>.
|
|
|
|
*
|
2013-05-04 11:53:11 +00:00
|
|
|
* @param tilemap {Tilemap} the tilemap this tile belongs to.
|
|
|
|
* @param index {number} The index of this tile type in the core map data.
|
|
|
|
* @param width {number} Width of the tile.
|
|
|
|
* @param height number} Height of the tile.
|
2013-05-03 11:32:39 +00:00
|
|
|
*/
|
2013-04-25 00:55:56 +00:00
|
|
|
constructor(game: Game, tilemap: Tilemap, index: number, width: number, height: number) {
|
2013-04-18 13:16:18 +00:00
|
|
|
|
2013-08-08 03:35:13 +00:00
|
|
|
this.game = game;
|
2013-04-25 00:55:56 +00:00
|
|
|
this.tilemap = tilemap;
|
|
|
|
this.index = index;
|
2013-04-18 13:16:18 +00:00
|
|
|
|
2013-04-25 00:55:56 +00:00
|
|
|
this.width = width;
|
|
|
|
this.height = height;
|
2013-05-31 17:21:32 +00:00
|
|
|
this.allowCollisions = Types.NONE;
|
2013-04-18 13:16:18 +00:00
|
|
|
|
2013-04-25 00:55:56 +00:00
|
|
|
}
|
2013-04-18 13:16:18 +00:00
|
|
|
|
2013-05-03 11:32:39 +00:00
|
|
|
/**
|
2013-08-08 03:35:13 +00:00
|
|
|
* Local reference to Game.
|
2013-05-03 11:32:39 +00:00
|
|
|
*/
|
2013-08-08 03:35:13 +00:00
|
|
|
public game: Game;
|
2013-04-18 13:16:18 +00:00
|
|
|
|
2013-05-03 11:32:39 +00:00
|
|
|
/**
|
|
|
|
* You can give this Tile a friendly name to help with debugging. Never used internally.
|
|
|
|
* @type {string}
|
|
|
|
*/
|
2013-04-25 00:55:56 +00:00
|
|
|
public name: string;
|
2013-04-18 13:16:18 +00:00
|
|
|
|
2013-05-03 11:32:39 +00:00
|
|
|
/**
|
|
|
|
* The virtual mass of the tile.
|
|
|
|
* @type {number}
|
|
|
|
*/
|
2013-04-28 11:25:02 +00:00
|
|
|
public mass: number = 1.0;
|
2013-05-28 20:38:37 +00:00
|
|
|
|
2013-05-03 11:32:39 +00:00
|
|
|
/**
|
|
|
|
* Tile width.
|
|
|
|
* @type {number}
|
|
|
|
*/
|
2013-04-25 00:55:56 +00:00
|
|
|
public width: number;
|
2013-05-28 20:38:37 +00:00
|
|
|
|
2013-05-03 11:32:39 +00:00
|
|
|
/**
|
|
|
|
* Tile height.
|
|
|
|
* @type {number}
|
|
|
|
*/
|
2013-04-25 00:55:56 +00:00
|
|
|
public height: number;
|
|
|
|
|
2013-05-03 11:32:39 +00:00
|
|
|
/**
|
|
|
|
* Bit field of flags (use with UP, DOWN, LEFT, RIGHT, etc) indicating collision directions.
|
|
|
|
* @type {number}
|
|
|
|
*/
|
2013-04-25 00:55:56 +00:00
|
|
|
public allowCollisions: number;
|
2013-04-18 13:16:18 +00:00
|
|
|
|
2013-05-03 11:32:39 +00:00
|
|
|
/**
|
|
|
|
* Indicating collide with any object on the left.
|
|
|
|
* @type {boolean}
|
|
|
|
*/
|
2013-08-08 10:34:33 +00:00
|
|
|
public collideLeft: boolean = false;
|
2013-05-28 20:38:37 +00:00
|
|
|
|
2013-05-03 11:32:39 +00:00
|
|
|
/**
|
|
|
|
* Indicating collide with any object on the right.
|
|
|
|
* @type {boolean}
|
|
|
|
*/
|
2013-08-08 10:34:33 +00:00
|
|
|
public collideRight: boolean = false;
|
2013-05-28 20:38:37 +00:00
|
|
|
|
2013-05-03 11:32:39 +00:00
|
|
|
/**
|
|
|
|
* Indicating collide with any object on the top.
|
|
|
|
* @type {boolean}
|
|
|
|
*/
|
2013-08-08 10:34:33 +00:00
|
|
|
public collideUp: boolean = false;
|
2013-05-28 20:38:37 +00:00
|
|
|
|
2013-05-03 11:32:39 +00:00
|
|
|
/**
|
|
|
|
* Indicating collide with any object on the bottom.
|
|
|
|
* @type {boolean}
|
|
|
|
*/
|
2013-08-08 10:34:33 +00:00
|
|
|
public collideDown: boolean = false;
|
2013-04-28 11:25:02 +00:00
|
|
|
|
2013-05-03 11:32:39 +00:00
|
|
|
/**
|
|
|
|
* Enable separation at x-axis.
|
|
|
|
* @type {boolean}
|
|
|
|
*/
|
2013-08-08 10:34:33 +00:00
|
|
|
public separateX: boolean = true;
|
2013-05-28 20:38:37 +00:00
|
|
|
|
2013-05-03 11:32:39 +00:00
|
|
|
/**
|
|
|
|
* Enable separation at y-axis.
|
|
|
|
* @type {boolean}
|
|
|
|
*/
|
2013-08-08 10:34:33 +00:00
|
|
|
public separateY: boolean = true;
|
2013-05-02 02:37:45 +00:00
|
|
|
|
2013-04-18 13:16:18 +00:00
|
|
|
/**
|
|
|
|
* A reference to the tilemap this tile object belongs to.
|
2013-05-03 11:32:39 +00:00
|
|
|
* @type {Tilemap}
|
2013-04-18 13:16:18 +00:00
|
|
|
*/
|
|
|
|
public tilemap: Tilemap;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* The index of this tile type in the core map data.
|
|
|
|
* For example, if your map only has 16 kinds of tiles in it,
|
|
|
|
* this number is usually between 0 and 15.
|
2013-05-03 11:32:39 +00:00
|
|
|
* @type {number}
|
2013-04-18 13:16:18 +00:00
|
|
|
*/
|
|
|
|
public index: number;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Clean up memory.
|
|
|
|
*/
|
|
|
|
public destroy() {
|
|
|
|
|
|
|
|
this.tilemap = null;
|
2013-04-12 16:19:56 +00:00
|
|
|
|
2013-04-18 13:16:18 +00:00
|
|
|
}
|
2013-04-12 16:19:56 +00:00
|
|
|
|
2013-05-03 11:32:39 +00:00
|
|
|
/**
|
|
|
|
* Set collision configs.
|
2013-05-04 11:53:11 +00:00
|
|
|
* @param collision {number} Bit field of flags. (see Tile.allowCollision)
|
|
|
|
* @param resetCollisions {boolean} Reset collision flags before set.
|
|
|
|
* @param separateX {boolean} Enable seprate at x-axis.
|
|
|
|
* @param separateY {boolean} Enable seprate at y-axis.
|
2013-05-03 11:32:39 +00:00
|
|
|
*/
|
2013-08-08 10:34:33 +00:00
|
|
|
public setCollision(collision: number, resetCollisions: boolean, separateX: boolean, separateY: boolean) {
|
2013-04-28 11:25:02 +00:00
|
|
|
|
|
|
|
if (resetCollisions)
|
|
|
|
{
|
|
|
|
this.resetCollision();
|
|
|
|
}
|
|
|
|
|
2013-05-02 02:37:45 +00:00
|
|
|
this.separateX = separateX;
|
|
|
|
this.separateY = separateY;
|
|
|
|
|
2013-04-28 11:25:02 +00:00
|
|
|
this.allowCollisions = collision;
|
|
|
|
|
2013-05-31 17:21:32 +00:00
|
|
|
if (collision & Types.ANY)
|
2013-04-28 11:25:02 +00:00
|
|
|
{
|
|
|
|
this.collideLeft = true;
|
|
|
|
this.collideRight = true;
|
|
|
|
this.collideUp = true;
|
|
|
|
this.collideDown = true;
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2013-05-31 17:21:32 +00:00
|
|
|
if (collision & Types.LEFT || collision & Types.WALL)
|
2013-04-28 11:25:02 +00:00
|
|
|
{
|
|
|
|
this.collideLeft = true;
|
|
|
|
}
|
|
|
|
|
2013-05-31 17:21:32 +00:00
|
|
|
if (collision & Types.RIGHT || collision & Types.WALL)
|
2013-04-28 11:25:02 +00:00
|
|
|
{
|
|
|
|
this.collideRight = true;
|
|
|
|
}
|
|
|
|
|
2013-05-31 17:21:32 +00:00
|
|
|
if (collision & Types.UP || collision & Types.CEILING)
|
2013-04-28 11:25:02 +00:00
|
|
|
{
|
|
|
|
this.collideUp = true;
|
|
|
|
}
|
|
|
|
|
2013-05-31 17:21:32 +00:00
|
|
|
if (collision & Types.DOWN || collision & Types.CEILING)
|
2013-04-28 11:25:02 +00:00
|
|
|
{
|
|
|
|
this.collideDown = true;
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
2013-05-03 11:32:39 +00:00
|
|
|
/**
|
|
|
|
* Reset collision status flags.
|
|
|
|
*/
|
2013-04-28 11:25:02 +00:00
|
|
|
public resetCollision() {
|
|
|
|
|
2013-05-31 17:21:32 +00:00
|
|
|
this.allowCollisions = Types.NONE;
|
2013-04-28 11:25:02 +00:00
|
|
|
this.collideLeft = false;
|
|
|
|
this.collideRight = false;
|
|
|
|
this.collideUp = false;
|
|
|
|
this.collideDown = false;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
2013-04-25 00:55:56 +00:00
|
|
|
/**
|
|
|
|
* Returns a string representation of this object.
|
|
|
|
* @method toString
|
|
|
|
* @return {string} a string representation of the object.
|
|
|
|
**/
|
|
|
|
public toString(): string {
|
|
|
|
|
|
|
|
return "[{Tiled (index=" + this.index + " collisions=" + this.allowCollisions + " width=" + this.width + " height=" + this.height + ")}]";
|
|
|
|
|
|
|
|
}
|
|
|
|
|
2013-04-12 16:19:56 +00:00
|
|
|
}
|
|
|
|
|
2013-04-18 13:16:18 +00:00
|
|
|
}
|