[HTML5] Fix mouse_mode and fullscreen detection.
The canvas_id is `#`-prefixed to work with emscripten as a CSS selector. When comparing to an event target ID (e.g. when checking if the canvas is fullscreen, or is locking the mouse) we need to skip the first char (the hash).
This commit is contained in:
parent
3115ac4b60
commit
08efe327b6
1 changed files with 2 additions and 2 deletions
|
@ -129,7 +129,7 @@ EM_BOOL OS_JavaScript::fullscreen_change_callback(int p_event_type, const Emscri
|
||||||
OS_JavaScript *os = get_singleton();
|
OS_JavaScript *os = get_singleton();
|
||||||
// Empty ID is canvas.
|
// Empty ID is canvas.
|
||||||
String target_id = String::utf8(p_event->id);
|
String target_id = String::utf8(p_event->id);
|
||||||
if (target_id.empty() || target_id == String::utf8(os->canvas_id)) {
|
if (target_id.empty() || target_id == String::utf8(&(os->canvas_id[1]))) {
|
||||||
// This event property is the only reliable data on
|
// This event property is the only reliable data on
|
||||||
// browser fullscreen state.
|
// browser fullscreen state.
|
||||||
os->video_mode.fullscreen = p_event->isFullscreen;
|
os->video_mode.fullscreen = p_event->isFullscreen;
|
||||||
|
@ -589,7 +589,7 @@ OS::MouseMode OS_JavaScript::get_mouse_mode() const {
|
||||||
|
|
||||||
EmscriptenPointerlockChangeEvent ev;
|
EmscriptenPointerlockChangeEvent ev;
|
||||||
emscripten_get_pointerlock_status(&ev);
|
emscripten_get_pointerlock_status(&ev);
|
||||||
return (ev.isActive && String::utf8(ev.id) == String::utf8(canvas_id)) ? MOUSE_MODE_CAPTURED : MOUSE_MODE_VISIBLE;
|
return (ev.isActive && String::utf8(ev.id) == String::utf8(&canvas_id[1])) ? MOUSE_MODE_CAPTURED : MOUSE_MODE_VISIBLE;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Wheel
|
// Wheel
|
||||||
|
|
Loading…
Reference in a new issue