summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
author TreeHugger Robot <treehugger-gerrit@google.com> 2019-07-30 00:20:34 +0000
committer Android (Google) Code Review <android-gerrit@google.com> 2019-07-30 00:20:34 +0000
commit5047e88810435d3e557bbc89f70c2c7249bf20fb (patch)
treebe7655175307627adde669c244b1c195cc68bf84
parentb0141a095f8791606b1c9afa3b24ffa4182ced38 (diff)
parent7c861474a69e2ce9f5ae6be7214dedbc3e9caae7 (diff)
Merge "Reparent child surfaces when swapping out new surfaces"
-rw-r--r--services/core/java/com/android/server/wm/WindowStateAnimator.java7
1 files changed, 7 insertions, 0 deletions
diff --git a/services/core/java/com/android/server/wm/WindowStateAnimator.java b/services/core/java/com/android/server/wm/WindowStateAnimator.java
index 41840a4c531c..d90e66e10e73 100644
--- a/services/core/java/com/android/server/wm/WindowStateAnimator.java
+++ b/services/core/java/com/android/server/wm/WindowStateAnimator.java
@@ -370,6 +370,13 @@ class WindowStateAnimator {
// of the proper size. The preserved surface will still be removed when client
// finishes drawing to the new surface.
mSurfaceDestroyDeferred = false;
+
+ // Make sure to reparent any children of the new surface back to the preserved
+ // surface before destroying it.
+ if (mSurfaceController != null && mPendingDestroySurface != null) {
+ mPostDrawTransaction.reparentChildren(mSurfaceController.mSurfaceControl,
+ mPendingDestroySurface.mSurfaceControl).apply();
+ }
destroySurfaceLocked();
mSurfaceDestroyDeferred = true;
return;