-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathutilsSpark.ts
59 lines (52 loc) · 1.8 KB
/
utilsSpark.ts
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
// utils.ts
export const W = 'w';
export const A = 'a';
export const S = 's';
export const D = 'd';
export const SHIFT = 'shift';
export const DIRECTIONS = [W, A, S, D];
export class KeyDisplay {
parent: HTMLDivElement;
map: Map<string, HTMLDivElement> = new Map();
constructor() {
this.parent = document.createElement("div");
this.parent.className = 'key-display-parent'; // Parent container class
document.body.append(this.parent);
DIRECTIONS.forEach((key) => {
const div = document.createElement("div");
div.textContent = key;
div.className = 'key-display'; // Default class
this.map.set(key, div);
this.parent.append(div); // Append to parent container
});
this.updatePosition();
}
public updatePosition() {
const positions = {
[W]: { top: `${window.innerHeight - 150}px`, left: `${300}px` },
[A]: { top: `${window.innerHeight - 100}px`, left: `${200}px` },
[S]: { top: `${window.innerHeight - 100}px`, left: `${300}px` },
[D]: { top: `${window.innerHeight - 100}px`, left: `${400}px` },
[SHIFT]: { top: `${window.innerHeight - 100}px`, left: `${50}px` }
};
DIRECTIONS.forEach((key) => {
const div = this.map.get(key);
if (div) {
div.style.top = positions[key].top;
div.style.left = positions[key].left;
}
});
}
public down(key: string) {
const div = this.map.get(key.toLowerCase());
if (div) {
div.classList.add('key-down');
}
}
public up(key: string) {
const div = this.map.get(key.toLowerCase());
if (div) {
div.classList.remove('key-down');
}
}
}