From 451887cd6f529e3e3bbe13ae86dc8b7e2c942982 Mon Sep 17 00:00:00 2001 From: Hongwei Wang Date: Mon, 24 Jun 2019 16:58:04 -0700 Subject: [PATCH] Comparing dimension and rotation instead of DisplayInfo DisplayInfo.equals is too much and only dimension/rotation changes should be concerned in PinnedStackController#onTaskStackBoundsChanged This regression is introduced in ag/6971276 Bug: 131418250 Test: Manual test PiP with YT / GMM Change-Id: I6f29fd2b7606e3e44d88003bcae511e4afea3d30 --- .../android/server/wm/PinnedStackController.java | 15 +++++++++++++-- 1 file changed, 13 insertions(+), 2 deletions(-) diff --git a/services/core/java/com/android/server/wm/PinnedStackController.java b/services/core/java/com/android/server/wm/PinnedStackController.java index ba23258770753..af729317392b4 100644 --- a/services/core/java/com/android/server/wm/PinnedStackController.java +++ b/services/core/java/com/android/server/wm/PinnedStackController.java @@ -25,6 +25,7 @@ import static com.android.server.wm.PinnedStackControllerProto.MOVEMENT_BOUNDS; import static com.android.server.wm.WindowManagerDebugConfig.TAG_WITH_CLASS_NAME; import static com.android.server.wm.WindowManagerDebugConfig.TAG_WM; +import android.annotation.NonNull; import android.app.RemoteAction; import android.content.pm.ParceledListSlice; import android.content.res.Resources; @@ -45,6 +46,7 @@ import android.view.IPinnedStackController; import android.view.IPinnedStackListener; import com.android.internal.policy.PipSnapAlgorithm; +import com.android.internal.util.Preconditions; import com.android.server.UiThread; import java.io.PrintWriter; @@ -326,8 +328,8 @@ class PinnedStackController { boolean onTaskStackBoundsChanged(Rect targetBounds, Rect outBounds) { synchronized (mService.mGlobalLock) { final DisplayInfo displayInfo = mDisplayContent.getDisplayInfo(); - if (mDisplayInfo.equals(displayInfo)) { - // We are already in the right orientation, ignore + if (isSameDimensionAndRotation(mDisplayInfo, displayInfo)) { + // No dimension/rotation change, ignore outBounds.setEmpty(); return false; } else if (targetBounds.isEmpty()) { @@ -427,6 +429,15 @@ class PinnedStackController { notifyActionsChanged(mActions); } + private boolean isSameDimensionAndRotation(@NonNull DisplayInfo display1, + @NonNull DisplayInfo display2) { + Preconditions.checkNotNull(display1); + Preconditions.checkNotNull(display2); + return ((display1.rotation == display2.rotation) + && (display1.logicalWidth == display2.logicalWidth) + && (display1.logicalHeight == display2.logicalHeight)); + } + /** * Notifies listeners that the PIP needs to be adjusted for the IME. */