Skip to content

Commit

Permalink
fix: [#3126] Fix keyboard events in scene scope
Browse files Browse the repository at this point in the history
  • Loading branch information
eonarheim committed Jul 16, 2024
1 parent c8d7f0e commit e6c7563
Show file tree
Hide file tree
Showing 5 changed files with 63 additions and 0 deletions.
12 changes: 12 additions & 0 deletions sandbox/tests/scene-keyboard/index.html
Original file line number Diff line number Diff line change
@@ -0,0 +1,12 @@
<!doctype html>
<html lang="en">
<head>
<meta charset="UTF-8" />
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
<title>Scene Keyboard</title>
</head>
<body>
<script src="../../lib/excalibur.js"></script>
<script src="index.js"></script>
</body>
</html>
38 changes: 38 additions & 0 deletions sandbox/tests/scene-keyboard/index.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,38 @@
var a = new ex.Scene();
a.on('initialize', () => {
console.log('a input:', a.input.keyboard);
// console.log('b input:', b.input.keyboard);
a.input.pointers.primary.on('down', (e) => {
a.engine.goToScene('b');
});
a.input.keyboard.on('press', (e) => {
console.log('a input:', a.input.keyboard.getKeys());
if (e.key === ex.Keys.Key1) {
a.engine.goToScene('b');
}
});
});

var b = new ex.Scene();
b.backgroundColor = ex.Color.DarkGray;
b.on('initialize', () => {
// console.log('a input:', a.input.keyboard);
console.log('b input:', b.input.keyboard);
b.input.pointers.primary.on('down', (e) => {
b.engine.goToScene('a');
});
b.input.keyboard.on('press', (e) => {
console.log('a input:', a.input.keyboard.getKeys());
console.log('b input:', b.input.keyboard.getKeys());
if (e.key === ex.Keys.Key2) {
b.engine.goToScene('a');
}
});
});

var game6 = new ex.Engine({
scenes: { a, b }
});

game6.goToScene('a');
game6.start();
1 change: 1 addition & 0 deletions src/engine/Director/Director.ts
Original file line number Diff line number Diff line change
Expand Up @@ -555,6 +555,7 @@ export class Director<TKnownScenes extends string = any> {
const context = { engine, previousScene, nextScene };
await this.currentScene._deactivate(context);
this.currentScene.events.emit('deactivate', new DeactivateEvent(context, this.currentScene));
this.currentScene.input.clear();
}

// wait for the scene to be loaded if needed
Expand Down
6 changes: 6 additions & 0 deletions src/engine/Input/InputHost.ts
Original file line number Diff line number Diff line change
Expand Up @@ -52,4 +52,10 @@ export class InputHost {
this.gamepads.update();
}
}

clear() {
this.keyboard.clear();
this.pointers.clear();
// this.gamepads.clear();
}
}
6 changes: 6 additions & 0 deletions src/engine/Input/Keyboard.ts
Original file line number Diff line number Diff line change
Expand Up @@ -346,6 +346,12 @@ export class Keyboard {
this._keys.length = 0;
};

public clear() {
this._keysDown.length = 0;
this._keysUp.length = 0;
this._keys.length = 0;
}

private _handleKeyDown = (ev: KeyboardEvent) => {
if (!this._enabled) {
return;
Expand Down

0 comments on commit e6c7563

Please sign in to comment.