2018-02-12 16:01:20 +00:00
|
|
|
/**
|
|
|
|
* @author Richard Davey <rich@photonstorm.com>
|
|
|
|
* @copyright 2018 Photon Storm Ltd.
|
|
|
|
* @license {@link https://github.com/photonstorm/phaser/blob/master/license.txt|MIT License}
|
|
|
|
*/
|
|
|
|
|
2018-02-07 17:10:01 +00:00
|
|
|
var GameObjectCreator = require('../gameobjects/GameObjectCreator');
|
2017-11-17 21:55:12 +00:00
|
|
|
var ParseToTilemap = require('./ParseToTilemap');
|
2017-11-11 16:38:52 +00:00
|
|
|
|
2018-04-16 15:37:07 +00:00
|
|
|
/**
|
|
|
|
* @typedef {object} TilemapConfig
|
|
|
|
*
|
|
|
|
* @property {string} [key] - The key in the Phaser cache that corresponds to the loaded tilemap data.
|
|
|
|
* @property {integer[][]} [data] - Instead of loading from the cache, you can also load directly from a 2D array of tile indexes.
|
|
|
|
* @property {integer} [tileWidth=32] - The width of a tile in pixels.
|
|
|
|
* @property {integer} [tileHeight=32] - The height of a tile in pixels.
|
|
|
|
* @property {integer} [width=10] - The width of the map in tiles.
|
|
|
|
* @property {integer} [height=10] - The height of the map in tiles.
|
|
|
|
* @property {boolean} [insertNull=false] - Controls how empty tiles, tiles with an index of -1,
|
|
|
|
* in the map data are handled. If `true`, empty locations will get a value of `null`. If `false`,
|
|
|
|
* empty location will get a Tile object with an index of -1. If you've a large sparsely populated
|
|
|
|
* map and the tile data doesn't need to change then setting this value to `true` will help with
|
|
|
|
* memory consumption. However if your map is small or you need to update the tiles dynamically,
|
|
|
|
* then leave the default value set.
|
|
|
|
*/
|
|
|
|
|
2017-11-29 19:46:29 +00:00
|
|
|
/**
|
2017-11-29 21:07:56 +00:00
|
|
|
* Creates a Tilemap from the given key or data, or creates a blank Tilemap if no key/data provided.
|
|
|
|
* When loading from CSV or a 2D array, you should specify the tileWidth & tileHeight. When parsing
|
|
|
|
* from a map from Tiled, the tileWidth, tileHeight, width & height will be pulled from the map
|
|
|
|
* data. For an empty map, you should specify tileWidth, tileHeight, width & height.
|
2017-11-29 19:46:29 +00:00
|
|
|
*
|
2018-02-07 23:27:01 +00:00
|
|
|
* @method Phaser.GameObjects.GameObjectCreator#tilemap
|
|
|
|
* @since 3.0.0
|
|
|
|
*
|
2018-04-16 15:37:07 +00:00
|
|
|
* @param {TilemapConfig} [config] - The config options for the Tilemap.
|
2018-02-07 23:27:01 +00:00
|
|
|
*
|
|
|
|
* @return {Phaser.Tilemaps.Tilemap}
|
2017-11-29 19:46:29 +00:00
|
|
|
*/
|
2017-11-11 16:38:52 +00:00
|
|
|
GameObjectCreator.register('tilemap', function (config)
|
|
|
|
{
|
2017-11-29 19:46:29 +00:00
|
|
|
// Defaults are applied in ParseToTilemap
|
2018-02-07 23:27:01 +00:00
|
|
|
var c = (config !== undefined) ? config : {};
|
|
|
|
|
|
|
|
return ParseToTilemap(
|
|
|
|
this.scene,
|
|
|
|
c.key,
|
|
|
|
c.tileWidth,
|
|
|
|
c.tileHeight,
|
|
|
|
c.width,
|
|
|
|
c.height,
|
|
|
|
c.data,
|
|
|
|
c.insertNull
|
|
|
|
);
|
2017-11-11 16:38:52 +00:00
|
|
|
});
|