diff options
author | Adam Scott <ascott.ca@gmail.com> | 2024-11-07 13:25:36 -0500 |
---|---|---|
committer | Adam Scott <ascott.ca@gmail.com> | 2024-11-11 15:08:16 -0500 |
commit | 529569299039a8f483d2d9bc17f01ef9d98aa6cf (patch) | |
tree | b5ba06922dac9924a5cf5df48beb6ac6a151520c /platform/web | |
parent | 75bf6df49a6fa87c718f4052343a4b6ff4de574c (diff) | |
download | redot-engine-529569299039a8f483d2d9bc17f01ef9d98aa6cf.tar.gz |
Fix issue where focus timer would throw continuously
Diffstat (limited to 'platform/web')
-rw-r--r-- | platform/web/js/libs/library_godot_input.js | 41 |
1 files changed, 32 insertions, 9 deletions
diff --git a/platform/web/js/libs/library_godot_input.js b/platform/web/js/libs/library_godot_input.js index dfab882fd3..8134631f1b 100644 --- a/platform/web/js/libs/library_godot_input.js +++ b/platform/web/js/libs/library_godot_input.js @@ -38,28 +38,41 @@ const GodotIME = { $GodotIME: { ime: null, active: false, + focusTimerIntervalId: -1, getModifiers: function (evt) { return (evt.shiftKey + 0) + ((evt.altKey + 0) << 1) + ((evt.ctrlKey + 0) << 2) + ((evt.metaKey + 0) << 3); }, ime_active: function (active) { - if (GodotIME.ime == null) { - return; + function clearFocusTimerInterval() { + clearInterval(GodotIME.focusTimerIntervalId); + GodotIME.focusTimerIntervalId = -1; } - function focus_timer() { - GodotIME.active = true; + function focusTimer() { + if (GodotIME.ime == null) { + clearFocusTimerInterval(); + return; + } GodotIME.ime.focus(); } + if (GodotIME.focusTimerIntervalId > -1) { + clearFocusTimerInterval(); + } + + if (GodotIME.ime == null) { + return; + } + + GodotIME.active = active; if (active) { GodotIME.ime.style.display = 'block'; - setInterval(focus_timer, 100); + GodotIME.focusTimerIntervalId = setInterval(focusTimer, 100); } else { GodotIME.ime.style.display = 'none'; GodotConfig.canvas.focus(); - GodotIME.active = false; } }, @@ -90,18 +103,24 @@ const GodotIME = { if (GodotIME.ime == null) { return; } - if (event.type === 'compositionstart') { + switch (event.type) { + case 'compositionstart': ime_cb(0, null); GodotIME.ime.innerHTML = ''; - } else if (event.type === 'compositionupdate') { + break; + case 'compositionupdate': { const ptr = GodotRuntime.allocString(event.data); ime_cb(1, ptr); GodotRuntime.free(ptr); - } else if (event.type === 'compositionend') { + } break; + case 'compositionend': { const ptr = GodotRuntime.allocString(event.data); ime_cb(2, ptr); GodotRuntime.free(ptr); GodotIME.ime.innerHTML = ''; + } break; + default: + // Do nothing. } } @@ -140,6 +159,10 @@ const GodotIME = { if (GodotIME.ime == null) { return; } + if (GodotIME.focusTimerIntervalId > -1) { + clearInterval(GodotIME.focusTimerIntervalId); + GodotIME.focusTimerIntervalId = -1; + } GodotIME.ime.remove(); GodotIME.ime = null; }, |