summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
author Ming-Shin Lu <lumark@google.com> 2022-08-19 14:52:59 +0000
committer Android (Google) Code Review <android-gerrit@google.com> 2022-08-19 14:52:59 +0000
commita9fa413a219371b831e41ff7ff9ad84bca4d847c (patch)
treef0d17db2197234336f9150e1c5e0c7db0ad032b4
parenta01ccaae137b0af94b1de9c65d5d5403cc27eb08 (diff)
parentbb40322347812614d44131945edda3defe6ddd1e (diff)
Merge "Fix toggleSoftInput can't hide IME when the app in multi-window mode" into tm-qpr-dev
-rw-r--r--core/java/android/view/inputmethod/InputMethodManager.java6
1 files changed, 4 insertions, 2 deletions
diff --git a/core/java/android/view/inputmethod/InputMethodManager.java b/core/java/android/view/inputmethod/InputMethodManager.java
index cae48683810e..b5a742bfb2eb 100644
--- a/core/java/android/view/inputmethod/InputMethodManager.java
+++ b/core/java/android/view/inputmethod/InputMethodManager.java
@@ -89,6 +89,7 @@ import android.view.InputEventSender;
import android.view.KeyEvent;
import android.view.View;
import android.view.ViewRootImpl;
+import android.view.WindowInsets;
import android.view.WindowManager.LayoutParams.SoftInputModeFlags;
import android.view.autofill.AutofillManager;
import android.window.ImeOnBackInvokedDispatcher;
@@ -2122,8 +2123,9 @@ public final class InputMethodManager {
null /* icProto */);
synchronized (mH) {
final View view = getServedViewLocked();
- if (mImeInsetsConsumer != null && view != null) {
- if (mImeInsetsConsumer.isRequestedVisible()) {
+ if (view != null) {
+ final WindowInsets rootInsets = view.getRootWindowInsets();
+ if (rootInsets != null && rootInsets.isVisible(WindowInsets.Type.ime())) {
hideSoftInputFromWindow(view.getWindowToken(), hideFlags, null,
SoftInputShowHideReason.HIDE_TOGGLE_SOFT_INPUT);
} else {