diff options
| author | 2020-06-12 10:06:40 +0200 | |
|---|---|---|
| committer | 2020-06-17 20:27:36 +0200 | |
| commit | 72d581e60281a1dbfb8d411c783e8839f247dfa5 (patch) | |
| tree | 4ad3e628b6ae8c71c8f4d81e426d8e4d1c57b9f7 | |
| parent | c744ad246ef8f8dd0dd9aa268bf99573da6c8ea8 (diff) | |
Close assistant activities on closeSystemDialogs
When the assistant is configured to be on top of the dream, it will have
higher z-order than any other activity. If it is also opaque, it will
prevent other activities from starting. We want to close the assistant
on closeSystemDialogs to allow other activities to start, e.g. on home
button press
Bug: 158117282
Test: atest AssistantStackTests
Change-Id: I226d95b82c1f5df5e5327ef85859d9b137d6e0e7
4 files changed, 23 insertions, 12 deletions
diff --git a/services/core/java/com/android/server/wm/ActivityTaskManagerService.java b/services/core/java/com/android/server/wm/ActivityTaskManagerService.java index 6dd1ea934497..2f3e60cc1368 100644 --- a/services/core/java/com/android/server/wm/ActivityTaskManagerService.java +++ b/services/core/java/com/android/server/wm/ActivityTaskManagerService.java @@ -6826,7 +6826,7 @@ public class ActivityTaskManagerService extends IActivityTaskManager.Stub { } mWindowManager.closeSystemDialogs(reason); - mRootWindowContainer.closeSystemDialogs(); + mRootWindowContainer.closeSystemDialogActivities(reason); } // Call into AM outside the synchronized block. mAmInternal.broadcastCloseSystemDialogs(reason); diff --git a/services/core/java/com/android/server/wm/RootWindowContainer.java b/services/core/java/com/android/server/wm/RootWindowContainer.java index 583663c5455f..2f90b6ae946d 100644 --- a/services/core/java/com/android/server/wm/RootWindowContainer.java +++ b/services/core/java/com/android/server/wm/RootWindowContainer.java @@ -40,6 +40,7 @@ import static android.view.WindowManager.TRANSIT_CRASHING_ACTIVITY_CLOSE; import static android.view.WindowManager.TRANSIT_NONE; import static android.view.WindowManager.TRANSIT_SHOW_SINGLE_TASK_DISPLAY; +import static com.android.server.policy.PhoneWindowManager.SYSTEM_DIALOG_REASON_ASSIST; import static com.android.server.policy.WindowManagerPolicy.FINISH_LAYOUT_REDO_LAYOUT; import static com.android.server.policy.WindowManagerPolicy.FINISH_LAYOUT_REDO_WALLPAPER; import static com.android.server.wm.ActivityStack.ActivityState.FINISHING; @@ -3121,14 +3122,25 @@ class RootWindowContainer extends WindowContainer<DisplayContent> return hasVisibleActivities; } - void closeSystemDialogs() { + void closeSystemDialogActivities(String reason) { forAllActivities((r) -> { - if ((r.info.flags & ActivityInfo.FLAG_FINISH_ON_CLOSE_SYSTEM_DIALOGS) != 0) { - r.finishIfPossible("close-sys", true /* oomAdj */); + if ((r.info.flags & ActivityInfo.FLAG_FINISH_ON_CLOSE_SYSTEM_DIALOGS) != 0 + || shouldCloseAssistant(r, reason)) { + r.finishIfPossible(reason, true /* oomAdj */); } }); } + private boolean shouldCloseAssistant(ActivityRecord r, String reason) { + if (!r.isActivityTypeAssistant()) return false; + if (reason == SYSTEM_DIALOG_REASON_ASSIST) return false; + // When the assistant is configured to be on top of the dream, it will have higher z-order + // than other activities. If it is also opaque, it will prevent other activities from + // starting. We want to close the assistant on closeSystemDialogs to allow other activities + // to start, e.g. on home button press. + return mWmService.mAssistantOnTopOfDream; + } + FinishDisabledPackageActivitiesHelper mFinishDisabledPackageActivitiesHelper = new FinishDisabledPackageActivitiesHelper(); class FinishDisabledPackageActivitiesHelper { diff --git a/services/core/java/com/android/server/wm/TaskDisplayArea.java b/services/core/java/com/android/server/wm/TaskDisplayArea.java index f793bd269cc9..1d6ea4f9d6fe 100644 --- a/services/core/java/com/android/server/wm/TaskDisplayArea.java +++ b/services/core/java/com/android/server/wm/TaskDisplayArea.java @@ -122,10 +122,6 @@ final class TaskDisplayArea extends DisplayArea<ActivityStack> { private final RootWindowContainer.FindTaskResult mTmpFindTaskResult = new RootWindowContainer.FindTaskResult(); - // Indicates whether the Assistant should show on top of the Dream (respectively, above - // everything else on screen). Otherwise, it will be put under always-on-top stacks. - private final boolean mAssistantOnTopOfDream; - /** * If this is the same as {@link #getFocusedStack} then the activity on the top of the focused * stack has been resumed. If stacks are changing position this will hold the old stack until @@ -151,9 +147,6 @@ final class TaskDisplayArea extends DisplayArea<ActivityStack> { mDisplayContent = displayContent; mRootWindowContainer = service.mRoot; mAtmService = service.mAtmService; - - mAssistantOnTopOfDream = mWmService.mContext.getResources().getBoolean( - com.android.internal.R.bool.config_assistantOnTopOfDream); } /** @@ -361,7 +354,7 @@ final class TaskDisplayArea extends DisplayArea<ActivityStack> { * @return the priority of the stack */ private int getPriority(ActivityStack stack) { - if (mAssistantOnTopOfDream && stack.isActivityTypeAssistant()) return 4; + if (mWmService.mAssistantOnTopOfDream && stack.isActivityTypeAssistant()) return 4; if (stack.isActivityTypeDream()) return 3; if (stack.inPinnedWindowingMode()) return 2; if (stack.isAlwaysOnTop()) return 1; diff --git a/services/core/java/com/android/server/wm/WindowManagerService.java b/services/core/java/com/android/server/wm/WindowManagerService.java index 0590288a7f8b..fcce3dcd0f32 100644 --- a/services/core/java/com/android/server/wm/WindowManagerService.java +++ b/services/core/java/com/android/server/wm/WindowManagerService.java @@ -528,6 +528,10 @@ public class WindowManagerService extends IWindowManager.Stub final boolean mAllowBootMessages; + // Indicates whether the Assistant should show on top of the Dream (respectively, above + // everything else on screen). Otherwise, it will be put under always-on-top stacks. + final boolean mAssistantOnTopOfDream; + final boolean mLimitedAlphaCompositing; final int mMaxUiWidth; @@ -1181,6 +1185,8 @@ public class WindowManagerService extends IWindowManager.Stub com.android.internal.R.bool.config_disableTransitionAnimation); mPerDisplayFocusEnabled = context.getResources().getBoolean( com.android.internal.R.bool.config_perDisplayFocusEnabled); + mAssistantOnTopOfDream = context.getResources().getBoolean( + com.android.internal.R.bool.config_assistantOnTopOfDream); mInputManager = inputManager; // Must be before createDisplayContentLocked. mDisplayManagerInternal = LocalServices.getService(DisplayManagerInternal.class); |