diff options
| author | 2022-08-19 14:52:59 +0000 | |
|---|---|---|
| committer | 2022-08-19 14:52:59 +0000 | |
| commit | a9fa413a219371b831e41ff7ff9ad84bca4d847c (patch) | |
| tree | f0d17db2197234336f9150e1c5e0c7db0ad032b4 | |
| parent | a01ccaae137b0af94b1de9c65d5d5403cc27eb08 (diff) | |
| parent | bb40322347812614d44131945edda3defe6ddd1e (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.java | 6 |
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 { |