diff options
author | Mitya Selivanov <automainint@guattari.tech> | 2024-11-08 08:56:45 +0100 |
---|---|---|
committer | Mitya Selivanov <automainint@guattari.tech> | 2024-11-08 08:56:45 +0100 |
commit | b12ca99506c7538a74cb2ed39ce0e1781e934a2a (patch) | |
tree | b22c0f8d5be056c8604c744c44a29b4c9b767eca /index.htm | |
parent | dc95a43da475b8ce55f25b670c9848d9dabf1cb7 (diff) | |
download | reduced_system_layer-b12ca99506c7538a74cb2ed39ce0e1781e934a2a.zip |
Update input
Diffstat (limited to 'index.htm')
-rw-r--r-- | index.htm | 45 |
1 files changed, 32 insertions, 13 deletions
@@ -98,10 +98,11 @@ if (!wait_for_events) { if (sleep_duration > 0) { + let timeout = sleep_duration; sleep_duration = 0; setTimeout(() => { window.requestAnimationFrame(animation_frame); - }, sleep_duration); + }, timeout); } else window.requestAnimationFrame(animation_frame); } @@ -126,24 +127,42 @@ window.requestAnimationFrame(animation_frame); }); - canvas.addEventListener("mouseenter", (ev) => { - console.log(ev); - window.requestAnimationFrame(animation_frame); - }); + let key_from_code = (code) => { + switch (code) { + case "KeyA": return 97; + } + return 0; + }; - canvas.addEventListener("mouseleave", (ev) => { - console.log(ev); - window.requestAnimationFrame(animation_frame); - }); + let mod_from_event = (ev) => { + let mod = 0; + if (ev.ctrlKey) mod |= 1; + if (ev.shiftKey) mod |= 2; + if (ev.altKey) mod |= 4; + if (ev.metaKey) mod |= 8; + return mod; + }; window.addEventListener("keydown", (ev) => { - console.log(ev); - window.requestAnimationFrame(animation_frame); + ev.preventDefault(); + if (!ev.repeat) { + let mod = mod_from_event(ev); + let key = key_from_code(ev.code); + if (key != 0) + program.instance.exports.js_keydown(key, mod); + window.requestAnimationFrame(animation_frame); + } }); window.addEventListener("keyup", (ev) => { - console.log(ev); - window.requestAnimationFrame(animation_frame); + ev.preventDefault(); + if (!ev.repeat) { + let mod = mod_from_event(ev); + let key = key_from_code(ev.code); + if (key != 0) + program.instance.exports.js_keyup(key, mod); + window.requestAnimationFrame(animation_frame); + } }); window.requestAnimationFrame(animation_frame); |