// #module import PlasmaPostFX from './assets/pipelines/PlasmaPostFX.js'; export default class Example extends Phaser.Scene { constructor () { super(); } preload () { this.load.setBaseURL('https://cdn.phaserfiles.com/v385'); this.load.image('tiles', 'assets/tilemaps/tiles/drawtiles-spaced.png'); this.load.image('car', 'assets/sprites/car90.png'); this.load.tilemapCSV('map', 'assets/tilemaps/csv/grid.csv'); } create () { const map = this.make.tilemap({ key: 'map', tileWidth: 32, tileHeight: 32 }); const tileset = map.addTilesetImage('tiles', null, 32, 32, 1, 2); const layer = map.createLayer(0, tileset, 0, 0); layer.setPostPipeline(PlasmaPostFX); const player = this.add.image(32 + 16, 32 + 16, 'car'); // Left this.input.keyboard.on('keydown-A', () => { const tile = layer.getTileAtWorldXY(player.x - 32, player.y, true); if (tile.index === 2) { // Blocked, we can't move } else { player.x -= 32; player.angle = 180; } }); // Right this.input.keyboard.on('keydown-D', () => { const tile = layer.getTileAtWorldXY(player.x + 32, player.y, true); if (tile.index === 2) { // Blocked, we can't move } else { player.x += 32; player.angle = 0; } }); // Up this.input.keyboard.on('keydown-W', () => { const tile = layer.getTileAtWorldXY(player.x, player.y - 32, true); if (tile.index === 2) { // Blocked, we can't move } else { player.y -= 32; player.angle = -90; } }); // Down this.input.keyboard.on('keydown-S', () => { const tile = layer.getTileAtWorldXY(player.x, player.y + 32, true); if (tile.index === 2) { // Blocked, we can't move } else { player.y += 32; player.angle = 90; } }); } } const config = { type: Phaser.WEBGL, width: 800, height: 600, backgroundColor: '#1a1a2d', parent: 'phaser-example', scene: Example, pipeline: { PlasmaPostFX } }; let game = new Phaser.Game(config);
Scan to open on your mobile device
// #module import PlasmaPostFX from './assets/pipelines/PlasmaPostFX.js'; export default class Example extends Phaser.Scene { constructor () { super(); } preload () { this.load.setBaseURL('https://cdn.phaserfiles.com/v385'); this.load.image('tiles', 'assets/tilemaps/tiles/drawtiles-spaced.png'); this.load.image('car', 'assets/sprites/car90.png'); this.load.tilemapCSV('map', 'assets/tilemaps/csv/grid.csv'); } create () { const map = this.make.tilemap({ key: 'map', tileWidth: 32, tileHeight: 32 }); const tileset = map.addTilesetImage('tiles', null, 32, 32, 1, 2); const layer = map.createLayer(0, tileset, 0, 0); layer.setPostPipeline(PlasmaPostFX); const player = this.add.image(32 + 16, 32 + 16, 'car'); // Left this.input.keyboard.on('keydown-A', () => { const tile = layer.getTileAtWorldXY(player.x - 32, player.y, true); if (tile.index === 2) { // Blocked, we can't move } else { player.x -= 32; player.angle = 180; } }); // Right this.input.keyboard.on('keydown-D', () => { const tile = layer.getTileAtWorldXY(player.x + 32, player.y, true); if (tile.index === 2) { // Blocked, we can't move } else { player.x += 32; player.angle = 0; } }); // Up this.input.keyboard.on('keydown-W', () => { const tile = layer.getTileAtWorldXY(player.x, player.y - 32, true); if (tile.index === 2) { // Blocked, we can't move } else { player.y -= 32; player.angle = -90; } }); // Down this.input.keyboard.on('keydown-S', () => { const tile = layer.getTileAtWorldXY(player.x, player.y + 32, true); if (tile.index === 2) { // Blocked, we can't move } else { player.y += 32; player.angle = 90; } }); } } const config = { type: Phaser.WEBGL, width: 800, height: 600, backgroundColor: '#1a1a2d', parent: 'phaser-example', scene: Example, pipeline: { PlasmaPostFX } }; let game = new Phaser.Game(config);