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

Commit 6820a5b7 authored by Automerger Merge Worker's avatar Automerger Merge Worker Committed by Android (Google) Code Review
Browse files

Merge "Merge "Fix bug in mixedhandler merging" into udc-dev am: 97e510a2 am: 8f58fe91"

parents 1473a179 a4fc6b9f
Loading
Loading
Loading
Loading
+9 −11
Original line number Diff line number Diff line
@@ -272,13 +272,18 @@ public class DefaultMixedHandler implements Transitions.TransitionHandler {
                info.getChanges().remove(i);
            }
        }
        Transitions.TransitionFinishCallback finishCB = (wct, wctCB) -> {
            --mixed.mInFlightSubAnimations;
            mixed.joinFinishArgs(wct, wctCB);
            if (mixed.mInFlightSubAnimations > 0) return;
            mActiveTransitions.remove(mixed);
            finishCallback.onTransitionFinished(mixed.mFinishWCT, wctCB);
        };
        if (pipChange == null) {
            if (mixed.mLeftoversHandler != null) {
                mixed.mInFlightSubAnimations = 1;
                if (mixed.mLeftoversHandler.startAnimation(mixed.mTransition,
                        info, startTransaction, finishTransaction, (wct, wctCB) -> {
                            mActiveTransitions.remove(mixed);
                            finishCallback.onTransitionFinished(wct, wctCB);
                        })) {
                        info, startTransaction, finishTransaction, finishCB)) {
                    return true;
                }
            }
@@ -287,13 +292,6 @@ public class DefaultMixedHandler implements Transitions.TransitionHandler {
        }
        ProtoLog.v(ShellProtoLogGroup.WM_SHELL_TRANSITIONS, " Splitting PIP into a separate"
                        + " animation because remote-animation likely doesn't support it");
        Transitions.TransitionFinishCallback finishCB = (wct, wctCB) -> {
            --mixed.mInFlightSubAnimations;
            mixed.joinFinishArgs(wct, wctCB);
            if (mixed.mInFlightSubAnimations > 0) return;
            mActiveTransitions.remove(mixed);
            finishCallback.onTransitionFinished(mixed.mFinishWCT, wctCB);
        };
        // Split the transition into 2 parts: the pip part and the rest.
        mixed.mInFlightSubAnimations = 2;
        // make a new startTransaction because pip's startEnterAnimation "consumes" it so