created a class to centralize all user inputs catching and expose user events

This commit is contained in:
kharhamel 2020-04-11 16:46:28 +02:00
parent 6bec8b3703
commit 793e5318f7
3 changed files with 77 additions and 45 deletions

View File

@ -2,35 +2,17 @@ import {CameraManager, CameraManagerInterface} from "./CameraManager";
import {RESOLUTION} from "../../Enum/EnvironmentVariable"; import {RESOLUTION} from "../../Enum/EnvironmentVariable";
import {Player} from "../Player/Player"; import {Player} from "../Player/Player";
import {GameScene, GameSceneInterface} from "./GameScene"; import {GameScene, GameSceneInterface} from "./GameScene";
import {UserInputManager} from "../UserInput/UserInputManager";
export interface MapManagerInterface { export interface MapManagerInterface {
keyZ: Phaser.Input.Keyboard.Key;
keyQ: Phaser.Input.Keyboard.Key;
keyS: Phaser.Input.Keyboard.Key;
keyD: Phaser.Input.Keyboard.Key;
keyRight: Phaser.Input.Keyboard.Key;
keyLeft: Phaser.Input.Keyboard.Key;
keyUp: Phaser.Input.Keyboard.Key;
keyDown: Phaser.Input.Keyboard.Key;
keyShift: Phaser.Input.Keyboard.Key;
Map: Phaser.Tilemaps.Tilemap; Map: Phaser.Tilemaps.Tilemap;
Terrain: Phaser.Tilemaps.Tileset; Terrain: Phaser.Tilemaps.Tileset;
Camera: CameraManagerInterface; Camera: CameraManagerInterface;
Scene: GameSceneInterface; Scene: GameSceneInterface;
userInputManager: UserInputManager;
update(): void; update(): void;
} }
export class MapManager implements MapManagerInterface{ export class MapManager implements MapManagerInterface{
keyZ: Phaser.Input.Keyboard.Key;
keyQ: Phaser.Input.Keyboard.Key;
keyS: Phaser.Input.Keyboard.Key;
keyD: Phaser.Input.Keyboard.Key;
keyRight: Phaser.Input.Keyboard.Key;
keyLeft: Phaser.Input.Keyboard.Key;
keyUp: Phaser.Input.Keyboard.Key;
keyDown: Phaser.Input.Keyboard.Key;
keyShift: Phaser.Input.Keyboard.Key;
Terrain : Phaser.Tilemaps.Tileset; Terrain : Phaser.Tilemaps.Tileset;
Camera: CameraManagerInterface; Camera: CameraManagerInterface;
CurrentPlayer: Player; CurrentPlayer: Player;
@ -38,6 +20,7 @@ export class MapManager implements MapManagerInterface{
Map: Phaser.Tilemaps.Tilemap; Map: Phaser.Tilemaps.Tilemap;
startX = (window.innerWidth / 2) / RESOLUTION; startX = (window.innerWidth / 2) / RESOLUTION;
startY = (window.innerHeight / 2) / RESOLUTION; startY = (window.innerHeight / 2) / RESOLUTION;
userInputManager: UserInputManager;
constructor(scene: GameSceneInterface){ constructor(scene: GameSceneInterface){
this.Scene = scene; this.Scene = scene;
@ -49,11 +32,9 @@ export class MapManager implements MapManagerInterface{
this.Map.createStaticLayer("Calque 1", [this.Terrain], 0, 0); this.Map.createStaticLayer("Calque 1", [this.Terrain], 0, 0);
this.Map.createStaticLayer("Calque 2", [this.Terrain], 0, 0); this.Map.createStaticLayer("Calque 2", [this.Terrain], 0, 0);
//initialise keyboard
this.initKeyBoard();
//initialise camera //initialise camera
this.Camera = new CameraManager(this.Scene, this.Scene.cameras.main, this); this.Camera = new CameraManager(this.Scene, this.Scene.cameras.main, this);
this.userInputManager = new UserInputManager(this.Scene);
//initialise player //initialise player
this.CurrentPlayer = new Player( this.CurrentPlayer = new Player(
this.Scene, this.Scene,
@ -65,22 +46,9 @@ export class MapManager implements MapManagerInterface{
this.CurrentPlayer.initAnimation(); this.CurrentPlayer.initAnimation();
} }
initKeyBoard() {
this.keyShift = this.Scene.input.keyboard.addKey(Phaser.Input.Keyboard.KeyCodes.SHIFT);
this.keyZ = this.Scene.input.keyboard.addKey(Phaser.Input.Keyboard.KeyCodes.Z);
this.keyQ = this.Scene.input.keyboard.addKey(Phaser.Input.Keyboard.KeyCodes.Q);
this.keyS = this.Scene.input.keyboard.addKey(Phaser.Input.Keyboard.KeyCodes.S);
this.keyD = this.Scene.input.keyboard.addKey(Phaser.Input.Keyboard.KeyCodes.D);
this.keyUp = this.Scene.input.keyboard.addKey(Phaser.Input.Keyboard.KeyCodes.UP);
this.keyLeft = this.Scene.input.keyboard.addKey(Phaser.Input.Keyboard.KeyCodes.LEFT);
this.keyDown = this.Scene.input.keyboard.addKey(Phaser.Input.Keyboard.KeyCodes.DOWN);
this.keyRight = this.Scene.input.keyboard.addKey(Phaser.Input.Keyboard.KeyCodes.RIGHT);
}
update() : void { update() : void {
this.CurrentPlayer.move(); let activeEvents = this.userInputManager.getEventListForGameTick();
this.CurrentPlayer.move(activeEvents);
} }
} }

View File

@ -3,6 +3,7 @@ import {getPlayerAnimations, playAnimation, PlayerAnimationNames} from "./Animat
import {GameSceneInterface} from "../Game/GameScene"; import {GameSceneInterface} from "../Game/GameScene";
import {ConnexionInstance} from "../Game/GameManager"; import {ConnexionInstance} from "../Game/GameManager";
import {CameraManagerInterface} from "../Game/CameraManager"; import {CameraManagerInterface} from "../Game/CameraManager";
import {ActiveEventList, UserInputEvent} from "../UserInput/UserInputManager";
export class Player extends Phaser.GameObjects.Sprite{ export class Player extends Phaser.GameObjects.Sprite{
MapManager : MapManagerInterface; MapManager : MapManagerInterface;
@ -36,13 +37,13 @@ export class Player extends Phaser.GameObjects.Sprite{
}) })
} }
move(){ move(activeEvents: ActiveEventList){
//if user client on shift, camera and player speed //if user client on shift, camera and player speed
let speedMultiplier = this.MapManager.keyShift.isDown ? 5 : 1; let speedMultiplier = activeEvents.get(UserInputEvent.SpeedUp) ? 5 : 1;
let haveMove = false; let haveMove = false;
let direction = null; let direction = null;
if((this.MapManager.keyZ.isDown || this.MapManager.keyUp.isDown)){ if(activeEvents.get(UserInputEvent.MoveUp)){
if(!this.CanMoveUp()){ if(!this.CanMoveUp()){
return; return;
} }
@ -51,7 +52,7 @@ export class Player extends Phaser.GameObjects.Sprite{
haveMove = true; haveMove = true;
direction = PlayerAnimationNames.WalkUp; direction = PlayerAnimationNames.WalkUp;
} }
if((this.MapManager.keyQ.isDown || this.MapManager.keyLeft.isDown)){ if(activeEvents.get(UserInputEvent.MoveLeft)){
if(!this.CanMoveLeft()){ if(!this.CanMoveLeft()){
return; return;
} }
@ -60,7 +61,7 @@ export class Player extends Phaser.GameObjects.Sprite{
haveMove = true; haveMove = true;
direction = PlayerAnimationNames.WalkLeft; direction = PlayerAnimationNames.WalkLeft;
} }
if((this.MapManager.keyS.isDown || this.MapManager.keyDown.isDown)){ if(activeEvents.get(UserInputEvent.MoveDown)){
if(!this.CanMoveDown()){ if(!this.CanMoveDown()){
return; return;
} }
@ -69,7 +70,7 @@ export class Player extends Phaser.GameObjects.Sprite{
haveMove = true; haveMove = true;
direction = PlayerAnimationNames.WalkDown; direction = PlayerAnimationNames.WalkDown;
} }
if((this.MapManager.keyD.isDown || this.MapManager.keyRight.isDown)){ if(activeEvents.get(UserInputEvent.MoveRight)){
if(!this.CanMoveRight()){ if(!this.CanMoveRight()){
return; return;
} }

View File

@ -0,0 +1,63 @@
import Map = Phaser.Structs.Map;
import {GameSceneInterface} from "../Game/GameScene";
interface UserInputManagerDatum {
keyCode: number;
keyInstance: Phaser.Input.Keyboard.Key;
event: UserInputEvent
}
export enum UserInputEvent {
MoveLeft = 1,
MoveUp,
MoveRight,
MoveDown,
SpeedUp,
}
//we cannot the map structure so we have to create a replacment
export class ActiveEventList {
private data:any;
constructor() {
this.data = {};
}
get(event: UserInputEvent): boolean {
return this.data[event] || false;
}
set(event: UserInputEvent, value: boolean): boolean {
return this.data[event] = true;
}
}
//this class is responsible for catching user inputs and listing all active user actions at every game tick events.
export class UserInputManager {
private data: UserInputManagerDatum[] = [
{keyCode: Phaser.Input.Keyboard.KeyCodes.Z, event: UserInputEvent.MoveUp, keyInstance: null},
{keyCode: Phaser.Input.Keyboard.KeyCodes.Q, event: UserInputEvent.MoveLeft, keyInstance: null},
{keyCode: Phaser.Input.Keyboard.KeyCodes.S, event: UserInputEvent.MoveDown, keyInstance: null},
{keyCode: Phaser.Input.Keyboard.KeyCodes.D, event: UserInputEvent.MoveRight, keyInstance: null},
{keyCode: Phaser.Input.Keyboard.KeyCodes.UP, event: UserInputEvent.MoveUp, keyInstance: null},
{keyCode: Phaser.Input.Keyboard.KeyCodes.LEFT, event: UserInputEvent.MoveLeft, keyInstance: null},
{keyCode: Phaser.Input.Keyboard.KeyCodes.DOWN, event: UserInputEvent.MoveDown, keyInstance: null},
{keyCode: Phaser.Input.Keyboard.KeyCodes.RIGHT, event: UserInputEvent.MoveRight, keyInstance: null},
{keyCode: Phaser.Input.Keyboard.KeyCodes.SHIFT, event: UserInputEvent.SpeedUp, keyInstance: null},
];
constructor(Scene : GameSceneInterface) {
this.data.forEach(d => {
d.keyInstance = Scene.input.keyboard.addKey(d.keyCode);
});
}
getEventListForGameTick(): ActiveEventList {
let eventsMap = new ActiveEventList();
this.data.forEach(d => {
if (d. keyInstance.isDown) {
eventsMap.set(d.event, true);
}
});
return eventsMap;
}
}