diff options
| author | 2019-07-30 00:20:34 +0000 | |
|---|---|---|
| committer | 2019-07-30 00:20:34 +0000 | |
| commit | 5047e88810435d3e557bbc89f70c2c7249bf20fb (patch) | |
| tree | be7655175307627adde669c244b1c195cc68bf84 | |
| parent | b0141a095f8791606b1c9afa3b24ffa4182ced38 (diff) | |
| parent | 7c861474a69e2ce9f5ae6be7214dedbc3e9caae7 (diff) | |
Merge "Reparent child surfaces when swapping out new surfaces"
| -rw-r--r-- | services/core/java/com/android/server/wm/WindowStateAnimator.java | 7 |
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; |