From 4e389254174e3202dc269365c363aac8ab3d7aa8 Mon Sep 17 00:00:00 2001 From: tuanddd Date: Fri, 23 Dec 2022 22:25:01 +0700 Subject: [PATCH] feat: switch character --- @types/phaser/index.d.ts | 4 +++ src/characters/player.ts | 30 ++++++++++++++-------- src/globals.d.ts | 3 +++ src/main.ts | 2 +- src/scenes/Game.ts | 54 +++++++++++++++++++++------------------- tsconfig.json | 3 ++- 6 files changed, 58 insertions(+), 38 deletions(-) create mode 100644 @types/phaser/index.d.ts create mode 100644 src/globals.d.ts diff --git a/@types/phaser/index.d.ts b/@types/phaser/index.d.ts new file mode 100644 index 0000000..ca7efb5 --- /dev/null +++ b/@types/phaser/index.d.ts @@ -0,0 +1,4 @@ +// @types/phaser/index.d.ts +/// +/// +/// diff --git a/src/characters/player.ts b/src/characters/player.ts index dad8eec..282ad6b 100644 --- a/src/characters/player.ts +++ b/src/characters/player.ts @@ -13,26 +13,34 @@ export class Player extends Phaser.GameObjects.GameObject { private keys!: any; private dir: AnimationDirection = "front"; public instance: any; + public characterType: CharacterType = "neko"; - constructor(public characterType: CharacterType, public scene: Phaser.Scene) { + constructor(public scene: Phaser.Scene, characterType?: CharacterType) { super(scene, "player"); + if (characterType) { + this.characterType = characterType; + } + this.load(); this.cursors = scene.input.keyboard.createCursorKeys(); this.keys = scene.input.keyboard.addKeys("W,A,S,D,Shift"); + } - // @ts-ignore - scene.load.spine( - "player", - `assets/${characterType}/char.json`, - `assets/${characterType}/char.atlas` - ); + load() { + ["fukuro", "ghost-neko", "neko", "tv-head"].forEach((char) => { + this.scene.load.spine( + `${char}-character`, + `assets/${char}/char.json`, + `assets/${char}/char.atlas` + ); + }); } - spawn(config: any) { - if (this.instance) return this.instance; - // @ts-ignore + spawn(config: any = {}) { + this.characterType = config.character ?? this.characterType; + this.instance?.destroy(); this.instance = this.scene.make.spine({ ...config, - key: "player", + key: `${this.characterType}-character`, skinName: "char_default", animationName: getBasicAnimation("idle", "front"), loop: true, diff --git a/src/globals.d.ts b/src/globals.d.ts new file mode 100644 index 0000000..dcb2600 --- /dev/null +++ b/src/globals.d.ts @@ -0,0 +1,3 @@ +declare interface Window { + SpinePlugin: any; +} diff --git a/src/main.ts b/src/main.ts index 3ccf06d..f78a29f 100644 --- a/src/main.ts +++ b/src/main.ts @@ -18,7 +18,7 @@ const config: Phaser.Types.Core.GameConfig = { scene: [ { key: "SpinePlugin", - plugin: (window as any).SpinePlugin, + plugin: window.SpinePlugin, mapping: "spine", }, ], diff --git a/src/scenes/Game.ts b/src/scenes/Game.ts index 8334933..33c5fef 100644 --- a/src/scenes/Game.ts +++ b/src/scenes/Game.ts @@ -6,6 +6,7 @@ import { Building, buildings } from "../objects/Building"; export default class Game extends Phaser.Scene { private player!: Player; private sprites: any[] = []; + private keys!: any; constructor() { super({ @@ -22,8 +23,23 @@ export default class Game extends Phaser.Scene { }); } + spawnPlayer(character?: string) { + const player = this.player.spawn({ + x: 200, + y: 200, + scale: 0.3, + character, + }); + this.matter.add.gameObject(player); + player.setFixedRotation(0); + this.cameras.main.startFollow(player, true); + + player.body.position.y = player.body.position.y * 1.15; + } + preload() { - this.player = new Player("neko", this); + this.player = new Player(this); + this.keys = this.input.keyboard.addKeys("H,J,K,L"); } create() { @@ -36,31 +52,9 @@ export default class Game extends Phaser.Scene { const floorTileset = map.addTilesetImage("floor", "floor"); map.createLayer("Ground", floorTileset, 0, 0); - const player = this.player.spawn({ - x: 200, - y: 200, - scale: 0.3, - }); - this.matter.add.gameObject(player); - player.setFixedRotation(0); - this.cameras.main.startFollow(player, true); - - // const airportTileset = map.addTilesetImage("airport", "airport"); - // const buildingsLayer = map.createLayer("Buildings", airportTileset, 0, 0); - // this.matter.world.convertTilemapLayer(map.objects); - - // const shapes = this.cache.json.get("airport-shapes"); - // const object = this.matter.add.sprite(500, 500, "airport", "airport", { - // // @ts-ignore - // shape: shapes.airport, - // isStatic: true, - // }); - // object.setDepth(object.y); - // this.buildings.push(object); - - player.body.position.y = player.body.position.y * 1.15; + this.spawnPlayer(); - // Test Buildings + // Buildings const buildingTilesets: Phaser.Tilemaps.Tileset[] = []; buildings.forEach((building) => { const object = new Building({ game: this, map, ...building }); @@ -77,6 +71,16 @@ export default class Game extends Phaser.Scene { return; } + if (this.keys.H.isDown) { + this.spawnPlayer("neko"); + } else if (this.keys.J.isDown) { + this.spawnPlayer("fukuro"); + } else if (this.keys.K.isDown) { + this.spawnPlayer("ghost-neko"); + } else if (this.keys.L.isDown) { + this.spawnPlayer("tv-head"); + } + // Check player vs buildings overlap // FIXME: Should have some preliminary check to avoid performance struggle. We don't want // to check for overlap every round of render, on every building diff --git a/tsconfig.json b/tsconfig.json index fbd0225..fefb25a 100644 --- a/tsconfig.json +++ b/tsconfig.json @@ -14,7 +14,8 @@ "noUnusedLocals": true, "noUnusedParameters": true, "noImplicitReturns": true, - "skipLibCheck": true + "skipLibCheck": true, + "typeRoots": ["@types", "node_modules/@types", "node_modules/phaser/@types"] }, "include": ["src"] }