diff options
| author | 2021-03-10 22:58:08 +0000 | |
|---|---|---|
| committer | 2021-03-10 22:58:08 +0000 | |
| commit | 09b7b5565936698fcbb1c04657b5bd4d5195dff4 (patch) | |
| tree | 39d276aacd0ba61ac40a68a10f2c2d4914aba0d5 | |
| parent | 61e7956648d4318810d0ab0a45134393cf489e04 (diff) | |
| parent | 0c603d91a7f3255426d6cbf9b453e64f756457c3 (diff) | |
Merge "Include whether in touch mode for WindowlessWindowManager" into rvc-qpr-dev
| -rw-r--r-- | core/java/android/view/WindowlessWindowManager.java | 17 |
1 files changed, 15 insertions, 2 deletions
diff --git a/core/java/android/view/WindowlessWindowManager.java b/core/java/android/view/WindowlessWindowManager.java index 1af4c3636ac5..f0006d988163 100644 --- a/core/java/android/view/WindowlessWindowManager.java +++ b/core/java/android/view/WindowlessWindowManager.java @@ -156,7 +156,10 @@ public class WindowlessWindowManager implements IWindowSession { mStateForWindow.put(window.asBinder(), state); } - return WindowManagerGlobal.ADD_OKAY | WindowManagerGlobal.ADD_FLAG_APP_VISIBLE; + final int res = WindowManagerGlobal.ADD_OKAY | WindowManagerGlobal.ADD_FLAG_APP_VISIBLE; + + // Include whether the window is in touch mode. + return isInTouchMode() ? res | WindowManagerGlobal.ADD_FLAG_IN_TOUCH_MODE : res; } /** @@ -207,6 +210,15 @@ public class WindowlessWindowManager implements IWindowSession { return !PixelFormat.formatHasAlpha(attrs.format); } + private boolean isInTouchMode() { + try { + return WindowManagerGlobal.getWindowSession().getInTouchMode(); + } catch (RemoteException e) { + Log.e(TAG, "Unable to check if the window is in touch mode", e); + } + return false; + } + /** @hide */ protected SurfaceControl getSurfaceControl(View rootView) { final ViewRootImpl root = rootView.getViewRootImpl(); @@ -268,7 +280,8 @@ public class WindowlessWindowManager implements IWindowSession { } } - return 0; + // Include whether the window is in touch mode. + return isInTouchMode() ? WindowManagerGlobal.RELAYOUT_RES_IN_TOUCH_MODE : 0; } @Override |