phaser/src/tilemaps/dynamiclayer/DynamicTilemapLayer.js

1316 lines
59 KiB
JavaScript
Raw Normal View History

2018-02-12 16:01:20 +00:00
/**
* @author Richard Davey <rich@photonstorm.com>
2020-01-15 12:07:09 +00:00
* @copyright 2020 Photon Storm Ltd.
2019-05-10 15:15:04 +00:00
* @license {@link https://opensource.org/licenses/MIT|MIT License}
2018-02-12 16:01:20 +00:00
*/
2018-02-07 17:10:01 +00:00
var Class = require('../../utils/Class');
var Components = require('../../gameobjects/components');
var DynamicTilemapLayerRender = require('./DynamicTilemapLayerRender');
2018-02-07 17:10:01 +00:00
var GameObject = require('../../gameobjects/GameObject');
var TilemapComponents = require('../components');
2017-06-09 04:00:12 +00:00
2018-02-07 15:27:21 +00:00
/**
* @classdesc
* A Dynamic Tilemap Layer is a Game Object that renders LayerData from a Tilemap when used in combination
* with one, or more, Tilesets.
2018-02-07 15:27:21 +00:00
*
* A Dynamic Tilemap Layer trades some speed for being able to apply powerful effects. Unlike a
* Static Tilemap Layer, you can apply per-tile effects like tint or alpha, and you can change the
* tiles in a DynamicTilemapLayer.
*
* Use this over a Static Tilemap Layer when you need those features.
2018-02-07 15:27:21 +00:00
*
* @class DynamicTilemapLayer
2018-02-08 01:08:59 +00:00
* @extends Phaser.GameObjects.GameObject
2018-10-10 09:49:13 +00:00
* @memberof Phaser.Tilemaps
2018-02-07 15:27:21 +00:00
* @constructor
2018-02-08 01:08:59 +00:00
* @since 3.0.0
2018-03-20 11:36:35 +00:00
*
2018-02-08 01:08:59 +00:00
* @extends Phaser.GameObjects.Components.Alpha
* @extends Phaser.GameObjects.Components.BlendMode
* @extends Phaser.GameObjects.Components.ComputedSize
2018-02-08 01:08:59 +00:00
* @extends Phaser.GameObjects.Components.Depth
* @extends Phaser.GameObjects.Components.Flip
* @extends Phaser.GameObjects.Components.GetBounds
* @extends Phaser.GameObjects.Components.Origin
* @extends Phaser.GameObjects.Components.Pipeline
* @extends Phaser.GameObjects.Components.ScrollFactor
2018-02-08 01:08:59 +00:00
* @extends Phaser.GameObjects.Components.Transform
* @extends Phaser.GameObjects.Components.Visible
2018-02-07 15:27:21 +00:00
*
* @param {Phaser.Scene} scene - The Scene to which this Game Object belongs.
2018-02-08 01:08:59 +00:00
* @param {Phaser.Tilemaps.Tilemap} tilemap - The Tilemap this layer is a part of.
2018-02-07 15:27:21 +00:00
* @param {integer} layerIndex - The index of the LayerData associated with this layer.
* @param {(string|string[]|Phaser.Tilemaps.Tileset|Phaser.Tilemaps.Tileset[])} tileset - The tileset, or an array of tilesets, used to render this layer. Can be a string or a Tileset object.
2018-02-07 15:27:21 +00:00
* @param {number} [x=0] - The world x position where the top left of this layer will be placed.
* @param {number} [y=0] - The world y position where the top left of this layer will be placed.
*/
var DynamicTilemapLayer = new Class({
2017-06-09 04:00:12 +00:00
Extends: GameObject,
Mixins: [
Components.Alpha,
Components.BlendMode,
Components.ComputedSize,
Components.Depth,
2017-06-09 04:00:12 +00:00
Components.Flip,
Components.GetBounds,
Components.Origin,
2018-01-29 21:46:48 +00:00
Components.Pipeline,
2017-06-09 04:00:12 +00:00
Components.Transform,
Components.Visible,
2017-06-22 02:19:03 +00:00
Components.ScrollFactor,
DynamicTilemapLayerRender
2017-06-09 04:00:12 +00:00
],
initialize:
function DynamicTilemapLayer (scene, tilemap, layerIndex, tileset, x, y)
2017-06-09 04:00:12 +00:00
{
GameObject.call(this, scene, 'DynamicTilemapLayer');
2017-06-09 04:00:12 +00:00
/**
* Used internally by physics system to perform fast type checks.
2018-03-20 11:36:35 +00:00
*
2018-02-08 01:08:59 +00:00
* @name Phaser.Tilemaps.DynamicTilemapLayer#isTilemap
* @type {boolean}
2018-10-09 12:40:00 +00:00
* @readonly
2018-02-08 01:08:59 +00:00
* @since 3.0.0
*/
this.isTilemap = true;
/**
* The Tilemap that this layer is a part of.
2018-03-20 11:36:35 +00:00
*
2018-02-08 01:08:59 +00:00
* @name Phaser.Tilemaps.DynamicTilemapLayer#tilemap
* @type {Phaser.Tilemaps.Tilemap}
* @since 3.0.0
*/
this.tilemap = tilemap;
/**
* The index of the LayerData associated with this layer.
2018-03-20 11:36:35 +00:00
*
2018-02-08 01:08:59 +00:00
* @name Phaser.Tilemaps.DynamicTilemapLayer#layerIndex
* @type {integer}
* @since 3.0.0
*/
this.layerIndex = layerIndex;
/**
* The LayerData associated with this layer. LayerData can only be associated with one
* tilemap layer.
2018-03-20 11:36:35 +00:00
*
2018-02-08 01:08:59 +00:00
* @name Phaser.Tilemaps.DynamicTilemapLayer#layer
* @type {Phaser.Tilemaps.LayerData}
* @since 3.0.0
*/
this.layer = tilemap.layers[layerIndex];
2018-02-08 01:08:59 +00:00
// Link the LayerData with this static tilemap layer
this.layer.tilemapLayer = this;
/**
* The Tileset/s associated with this layer.
*
* As of Phaser 3.14 this property is now an array of Tileset objects, previously it was a single reference.
2018-03-20 11:36:35 +00:00
*
2018-02-08 01:08:59 +00:00
* @name Phaser.Tilemaps.DynamicTilemapLayer#tileset
* @type {Phaser.Tilemaps.Tileset[]}
2018-02-08 01:08:59 +00:00
* @since 3.0.0
*/
this.tileset = [];
/**
* Used internally with the canvas render. This holds the tiles that are visible within the
* camera.
2018-03-20 11:36:35 +00:00
*
2018-02-08 01:08:59 +00:00
* @name Phaser.Tilemaps.DynamicTilemapLayer#culledTiles
* @type {array}
* @since 3.0.0
*/
2017-06-09 04:00:12 +00:00
this.culledTiles = [];
/**
* You can control if the Cameras should cull tiles before rendering them or not.
* By default the camera will try to cull the tiles in this layer, to avoid over-drawing to the renderer.
*
* However, there are some instances when you may wish to disable this, and toggling this flag allows
* you to do so. Also see `setSkipCull` for a chainable method that does the same thing.
*
* @name Phaser.Tilemaps.DynamicTilemapLayer#skipCull
* @type {boolean}
* @since 3.11.0
*/
this.skipCull = false;
/**
* The total number of tiles drawn by the renderer in the last frame.
*
* @name Phaser.Tilemaps.DynamicTilemapLayer#tilesDrawn
2018-08-02 21:14:32 +00:00
* @type {integer}
2018-10-09 12:40:00 +00:00
* @readonly
* @since 3.11.0
*/
this.tilesDrawn = 0;
/**
* The total number of tiles in this layer. Updated every frame.
*
* @name Phaser.Tilemaps.DynamicTilemapLayer#tilesTotal
2018-08-02 21:14:32 +00:00
* @type {integer}
2018-10-09 12:40:00 +00:00
* @readonly
* @since 3.11.0
*/
this.tilesTotal = this.layer.width * this.layer.height;
2018-07-12 15:44:36 +00:00
/**
* The amount of extra tiles to add into the cull rectangle when calculating its horizontal size.
*
2018-07-12 15:44:36 +00:00
* See the method `setCullPadding` for more details.
*
* @name Phaser.Tilemaps.DynamicTilemapLayer#cullPaddingX
2018-08-02 21:14:32 +00:00
* @type {integer}
* @default 1
* @since 3.11.0
*/
this.cullPaddingX = 1;
/**
* The amount of extra tiles to add into the cull rectangle when calculating its vertical size.
*
* See the method `setCullPadding` for more details.
*
* @name Phaser.Tilemaps.DynamicTilemapLayer#cullPaddingY
2018-08-02 21:14:32 +00:00
* @type {integer}
* @default 1
2018-07-12 15:44:36 +00:00
* @since 3.11.0
*/
this.cullPaddingY = 1;
2018-07-12 15:44:36 +00:00
/**
* The callback that is invoked when the tiles are culled.
*
* By default it will call `TilemapComponents.CullTiles` but you can override this to call any function you like.
*
* It will be sent 3 arguments:
*
* 1. The Phaser.Tilemaps.LayerData object for this Layer
* 2. The Camera that is culling the layer. You can check its `dirty` property to see if it has changed since the last cull.
* 3. A reference to the `culledTiles` array, which should be used to store the tiles you want rendered.
*
* See the `TilemapComponents.CullTiles` source code for details on implementing your own culling system.
*
* @name Phaser.Tilemaps.DynamicTilemapLayer#cullCallback
* @type {function}
* @since 3.11.0
*/
this.cullCallback = TilemapComponents.CullTiles;
/**
* The rendering (draw) order of the tiles in this layer.
*
* The default is 0 which is 'right-down', meaning it will draw the tiles starting from the top-left,
* drawing to the right and then moving down to the next row.
*
* The draw orders are:
*
* 0 = right-down
* 1 = left-down
* 2 = right-up
* 3 = left-up
*
* This can be changed via the `setRenderOrder` method.
*
* @name Phaser.Tilemaps.DynamicTilemapLayer#_renderOrder
* @type {integer}
* @default 0
* @private
* @since 3.12.0
*/
this._renderOrder = 0;
/**
* An array holding the mapping between the tile indexes and the tileset they belong to.
*
* @name Phaser.Tilemaps.DynamicTilemapLayer#gidMap
* @type {Phaser.Tilemaps.Tileset[]}
* @since 3.14.0
*/
this.gidMap = [];
this.setTilesets(tileset);
this.setAlpha(this.layer.alpha);
2017-06-09 04:00:12 +00:00
this.setPosition(x, y);
this.setOrigin();
this.setSize(tilemap.tileWidth * this.layer.width, tilemap.tileHeight * this.layer.height);
2018-02-08 01:08:59 +00:00
2018-01-29 21:46:48 +00:00
this.initPipeline('TextureTintPipeline');
2017-06-09 04:00:12 +00:00
},
/**
* Populates the internal `tileset` array with the Tileset references this Layer requires for rendering.
*
* @method Phaser.Tilemaps.DynamicTilemapLayer#setTilesets
* @private
* @since 3.14.0
*
* @param {(string|string[]|Phaser.Tilemaps.Tileset|Phaser.Tilemaps.Tileset[])} tileset - The tileset, or an array of tilesets, used to render this layer. Can be a string or a Tileset object.
*/
setTilesets: function (tilesets)
{
var gidMap = [];
var setList = [];
var map = this.tilemap;
if (!Array.isArray(tilesets))
{
tilesets = [ tilesets ];
}
for (var i = 0; i < tilesets.length; i++)
{
var tileset = tilesets[i];
if (typeof tileset === 'string')
{
tileset = map.getTileset(tileset);
}
if (tileset)
{
setList.push(tileset);
var s = tileset.firstgid;
for (var t = 0; t < tileset.total; t++)
{
gidMap[s + t] = tileset;
}
}
}
this.gidMap = gidMap;
this.tileset = setList;
},
/**
* Sets the rendering (draw) order of the tiles in this layer.
*
* The default is 'right-down', meaning it will order the tiles starting from the top-left,
* drawing to the right and then moving down to the next row.
*
* The draw orders are:
*
* 0 = right-down
* 1 = left-down
* 2 = right-up
* 3 = left-up
*
* Setting the render order does not change the tiles or how they are stored in the layer,
* it purely impacts the order in which they are rendered.
*
* You can provide either an integer (0 to 3), or the string version of the order.
*
* @method Phaser.Tilemaps.DynamicTilemapLayer#setRenderOrder
* @since 3.12.0
*
* @param {(integer|string)} renderOrder - The render (draw) order value. Either an integer between 0 and 3, or a string: 'right-down', 'left-down', 'right-up' or 'left-up'.
*
* @return {this} This Tilemap Layer object.
*/
setRenderOrder: function (renderOrder)
{
var orders = [ 'right-down', 'left-down', 'right-up', 'left-up' ];
if (typeof renderOrder === 'string')
{
renderOrder = orders.indexOf(renderOrder);
}
if (renderOrder >= 0 && renderOrder < 4)
{
this._renderOrder = renderOrder;
}
return this;
},
/**
2018-02-08 02:02:37 +00:00
* Calculates interesting faces at the given tile coordinates of the specified layer. Interesting
* faces are used internally for optimizing collisions against tiles. This method is mostly used
* internally to optimize recalculating faces when only one tile has been changed.
2018-03-20 11:36:35 +00:00
*
2018-02-08 01:08:59 +00:00
* @method Phaser.Tilemaps.DynamicTilemapLayer#calculateFacesAt
* @since 3.0.0
2018-03-20 11:36:35 +00:00
*
2018-02-08 02:02:37 +00:00
* @param {integer} tileX - The x coordinate.
* @param {integer} tileY - The y coordinate.
*
2018-02-08 01:08:59 +00:00
* @return {Phaser.Tilemaps.DynamicTilemapLayer} This Tilemap Layer object.
*/
calculateFacesAt: function (tileX, tileY)
{
TilemapComponents.CalculateFacesAt(tileX, tileY, this.layer);
2018-02-08 01:08:59 +00:00
return this;
},
/**
2018-02-08 02:02:37 +00:00
* Calculates interesting faces within the rectangular area specified (in tile coordinates) of the
* layer. Interesting faces are used internally for optimizing collisions against tiles. This method
* is mostly used internally.
2018-03-20 11:36:35 +00:00
*
2018-02-08 01:08:59 +00:00
* @method Phaser.Tilemaps.DynamicTilemapLayer#calculateFacesWithin
* @since 3.0.0
2018-03-20 11:36:35 +00:00
*
2018-09-28 13:46:31 +00:00
* @param {integer} [tileX=0] - The left most tile index (in tile coordinates) to use as the origin of the area.
* @param {integer} [tileY=0] - The top most tile index (in tile coordinates) to use as the origin of the area.
* @param {integer} [width=max width based on tileX] - How many tiles wide from the `tileX` index the area will be.
* @param {integer} [height=max height based on tileY] - How many tiles tall from the `tileY` index the area will be.
*
2018-02-08 01:08:59 +00:00
* @return {Phaser.Tilemaps.DynamicTilemapLayer} This Tilemap Layer object.
*/
calculateFacesWithin: function (tileX, tileY, width, height)
{
TilemapComponents.CalculateFacesWithin(tileX, tileY, width, height, this.layer);
2018-02-08 02:02:37 +00:00
return this;
},
/**
2018-02-08 02:02:37 +00:00
* Creates a Sprite for every object matching the given tile indexes in the layer. You can
* optionally specify if each tile will be replaced with a new tile after the Sprite has been
* created. This is useful if you want to lay down special tiles in a level that are converted to
* Sprites, but want to replace the tile itself with a floor tile or similar once converted.
2018-03-20 11:36:35 +00:00
*
2018-02-08 01:08:59 +00:00
* @method Phaser.Tilemaps.DynamicTilemapLayer#createFromTiles
* @since 3.0.0
2018-03-20 11:36:35 +00:00
*
2018-03-20 15:11:33 +00:00
* @param {(integer|array)} indexes - The tile index, or array of indexes, to create Sprites from.
* @param {(integer|array)} replacements - The tile index, or array of indexes, to change a converted
2018-02-08 02:02:37 +00:00
* tile to. Set to `null` to leave the tiles unchanged. If an array is given, it is assumed to be a
* one-to-one mapping with the indexes array.
2019-05-09 14:32:53 +00:00
* @param {Phaser.Types.GameObjects.Sprite.SpriteConfig} spriteConfig - The config object to pass into the Sprite creator (i.e.
2018-02-08 02:02:37 +00:00
* scene.make.sprite).
* @param {Phaser.Scene} [scene=scene the map is within] - The Scene to create the Sprites within.
* @param {Phaser.Cameras.Scene2D.Camera} [camera=main camera] - The Camera to use when determining the world XY
*
2018-02-08 02:02:37 +00:00
* @return {Phaser.GameObjects.Sprite[]} An array of the Sprites that were created.
*/
createFromTiles: function (indexes, replacements, spriteConfig, scene, camera)
{
return TilemapComponents.CreateFromTiles(indexes, replacements, spriteConfig, scene, camera, this.layer);
},
/**
2018-02-08 02:02:37 +00:00
* Returns the tiles in the given layer that are within the cameras viewport.
* This is used internally.
2018-03-20 11:36:35 +00:00
*
2018-02-08 01:08:59 +00:00
* @method Phaser.Tilemaps.DynamicTilemapLayer#cull
* @since 3.0.0
2018-03-20 11:36:35 +00:00
*
2018-02-08 02:02:37 +00:00
* @param {Phaser.Cameras.Scene2D.Camera} [camera] - The Camera to run the cull check against.
*
2018-02-08 01:08:59 +00:00
* @return {Phaser.Tilemaps.Tile[]} An array of Tile objects.
*/
cull: function (camera)
2017-06-09 04:00:12 +00:00
{
return this.cullCallback(this.layer, camera, this.culledTiles, this._renderOrder);
},
/**
2018-02-08 02:02:37 +00:00
* Copies the tiles in the source rectangular area to a new destination (all specified in tile
* coordinates) within the layer. This copies all tile properties & recalculates collision
* information in the destination region.
2018-03-20 11:36:35 +00:00
*
2018-02-08 01:08:59 +00:00
* @method Phaser.Tilemaps.DynamicTilemapLayer#copy
* @since 3.0.0
2018-03-20 11:36:35 +00:00
*
2018-09-28 13:46:31 +00:00
* @param {integer} srcTileX - The x coordinate of the area to copy from, in tiles, not pixels.
* @param {integer} srcTileY - The y coordinate of the area to copy from, in tiles, not pixels.
* @param {integer} width - The width of the area to copy, in tiles, not pixels.
* @param {integer} height - The height of the area to copy, in tiles, not pixels.
* @param {integer} destTileX - The x coordinate of the area to copy to, in tiles, not pixels.
* @param {integer} destTileY - The y coordinate of the area to copy to, in tiles, not pixels.
* @param {boolean} [recalculateFaces=true] - `true` if the faces data should be recalculated.
*
2018-02-08 01:08:59 +00:00
* @return {Phaser.Tilemaps.DynamicTilemapLayer} This Tilemap Layer object.
*/
copy: function (srcTileX, srcTileY, width, height, destTileX, destTileY, recalculateFaces)
{
TilemapComponents.Copy(srcTileX, srcTileY, width, height, destTileX, destTileY, recalculateFaces, this.layer);
2018-02-08 01:08:59 +00:00
return this;
},
/**
2018-02-08 01:08:59 +00:00
* Destroys this DynamicTilemapLayer and removes its link to the associated LayerData.
2018-03-20 11:36:35 +00:00
*
2018-02-08 01:08:59 +00:00
* @method Phaser.Tilemaps.DynamicTilemapLayer#destroy
* @since 3.0.0
2019-04-08 14:59:30 +00:00
*
* @param {boolean} [removeFromTilemap=true] - Remove this layer from the parent Tilemap?
2018-02-08 01:08:59 +00:00
*/
2019-04-08 14:59:30 +00:00
destroy: function (removeFromTilemap)
{
2019-04-08 14:59:30 +00:00
if (removeFromTilemap === undefined) { removeFromTilemap = true; }
if (!this.tilemap)
{
// Abort, we've already been destroyed
return;
}
// Uninstall this layer only if it is still installed on the LayerData object
if (this.layer.tilemapLayer === this)
{
this.layer.tilemapLayer = undefined;
}
2018-02-08 01:08:59 +00:00
2019-04-08 14:59:30 +00:00
if (removeFromTilemap)
{
this.tilemap.removeLayer(this);
}
this.tilemap = undefined;
this.layer = undefined;
this.culledTiles.length = 0;
this.cullCallback = null;
2018-02-08 01:08:59 +00:00
this.gidMap = [];
this.tileset = [];
GameObject.prototype.destroy.call(this);
},
/**
2018-02-08 02:02:37 +00:00
* Sets the tiles in the given rectangular area (in tile coordinates) of the layer with the
* specified index. Tiles will be set to collide if the given index is a colliding index.
* Collision information in the region will be recalculated.
2018-03-20 11:36:35 +00:00
*
2018-02-08 01:08:59 +00:00
* @method Phaser.Tilemaps.DynamicTilemapLayer#fill
* @since 3.0.0
2018-03-20 11:36:35 +00:00
*
2018-09-28 13:46:31 +00:00
* @param {integer} index - The tile index to fill the area with.
* @param {integer} [tileX=0] - The left most tile index (in tile coordinates) to use as the origin of the area.
* @param {integer} [tileY=0] - The top most tile index (in tile coordinates) to use as the origin of the area.
* @param {integer} [width=max width based on tileX] - How many tiles wide from the `tileX` index the area will be.
* @param {integer} [height=max height based on tileY] - How many tiles tall from the `tileY` index the area will be.
* @param {boolean} [recalculateFaces=true] - `true` if the faces data should be recalculated.
*
2018-02-08 01:08:59 +00:00
* @return {Phaser.Tilemaps.DynamicTilemapLayer} This Tilemap Layer object.
*/
fill: function (index, tileX, tileY, width, height, recalculateFaces)
{
TilemapComponents.Fill(index, tileX, tileY, width, height, recalculateFaces, this.layer);
2018-02-08 01:08:59 +00:00
return this;
},
/**
2018-02-08 02:02:37 +00:00
* For each tile in the given rectangular area (in tile coordinates) of the layer, run the given
* filter callback function. Any tiles that pass the filter test (i.e. where the callback returns
* true) will returned as a new array. Similar to Array.prototype.Filter in vanilla JS.
2018-03-20 11:36:35 +00:00
*
2018-02-08 01:08:59 +00:00
* @method Phaser.Tilemaps.DynamicTilemapLayer#filterTiles
* @since 3.0.0
2018-03-20 11:36:35 +00:00
*
2018-02-08 02:02:37 +00:00
* @param {function} callback - The callback. Each tile in the given area will be passed to this
* callback as the first and only parameter. The callback should return true for tiles that pass the
* filter.
* @param {object} [context] - The context under which the callback should be run.
2018-09-28 13:46:31 +00:00
* @param {integer} [tileX=0] - The left most tile index (in tile coordinates) to use as the origin of the area to filter.
* @param {integer} [tileY=0] - The top most tile index (in tile coordinates) to use as the origin of the area to filter.
* @param {integer} [width=max width based on tileX] - How many tiles wide from the `tileX` index the area will be.
* @param {integer} [height=max height based on tileY] - How many tiles tall from the `tileY` index the area will be.
2019-05-09 11:39:19 +00:00
* @param {Phaser.Types.Tilemaps.FilteringOptions} [filteringOptions] - Optional filters to apply when getting the tiles.
*
2018-02-08 01:08:59 +00:00
* @return {Phaser.Tilemaps.Tile[]} An array of Tile objects.
*/
filterTiles: function (callback, context, tileX, tileY, width, height, filteringOptions)
{
return TilemapComponents.FilterTiles(callback, context, tileX, tileY, width, height, filteringOptions, this.layer);
},
/**
2018-02-08 02:02:37 +00:00
* Searches the entire map layer for the first tile matching the given index, then returns that Tile
* object. If no match is found, it returns null. The search starts from the top-left tile and
* continues horizontally until it hits the end of the row, then it drops down to the next column.
* If the reverse boolean is true, it scans starting from the bottom-right corner traveling up to
* the top-left.
2018-03-20 11:36:35 +00:00
*
2018-02-08 01:08:59 +00:00
* @method Phaser.Tilemaps.DynamicTilemapLayer#findByIndex
* @since 3.0.0
2018-03-20 11:36:35 +00:00
*
2018-02-08 02:02:37 +00:00
* @param {integer} index - The tile index value to search for.
* @param {integer} [skip=0] - The number of times to skip a matching tile before returning.
* @param {boolean} [reverse=false] - If true it will scan the layer in reverse, starting at the
* bottom-right. Otherwise it scans from the top-left.
*
2018-02-08 01:08:59 +00:00
* @return {Phaser.Tilemaps.Tile} A Tile object.
*/
findByIndex: function (findIndex, skip, reverse)
{
return TilemapComponents.FindByIndex(findIndex, skip, reverse, this.layer);
},
/**
2018-02-08 02:02:37 +00:00
* Find the first tile in the given rectangular area (in tile coordinates) of the layer that
* satisfies the provided testing function. I.e. finds the first tile for which `callback` returns
* true. Similar to Array.prototype.find in vanilla JS.
2018-03-20 11:36:35 +00:00
*
2018-02-08 01:08:59 +00:00
* @method Phaser.Tilemaps.DynamicTilemapLayer#findTile
* @since 3.0.0
2018-03-20 11:36:35 +00:00
*
2018-09-28 13:46:31 +00:00
* @param {FindTileCallback} callback - The callback. Each tile in the given area will be passed to this callback as the first and only parameter.
2018-02-08 02:02:37 +00:00
* @param {object} [context] - The context under which the callback should be run.
2018-09-28 13:46:31 +00:00
* @param {integer} [tileX=0] - The left most tile index (in tile coordinates) to use as the origin of the area to search.
* @param {integer} [tileY=0] - The top most tile index (in tile coordinates) to use as the origin of the area to search.
* @param {integer} [width=max width based on tileX] - How many tiles wide from the `tileX` index the area will be.
* @param {integer} [height=max height based on tileY] - How many tiles tall from the `tileY` index the area will be.
2019-05-09 11:39:19 +00:00
* @param {Phaser.Types.Tilemaps.FilteringOptions} [filteringOptions] - Optional filters to apply when getting the tiles.
*
2018-03-20 11:36:35 +00:00
* @return {?Phaser.Tilemaps.Tile}
*/
findTile: function (callback, context, tileX, tileY, width, height, filteringOptions)
{
return TilemapComponents.FindTile(callback, context, tileX, tileY, width, height, filteringOptions, this.layer);
},
/**
2018-02-08 02:02:37 +00:00
* For each tile in the given rectangular area (in tile coordinates) of the layer, run the given
* callback. Similar to Array.prototype.forEach in vanilla JS.
2018-03-20 11:36:35 +00:00
*
2018-02-08 01:08:59 +00:00
* @method Phaser.Tilemaps.DynamicTilemapLayer#forEachTile
* @since 3.0.0
2018-03-20 11:36:35 +00:00
*
2018-09-28 13:46:31 +00:00
* @param {EachTileCallback} callback - The callback. Each tile in the given area will be passed to this callback as the first and only parameter.
2018-02-08 02:02:37 +00:00
* @param {object} [context] - The context under which the callback should be run.
2018-09-28 13:46:31 +00:00
* @param {integer} [tileX=0] - The left most tile index (in tile coordinates) to use as the origin of the area to search.
* @param {integer} [tileY=0] - The top most tile index (in tile coordinates) to use as the origin of the area to search.
* @param {integer} [width=max width based on tileX] - How many tiles wide from the `tileX` index the area will be.
* @param {integer} [height=max height based on tileY] - How many tiles tall from the `tileY` index the area will be.
2019-05-09 11:39:19 +00:00
* @param {Phaser.Types.Tilemaps.FilteringOptions} [filteringOptions] - Optional filters to apply when getting the tiles.
*
2018-02-08 01:08:59 +00:00
* @return {Phaser.Tilemaps.DynamicTilemapLayer} This Tilemap Layer object.
*/
forEachTile: function (callback, context, tileX, tileY, width, height, filteringOptions)
{
TilemapComponents.ForEachTile(callback, context, tileX, tileY, width, height, filteringOptions, this.layer);
2018-03-20 11:36:35 +00:00
return this;
},
/**
2018-02-08 02:02:37 +00:00
* Gets a tile at the given tile coordinates from the given layer.
2018-03-20 11:36:35 +00:00
*
2018-02-08 01:08:59 +00:00
* @method Phaser.Tilemaps.DynamicTilemapLayer#getTileAt
* @since 3.0.0
2018-03-20 11:36:35 +00:00
*
2018-02-08 02:02:37 +00:00
* @param {integer} tileX - X position to get the tile from (given in tile units, not pixels).
* @param {integer} tileY - Y position to get the tile from (given in tile units, not pixels).
2018-09-28 13:46:31 +00:00
* @param {boolean} [nonNull=false] - If true getTile won't return null for empty tiles, but a Tile object with an index of -1.
*
2018-02-08 02:02:37 +00:00
* @return {Phaser.Tilemaps.Tile} The tile at the given coordinates or null if no tile was found or the coordinates were invalid.
*/
getTileAt: function (tileX, tileY, nonNull)
{
2017-11-16 19:09:07 +00:00
return TilemapComponents.GetTileAt(tileX, tileY, nonNull, this.layer);
},
/**
2018-02-08 02:02:37 +00:00
* Gets a tile at the given world coordinates from the given layer.
2018-03-20 11:36:35 +00:00
*
2018-02-08 01:08:59 +00:00
* @method Phaser.Tilemaps.DynamicTilemapLayer#getTileAtWorldXY
* @since 3.0.0
2018-03-20 11:36:35 +00:00
*
2018-02-08 02:02:37 +00:00
* @param {number} worldX - X position to get the tile from (given in pixels)
* @param {number} worldY - Y position to get the tile from (given in pixels)
2018-09-28 13:46:31 +00:00
* @param {boolean} [nonNull=false] - If true, function won't return null for empty tiles, but a Tile object with an index of -1.
* @param {Phaser.Cameras.Scene2D.Camera} [camera=main camera] - The Camera to use when calculating the tile index from the world values.
*
2018-02-08 02:02:37 +00:00
* @return {Phaser.Tilemaps.Tile} The tile at the given coordinates or null if no tile was found or the coordinates
* were invalid.
*/
getTileAtWorldXY: function (worldX, worldY, nonNull, camera)
2017-11-16 19:27:52 +00:00
{
return TilemapComponents.GetTileAtWorldXY(worldX, worldY, nonNull, camera, this.layer);
2017-11-16 19:27:52 +00:00
},
/**
2018-02-08 02:02:37 +00:00
* Gets the tiles in the given rectangular area (in tile coordinates) of the layer.
2018-03-20 11:36:35 +00:00
*
2018-02-08 01:08:59 +00:00
* @method Phaser.Tilemaps.DynamicTilemapLayer#getTilesWithin
* @since 3.0.0
2018-03-20 11:36:35 +00:00
*
2018-09-28 13:46:31 +00:00
* @param {integer} [tileX=0] - The left most tile index (in tile coordinates) to use as the origin of the area.
* @param {integer} [tileY=0] - The top most tile index (in tile coordinates) to use as the origin of the area.
* @param {integer} [width=max width based on tileX] - How many tiles wide from the `tileX` index the area will be.
* @param {integer} [height=max height based on tileY] - How many tiles tall from the `tileY` index the area will be.
2019-05-09 11:39:19 +00:00
* @param {Phaser.Types.Tilemaps.FilteringOptions} [filteringOptions] - Optional filters to apply when getting the tiles.
*
2018-02-08 01:08:59 +00:00
* @return {Phaser.Tilemaps.Tile[]} An array of Tile objects.
*/
getTilesWithin: function (tileX, tileY, width, height, filteringOptions)
{
return TilemapComponents.GetTilesWithin(tileX, tileY, width, height, filteringOptions, this.layer);
},
/**
2018-02-08 02:02:37 +00:00
* Gets the tiles that overlap with the given shape in the given layer. The shape must be a Circle,
* Line, Rectangle or Triangle. The shape should be in world coordinates.
2018-03-20 11:36:35 +00:00
*
2018-02-08 01:08:59 +00:00
* @method Phaser.Tilemaps.DynamicTilemapLayer#getTilesWithinShape
* @since 3.0.0
2018-03-20 11:36:35 +00:00
*
2018-03-20 15:11:33 +00:00
* @param {(Phaser.Geom.Circle|Phaser.Geom.Line|Phaser.Geom.Rectangle|Phaser.Geom.Triangle)} shape - A shape in world (pixel) coordinates
2019-05-09 11:39:19 +00:00
* @param {Phaser.Types.Tilemaps.FilteringOptions} [filteringOptions] - Optional filters to apply when getting the tiles.
2018-09-28 13:46:31 +00:00
* @param {Phaser.Cameras.Scene2D.Camera} [camera=main camera] - The Camera to use when factoring in which tiles to return.
*
2018-02-08 01:08:59 +00:00
* @return {Phaser.Tilemaps.Tile[]} An array of Tile objects.
*/
getTilesWithinShape: function (shape, filteringOptions, camera)
{
return TilemapComponents.GetTilesWithinShape(shape, filteringOptions, camera, this.layer, this.tilemap.orientation);
},
/**
2018-02-08 02:02:37 +00:00
* Gets the tiles in the given rectangular area (in world coordinates) of the layer.
2018-03-20 11:36:35 +00:00
*
2018-02-08 01:08:59 +00:00
* @method Phaser.Tilemaps.DynamicTilemapLayer#getTilesWithinWorldXY
* @since 3.0.0
2018-03-20 11:36:35 +00:00
*
2018-09-28 13:46:31 +00:00
* @param {number} worldX - The world x coordinate for the top-left of the area.
* @param {number} worldY - The world y coordinate for the top-left of the area.
* @param {number} width - The width of the area.
* @param {number} height - The height of the area.
2019-05-09 11:39:19 +00:00
* @param {Phaser.Types.Tilemaps.FilteringOptions} [filteringOptions] - Optional filters to apply when getting the tiles.
2018-09-28 13:46:31 +00:00
* @param {Phaser.Cameras.Scene2D.Camera} [camera=main camera] - The Camera to use when factoring in which tiles to return.
*
2018-02-08 01:08:59 +00:00
* @return {Phaser.Tilemaps.Tile[]} An array of Tile objects.
*/
getTilesWithinWorldXY: function (worldX, worldY, width, height, filteringOptions, camera)
{
return TilemapComponents.GetTilesWithinWorldXY(worldX, worldY, width, height, filteringOptions, camera, this.layer, this.tilemap.orientation);
},
/**
2018-02-08 02:02:37 +00:00
* Checks if there is a tile at the given location (in tile coordinates) in the given layer. Returns
* false if there is no tile or if the tile at that location has an index of -1.
2018-03-20 11:36:35 +00:00
*
2018-02-08 01:08:59 +00:00
* @method Phaser.Tilemaps.DynamicTilemapLayer#hasTileAt
* @since 3.0.0
2018-03-20 11:36:35 +00:00
*
2018-09-28 13:46:31 +00:00
* @param {integer} tileX - The x coordinate, in tiles, not pixels.
* @param {integer} tileY - The y coordinate, in tiles, not pixels.
*
2018-09-28 13:46:31 +00:00
* @return {boolean} `true` if a tile was found at the given location, otherwise `false`.
*/
hasTileAt: function (tileX, tileY)
{
return TilemapComponents.HasTileAt(tileX, tileY, this.layer);
},
/**
2018-02-08 02:02:37 +00:00
* Checks if there is a tile at the given location (in world coordinates) in the given layer. Returns
* false if there is no tile or if the tile at that location has an index of -1.
2018-03-20 11:36:35 +00:00
*
2018-02-08 01:08:59 +00:00
* @method Phaser.Tilemaps.DynamicTilemapLayer#hasTileAtWorldXY
* @since 3.0.0
2018-03-20 11:36:35 +00:00
*
2018-09-28 13:46:31 +00:00
* @param {number} worldX - The x coordinate, in pixels.
* @param {number} worldY - The y coordinate, in pixels.
* @param {Phaser.Cameras.Scene2D.Camera} [camera=main camera] - The Camera to use when factoring in which tiles to return.
*
2018-09-28 13:46:31 +00:00
* @return {boolean} `true` if a tile was found at the given location, otherwise `false`.
*/
hasTileAtWorldXY: function (worldX, worldY, camera)
{
return TilemapComponents.HasTileAtWorldXY(worldX, worldY, camera, this.layer);
},
/**
2018-02-08 02:02:37 +00:00
* Puts a tile at the given tile coordinates in the specified layer. You can pass in either an index
* or a Tile object. If you pass in a Tile, all attributes will be copied over to the specified
* location. If you pass in an index, only the index at the specified location will be changed.
* Collision information will be recalculated at the specified location.
2018-03-20 11:36:35 +00:00
*
2018-02-08 01:08:59 +00:00
* @method Phaser.Tilemaps.DynamicTilemapLayer#putTileAt
* @since 3.0.0
2018-03-20 11:36:35 +00:00
*
2018-03-20 15:11:33 +00:00
* @param {(integer|Phaser.Tilemaps.Tile)} tile - The index of this tile to set or a Tile object.
2018-09-28 13:46:31 +00:00
* @param {integer} tileX - The x coordinate, in tiles, not pixels.
* @param {integer} tileY - The y coordinate, in tiles, not pixels.
* @param {boolean} [recalculateFaces=true] - `true` if the faces data should be recalculated.
*
2018-02-08 01:08:59 +00:00
* @return {Phaser.Tilemaps.Tile} A Tile object.
*/
putTileAt: function (tile, tileX, tileY, recalculateFaces)
2017-11-16 19:09:07 +00:00
{
return TilemapComponents.PutTileAt(tile, tileX, tileY, recalculateFaces, this.layer, this.tilemap.orientation);
2017-11-16 19:09:07 +00:00
},
/**
2018-02-08 02:02:37 +00:00
* Puts a tile at the given world coordinates (pixels) in the specified layer. You can pass in either
* an index or a Tile object. If you pass in a Tile, all attributes will be copied over to the
* specified location. If you pass in an index, only the index at the specified location will be
* changed. Collision information will be recalculated at the specified location.
2018-03-20 11:36:35 +00:00
*
2018-02-08 01:08:59 +00:00
* @method Phaser.Tilemaps.DynamicTilemapLayer#putTileAtWorldXY
* @since 3.0.0
2018-03-20 11:36:35 +00:00
*
2018-03-20 15:11:33 +00:00
* @param {(integer|Phaser.Tilemaps.Tile)} tile - The index of this tile to set or a Tile object.
2018-09-28 13:46:31 +00:00
* @param {number} worldX - The x coordinate, in pixels.
* @param {number} worldY - The y coordinate, in pixels.
* @param {boolean} [recalculateFaces=true] - `true` if the faces data should be recalculated.
* @param {Phaser.Cameras.Scene2D.Camera} [camera=main camera] - The Camera to use when calculating the tile index from the world values.
*
2018-02-08 01:08:59 +00:00
* @return {Phaser.Tilemaps.Tile} A Tile object.
*/
putTileAtWorldXY: function (tile, worldX, worldY, recalculateFaces, camera)
{
2020-01-19 19:55:09 +00:00
return TilemapComponents.PutTileAtWorldXY(tile, worldX, worldY, recalculateFaces, camera, this.layer, this.tilemap.orientation);
},
/**
2018-02-08 02:02:37 +00:00
* Puts an array of tiles or a 2D array of tiles at the given tile coordinates in the specified
* layer. The array can be composed of either tile indexes or Tile objects. If you pass in a Tile,
* all attributes will be copied over to the specified location. If you pass in an index, only the
* index at the specified location will be changed. Collision information will be recalculated
* within the region tiles were changed.
2018-03-20 11:36:35 +00:00
*
2018-02-08 01:08:59 +00:00
* @method Phaser.Tilemaps.DynamicTilemapLayer#putTilesAt
* @since 3.0.0
2018-03-20 11:36:35 +00:00
*
2018-09-28 13:46:31 +00:00
* @param {(integer[]|integer[][]|Phaser.Tilemaps.Tile[]|Phaser.Tilemaps.Tile[][])} tile - A row (array) or grid (2D array) of Tiles or tile indexes to place.
* @param {integer} tileX - The x coordinate, in tiles, not pixels.
* @param {integer} tileY - The y coordinate, in tiles, not pixels.
* @param {boolean} [recalculateFaces=true] - `true` if the faces data should be recalculated.
*
2018-02-08 01:08:59 +00:00
* @return {Phaser.Tilemaps.DynamicTilemapLayer} This Tilemap Layer object.
*/
putTilesAt: function (tilesArray, tileX, tileY, recalculateFaces)
{
TilemapComponents.PutTilesAt(tilesArray, tileX, tileY, recalculateFaces, this.layer, this.tilemap.orientation);
2018-02-08 01:08:59 +00:00
return this;
},
/**
2018-02-08 02:02:37 +00:00
* Randomizes the indexes of a rectangular region of tiles (in tile coordinates) within the
* specified layer. Each tile will receive a new index. If an array of indexes is passed in, then
* those will be used for randomly assigning new tile indexes. If an array is not provided, the
* indexes found within the region (excluding -1) will be used for randomly assigning new tile
* indexes. This method only modifies tile indexes and does not change collision information.
2018-03-20 11:36:35 +00:00
*
2018-02-08 01:08:59 +00:00
* @method Phaser.Tilemaps.DynamicTilemapLayer#randomize
* @since 3.0.0
2018-03-20 11:36:35 +00:00
*
2018-09-28 13:46:31 +00:00
* @param {integer} [tileX=0] - The left most tile index (in tile coordinates) to use as the origin of the area.
* @param {integer} [tileY=0] - The top most tile index (in tile coordinates) to use as the origin of the area.
* @param {integer} [width=max width based on tileX] - How many tiles wide from the `tileX` index the area will be.
* @param {integer} [height=max height based on tileY] - How many tiles tall from the `tileY` index the area will be.
2018-02-08 02:02:37 +00:00
* @param {integer[]} [indexes] - An array of indexes to randomly draw from during randomization.
*
2018-02-08 01:08:59 +00:00
* @return {Phaser.Tilemaps.DynamicTilemapLayer} This Tilemap Layer object.
*/
randomize: function (tileX, tileY, width, height, indexes)
{
TilemapComponents.Randomize(tileX, tileY, width, height, indexes, this.layer);
2018-02-08 01:08:59 +00:00
return this;
},
/**
2018-02-08 02:02:37 +00:00
* Removes the tile at the given tile coordinates in the specified layer and updates the layer's
* collision information.
2018-03-20 11:36:35 +00:00
*
2018-02-08 01:08:59 +00:00
* @method Phaser.Tilemaps.DynamicTilemapLayer#removeTileAt
* @since 3.0.0
2018-03-20 11:36:35 +00:00
*
2018-09-28 13:46:31 +00:00
* @param {integer} tileX - The x coordinate, in tiles, not pixels.
* @param {integer} tileY - The y coordinate, in tiles, not pixels.
* @param {boolean} [replaceWithNull=true] - If true, this will replace the tile at the specified location with null instead of a Tile with an index of -1.
* @param {boolean} [recalculateFaces=true] - `true` if the faces data should be recalculated.
*
2018-02-08 01:08:59 +00:00
* @return {Phaser.Tilemaps.Tile} A Tile object.
*/
removeTileAt: function (tileX, tileY, replaceWithNull, recalculateFaces)
2017-11-16 19:09:07 +00:00
{
return TilemapComponents.RemoveTileAt(tileX, tileY, replaceWithNull, recalculateFaces, this.layer);
2017-11-16 19:09:07 +00:00
},
/**
2018-02-08 02:02:37 +00:00
* Removes the tile at the given world coordinates in the specified layer and updates the layer's
* collision information.
2018-03-20 11:36:35 +00:00
*
2018-02-08 01:08:59 +00:00
* @method Phaser.Tilemaps.DynamicTilemapLayer#removeTileAtWorldXY
* @since 3.0.0
2018-03-20 11:36:35 +00:00
*
2018-09-28 13:46:31 +00:00
* @param {number} worldX - The x coordinate, in pixels.
* @param {number} worldY - The y coordinate, in pixels.
* @param {boolean} [replaceWithNull=true] - If true, this will replace the tile at the specified location with null instead of a Tile with an index of -1.
* @param {boolean} [recalculateFaces=true] - `true` if the faces data should be recalculated.
* @param {Phaser.Cameras.Scene2D.Camera} [camera=main camera] - The Camera to use when calculating the tile index from the world values.
*
2018-02-08 01:08:59 +00:00
* @return {Phaser.Tilemaps.Tile} A Tile object.
*/
removeTileAtWorldXY: function (worldX, worldY, replaceWithNull, recalculateFaces, camera)
{
return TilemapComponents.RemoveTileAtWorldXY(worldX, worldY, replaceWithNull, recalculateFaces, camera, this.layer, this.tilemap.orientation);
},
/**
2018-02-08 02:02:37 +00:00
* Draws a debug representation of the layer to the given Graphics. This is helpful when you want to
* get a quick idea of which of your tiles are colliding and which have interesting faces. The tiles
* are drawn starting at (0, 0) in the Graphics, allowing you to place the debug representation
* wherever you want on the screen.
2018-03-20 11:36:35 +00:00
*
2018-02-08 01:08:59 +00:00
* @method Phaser.Tilemaps.DynamicTilemapLayer#renderDebug
* @since 3.0.0
2018-03-20 11:36:35 +00:00
*
2018-02-08 02:02:37 +00:00
* @param {Phaser.GameObjects.Graphics} graphics - The target Graphics object to draw upon.
2019-05-09 11:39:19 +00:00
* @param {Phaser.Types.Tilemaps.StyleConfig} styleConfig - An object specifying the colors to use for the debug drawing.
*
2018-02-08 01:08:59 +00:00
* @return {Phaser.Tilemaps.DynamicTilemapLayer} This Tilemap Layer object.
*/
renderDebug: function (graphics, styleConfig)
{
TilemapComponents.RenderDebug(graphics, styleConfig, this.layer);
2018-02-08 01:08:59 +00:00
return this;
},
/**
2018-02-08 02:02:37 +00:00
* Scans the given rectangular area (given in tile coordinates) for tiles with an index matching
* `findIndex` and updates their index to match `newIndex`. This only modifies the index and does
* not change collision information.
2018-03-20 11:36:35 +00:00
*
2018-02-08 01:08:59 +00:00
* @method Phaser.Tilemaps.DynamicTilemapLayer#replaceByIndex
* @since 3.0.0
2018-03-20 11:36:35 +00:00
*
2018-09-28 13:46:31 +00:00
* @param {integer} findIndex - The index of the tile to search for.
* @param {integer} newIndex - The index of the tile to replace it with.
* @param {integer} [tileX=0] - The left most tile index (in tile coordinates) to use as the origin of the area.
* @param {integer} [tileY=0] - The top most tile index (in tile coordinates) to use as the origin of the area.
* @param {integer} [width=max width based on tileX] - How many tiles wide from the `tileX` index the area will be.
* @param {integer} [height=max height based on tileY] - How many tiles tall from the `tileY` index the area will be.
*
2018-02-08 01:08:59 +00:00
* @return {Phaser.Tilemaps.DynamicTilemapLayer} This Tilemap Layer object.
*/
replaceByIndex: function (findIndex, newIndex, tileX, tileY, width, height)
{
TilemapComponents.ReplaceByIndex(findIndex, newIndex, tileX, tileY, width, height, this.layer);
2018-02-08 01:08:59 +00:00
return this;
},
/**
* You can control if the Cameras should cull tiles before rendering them or not.
* By default the camera will try to cull the tiles in this layer, to avoid over-drawing to the renderer.
*
* However, there are some instances when you may wish to disable this.
*
* @method Phaser.Tilemaps.DynamicTilemapLayer#setSkipCull
* @since 3.11.0
*
* @param {boolean} [value=true] - Set to `true` to stop culling tiles. Set to `false` to enable culling again.
*
* @return {this} This Tilemap Layer object.
*/
setSkipCull: function (value)
{
if (value === undefined) { value = true; }
this.skipCull = value;
return this;
},
2018-07-12 15:44:36 +00:00
/**
* When a Camera culls the tiles in this layer it does so using its view into the world, building up a
2018-07-12 15:44:36 +00:00
* rectangle inside which the tiles must exist or they will be culled. Sometimes you may need to expand the size
* of this 'cull rectangle', especially if you plan on rotating the Camera viewing the layer. Do so
* by providing the padding values. The values given are in tiles, not pixels. So if the tile width was 32px
* and you set `paddingX` to be 4, it would add 32px x 4 to the cull rectangle (adjusted for scale)
*
2018-07-12 15:44:36 +00:00
* @method Phaser.Tilemaps.DynamicTilemapLayer#setCullPadding
* @since 3.11.0
*
2018-08-02 21:14:32 +00:00
* @param {integer} [paddingX=1] - The amount of extra horizontal tiles to add to the cull check padding.
* @param {integer} [paddingY=1] - The amount of extra vertical tiles to add to the cull check padding.
2018-07-12 15:44:36 +00:00
*
* @return {this} This Tilemap Layer object.
*/
setCullPadding: function (paddingX, paddingY)
{
if (paddingX === undefined) { paddingX = 1; }
if (paddingY === undefined) { paddingY = 1; }
this.cullPaddingX = paddingX;
this.cullPaddingY = paddingY;
2018-07-12 15:44:36 +00:00
return this;
},
/**
2018-02-08 02:02:37 +00:00
* Sets collision on the given tile or tiles within a layer by index. You can pass in either a
* single numeric index or an array of indexes: [2, 3, 15, 20]. The `collides` parameter controls if
* collision will be enabled (true) or disabled (false).
2018-03-20 11:36:35 +00:00
*
* If no layer specified, the map's current layer is used.
*
2019-10-11 17:29:55 +00:00
* @method Phaser.Tilemaps.DynamicTilemapLayer#setCollision
2018-02-08 01:08:59 +00:00
* @since 3.0.0
2018-03-20 11:36:35 +00:00
*
2018-03-20 15:11:33 +00:00
* @param {(integer|array)} indexes - Either a single tile index, or an array of tile indexes.
2018-11-20 12:45:47 +00:00
* @param {boolean} [collides=true] - If true it will enable collision. If false it will clear collision.
* @param {boolean} [recalculateFaces=true] - Whether or not to recalculate the tile faces after the update.
* @param {boolean} [updateLayer=true] - If true, updates the current tiles on the layer. Set to
* false if no tiles have been placed for significant performance boost.
*
* @return {?Phaser.Tilemaps.Tilemap} Return this Tilemap object, or null if the layer given was invalid.
*/
setCollision: function (indexes, collides, recalculateFaces, updateLayer)
{
TilemapComponents.SetCollision(indexes, collides, recalculateFaces, this.layer, updateLayer);
2018-02-08 01:08:59 +00:00
return this;
},
/**
2018-02-08 02:02:37 +00:00
* Sets collision on a range of tiles in a layer whose index is between the specified `start` and
* `stop` (inclusive). Calling this with a start value of 10 and a stop value of 14 would set
* collision for tiles 10, 11, 12, 13 and 14. The `collides` parameter controls if collision will be
* enabled (true) or disabled (false).
2018-03-20 11:36:35 +00:00
*
2018-02-08 01:08:59 +00:00
* @method Phaser.Tilemaps.DynamicTilemapLayer#setCollisionBetween
* @since 3.0.0
2018-03-20 11:36:35 +00:00
*
2018-02-08 02:02:37 +00:00
* @param {integer} start - The first index of the tile to be set for collision.
* @param {integer} stop - The last index of the tile to be set for collision.
2018-11-20 12:45:47 +00:00
* @param {boolean} [collides=true] - If true it will enable collision. If false it will clear collision.
* @param {boolean} [recalculateFaces=true] - Whether or not to recalculate the tile faces after the update.
*
2018-02-08 01:08:59 +00:00
* @return {Phaser.Tilemaps.DynamicTilemapLayer} This Tilemap Layer object.
*/
setCollisionBetween: function (start, stop, collides, recalculateFaces)
{
TilemapComponents.SetCollisionBetween(start, stop, collides, recalculateFaces, this.layer);
2018-02-08 01:08:59 +00:00
return this;
},
/**
2018-02-08 02:02:37 +00:00
* Sets collision on the tiles within a layer by checking tile properties. If a tile has a property
* that matches the given properties object, its collision flag will be set. The `collides`
* parameter controls if collision will be enabled (true) or disabled (false). Passing in
* `{ collides: true }` would update the collision flag on any tiles with a "collides" property that
* has a value of true. Any tile that doesn't have "collides" set to true will be ignored. You can
* also use an array of values, e.g. `{ types: ["stone", "lava", "sand" ] }`. If a tile has a
* "types" property that matches any of those values, its collision flag will be updated.
2018-03-20 11:36:35 +00:00
*
2018-02-08 01:08:59 +00:00
* @method Phaser.Tilemaps.DynamicTilemapLayer#setCollisionByProperty
* @since 3.0.0
*
2018-11-20 12:45:47 +00:00
* @param {object} properties - An object with tile properties and corresponding values that should be checked.
* @param {boolean} [collides=true] - If true it will enable collision. If false it will clear collision.
* @param {boolean} [recalculateFaces=true] - Whether or not to recalculate the tile faces after the update.
2018-03-20 11:36:35 +00:00
*
2018-02-08 01:08:59 +00:00
* @return {Phaser.Tilemaps.DynamicTilemapLayer} This Tilemap Layer object.
*/
setCollisionByProperty: function (properties, collides, recalculateFaces)
{
TilemapComponents.SetCollisionByProperty(properties, collides, recalculateFaces, this.layer);
2018-02-08 01:08:59 +00:00
return this;
},
/**
2018-02-08 02:02:37 +00:00
* Sets collision on all tiles in the given layer, except for tiles that have an index specified in
* the given array. The `collides` parameter controls if collision will be enabled (true) or
* disabled (false).
2018-03-20 11:36:35 +00:00
*
2018-02-08 01:08:59 +00:00
* @method Phaser.Tilemaps.DynamicTilemapLayer#setCollisionByExclusion
* @since 3.0.0
2018-03-20 11:36:35 +00:00
*
2018-02-08 02:02:37 +00:00
* @param {integer[]} indexes - An array of the tile indexes to not be counted for collision.
2018-11-20 12:45:47 +00:00
* @param {boolean} [collides=true] - If true it will enable collision. If false it will clear collision.
* @param {boolean} [recalculateFaces=true] - Whether or not to recalculate the tile faces after the update.
*
2018-02-08 01:08:59 +00:00
* @return {Phaser.Tilemaps.DynamicTilemapLayer} This Tilemap Layer object.
*/
setCollisionByExclusion: function (indexes, collides, recalculateFaces)
{
TilemapComponents.SetCollisionByExclusion(indexes, collides, recalculateFaces, this.layer);
2018-02-08 01:08:59 +00:00
return this;
},
/**
2018-02-08 02:02:37 +00:00
* Sets collision on the tiles within a layer by checking each tiles collision group data
* (typically defined in Tiled within the tileset collision editor). If any objects are found within
* a tiles collision group, the tile's colliding information will be set. The `collides` parameter
* controls if collision will be enabled (true) or disabled (false).
2018-03-20 11:36:35 +00:00
*
2018-02-08 01:08:59 +00:00
* @method Phaser.Tilemaps.DynamicTilemapLayer#setCollisionFromCollisionGroup
* @since 3.0.0
2018-03-20 11:36:35 +00:00
*
2018-11-20 12:45:47 +00:00
* @param {boolean} [collides=true] - If true it will enable collision. If false it will clear collision.
* @param {boolean} [recalculateFaces=true] - Whether or not to recalculate the tile faces after the update.
*
2018-02-08 01:08:59 +00:00
* @return {Phaser.Tilemaps.DynamicTilemapLayer} This Tilemap Layer object.
*/
setCollisionFromCollisionGroup: function (collides, recalculateFaces)
{
TilemapComponents.SetCollisionFromCollisionGroup(collides, recalculateFaces, this.layer);
2018-02-08 01:08:59 +00:00
return this;
},
/**
2018-02-08 02:02:37 +00:00
* Sets a global collision callback for the given tile index within the layer. This will affect all
* tiles on this layer that have the same index. If a callback is already set for the tile index it
* will be replaced. Set the callback to null to remove it. If you want to set a callback for a tile
* at a specific location on the map then see setTileLocationCallback.
2018-03-20 11:36:35 +00:00
*
2018-02-08 01:08:59 +00:00
* @method Phaser.Tilemaps.DynamicTilemapLayer#setTileIndexCallback
* @since 3.0.0
2018-03-20 11:36:35 +00:00
*
2019-01-31 12:19:01 +00:00
* @param {(integer|integer[])} indexes - Either a single tile index, or an array of tile indexes to have a collision callback set for.
2018-02-08 02:02:37 +00:00
* @param {function} callback - The callback that will be invoked when the tile is collided with.
* @param {object} callbackContext - The context under which the callback is called.
*
2018-02-08 01:08:59 +00:00
* @return {Phaser.Tilemaps.DynamicTilemapLayer} This Tilemap Layer object.
*/
2017-11-29 13:53:04 +00:00
setTileIndexCallback: function (indexes, callback, callbackContext)
{
TilemapComponents.SetTileIndexCallback(indexes, callback, callbackContext, this.layer);
2018-02-08 01:08:59 +00:00
2017-11-29 13:53:04 +00:00
return this;
},
/**
2018-02-08 02:02:37 +00:00
* Sets a collision callback for the given rectangular area (in tile coordinates) within the layer.
* If a callback is already set for the tile index it will be replaced. Set the callback to null to
* remove it.
2018-03-20 11:36:35 +00:00
*
2018-02-08 01:08:59 +00:00
* @method Phaser.Tilemaps.DynamicTilemapLayer#setTileLocationCallback
* @since 3.0.0
2018-03-20 11:36:35 +00:00
*
2018-09-28 13:46:31 +00:00
* @param {integer} [tileX=0] - The left most tile index (in tile coordinates) to use as the origin of the area.
* @param {integer} [tileY=0] - The top most tile index (in tile coordinates) to use as the origin of the area.
* @param {integer} [width=max width based on tileX] - How many tiles wide from the `tileX` index the area will be.
* @param {integer} [height=max height based on tileY] - How many tiles tall from the `tileY` index the area will be.
2019-01-31 12:19:01 +00:00
* @param {function} [callback] - The callback that will be invoked when the tile is collided with.
2018-04-16 15:02:27 +00:00
* @param {object} [callbackContext] - The context under which the callback is called.
*
2018-02-08 01:08:59 +00:00
* @return {Phaser.Tilemaps.DynamicTilemapLayer} This Tilemap Layer object.
*/
2017-11-29 14:20:24 +00:00
setTileLocationCallback: function (tileX, tileY, width, height, callback, callbackContext)
{
TilemapComponents.SetTileLocationCallback(tileX, tileY, width, height, callback, callbackContext, this.layer);
2018-02-08 01:08:59 +00:00
2017-11-29 14:20:24 +00:00
return this;
},
/**
2018-02-08 02:02:37 +00:00
* Shuffles the tiles in a rectangular region (specified in tile coordinates) within the given
* layer. It will only randomize the tiles in that area, so if they're all the same nothing will
* appear to have changed! This method only modifies tile indexes and does not change collision
* information.
2018-03-20 11:36:35 +00:00
*
2018-02-08 01:08:59 +00:00
* @method Phaser.Tilemaps.DynamicTilemapLayer#shuffle
* @since 3.0.0
2018-03-20 11:36:35 +00:00
*
2018-09-28 13:46:31 +00:00
* @param {integer} [tileX=0] - The left most tile index (in tile coordinates) to use as the origin of the area.
* @param {integer} [tileY=0] - The top most tile index (in tile coordinates) to use as the origin of the area.
* @param {integer} [width=max width based on tileX] - How many tiles wide from the `tileX` index the area will be.
* @param {integer} [height=max height based on tileY] - How many tiles tall from the `tileY` index the area will be.
*
2018-02-08 01:08:59 +00:00
* @return {Phaser.Tilemaps.DynamicTilemapLayer} This Tilemap Layer object.
*/
shuffle: function (tileX, tileY, width, height)
{
TilemapComponents.Shuffle(tileX, tileY, width, height, this.layer);
2018-02-08 01:08:59 +00:00
return this;
},
2017-06-22 02:19:03 +00:00
/**
2018-02-08 02:02:37 +00:00
* Scans the given rectangular area (given in tile coordinates) for tiles with an index matching
* `indexA` and swaps then with `indexB`. This only modifies the index and does not change collision
* information.
2018-03-20 11:36:35 +00:00
*
2018-02-08 01:08:59 +00:00
* @method Phaser.Tilemaps.DynamicTilemapLayer#swapByIndex
* @since 3.0.0
2018-03-20 11:36:35 +00:00
*
2018-02-08 02:02:37 +00:00
* @param {integer} tileA - First tile index.
* @param {integer} tileB - Second tile index.
2018-09-28 13:46:31 +00:00
* @param {integer} [tileX=0] - The left most tile index (in tile coordinates) to use as the origin of the area.
* @param {integer} [tileY=0] - The top most tile index (in tile coordinates) to use as the origin of the area.
* @param {integer} [width=max width based on tileX] - How many tiles wide from the `tileX` index the area will be.
* @param {integer} [height=max height based on tileY] - How many tiles tall from the `tileY` index the area will be.
*
2018-02-08 01:08:59 +00:00
* @return {Phaser.Tilemaps.DynamicTilemapLayer} This Tilemap Layer object.
*/
swapByIndex: function (indexA, indexB, tileX, tileY, width, height)
{
TilemapComponents.SwapByIndex(indexA, indexB, tileX, tileY, width, height, this.layer);
2018-02-08 01:08:59 +00:00
return this;
},
/**
2018-02-08 02:02:37 +00:00
* Converts from tile X coordinates (tile units) to world X coordinates (pixels), factoring in the
* layers position, scale and scroll.
2018-03-20 11:36:35 +00:00
*
2018-02-08 01:08:59 +00:00
* @method Phaser.Tilemaps.DynamicTilemapLayer#tileToWorldX
* @since 3.0.0
2018-03-20 11:36:35 +00:00
*
2018-09-28 13:46:31 +00:00
* @param {integer} tileX - The x coordinate, in tiles, not pixels.
* @param {Phaser.Cameras.Scene2D.Camera} [camera=main camera] - The Camera to use when calculating the tile index from the world values.
*
* @return {number}
*/
tileToWorldX: function (tileX, camera)
{
2020-01-17 15:15:59 +00:00
return TilemapComponents.TileToWorldX(tileX, camera, this.layer, this.tilemap.orientation);
},
/**
2018-02-08 02:02:37 +00:00
* Converts from tile Y coordinates (tile units) to world Y coordinates (pixels), factoring in the
* layers position, scale and scroll.
2018-03-20 11:36:35 +00:00
*
2018-02-08 01:08:59 +00:00
* @method Phaser.Tilemaps.DynamicTilemapLayer#tileToWorldY
* @since 3.0.0
2018-03-20 11:36:35 +00:00
*
2018-09-28 13:46:31 +00:00
* @param {integer} tileY - The y coordinate, in tiles, not pixels.
* @param {Phaser.Cameras.Scene2D.Camera} [camera=main camera] - The Camera to use when calculating the tile index from the world values.
*
* @return {number}
*/
tileToWorldY: function (tileY, camera)
{
2020-01-17 15:15:59 +00:00
return TilemapComponents.TileToWorldY(tileY, camera, this.layer, this.tilemap.orientation);
},
/**
2018-02-08 02:02:37 +00:00
* Converts from tile XY coordinates (tile units) to world XY coordinates (pixels), factoring in the
* layers position, scale and scroll. This will return a new Vector2 object or update the given
* `point` object.
2018-03-20 11:36:35 +00:00
*
2018-02-08 01:08:59 +00:00
* @method Phaser.Tilemaps.DynamicTilemapLayer#tileToWorldXY
* @since 3.0.0
2018-03-20 11:36:35 +00:00
*
2018-09-28 13:46:31 +00:00
* @param {integer} tileX - The x coordinate, in tiles, not pixels.
* @param {integer} tileY - The y coordinate, in tiles, not pixels.
* @param {Phaser.Math.Vector2} [point] - A Vector2 to store the coordinates in. If not given a new Vector2 is created.
* @param {Phaser.Cameras.Scene2D.Camera} [camera=main camera] - The Camera to use when calculating the tile index from the world values.
*
2018-02-08 01:08:59 +00:00
* @return {Phaser.Math.Vector2}
*/
tileToWorldXY: function (tileX, tileY, point, camera)
{
2020-01-17 15:15:59 +00:00
return TilemapComponents.TileToWorldXY(tileX, tileY, point, camera, this.layer, this.tilemap.orientation);
},
2017-12-03 14:56:12 +00:00
/**
2018-02-08 02:02:37 +00:00
* Randomizes the indexes of a rectangular region of tiles (in tile coordinates) within the
2019-10-29 06:33:06 +00:00
* specified layer. Each tile will receive a new index. New indexes are drawn from the given
2018-02-08 02:02:37 +00:00
* weightedIndexes array. An example weighted array:
*
* [
* { index: 6, weight: 4 }, // Probability of index 6 is 4 / 8
* { index: 7, weight: 2 }, // Probability of index 7 would be 2 / 8
* { index: 8, weight: 1.5 }, // Probability of index 8 would be 1.5 / 8
* { index: 26, weight: 0.5 } // Probability of index 27 would be 0.5 / 8
* ]
*
* The probability of any index being choose is (the index's weight) / (sum of all weights). This
* method only modifies tile indexes and does not change collision information.
2018-03-20 11:36:35 +00:00
*
2018-02-08 01:08:59 +00:00
* @method Phaser.Tilemaps.DynamicTilemapLayer#weightedRandomize
* @since 3.0.0
2018-03-20 11:36:35 +00:00
*
2018-09-28 13:46:31 +00:00
* @param {integer} [tileX=0] - The left most tile index (in tile coordinates) to use as the origin of the area.
* @param {integer} [tileY=0] - The top most tile index (in tile coordinates) to use as the origin of the area.
* @param {integer} [width=max width based on tileX] - How many tiles wide from the `tileX` index the area will be.
* @param {integer} [height=max height based on tileY] - How many tiles tall from the `tileY` index the area will be.
2018-02-08 02:02:37 +00:00
* @param {object[]} [weightedIndexes] - An array of objects to randomly draw from during
* randomization. They should be in the form: { index: 0, weight: 4 } or
* { index: [0, 1], weight: 4 } if you wish to draw from multiple tile indexes.
2017-12-03 14:56:12 +00:00
*
2018-02-08 01:08:59 +00:00
* @return {Phaser.Tilemaps.DynamicTilemapLayer} This Tilemap Layer object.
2017-12-03 14:56:12 +00:00
*/
weightedRandomize: function (tileX, tileY, width, height, weightedIndexes)
{
TilemapComponents.WeightedRandomize(tileX, tileY, width, height, weightedIndexes, this.layer);
2018-02-08 01:08:59 +00:00
2017-12-03 14:56:12 +00:00
return this;
},
/**
2018-02-08 02:02:37 +00:00
* Converts from world X coordinates (pixels) to tile X coordinates (tile units), factoring in the
* layers position, scale and scroll.
2018-03-20 11:36:35 +00:00
*
2018-02-08 01:08:59 +00:00
* @method Phaser.Tilemaps.DynamicTilemapLayer#worldToTileX
* @since 3.0.0
2018-03-20 11:36:35 +00:00
*
2018-09-28 13:46:31 +00:00
* @param {number} worldX - The x coordinate to be converted, in pixels, not tiles.
* @param {boolean} [snapToFloor=true] - Whether or not to round the tile coordinate down to the nearest integer.
* @param {Phaser.Cameras.Scene2D.Camera} [camera=main camera] - The Camera to use when calculating the tile index from the world values.
*
* @return {number}
*/
worldToTileX: function (worldX, snapToFloor, camera)
{
2020-01-17 15:15:59 +00:00
return TilemapComponents.WorldToTileX(worldX, snapToFloor, camera, this.layer, this.tilemap.orientation);
},
/**
2018-02-08 02:02:37 +00:00
* Converts from world Y coordinates (pixels) to tile Y coordinates (tile units), factoring in the
* layers position, scale and scroll.
2018-03-20 11:36:35 +00:00
*
2018-04-16 15:02:27 +00:00
* @method Phaser.Tilemaps.DynamicTilemapLayer#worldToTileY
2018-02-08 01:08:59 +00:00
* @since 3.0.0
2018-03-20 11:36:35 +00:00
*
2018-09-28 13:46:31 +00:00
* @param {number} worldY - The y coordinate to be converted, in pixels, not tiles.
* @param {boolean} [snapToFloor=true] - Whether or not to round the tile coordinate down to the nearest integer.
* @param {Phaser.Cameras.Scene2D.Camera} [camera=main camera] - The Camera to use when calculating the tile index from the world values.
*
* @return {number}
*/
worldToTileY: function (worldY, snapToFloor, camera)
{
2020-01-17 15:15:59 +00:00
return TilemapComponents.WorldToTileY(worldY, snapToFloor, camera, this.layer, this.tilemap.orientation);
},
/**
2018-02-08 02:02:37 +00:00
* Converts from world XY coordinates (pixels) to tile XY coordinates (tile units), factoring in the
* layers position, scale and scroll. This will return a new Vector2 object or update the given
* `point` object.
2018-03-20 11:36:35 +00:00
*
2018-02-08 01:08:59 +00:00
* @method Phaser.Tilemaps.DynamicTilemapLayer#worldToTileXY
* @since 3.0.0
2018-03-20 11:36:35 +00:00
*
2018-09-28 13:46:31 +00:00
* @param {number} worldX - The x coordinate to be converted, in pixels, not tiles.
* @param {number} worldY - The y coordinate to be converted, in pixels, not tiles.
* @param {boolean} [snapToFloor=true] - Whether or not to round the tile coordinate down to the nearest integer.
* @param {Phaser.Math.Vector2} [point] - A Vector2 to store the coordinates in. If not given a new Vector2 is created.
* @param {Phaser.Cameras.Scene2D.Camera} [camera=main camera] - The Camera to use when calculating the tile index from the world values.
*
2018-02-08 01:08:59 +00:00
* @return {Phaser.Math.Vector2}
*/
worldToTileXY: function (worldX, worldY, snapToFloor, point, camera)
{
2020-01-17 15:15:59 +00:00
return TilemapComponents.WorldToTileXY(worldX, worldY, snapToFloor, point, camera, this.layer, this.tilemap.orientation);
}
2017-06-09 04:00:12 +00:00
});
module.exports = DynamicTilemapLayer;