2018-02-12 16:01:20 +00:00
|
|
|
/**
|
2024-02-19 17:12:18 +00:00
|
|
|
* @author Richard Davey <rich@phaser.io>
|
|
|
|
* @copyright 2013-2024 Phaser Studio Inc.
|
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
|
|
|
*/
|
|
|
|
|
2017-11-26 15:33:19 +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-02-08 01:08:59 +00:00
|
|
|
* @function Phaser.Tilemaps.Components.FindByIndex
|
|
|
|
* @since 3.0.0
|
|
|
|
*
|
2020-11-23 10:22:13 +00:00
|
|
|
* @param {number} index - The tile index value to search for.
|
2020-11-23 10:48:24 +00:00
|
|
|
* @param {number} skip - The number of times to skip a matching tile before returning.
|
|
|
|
* @param {boolean} reverse - If true it will scan the layer in reverse, starting at the bottom-right. Otherwise it scans from the top-left.
|
2018-02-08 02:02:37 +00:00
|
|
|
* @param {Phaser.Tilemaps.LayerData} layer - The Tilemap Layer to act upon.
|
2018-03-20 11:36:35 +00:00
|
|
|
*
|
|
|
|
* @return {?Phaser.Tilemaps.Tile} The first (or n skipped) tile with the matching index.
|
2017-11-26 15:33:19 +00:00
|
|
|
*/
|
2017-11-17 01:08:58 +00:00
|
|
|
var FindByIndex = function (findIndex, skip, reverse, layer)
|
|
|
|
{
|
|
|
|
if (skip === undefined) { skip = 0; }
|
|
|
|
if (reverse === undefined) { reverse = false; }
|
|
|
|
|
|
|
|
var count = 0;
|
|
|
|
var tx;
|
|
|
|
var ty;
|
|
|
|
var tile;
|
|
|
|
|
|
|
|
if (reverse)
|
|
|
|
{
|
|
|
|
for (ty = layer.height - 1; ty >= 0; ty--)
|
|
|
|
{
|
|
|
|
for (tx = layer.width - 1; tx >= 0; tx--)
|
|
|
|
{
|
|
|
|
tile = layer.data[ty][tx];
|
|
|
|
if (tile && tile.index === findIndex)
|
|
|
|
{
|
|
|
|
if (count === skip)
|
|
|
|
{
|
|
|
|
return tile;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
count += 1;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
for (ty = 0; ty < layer.height; ty++)
|
|
|
|
{
|
|
|
|
for (tx = 0; tx < layer.width; tx++)
|
|
|
|
{
|
|
|
|
tile = layer.data[ty][tx];
|
|
|
|
if (tile && tile.index === findIndex)
|
|
|
|
{
|
|
|
|
if (count === skip)
|
|
|
|
{
|
|
|
|
return tile;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
count += 1;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return null;
|
|
|
|
};
|
|
|
|
|
|
|
|
module.exports = FindByIndex;
|