phaser/Phaser/tilemap/Tile.ts

204 lines
5.2 KiB
TypeScript
Raw Normal View History

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
*
* A Tile is a single representation of a tile within a Tilemap
2013-04-18 13:16:18 +00:00
*/
module Phaser {
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>.
*
* @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
*/
constructor(game: Game, tilemap: Tilemap, index: number, width: number, height: number) {
2013-04-18 13:16:18 +00:00
this.game = game;
this.tilemap = tilemap;
this.index = index;
2013-04-18 13:16:18 +00:00
this.width = width;
this.height = height;
this.allowCollisions = Types.NONE;
2013-04-18 13:16:18 +00:00
}
2013-04-18 13:16:18 +00:00
2013-05-03 11:32:39 +00:00
/**
* Local reference to Game.
2013-05-03 11:32:39 +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}
*/
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}
*/
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}
*/
public width: number;
2013-05-28 20:38:37 +00:00
2013-05-03 11:32:39 +00:00
/**
* Tile height.
* @type {number}
*/
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}
*/
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-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-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.
* @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) {
if (resetCollisions)
{
this.resetCollision();
}
this.separateX = separateX;
this.separateY = separateY;
this.allowCollisions = collision;
if (collision & Types.ANY)
{
this.collideLeft = true;
this.collideRight = true;
this.collideUp = true;
this.collideDown = true;
return;
}
if (collision & Types.LEFT || collision & Types.WALL)
{
this.collideLeft = true;
}
if (collision & Types.RIGHT || collision & Types.WALL)
{
this.collideRight = true;
}
if (collision & Types.UP || collision & Types.CEILING)
{
this.collideUp = true;
}
if (collision & Types.DOWN || collision & Types.CEILING)
{
this.collideDown = true;
}
}
2013-05-03 11:32:39 +00:00
/**
* Reset collision status flags.
*/
public resetCollision() {
this.allowCollisions = Types.NONE;
this.collideLeft = false;
this.collideRight = false;
this.collideUp = false;
this.collideDown = false;
}
/**
* 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
}