2017-11-11 16:38:52 +00:00
|
|
|
var Class = require('../../utils/Class');
|
2017-11-16 17:44:24 +00:00
|
|
|
var GenerateEmptyMapData = require('./emptymap/GenerateEmptyMapData');
|
|
|
|
var GenerateEmptyMapLayer = require('./emptymap/GenerateEmptyMapLayer');
|
2017-11-11 16:38:52 +00:00
|
|
|
var StaticTilemapLayer = require('./staticlayer/StaticTilemapLayer.js');
|
|
|
|
var DynamicTilemapLayer = require('./dynamiclayer/DynamicTilemapLayer.js');
|
|
|
|
var Tileset = require('./Tileset');
|
|
|
|
var Formats = require('./Formats');
|
2017-11-15 19:50:56 +00:00
|
|
|
var TilemapComponents = require('./components');
|
2017-11-16 17:44:24 +00:00
|
|
|
var Tile = require('./Tile');
|
2017-11-11 16:38:52 +00:00
|
|
|
|
|
|
|
var Tilemap = new Class({
|
|
|
|
|
|
|
|
initialize:
|
|
|
|
|
|
|
|
function Tilemap (scene, mapData, tileWidth, tileHeight, width, height)
|
|
|
|
{
|
|
|
|
this.scene = scene;
|
|
|
|
|
|
|
|
if (mapData === null)
|
|
|
|
{
|
|
|
|
mapData = GenerateEmptyMapData(tileWidth, tileHeight, width, height);
|
|
|
|
}
|
|
|
|
|
|
|
|
this.tilesets = [];
|
|
|
|
this.tileWidth = mapData.tileWidth;
|
|
|
|
this.tileHeight = mapData.tileHeight;
|
|
|
|
|
|
|
|
this.width = mapData.width;
|
|
|
|
this.height = mapData.height;
|
|
|
|
this.orientation = mapData.orientation;
|
|
|
|
this.format = mapData.format;
|
|
|
|
this.version = mapData.version;
|
|
|
|
this.properties = mapData.properties;
|
|
|
|
this.widthInPixels = mapData.widthInPixels;
|
|
|
|
this.heightInPixels = mapData.heightInPixels;
|
|
|
|
this.layers = mapData.layers;
|
|
|
|
this.tilesets = mapData.tilesets;
|
|
|
|
this.tiles = mapData.tiles;
|
|
|
|
this.objects = mapData.objects;
|
2017-11-15 21:05:11 +00:00
|
|
|
this.currentLayerIndex = 0;
|
2017-11-11 16:38:52 +00:00
|
|
|
|
|
|
|
// TODO: collision, collideIndexes, imagecollections, images
|
|
|
|
// TODO: debugging methods
|
|
|
|
},
|
|
|
|
|
|
|
|
addTilesetImage: function (tilesetName, key, tileWidth, tileHeight, tileMargin, tileSpacing, gid)
|
|
|
|
{
|
|
|
|
if (tilesetName === undefined) { return null; }
|
|
|
|
if (key === undefined || key === null) { key = tilesetName; }
|
|
|
|
if (tileWidth === undefined) { tileWidth = this.tileWidth; }
|
|
|
|
if (tileHeight === undefined) { tileHeight = this.tileHeight; }
|
|
|
|
if (tileMargin === undefined) { tileMargin = 0; }
|
|
|
|
if (tileSpacing === undefined) { tileSpacing = 0; }
|
|
|
|
if (gid === undefined) { gid = 0; }
|
|
|
|
|
|
|
|
// In-case we're working from a blank map
|
|
|
|
if (tileWidth === 0) { tileWidth = 32; }
|
|
|
|
if (tileHeight === 0) { tileHeight = 32; }
|
|
|
|
|
|
|
|
if (!this.scene.sys.textures.exists(key))
|
|
|
|
{
|
|
|
|
console.warn('Invalid image key given for tileset: "' + key + '"');
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
|
|
|
var texture = this.scene.sys.textures.get(key);
|
|
|
|
|
|
|
|
// TODO: potentially add in v2 support for bitmap data
|
|
|
|
|
|
|
|
var index = this.getTilesetIndex(tilesetName);
|
|
|
|
|
|
|
|
if (index === null && this.format === Formats.TILED_JSON)
|
|
|
|
{
|
|
|
|
console.warn('No data found in the JSON tilemap from Tiled matching the tileset name: "' + tilesetName + '"');
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (this.tilesets[index])
|
|
|
|
{
|
|
|
|
this.tilesets[index].setImage(texture);
|
|
|
|
return this.tilesets[index];
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
var tileset = new Tileset(tilesetName, gid, tileWidth, tileHeight, tileMargin, tileSpacing, {});
|
|
|
|
tileset.setImage(texture);
|
|
|
|
|
|
|
|
this.tilesets.push(tileset);
|
|
|
|
|
|
|
|
// TODO: add in GID & master list of tiles
|
|
|
|
}
|
|
|
|
|
|
|
|
return tileset;
|
|
|
|
},
|
|
|
|
|
2017-11-16 17:44:24 +00:00
|
|
|
// Creates & selects
|
2017-11-17 01:08:58 +00:00
|
|
|
createBlankDynamicLayer: function (name, tileset, x, y, width, height, tileWidth, tileHeight)
|
|
|
|
{
|
2017-11-16 17:44:24 +00:00
|
|
|
if (tileWidth === undefined) { tileWidth = this.tileWidth; }
|
|
|
|
if (tileHeight === undefined) { tileHeight = this.tileHeight; }
|
|
|
|
if (width === undefined) { width = this.width; }
|
|
|
|
if (height === undefined) { height = this.height; }
|
|
|
|
if (x === undefined) { x = 0; }
|
|
|
|
if (y === undefined) { y = 0; }
|
|
|
|
|
|
|
|
var index = this.getLayerIndex(name);
|
|
|
|
|
|
|
|
if (index !== null)
|
|
|
|
{
|
|
|
|
console.warn('Cannot create blank layer: layer with matching name already exists ' + name);
|
2017-11-17 01:08:58 +00:00
|
|
|
return null;
|
2017-11-16 17:44:24 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
var layer = GenerateEmptyMapLayer(name, tileWidth, tileHeight, width, height);
|
|
|
|
|
|
|
|
var row;
|
|
|
|
for (var tileY = 0; tileY < height; tileY++)
|
|
|
|
{
|
|
|
|
row = [];
|
|
|
|
for (var tileX = 0; tileX < width; tileX++)
|
|
|
|
{
|
|
|
|
row.push(new Tile(layer, -1, tileX, tileY, tileWidth, tileHeight));
|
|
|
|
}
|
|
|
|
layer.data.push(row);
|
|
|
|
}
|
|
|
|
|
|
|
|
this.layers.push(layer);
|
|
|
|
this.currentLayerIndex = this.layers.length - 1;
|
|
|
|
|
|
|
|
// TODO: decide about v2 trimming to game width/height
|
|
|
|
|
|
|
|
var dynamicLayer = new DynamicTilemapLayer(this.scene, this, this.currentLayerIndex, tileset, x, y);
|
|
|
|
this.scene.sys.displayList.add(dynamicLayer);
|
|
|
|
return dynamicLayer;
|
|
|
|
},
|
|
|
|
|
|
|
|
// Creates & selects
|
2017-11-11 16:38:52 +00:00
|
|
|
createStaticLayer: function (layerID, tileset, x, y)
|
|
|
|
{
|
2017-11-15 19:50:56 +00:00
|
|
|
var index = this.getLayerIndex(layerID);
|
2017-11-11 16:38:52 +00:00
|
|
|
|
2017-11-15 19:50:56 +00:00
|
|
|
if (index === null)
|
2017-11-11 16:38:52 +00:00
|
|
|
{
|
2017-11-17 01:08:58 +00:00
|
|
|
console.warn('Cannot create tilemap layer: invalid layer ID given: ' + layerID);
|
|
|
|
return null;
|
2017-11-11 16:38:52 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// TODO: new feature, allow multiple CSV layers
|
|
|
|
// TODO: display dimension
|
|
|
|
|
2017-11-16 17:44:24 +00:00
|
|
|
this.currentLayerIndex = index;
|
|
|
|
|
2017-11-11 16:38:52 +00:00
|
|
|
var layer = new StaticTilemapLayer(this.scene, this, index, tileset, x, y);
|
|
|
|
this.scene.sys.displayList.add(layer);
|
|
|
|
return layer;
|
|
|
|
},
|
|
|
|
|
2017-11-16 17:44:24 +00:00
|
|
|
// Creates & selects
|
2017-11-11 16:38:52 +00:00
|
|
|
createDynamicLayer: function (layerID, tileset, x, y)
|
|
|
|
{
|
2017-11-15 19:50:56 +00:00
|
|
|
var index = this.getLayerIndex(layerID);
|
2017-11-11 16:38:52 +00:00
|
|
|
|
2017-11-15 19:50:56 +00:00
|
|
|
if (index === null)
|
2017-11-11 16:38:52 +00:00
|
|
|
{
|
2017-11-17 01:08:58 +00:00
|
|
|
console.warn('Cannot create tilemap layer: invalid layer ID given: ' + layerID);
|
|
|
|
return null;
|
2017-11-11 16:38:52 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// TODO: new feature, allow multiple CSV layers
|
|
|
|
// TODO: display dimension
|
|
|
|
|
2017-11-16 17:44:24 +00:00
|
|
|
this.currentLayerIndex = index;
|
|
|
|
|
2017-11-11 16:38:52 +00:00
|
|
|
var layer = new DynamicTilemapLayer(this.scene, this, index, tileset, x, y);
|
|
|
|
this.scene.sys.displayList.add(layer);
|
|
|
|
return layer;
|
2017-11-15 19:50:56 +00:00
|
|
|
},
|
|
|
|
|
2017-11-16 02:06:07 +00:00
|
|
|
copy: function (srcTileX, srcTileY, width, height, destTileX, destTileY, layer)
|
2017-11-15 22:36:41 +00:00
|
|
|
{
|
|
|
|
layer = this.getLayer(layer);
|
2017-11-16 02:06:07 +00:00
|
|
|
if (layer !== null)
|
|
|
|
{
|
|
|
|
TilemapComponents.Copy(srcTileX, srcTileY, width, height, destTileX, destTileY, layer);
|
|
|
|
}
|
|
|
|
return this;
|
|
|
|
},
|
|
|
|
|
2017-11-17 01:09:28 +00:00
|
|
|
destroy: function ()
|
|
|
|
{
|
|
|
|
this.layers.length = 0;
|
|
|
|
this.tilesets.length = 0;
|
|
|
|
this.tiles.length = 0;
|
|
|
|
this.objects.length = 0;
|
|
|
|
this.scene = undefined;
|
|
|
|
},
|
|
|
|
|
2017-11-16 02:06:07 +00:00
|
|
|
fill: function (index, tileX, tileY, width, height, layer)
|
|
|
|
{
|
|
|
|
layer = this.getLayer(layer);
|
|
|
|
if (layer !== null)
|
|
|
|
{
|
|
|
|
TilemapComponents.Fill(index, tileX, tileY, width, height, layer);
|
|
|
|
}
|
|
|
|
return this;
|
|
|
|
},
|
2017-11-15 22:36:41 +00:00
|
|
|
|
2017-11-17 01:08:58 +00:00
|
|
|
findByIndex: function (findIndex, skip, reverse, layer)
|
|
|
|
{
|
|
|
|
layer = this.getLayer(layer);
|
|
|
|
if (layer === null) { return null; }
|
|
|
|
return TilemapComponents.FindByIndex(findIndex, skip, reverse, layer);
|
|
|
|
},
|
|
|
|
|
2017-11-16 02:06:07 +00:00
|
|
|
forEachTile: function (callback, context, tileX, tileY, width, height, layer)
|
|
|
|
{
|
|
|
|
layer = this.getLayer(layer);
|
|
|
|
if (layer !== null)
|
|
|
|
{
|
|
|
|
TilemapComponents.ForEachTile(callback, context, tileX, tileY, width, height, layer);
|
|
|
|
}
|
|
|
|
return this;
|
2017-11-15 22:36:41 +00:00
|
|
|
},
|
|
|
|
|
2017-11-15 20:55:26 +00:00
|
|
|
getIndex: function (location, name)
|
|
|
|
{
|
|
|
|
for (var i = 0; i < location.length; i++)
|
|
|
|
{
|
|
|
|
if (location[i].name === name)
|
|
|
|
{
|
|
|
|
return i;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return null;
|
|
|
|
},
|
|
|
|
|
|
|
|
getLayer: function (layer)
|
|
|
|
{
|
|
|
|
var index = this.getLayerIndex(layer);
|
|
|
|
return index !== null ? this.layers[index] : null;
|
|
|
|
},
|
|
|
|
|
|
|
|
getLayerIndex: function (layer)
|
|
|
|
{
|
|
|
|
if (layer === undefined)
|
|
|
|
{
|
2017-11-15 21:05:11 +00:00
|
|
|
return this.currentLayerIndex;
|
2017-11-15 20:55:26 +00:00
|
|
|
}
|
|
|
|
else if (typeof layer === 'string')
|
|
|
|
{
|
|
|
|
return this.getLayerIndexByName(layer);
|
|
|
|
}
|
|
|
|
else if (typeof layer === 'number' && layer < this.layers.length)
|
|
|
|
{
|
|
|
|
return layer;
|
|
|
|
}
|
|
|
|
else if (layer instanceof StaticTilemapLayer || layer instanceof DynamicTilemapLayer)
|
|
|
|
{
|
|
|
|
return layer.layerIndex;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
|
|
|
getLayerIndexByName: function (name)
|
|
|
|
{
|
|
|
|
return this.getIndex(this.layers, name);
|
|
|
|
},
|
|
|
|
|
2017-11-16 19:09:07 +00:00
|
|
|
getTileAt: function (tileX, tileY, nonNull, layer)
|
2017-11-15 19:50:56 +00:00
|
|
|
{
|
|
|
|
layer = this.getLayer(layer);
|
|
|
|
if (layer === null) { return null; }
|
2017-11-16 19:09:07 +00:00
|
|
|
return TilemapComponents.GetTileAt(tileX, tileY, nonNull, layer);
|
2017-11-15 20:55:26 +00:00
|
|
|
},
|
|
|
|
|
2017-11-16 19:27:52 +00:00
|
|
|
getTileAtWorldXY: function (worldX, worldY, nonNull, layer)
|
|
|
|
{
|
|
|
|
layer = this.getLayer(layer);
|
|
|
|
if (layer === null) { return null; }
|
|
|
|
return TilemapComponents.GetTileAtWorldXY(worldX, worldY, nonNull, layer);
|
|
|
|
},
|
|
|
|
|
2017-11-15 22:36:41 +00:00
|
|
|
getTilesWithin: function (tileX, tileY, width, height, layer)
|
|
|
|
{
|
|
|
|
layer = this.getLayer(layer);
|
|
|
|
if (layer === null) { return null; }
|
|
|
|
return TilemapComponents.GetTilesWithin(tileX, tileY, width, height, layer);
|
|
|
|
},
|
|
|
|
|
2017-11-15 20:55:26 +00:00
|
|
|
getTilesetIndex: function (name)
|
|
|
|
{
|
|
|
|
return this.getIndex(this.tilesets, name);
|
|
|
|
},
|
|
|
|
|
2017-11-15 21:28:15 +00:00
|
|
|
hasTileAt: function (tileX, tileY, layer)
|
|
|
|
{
|
|
|
|
layer = this.getLayer(layer);
|
|
|
|
if (layer === null) { return null; }
|
|
|
|
return TilemapComponents.HasTileAt(tileX, tileY, layer);
|
|
|
|
},
|
|
|
|
|
2017-11-15 20:55:26 +00:00
|
|
|
layer: {
|
|
|
|
get: function ()
|
|
|
|
{
|
2017-11-15 21:05:11 +00:00
|
|
|
return this.layers[this.currentLayerIndex];
|
2017-11-15 20:55:26 +00:00
|
|
|
},
|
|
|
|
|
|
|
|
set: function (layer)
|
|
|
|
{
|
|
|
|
this.setLayer(layer);
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
2017-11-16 19:09:07 +00:00
|
|
|
putTile: function (tile, tileX, tileY, layer)
|
|
|
|
{
|
|
|
|
layer = this.getLayer(layer);
|
|
|
|
if (layer === null) { return null; }
|
|
|
|
return TilemapComponents.PutTile(tile, tileX, tileY, layer);
|
|
|
|
},
|
|
|
|
|
2017-11-16 02:06:07 +00:00
|
|
|
randomize: function (tileX, tileY, width, height, indices, layer)
|
|
|
|
{
|
|
|
|
layer = this.getLayer(layer);
|
|
|
|
if (layer !== null)
|
|
|
|
{
|
2017-11-16 19:09:07 +00:00
|
|
|
TilemapComponents.Randomize(tileX, tileY, width, height, indices, layer);
|
2017-11-16 02:06:07 +00:00
|
|
|
}
|
|
|
|
return this;
|
|
|
|
},
|
|
|
|
|
2017-11-17 01:09:28 +00:00
|
|
|
removeAllLayers: function ()
|
|
|
|
{
|
|
|
|
this.layers.length = 0;
|
|
|
|
this.currentLayerIndex = 0;
|
|
|
|
return this;
|
|
|
|
},
|
|
|
|
|
2017-11-16 19:09:07 +00:00
|
|
|
removeTile: function (tileX, tileY, replaceWithNull, layer)
|
|
|
|
{
|
|
|
|
layer = this.getLayer(layer);
|
|
|
|
if (layer === null) { return null; }
|
|
|
|
return TilemapComponents.RemoveTile(tileX, tileY, replaceWithNull, layer);
|
|
|
|
},
|
|
|
|
|
2017-11-17 01:08:58 +00:00
|
|
|
replaceByIndex: function (findIndex, newIndex, tileX, tileY, width, height, layer)
|
|
|
|
{
|
|
|
|
layer = this.getLayer(layer);
|
|
|
|
if (layer !== null)
|
|
|
|
{
|
|
|
|
TilemapComponents.ReplaceByIndex(findIndex, newIndex, tileX, tileY, width, height, layer);
|
|
|
|
}
|
|
|
|
return this;
|
|
|
|
},
|
|
|
|
|
2017-11-15 20:55:26 +00:00
|
|
|
setLayer: function (layer)
|
|
|
|
{
|
|
|
|
var index = this.getLayerIndex(layer);
|
|
|
|
if (index !== null)
|
|
|
|
{
|
2017-11-15 21:05:11 +00:00
|
|
|
this.currentLayerIndex = index;
|
2017-11-15 20:55:26 +00:00
|
|
|
}
|
|
|
|
return this;
|
2017-11-16 02:06:07 +00:00
|
|
|
},
|
|
|
|
|
2017-11-17 01:09:28 +00:00
|
|
|
setTileSize: function (tileWidth, tileHeight)
|
|
|
|
{
|
|
|
|
this.tileWidth = tileWidth;
|
|
|
|
this.tileHeight = tileHeight;
|
|
|
|
this.widthInPixels = this.width * tileWidth;
|
|
|
|
this.heightInPixels = this.height * tileHeight;
|
|
|
|
},
|
|
|
|
|
2017-11-16 02:06:07 +00:00
|
|
|
shuffle: function (tileX, tileY, width, height, layer)
|
|
|
|
{
|
|
|
|
layer = this.getLayer(layer);
|
|
|
|
if (layer !== null)
|
|
|
|
{
|
|
|
|
TilemapComponents.Shuffle(tileX, tileY, width, height, layer);
|
|
|
|
}
|
|
|
|
return this;
|
2017-11-17 01:08:58 +00:00
|
|
|
},
|
|
|
|
|
|
|
|
swapByIndex: function (indexA, indexB, tileX, tileY, width, height, layer)
|
|
|
|
{
|
|
|
|
layer = this.getLayer(layer);
|
|
|
|
if (layer !== null)
|
|
|
|
{
|
|
|
|
TilemapComponents.SwapByIndex(indexA, indexB, tileX, tileY, width, height, layer);
|
|
|
|
}
|
|
|
|
return this;
|
2017-11-11 16:38:52 +00:00
|
|
|
}
|
2017-11-15 20:55:26 +00:00
|
|
|
|
2017-11-11 16:38:52 +00:00
|
|
|
});
|
|
|
|
|
|
|
|
module.exports = Tilemap;
|