summaryrefslogtreecommitdiffstats
path: root/platform/web
diff options
context:
space:
mode:
authorAdam Scott <ascott.ca@gmail.com>2024-11-07 13:25:36 -0500
committerAdam Scott <ascott.ca@gmail.com>2024-11-11 15:08:16 -0500
commit529569299039a8f483d2d9bc17f01ef9d98aa6cf (patch)
treeb5ba06922dac9924a5cf5df48beb6ac6a151520c /platform/web
parent75bf6df49a6fa87c718f4052343a4b6ff4de574c (diff)
downloadredot-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.js41
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;
},