diff --git a/android-project/app/src/main/java/org/libsdl/app/SDLSurface.java b/android-project/app/src/main/java/org/libsdl/app/SDLSurface.java index 1579b73345..42eceb5096 100644 --- a/android-project/app/src/main/java/org/libsdl/app/SDLSurface.java +++ b/android-project/app/src/main/java/org/libsdl/app/SDLSurface.java @@ -208,6 +208,12 @@ public class SDLSurface extends SurfaceView implements SurfaceHolder.Callback, WindowInsets.Type.displayCutout()); SDLActivity.onNativeInsetsChanged(combined.left, combined.right, combined.top, combined.bottom); + + if (insets.isVisible(WindowInsets.Type.ime())) { + SDLActivity.onNativeScreenKeyboardShown(); + } else { + SDLActivity.onNativeScreenKeyboardHidden(); + } } // Pass these to any child views in case they need them diff --git a/src/video/SDL_video.c b/src/video/SDL_video.c index a338645c96..764eee219d 100644 --- a/src/video/SDL_video.c +++ b/src/video/SDL_video.c @@ -5900,7 +5900,7 @@ bool SDL_ScreenKeyboardShown(SDL_Window *window) void SDL_SendScreenKeyboardShown(void) { - if (_this->screen_keyboard_shown) { + if (!_this || _this->screen_keyboard_shown) { return; } @@ -5916,7 +5916,7 @@ void SDL_SendScreenKeyboardShown(void) void SDL_SendScreenKeyboardHidden(void) { - if (!_this->screen_keyboard_shown) { + if (!_this || !_this->screen_keyboard_shown) { return; }