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

Commit 10dd8449 authored by Johannes Gallmann's avatar Johannes Gallmann Committed by Automerger Merge Worker
Browse files

Merge "Add onEndCallback to ContainerAnimationRunner" into tm-qpr-dev am: 83683829 am: 72313fea

parents 8a548cfa 72313fea
Loading
Loading
Loading
Loading
+10 −3
Original line number Diff line number Diff line
@@ -300,7 +300,7 @@ public class QuickstepTransitionManager implements OnDeviceProfileChangeListener
        ItemInfo tag = (ItemInfo) v.getTag();
        if (tag != null && tag.shouldUseBackgroundAnimation()) {
            ContainerAnimationRunner containerAnimationRunner =
                    ContainerAnimationRunner.from(v, mStartingWindowListener);
                    ContainerAnimationRunner.from(v, mStartingWindowListener, onEndCallback);
            if (containerAnimationRunner != null) {
                delegateRunner = containerAnimationRunner;
            }
@@ -1764,7 +1764,7 @@ public class QuickstepTransitionManager implements OnDeviceProfileChangeListener

        @Nullable
        private static ContainerAnimationRunner from(
                View v, StartingWindowListener startingWindowListener) {
                View v, StartingWindowListener startingWindowListener, RunnableList onEndCallback) {
            View viewToUse = findViewWithBackground(v);
            if (viewToUse == null) {
                viewToUse = v;
@@ -1791,8 +1791,15 @@ public class QuickstepTransitionManager implements OnDeviceProfileChangeListener
            ActivityLaunchAnimator.Callback callback = task -> ColorUtils.setAlphaComponent(
                    startingWindowListener.getBackgroundColor(), 255);

            ActivityLaunchAnimator.Listener listener = new ActivityLaunchAnimator.Listener() {
                @Override
                public void onLaunchAnimationEnd() {
                    onEndCallback.executeAllAndDestroy();
                }
            };

            return new ContainerAnimationRunner(
                    new ActivityLaunchAnimator.AnimationDelegate(controller, callback));
                    new ActivityLaunchAnimator.AnimationDelegate(controller, callback, listener));
        }

        /** Finds the closest parent of [view] (inclusive) with a background drawable. */