2013-10-01 12:54:29 +00:00
|
|
|
/**
|
|
|
|
* @author Richard Davey <rich@photonstorm.com>
|
2014-02-05 05:54:25 +00:00
|
|
|
* @copyright 2014 Photon Storm Ltd.
|
2013-10-01 12:54:29 +00:00
|
|
|
* @license {@link https://github.com/photonstorm/phaser/blob/master/license.txt|MIT License}
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
2014-02-13 15:03:46 +00:00
|
|
|
* A TileSprite is a Sprite that has a repeating texture. The texture can be scrolled and scaled and will automatically wrap on the edges as it does so.
|
2014-03-12 16:33:53 +00:00
|
|
|
* Please note that TileSprites, as with normal Sprites, have no input handler or physics bodies by default. Both need enabling.
|
2014-02-13 15:03:46 +00:00
|
|
|
*
|
|
|
|
* @class Phaser.TileSprite
|
2013-10-01 12:54:29 +00:00
|
|
|
* @constructor
|
2014-10-19 23:54:56 +00:00
|
|
|
* @extends PIXI.TilingSprite
|
2014-02-13 23:13:10 +00:00
|
|
|
* @param {Phaser.Game} game - A reference to the currently running game.
|
|
|
|
* @param {number} x - The x coordinate (in world space) to position the TileSprite at.
|
|
|
|
* @param {number} y - The y coordinate (in world space) to position the TileSprite at.
|
|
|
|
* @param {number} width - The width of the TileSprite.
|
|
|
|
* @param {number} height - The height of the TileSprite.
|
|
|
|
* @param {string|Phaser.RenderTexture|Phaser.BitmapData|PIXI.Texture} key - This is the image or texture used by the TileSprite during rendering. It can be a string which is a reference to the Cache entry, or an instance of a RenderTexture or PIXI.Texture.
|
|
|
|
* @param {string|number} frame - If this TileSprite is using part of a sprite sheet or texture atlas you can specify the exact frame to use by giving a string or numeric index.
|
2013-10-01 12:54:29 +00:00
|
|
|
*/
|
2014-02-13 23:13:10 +00:00
|
|
|
Phaser.TileSprite = function (game, x, y, width, height, key, frame) {
|
2013-09-03 02:19:42 +00:00
|
|
|
|
|
|
|
x = x || 0;
|
|
|
|
y = y || 0;
|
|
|
|
width = width || 256;
|
|
|
|
height = height || 256;
|
|
|
|
key = key || null;
|
2014-02-13 23:13:10 +00:00
|
|
|
frame = frame || null;
|
2013-09-03 02:19:42 +00:00
|
|
|
|
2013-11-25 03:13:04 +00:00
|
|
|
/**
|
|
|
|
* @property {number} type - The const type of this object.
|
|
|
|
* @readonly
|
2013-10-01 12:54:29 +00:00
|
|
|
*/
|
2013-11-25 03:13:04 +00:00
|
|
|
this.type = Phaser.TILESPRITE;
|
2013-09-12 20:54:41 +00:00
|
|
|
|
2014-02-13 23:13:10 +00:00
|
|
|
/**
|
|
|
|
* @property {Phaser.Point} _scroll - Internal cache var.
|
|
|
|
* @private
|
|
|
|
*/
|
|
|
|
this._scroll = new Phaser.Point();
|
|
|
|
|
|
|
|
PIXI.TilingSprite.call(this, PIXI.TextureCache['__default'], width, height);
|
|
|
|
|
2015-02-17 06:00:41 +00:00
|
|
|
Phaser.Utils.mixinPrototype(this, Phaser.Component.Core.prototype);
|
|
|
|
|
|
|
|
var components = [
|
|
|
|
'Angle',
|
|
|
|
'Animation',
|
|
|
|
'AutoCull',
|
|
|
|
'Bounds',
|
|
|
|
'Destroy',
|
|
|
|
'FixedToCamera',
|
|
|
|
'InputEnabled',
|
|
|
|
'InWorld',
|
|
|
|
'LoadTexture',
|
|
|
|
'Overlap',
|
|
|
|
'PhysicsBody',
|
|
|
|
'Reset',
|
|
|
|
'Smoothed'
|
|
|
|
];
|
|
|
|
|
|
|
|
Phaser.Component.Core.install.call(this, components);
|
|
|
|
Phaser.Component.Core.init.call(this, game, x, y, key, frame);
|
2014-06-11 13:38:14 +00:00
|
|
|
|
2013-09-03 02:19:42 +00:00
|
|
|
};
|
|
|
|
|
2014-02-13 15:03:46 +00:00
|
|
|
Phaser.TileSprite.prototype = Object.create(PIXI.TilingSprite.prototype);
|
2013-09-03 02:19:42 +00:00
|
|
|
Phaser.TileSprite.prototype.constructor = Phaser.TileSprite;
|
2014-02-13 23:13:10 +00:00
|
|
|
|
2015-02-25 02:49:50 +00:00
|
|
|
Phaser.TileSprite.prototype.preUpdatePhysics = Phaser.Component.PhysicsBody.preUpdate;
|
|
|
|
Phaser.TileSprite.prototype.preUpdateLifeSpan = Phaser.Component.LifeSpan.preUpdate;
|
|
|
|
Phaser.TileSprite.prototype.preUpdateInWorld = Phaser.Component.InWorld.preUpdate;
|
|
|
|
Phaser.TileSprite.prototype.preUpdateCore = Phaser.Component.Core.preUpdate;
|
|
|
|
|
2014-02-13 23:13:10 +00:00
|
|
|
/**
|
|
|
|
* Automatically called by World.preUpdate.
|
|
|
|
*
|
|
|
|
* @method Phaser.TileSprite#preUpdate
|
|
|
|
* @memberof Phaser.TileSprite
|
|
|
|
*/
|
|
|
|
Phaser.TileSprite.prototype.preUpdate = function() {
|
|
|
|
|
2014-03-21 18:04:24 +00:00
|
|
|
if (this._scroll.x !== 0)
|
|
|
|
{
|
|
|
|
this.tilePosition.x += this._scroll.x * this.game.time.physicsElapsed;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (this._scroll.y !== 0)
|
|
|
|
{
|
|
|
|
this.tilePosition.y += this._scroll.y * this.game.time.physicsElapsed;
|
|
|
|
}
|
|
|
|
|
2015-02-25 02:49:50 +00:00
|
|
|
if (!this.preUpdatePhysics() || !this.preUpdateLifeSpan() || !this.preUpdateInWorld())
|
|
|
|
{
|
|
|
|
return false;
|
|
|
|
}
|
2014-02-28 19:45:15 +00:00
|
|
|
|
2015-02-25 02:49:50 +00:00
|
|
|
return this.preUpdateCore();
|
2014-02-13 23:13:10 +00:00
|
|
|
|
2014-03-23 08:40:24 +00:00
|
|
|
};
|
2014-02-13 23:13:10 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Sets this TileSprite to automatically scroll in the given direction until stopped via TileSprite.stopScroll().
|
|
|
|
* The scroll speed is specified in pixels per second.
|
|
|
|
* A negative x value will scroll to the left. A positive x value will scroll to the right.
|
|
|
|
* A negative y value will scroll up. A positive y value will scroll down.
|
|
|
|
*
|
|
|
|
* @method Phaser.TileSprite#autoScroll
|
|
|
|
* @memberof Phaser.TileSprite
|
2014-08-07 12:47:54 +00:00
|
|
|
* @param {number} x - Horizontal scroll speed in pixels per second.
|
|
|
|
* @param {number} y - Vertical scroll speed in pixels per second.
|
2014-02-13 23:13:10 +00:00
|
|
|
*/
|
|
|
|
Phaser.TileSprite.prototype.autoScroll = function(x, y) {
|
|
|
|
|
|
|
|
this._scroll.set(x, y);
|
|
|
|
|
2014-03-23 08:40:24 +00:00
|
|
|
};
|
2014-02-13 23:13:10 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Stops an automatically scrolling TileSprite.
|
|
|
|
*
|
|
|
|
* @method Phaser.TileSprite#stopScroll
|
|
|
|
* @memberof Phaser.TileSprite
|
|
|
|
*/
|
|
|
|
Phaser.TileSprite.prototype.stopScroll = function() {
|
|
|
|
|
|
|
|
this._scroll.set(0, 0);
|
|
|
|
|
2014-03-23 08:40:24 +00:00
|
|
|
};
|
2014-02-13 23:13:10 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Destroys the TileSprite. This removes it from its parent group, destroys the event and animation handlers if present
|
|
|
|
* and nulls its reference to game, freeing it up for garbage collection.
|
2014-03-23 07:59:28 +00:00
|
|
|
*
|
2014-02-13 23:13:10 +00:00
|
|
|
* @method Phaser.TileSprite#destroy
|
|
|
|
* @memberof Phaser.TileSprite
|
2014-02-27 20:05:16 +00:00
|
|
|
* @param {boolean} [destroyChildren=true] - Should every child of this object have its destroy method called?
|
2014-02-13 23:13:10 +00:00
|
|
|
*/
|
2014-02-27 20:05:16 +00:00
|
|
|
Phaser.TileSprite.prototype.destroy = function(destroyChildren) {
|
|
|
|
|
2015-02-17 06:00:41 +00:00
|
|
|
Phaser.Component.Destroy.prototype.destroy.call(this, destroyChildren);
|
2014-04-22 00:43:22 +00:00
|
|
|
|
2015-02-03 21:32:25 +00:00
|
|
|
PIXI.TilingSprite.prototype.destroy.call(this);
|
|
|
|
|
2014-03-23 08:40:24 +00:00
|
|
|
};
|
2014-02-13 23:13:10 +00:00
|
|
|
|
2014-03-20 03:48:54 +00:00
|
|
|
/**
|
|
|
|
* Resets the TileSprite. This places the TileSprite at the given x/y world coordinates, resets the tilePosition and then
|
|
|
|
* sets alive, exists, visible and renderable all to true. Also resets the outOfBounds state.
|
|
|
|
* If the TileSprite has a physics body that too is reset.
|
2014-06-30 10:49:53 +00:00
|
|
|
*
|
2014-03-20 03:48:54 +00:00
|
|
|
* @method Phaser.TileSprite#reset
|
|
|
|
* @memberof Phaser.TileSprite
|
|
|
|
* @param {number} x - The x coordinate (in world space) to position the Sprite at.
|
|
|
|
* @param {number} y - The y coordinate (in world space) to position the Sprite at.
|
|
|
|
* @return (Phaser.TileSprite) This instance.
|
|
|
|
*/
|
|
|
|
Phaser.TileSprite.prototype.reset = function(x, y) {
|
|
|
|
|
2015-02-17 06:00:41 +00:00
|
|
|
Phaser.Component.Reset.prototype.reset.call(this, x, y);
|
2014-03-20 03:48:54 +00:00
|
|
|
|
|
|
|
this.tilePosition.x = 0;
|
|
|
|
this.tilePosition.y = 0;
|
|
|
|
|
|
|
|
return this;
|
2014-06-30 10:49:53 +00:00
|
|
|
|
2014-03-20 03:48:54 +00:00
|
|
|
};
|