Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit f8de2736 authored by Wei Sheng Shih's avatar Wei Sheng Shih Committed by Automerger Merge Worker
Browse files

Merge "Fix no AVD transfer to client when using setOnExitAnimationListener"...

Merge "Fix no AVD transfer to client when using setOnExitAnimationListener" into udc-dev am: 17cea5da

Original change: https://googleplex-android-review.googlesource.com/c/platform/frameworks/base/+/23757143



Change-Id: Iefe7e708a9a3336d68ff9749fc576a48a1c77d62
Signed-off-by: default avatarAutomerger Merge Worker <android-build-automerger-merge-worker@system.gserviceaccount.com>
parents fb2c5d5e 17cea5da
Loading
Loading
Loading
Loading
+8 −7
Original line number Diff line number Diff line
@@ -4230,21 +4230,22 @@ public final class ActivityThread extends ClientTransactionHandler
        decorView.addView(view);
        view.requestLayout();

        view.getViewTreeObserver().addOnDrawListener(new ViewTreeObserver.OnDrawListener() {
        view.getViewTreeObserver().addOnPreDrawListener(new ViewTreeObserver.OnPreDrawListener() {
            private boolean mHandled = false;
            @Override
            public void onDraw() {
            public boolean onPreDraw() {
                if (mHandled) {
                    return;
                    return true;
                }
                mHandled = true;
                // Transfer the splash screen view from shell to client.
                // Call syncTransferSplashscreenViewTransaction at the first onDraw so we can ensure
                // the client view is ready to show and we can use applyTransactionOnDraw to make
                // all transitions happen at the same frame.
                // Call syncTransferSplashscreenViewTransaction at the first onPreDraw, so we can
                // ensure the client view is ready to show, and can use applyTransactionOnDraw to
                // make all transitions happen at the same frame.
                syncTransferSplashscreenViewTransaction(
                        view, r.token, decorView, startingWindowLeash);
                view.post(() -> view.getViewTreeObserver().removeOnDrawListener(this));
                view.post(() -> view.getViewTreeObserver().removeOnPreDrawListener(this));
                return true;
            }
        });
    }