diff options
| author | Heemin Seog <hseog@google.com> | 2020-08-27 17:25:54 +0000 |
|---|---|---|
| committer | Automerger Merge Worker <android-build-automerger-merge-worker@system.gserviceaccount.com> | 2020-08-27 17:25:54 +0000 |
| commit | 026c5e70ba79474c4a6eb40af84dd47a5f33ffaf (patch) | |
| tree | aec44baafc4c341597a61bdd725bd1b81b8c57f0 /core/java/android/inputmethodservice/InputMethodService.java | |
| parent | 31dbc67d16062c2f21ffcaeb2470be4a1341d0ab (diff) | |
| parent | bab4e2077c82e6a2e94caf77b4cbac90dec66a91 (diff) | |
Merge "Smooth out IME animation for automotive devices" into rvc-qpr-dev am: d9892a1fac am: bab4e2077c
Original change: https://googleplex-android-review.googlesource.com/c/platform/frameworks/base/+/12404434
Change-Id: I1271f81fb84bf404613d26a9bfe747ba9cb1072d
Diffstat (limited to 'core/java/android/inputmethodservice/InputMethodService.java')
| -rw-r--r-- | core/java/android/inputmethodservice/InputMethodService.java | 14 |
1 files changed, 9 insertions, 5 deletions
diff --git a/core/java/android/inputmethodservice/InputMethodService.java b/core/java/android/inputmethodservice/InputMethodService.java index 7250801eec81..55afefed734e 100644 --- a/core/java/android/inputmethodservice/InputMethodService.java +++ b/core/java/android/inputmethodservice/InputMethodService.java @@ -1210,15 +1210,19 @@ public class InputMethodService extends AbstractInputMethodService { mWindow.getWindow().getAttributes().setFitInsetsIgnoringVisibility(true); // IME layout should always be inset by navigation bar, no matter its current visibility, - // unless automotive requests it, since automotive may hide the navigation bar. + // unless automotive requests it. Automotive devices may request the navigation bar to be + // hidden when the IME shows up (controlled via config_automotiveHideNavBarForKeyboard) + // in order to maximize the visible screen real estate. When this happens, the IME window + // should animate from the bottom of the screen to reduce the jank that happens from the + // lack of synchronization between the bottom system window and the IME window. + if (mIsAutomotive && mAutomotiveHideNavBarForKeyboard) { + mWindow.getWindow().setDecorFitsSystemWindows(false); + } mWindow.getWindow().getDecorView().setOnApplyWindowInsetsListener( (v, insets) -> v.onApplyWindowInsets( new WindowInsets.Builder(insets).setInsets( navigationBars(), - mIsAutomotive && mAutomotiveHideNavBarForKeyboard - ? android.graphics.Insets.NONE - : insets.getInsetsIgnoringVisibility(navigationBars()) - ) + insets.getInsetsIgnoringVisibility(navigationBars())) .build())); // For ColorView in DecorView to work, FLAG_DRAWS_SYSTEM_BAR_BACKGROUNDS needs to be set |
