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
|
|
|
*/
|
|
|
|
|
2017-11-29 15:05:53 +00:00
|
|
|
var GetTilesWithin = require('./GetTilesWithin');
|
2018-02-07 17:10:01 +00:00
|
|
|
var Color = require('../../display/color');
|
2017-11-29 15:05:53 +00:00
|
|
|
|
2018-09-26 15:18:44 +00:00
|
|
|
var defaultTileColor = new Color(105, 210, 231, 150);
|
|
|
|
var defaultCollidingTileColor = new Color(243, 134, 48, 200);
|
|
|
|
var defaultFaceColor = new Color(40, 39, 37, 150);
|
|
|
|
|
2017-11-29 15:05:53 +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-02-08 01:08:59 +00:00
|
|
|
* @function Phaser.Tilemaps.Components.RenderDebug
|
|
|
|
* @since 3.0.0
|
|
|
|
*
|
|
|
|
* @param {Phaser.GameObjects.Graphics} graphics - The target Graphics object to draw upon.
|
2020-11-23 10:54:14 +00:00
|
|
|
* @param {Phaser.Types.Tilemaps.DebugStyleOptions} styleConfig - An object specifying the colors to use for the debug drawing.
|
2018-02-08 02:02:37 +00:00
|
|
|
* @param {Phaser.Tilemaps.LayerData} layer - The Tilemap Layer to act upon.
|
2017-11-29 15:05:53 +00:00
|
|
|
*/
|
|
|
|
var RenderDebug = function (graphics, styleConfig, layer)
|
|
|
|
{
|
|
|
|
if (styleConfig === undefined) { styleConfig = {}; }
|
|
|
|
|
|
|
|
// Default colors without needlessly creating Color objects
|
2018-09-26 15:18:44 +00:00
|
|
|
var tileColor = (styleConfig.tileColor !== undefined) ? styleConfig.tileColor : defaultTileColor;
|
|
|
|
var collidingTileColor = (styleConfig.collidingTileColor !== undefined) ? styleConfig.collidingTileColor : defaultCollidingTileColor;
|
|
|
|
var faceColor = (styleConfig.faceColor !== undefined) ? styleConfig.faceColor : defaultFaceColor;
|
2017-11-29 15:05:53 +00:00
|
|
|
|
|
|
|
var tiles = GetTilesWithin(0, 0, layer.width, layer.height, null, layer);
|
|
|
|
|
2019-06-22 06:55:50 +00:00
|
|
|
graphics.translateCanvas(layer.tilemapLayer.x, layer.tilemapLayer.y);
|
|
|
|
graphics.scaleCanvas(layer.tilemapLayer.scaleX, layer.tilemapLayer.scaleY);
|
2018-09-25 14:37:46 +00:00
|
|
|
|
2017-11-29 15:05:53 +00:00
|
|
|
for (var i = 0; i < tiles.length; i++)
|
|
|
|
{
|
|
|
|
var tile = tiles[i];
|
|
|
|
|
|
|
|
var tw = tile.width;
|
|
|
|
var th = tile.height;
|
2017-12-01 15:40:55 +00:00
|
|
|
var x = tile.pixelX;
|
|
|
|
var y = tile.pixelY;
|
2017-11-29 15:05:53 +00:00
|
|
|
|
|
|
|
var color = tile.collides ? collidingTileColor : tileColor;
|
2018-09-25 14:37:46 +00:00
|
|
|
|
2017-11-29 15:05:53 +00:00
|
|
|
if (color !== null)
|
|
|
|
{
|
|
|
|
graphics.fillStyle(color.color, color.alpha / 255);
|
|
|
|
graphics.fillRect(x, y, tw, th);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Inset the face line to prevent neighboring tile's lines from overlapping
|
|
|
|
x += 1;
|
|
|
|
y += 1;
|
|
|
|
tw -= 2;
|
|
|
|
th -= 2;
|
|
|
|
|
|
|
|
if (faceColor !== null)
|
|
|
|
{
|
|
|
|
graphics.lineStyle(1, faceColor.color, faceColor.alpha / 255);
|
2018-09-25 14:37:46 +00:00
|
|
|
|
2017-11-29 15:05:53 +00:00
|
|
|
if (tile.faceTop) { graphics.lineBetween(x, y, x + tw, y); }
|
|
|
|
if (tile.faceRight) { graphics.lineBetween(x + tw, y, x + tw, y + th); }
|
|
|
|
if (tile.faceBottom) { graphics.lineBetween(x, y + th, x + tw, y + th); }
|
|
|
|
if (tile.faceLeft) { graphics.lineBetween(x, y, x, y + th); }
|
|
|
|
}
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
module.exports = RenderDebug;
|