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

Commit 3bb5e8e5 authored by Tony's avatar Tony
Browse files

Set RecentView's translationX based on to/from state

Also make sure to reset it when setting the state without animation,
otherwise it's possible for recents to stay translated offscreen
when it's not being animated back (e.g. when swiping up after
launching an app from all apps).

Bug: 74602990
Change-Id: Ib0596c84cfb67242f436f9aba8af53556d5ca743
parent 9da6c526
Loading
Loading
Loading
Loading
+5 −0
Original line number Diff line number Diff line
@@ -89,6 +89,11 @@ public class AllAppsState extends LauncherState {
        return 0;
    }

    @Override
    public float getOverviewTranslationX(Launcher launcher) {
        return 0;
    }

    @Override
    public LauncherState getHistoryForState(LauncherState previousState) {
        return previousState == OVERVIEW ? OVERVIEW : NORMAL;
+5 −0
Original line number Diff line number Diff line
@@ -56,6 +56,11 @@ public class OverviewState extends LauncherState {
        return getScaleAndTranslationForPageRect(launcher, pageRect);
    }

    @Override
    public float getOverviewTranslationX(Launcher launcher) {
        return 0;
    }

    @Override
    public void onStateEnabled(Launcher launcher) {
        RecentsView rv = launcher.getOverviewPanel();
+19 −27
Original line number Diff line number Diff line
@@ -16,7 +16,6 @@
package com.android.launcher3.uioverrides;

import static com.android.launcher3.LauncherState.NORMAL;
import static com.android.launcher3.anim.Interpolators.ACCEL;

import android.animation.Animator;
import android.animation.AnimatorListenerAdapter;
@@ -33,7 +32,6 @@ import com.android.launcher3.anim.AnimatorSetBuilder;
import com.android.launcher3.anim.Interpolators;
import com.android.quickstep.AnimatedFloat;
import com.android.quickstep.views.RecentsView;
import com.android.quickstep.views.TaskView;

public class RecentsViewStateController implements StateHandler {

@@ -45,8 +43,6 @@ public class RecentsViewStateController implements StateHandler {
    // overall transition while the RecentsView is being shown or hidden.
    private final AnimatedFloat mVisibilityMultiplier = new AnimatedFloat(this::onVisibilityProgress);

    private boolean mIsRecentsSlidingInOrOut;

    public RecentsViewStateController(Launcher launcher) {
        mLauncher = launcher;
        mRecentsView = launcher.getOverviewPanel();
@@ -59,16 +55,17 @@ public class RecentsViewStateController implements StateHandler {
        if (state.overviewUi) {
            mRecentsView.resetTaskVisuals();
        }
        float overviewTranslationX = state.getOverviewTranslationX(mLauncher);
        int direction = mRecentsView.isRtl() ? -1 : 1;
        mRecentsView.setTranslationX(overviewTranslationX * direction);
    }

    @Override
    public void setStateWithAnimation(final LauncherState toState,
            AnimatorSetBuilder builder, AnimationConfig config) {
        LauncherState fromState = mLauncher.getStateManager().getState();
        mIsRecentsSlidingInOrOut = fromState == NORMAL && toState.overviewUi
                || fromState.overviewUi && toState == NORMAL;

        // Scroll to the workspace card before changing to the NORMAL state.
        LauncherState fromState = mLauncher.getStateManager().getState();
        int currPage = mRecentsView.getCurrentPage();
        if (fromState.overviewUi && toState == NORMAL && currPage != 0 && !config.userControlled) {
            int maxSnapDuration = PagedView.SLOW_PAGE_SNAP_ANIMATION_DURATION;
@@ -83,19 +80,27 @@ public class RecentsViewStateController implements StateHandler {
                mTransitionProgress.animateToValue(toState.overviewUi ? 1 : 0);
        progressAnim.setDuration(config.duration);
        progressAnim.setInterpolator(Interpolators.LINEAR);
        progressAnim.addListener(new AnimationSuccessListener() {

            @Override
            public void onAnimationSuccess(Animator animator) {
                mRecentsView.setCurrentPage(mRecentsView.getPageNearestToCenterOfScreen());
            }
        });
        builder.play(progressAnim);

        ObjectAnimator visibilityAnim = animateVisibility(toState.overviewUi);
        visibilityAnim.setDuration(config.duration);
        visibilityAnim.setInterpolator(Interpolators.LINEAR);
        builder.play(visibilityAnim);

        int direction = mRecentsView.isRtl() ? -1 : 1;
        float fromTranslationX = fromState.getOverviewTranslationX(mLauncher) * direction;
        float toTranslationX = toState.getOverviewTranslationX(mLauncher) * direction;
        ObjectAnimator translationXAnim = ObjectAnimator.ofFloat(mRecentsView, View.TRANSLATION_X,
                fromTranslationX, toTranslationX);
        translationXAnim.setDuration(config.duration);
        translationXAnim.setInterpolator(Interpolators.ACCEL);
        if (toState.overviewUi) {
            translationXAnim.addUpdateListener(valueAnimator -> {
                // While animating into recents, update the visible task data as needed
                mRecentsView.loadVisibleTaskData();
            });
        }
        builder.play(translationXAnim);
    }

    public void setVisibility(boolean isVisible) {
@@ -131,15 +136,6 @@ public class RecentsViewStateController implements StateHandler {

    private void onTransitionProgress() {
        applyProgress();
        if (mIsRecentsSlidingInOrOut) {
            float interpolatedProgress = ACCEL.getInterpolation(mTransitionProgress.value);
            // Slide in from the side as we swipe.
            int translation = mRecentsView.getWidth();
            if (mRecentsView.isRtl()) {
                translation = -translation;
            }
            mRecentsView.setTranslationX(translation * (1 - interpolatedProgress));
        }
    }

    private void onVisibilityProgress() {
@@ -148,9 +144,5 @@ public class RecentsViewStateController implements StateHandler {

    private void applyProgress() {
        mRecentsView.setAlpha(mTransitionProgress.value * mVisibilityMultiplier.value);
        if (mIsRecentsSlidingInOrOut) {
            // While animating into recents, update the visible task data as needed
            mRecentsView.loadVisibleTaskData();
        }
    }
}
+4 −0
Original line number Diff line number Diff line
@@ -165,6 +165,10 @@ public class LauncherState {
        return 1f;
    }

    public float getOverviewTranslationX(Launcher launcher) {
        return launcher.getDragLayer().getMeasuredWidth();
    }

    public void onStateEnabled(Launcher launcher) {
        dispatchWindowStateChanged(launcher);
    }