blob: e9a34953d5e6d3c825eadd42154a42e9858ffb7e [file] [log] [blame]
Sunny Goyal4c7f2152017-10-17 17:17:16 -07001/*
2 * Copyright (C) 2017 The Android Open Source Project
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16package com.android.launcher3;
17
Sunny Goyal210e1742019-10-17 12:05:38 -070018import static com.android.launcher3.anim.Interpolators.ACCEL_2;
Winson Chungf9935182020-10-23 09:26:44 -070019import static com.android.launcher3.logging.StatsLogManager.LAUNCHER_STATE_HOME;
Sunny Goyalab3963d2019-05-23 00:50:08 -070020import static com.android.launcher3.testing.TestProtocol.ALL_APPS_STATE_ORDINAL;
21import static com.android.launcher3.testing.TestProtocol.BACKGROUND_APP_STATE_ORDINAL;
Tony Wickham4fdba142019-11-04 16:23:51 -080022import static com.android.launcher3.testing.TestProtocol.HINT_STATE_ORDINAL;
Sunny Goyalab3963d2019-05-23 00:50:08 -070023import static com.android.launcher3.testing.TestProtocol.NORMAL_STATE_ORDINAL;
Zak Cohena39544d2020-04-27 16:26:55 -070024import static com.android.launcher3.testing.TestProtocol.OVERVIEW_MODAL_TASK_STATE_ORDINAL;
Vinit Nayakd987a822021-02-22 14:49:27 -080025import static com.android.launcher3.testing.TestProtocol.OVERVIEW_SPLIT_SELECT_ORDINAL;
Sunny Goyalab3963d2019-05-23 00:50:08 -070026import static com.android.launcher3.testing.TestProtocol.OVERVIEW_STATE_ORDINAL;
27import static com.android.launcher3.testing.TestProtocol.QUICK_SWITCH_STATE_ORDINAL;
28import static com.android.launcher3.testing.TestProtocol.SPRING_LOADED_STATE_ORDINAL;
Sunny Goyal0c723352017-12-12 12:02:29 -080029
Winson Chung8687bc22020-02-27 23:34:24 -080030import android.content.Context;
Sunny Goyal0c723352017-12-12 12:02:29 -080031import android.view.animation.Interpolator;
Sunny Goyalbe93f262017-10-20 17:05:27 -070032
Sunny Goyal35e7d382020-05-08 13:37:58 -070033import com.android.launcher3.statemanager.BaseState;
34import com.android.launcher3.statemanager.StateManager;
Tony Wickham4fdba142019-11-04 16:23:51 -080035import com.android.launcher3.states.HintState;
Sunny Goyalc99cb172017-10-19 16:15:09 -070036import com.android.launcher3.states.SpringLoadedState;
Tony Wickhamf844ee92020-05-27 15:41:32 -050037import com.android.launcher3.testing.TestProtocol;
Tonye06fef42019-03-22 15:44:28 -050038import com.android.launcher3.uioverrides.states.AllAppsState;
39import com.android.launcher3.uioverrides.states.OverviewState;
Sunny Goyal4c7f2152017-10-17 17:17:16 -070040
Sunny Goyalcd7c0aa2017-10-19 12:36:27 -070041import java.util.Arrays;
42
Sunny Goyal4c7f2152017-10-17 17:17:16 -070043/**
Sunny Goyalbe93f262017-10-20 17:05:27 -070044 * Base state for various states used for the Launcher
Sunny Goyal4c7f2152017-10-17 17:17:16 -070045 */
Sunny Goyal35e7d382020-05-08 13:37:58 -070046public abstract class LauncherState implements BaseState<LauncherState> {
Sunny Goyal4c7f2152017-10-17 17:17:16 -070047
Sunny Goyal7185dd62018-03-14 17:51:49 -070048 /**
49 * Set of elements indicating various workspace elements which change visibility across states
50 * Note that workspace is not included here as in that case, we animate individual pages
51 */
52 public static final int NONE = 0;
Tony Wickhambd6f05e2018-03-21 08:16:33 -070053 public static final int HOTSEAT_ICONS = 1 << 0;
Sunny Goyalc373e1c2021-03-09 17:27:53 -080054 public static final int ALL_APPS_CONTENT = 1 << 1;
55 public static final int VERTICAL_SWIPE_INDICATOR = 1 << 2;
56 public static final int OVERVIEW_ACTIONS = 1 << 3;
57 public static final int TASKBAR = 1 << 4;
58 public static final int CLEAR_ALL_BUTTON = 1 << 5;
59 public static final int WORKSPACE_PAGE_INDICATOR = 1 << 6;
60 public static final int SPLIT_PLACHOLDER_VIEW = 1 << 7;
Zak Cohen43a16152020-02-25 14:29:37 -080061
Sunny Goyal8f965462020-04-23 19:00:36 -070062 // Flag indicating workspace has multiple pages visible.
Sunny Goyal35e7d382020-05-08 13:37:58 -070063 public static final int FLAG_MULTI_PAGE = BaseState.getFlag(0);
Sunny Goyal8f965462020-04-23 19:00:36 -070064 // Flag indicating that workspace and its contents are not accessible
Sunny Goyal35e7d382020-05-08 13:37:58 -070065 public static final int FLAG_WORKSPACE_INACCESSIBLE = BaseState.getFlag(1);
Sunny Goyal8f965462020-04-23 19:00:36 -070066
Sunny Goyal8f965462020-04-23 19:00:36 -070067 // Flag indicating the state allows workspace icons to be dragged.
Sunny Goyal35e7d382020-05-08 13:37:58 -070068 public static final int FLAG_WORKSPACE_ICONS_CAN_BE_DRAGGED = BaseState.getFlag(2);
Sunny Goyal8f965462020-04-23 19:00:36 -070069 // Flag to indicate that workspace should draw page background
Sunny Goyal35e7d382020-05-08 13:37:58 -070070 public static final int FLAG_WORKSPACE_HAS_BACKGROUNDS = BaseState.getFlag(3);
Sunny Goyal8f965462020-04-23 19:00:36 -070071 // True if the back button should be hidden when in this state (assuming no floating views are
72 // open, launcher has window focus, etc).
Sunny Goyal35e7d382020-05-08 13:37:58 -070073 public static final int FLAG_HIDE_BACK_BUTTON = BaseState.getFlag(4);
Sunny Goyal8f965462020-04-23 19:00:36 -070074 // Flag to indicate if the state would have scrim over sysui region: statu sbar and nav bar
Sunny Goyal35e7d382020-05-08 13:37:58 -070075 public static final int FLAG_HAS_SYS_UI_SCRIM = BaseState.getFlag(5);
Sunny Goyal8f965462020-04-23 19:00:36 -070076 // Flag to inticate that all popups should be closed when this state is enabled.
Sunny Goyal35e7d382020-05-08 13:37:58 -070077 public static final int FLAG_CLOSE_POPUPS = BaseState.getFlag(6);
78 public static final int FLAG_OVERVIEW_UI = BaseState.getFlag(7);
Sunny Goyal8f965462020-04-23 19:00:36 -070079
Sunny Goyal6c6c2f42018-03-02 14:57:46 -080080
Sunny Goyalf2393f12020-04-01 20:13:12 -070081 public static final float NO_OFFSET = 0;
82 public static final float NO_SCALE = 1;
83
Sunny Goyal0c723352017-12-12 12:02:29 -080084 protected static final PageAlphaProvider DEFAULT_ALPHA_PROVIDER =
85 new PageAlphaProvider(ACCEL_2) {
86 @Override
87 public float getPageAlpha(int pageIndex) {
88 return 1;
89 }
90 };
Sunny Goyalcd7c0aa2017-10-19 12:36:27 -070091
Zak Cohena39544d2020-04-27 16:26:55 -070092 private static final LauncherState[] sAllStates = new LauncherState[9];
Sunny Goyalcd7c0aa2017-10-19 12:36:27 -070093
Sunny Goyal75c59ac2018-01-15 14:23:11 -080094 /**
95 * TODO: Create a separate class for NORMAL state.
96 */
vadimt6895e402019-02-15 16:42:14 -080097 public static final LauncherState NORMAL = new LauncherState(NORMAL_STATE_ORDINAL,
Winson Chungf9935182020-10-23 09:26:44 -070098 LAUNCHER_STATE_HOME,
Sunny Goyal5d1873a2018-05-08 11:10:44 -070099 FLAG_DISABLE_RESTORE | FLAG_WORKSPACE_ICONS_CAN_BE_DRAGGED | FLAG_HIDE_BACK_BUTTON |
Tony Wickhamc7203ad2020-02-03 18:36:06 -0800100 FLAG_HAS_SYS_UI_SCRIM) {
101 @Override
Sunny Goyal8f965462020-04-23 19:00:36 -0700102 public int getTransitionDuration(Context context) {
Tony Wickhamc7203ad2020-02-03 18:36:06 -0800103 // Arbitrary duration, when going to NORMAL we use the state we're coming from instead.
104 return 0;
105 }
106 };
Sunny Goyalcd7c0aa2017-10-19 12:36:27 -0700107
Sunny Goyal7185dd62018-03-14 17:51:49 -0700108 /**
109 * Various Launcher states arranged in the increasing order of UI layers
110 */
vadimt2a648aa2019-02-14 17:47:11 -0800111 public static final LauncherState SPRING_LOADED = new SpringLoadedState(
112 SPRING_LOADED_STATE_ORDINAL);
vadimt2a648aa2019-02-14 17:47:11 -0800113 public static final LauncherState ALL_APPS = new AllAppsState(ALL_APPS_STATE_ORDINAL);
Tony Wickham4fdba142019-11-04 16:23:51 -0800114 public static final LauncherState HINT_STATE = new HintState(HINT_STATE_ORDINAL);
Tony1787ee92019-03-20 12:38:35 -0500115
116 public static final LauncherState OVERVIEW = new OverviewState(OVERVIEW_STATE_ORDINAL);
Zak Cohena39544d2020-04-27 16:26:55 -0700117 public static final LauncherState OVERVIEW_MODAL_TASK = OverviewState.newModalTaskState(
118 OVERVIEW_MODAL_TASK_STATE_ORDINAL);
Tonye4c2e2b2019-03-25 10:23:39 -0500119 public static final LauncherState QUICK_SWITCH =
120 OverviewState.newSwitchState(QUICK_SWITCH_STATE_ORDINAL);
Tony1787ee92019-03-20 12:38:35 -0500121 public static final LauncherState BACKGROUND_APP =
122 OverviewState.newBackgroundState(BACKGROUND_APP_STATE_ORDINAL);
Vinit Nayakd987a822021-02-22 14:49:27 -0800123 public static final LauncherState OVERVIEW_SPLIT_SELECT =
124 OverviewState.newSplitSelectState(OVERVIEW_SPLIT_SELECT_ORDINAL);
Tony Wickham6becf7c2018-04-19 11:39:34 -0700125
Sunny Goyalcd7c0aa2017-10-19 12:36:27 -0700126 public final int ordinal;
127
Sunny Goyalf9403d92017-10-18 10:55:56 -0700128 /**
Winson Chungf9935182020-10-23 09:26:44 -0700129 * Used for {@link com.android.launcher3.logging.StatsLogManager}
Sunny Goyalf9403d92017-10-18 10:55:56 -0700130 */
Winson Chungf9935182020-10-23 09:26:44 -0700131 public final int statsLogOrdinal;
Sunny Goyal4c7f2152017-10-17 17:17:16 -0700132
Sunny Goyalf9403d92017-10-18 10:55:56 -0700133 /**
Sunny Goyal6c6c2f42018-03-02 14:57:46 -0800134 * True if the state has overview panel visible.
135 */
136 public final boolean overviewUi;
137
Sunny Goyal8f965462020-04-23 19:00:36 -0700138 private final int mFlags;
Sunny Goyal5d1873a2018-05-08 11:10:44 -0700139
Winson Chungf9935182020-10-23 09:26:44 -0700140 public LauncherState(int id, int statsLogOrdinal, int flags) {
141 this.statsLogOrdinal = statsLogOrdinal;
Sunny Goyal8f965462020-04-23 19:00:36 -0700142 this.mFlags = flags;
Sunny Goyal6c6c2f42018-03-02 14:57:46 -0800143 this.overviewUi = (flags & FLAG_OVERVIEW_UI) != 0;
Sunny Goyalcd7c0aa2017-10-19 12:36:27 -0700144 this.ordinal = id;
145 sAllStates[id] = this;
146 }
147
Sunny Goyal8f965462020-04-23 19:00:36 -0700148 /**
149 * Returns if the state has the provided flag
150 */
Sunny Goyal35e7d382020-05-08 13:37:58 -0700151 @Override
Sunny Goyal8f965462020-04-23 19:00:36 -0700152 public final boolean hasFlag(int mask) {
153 return (mFlags & mask) != 0;
154 }
155
Sunny Goyalcd7c0aa2017-10-19 12:36:27 -0700156 public static LauncherState[] values() {
157 return Arrays.copyOf(sAllStates, sAllStates.length);
Sunny Goyal4c7f2152017-10-17 17:17:16 -0700158 }
Sunny Goyalc99cb172017-10-19 16:15:09 -0700159
Tonybc234402019-03-19 13:30:25 -0500160 public ScaleAndTranslation getWorkspaceScaleAndTranslation(Launcher launcher) {
Sunny Goyalf2393f12020-04-01 20:13:12 -0700161 return new ScaleAndTranslation(NO_SCALE, NO_OFFSET, NO_OFFSET);
Sunny Goyalc99cb172017-10-19 16:15:09 -0700162 }
163
Tonybc234402019-03-19 13:30:25 -0500164 public ScaleAndTranslation getHotseatScaleAndTranslation(Launcher launcher) {
Tony Wickham57e489c2019-03-04 14:57:07 -0800165 // For most states, treat the hotseat as if it were part of the workspace.
166 return getWorkspaceScaleAndTranslation(launcher);
Tony4bb4b892019-03-03 15:32:12 -0800167 }
168
Sunny Goyalf2393f12020-04-01 20:13:12 -0700169 /**
170 * Returns an array of two elements.
Samuel Fufa2ea01e42020-12-02 13:48:18 -0600171 * The first specifies the scale for the overview
172 * The second is the factor ([0, 1], 0 => center-screen; 1 => offscreen) by which overview
173 * should be shifted horizontally.
Sunny Goyalf2393f12020-04-01 20:13:12 -0700174 */
175 public float[] getOverviewScaleAndOffset(Launcher launcher) {
176 return launcher.getNormalOverviewScaleAndOffset();
Tony3bb5e8e2018-03-14 12:05:00 +0000177 }
178
Tony Wickham4fdba142019-11-04 16:23:51 -0800179 public ScaleAndTranslation getQsbScaleAndTranslation(Launcher launcher) {
Sunny Goyalf2393f12020-04-01 20:13:12 -0700180 return new ScaleAndTranslation(NO_SCALE, NO_OFFSET, NO_OFFSET);
Tony Wickham4fdba142019-11-04 16:23:51 -0800181 }
182
Tony54068172019-05-12 13:24:51 -0500183 public float getOverviewFullscreenProgress() {
184 return 0;
185 }
186
Sunny Goyal7185dd62018-03-14 17:51:49 -0700187 public int getVisibleElements(Launcher launcher) {
Tony Wickhama29a0462021-03-02 12:28:25 -0800188 DeviceProfile deviceProfile = launcher.getDeviceProfile();
189 int flags = WORKSPACE_PAGE_INDICATOR | VERTICAL_SWIPE_INDICATOR | TASKBAR;
Tony Wickhama29a0462021-03-02 12:28:25 -0800190 if (!deviceProfile.isTaskbarPresent) {
191 flags |= HOTSEAT_ICONS;
192 }
Samuel Fufa2ea01e42020-12-02 13:48:18 -0600193 return flags;
Sunny Goyal7185dd62018-03-14 17:51:49 -0700194 }
195
Sunny Goyal228153d2018-01-04 15:35:22 -0800196 /**
Tony Wickhama29a0462021-03-02 12:28:25 -0800197 * A shorthand for checking getVisibleElements() & elements == elements.
198 * @return Whether all of the given elements are visible.
199 */
200 public boolean areElementsVisible(Launcher launcher, int elements) {
201 return (getVisibleElements(launcher) & elements) == elements;
202 }
203
204 /**
Sunny Goyal228153d2018-01-04 15:35:22 -0800205 * Fraction shift in the vertical translation UI and related properties
206 *
207 * @see com.android.launcher3.allapps.AllAppsTransitionController
208 */
209 public float getVerticalProgress(Launcher launcher) {
210 return 1f;
211 }
212
Sunny Goyal927447e2018-05-04 13:19:29 -0700213 public float getWorkspaceScrimAlpha(Launcher launcher) {
214 return 0;
215 }
216
Tony Wickhamc0880512019-07-24 17:32:08 -0700217 public float getOverviewScrimAlpha(Launcher launcher) {
218 return 0;
219 }
220
Winson Chung8687bc22020-02-27 23:34:24 -0800221 /**
Zak Cohena39544d2020-04-27 16:26:55 -0700222 * For this state, how modal should over view been shown. 0 modalness means all tasks drawn,
223 * 1 modalness means the current task is show on its own.
224 */
225 public float getOverviewModalness() {
226 return 0;
227 }
228
229 /**
Vinit Nayakd987a822021-02-22 14:49:27 -0800230 * For this state, how much additional vertical translation there should be for each of the
231 * child TaskViews.
232 */
233 public float getOverviewSecondaryTranslation(Launcher launcher) {
234 return 0;
235 }
236
237 /**
Lucas Dupin4918ed32020-03-17 17:11:32 -0700238 * The amount of blur and wallpaper zoom to apply to the background of either the app
239 * or Launcher surface in this state. Should be a number between 0 and 1, inclusive.
240 *
241 * 0 means completely zoomed in, without blurs. 1 is zoomed out, with blurs.
Winson Chung8687bc22020-02-27 23:34:24 -0800242 */
Winson Chungb330d6e2020-04-20 11:57:11 -0700243 public final float getDepth(Context context) {
Jon Miranda36d10152020-06-19 16:35:08 -0700244 return getDepth(context,
245 BaseDraggingActivity.fromContext(context).getDeviceProfile().isMultiWindowMode);
246 }
247
248 /**
249 * Returns the amount of blur and wallpaper zoom for this state with {@param isMultiWindowMode}.
Samuel Fufa2ea01e42020-12-02 13:48:18 -0600250 *
Jon Miranda36d10152020-06-19 16:35:08 -0700251 * @see #getDepth(Context).
252 */
253 public final float getDepth(Context context, boolean isMultiWindowMode) {
254 if (isMultiWindowMode) {
Winson Chungb330d6e2020-04-20 11:57:11 -0700255 return 0;
256 }
257 return getDepthUnchecked(context);
258 }
259
260 protected float getDepthUnchecked(Context context) {
Lucas Dupin4918ed32020-03-17 17:11:32 -0700261 return 0f;
Winson Chung8687bc22020-02-27 23:34:24 -0800262 }
263
Sunny Goyal3e3f44c2017-10-23 17:14:52 -0700264 public String getDescription(Launcher launcher) {
265 return launcher.getWorkspace().getCurrentPageDescription();
266 }
267
Sunny Goyalbc683e92017-12-06 10:25:07 -0800268 public PageAlphaProvider getWorkspacePageAlphaProvider(Launcher launcher) {
Jon Mirandae3832222020-07-06 15:38:38 -0700269 if ((this != NORMAL && this != HINT_STATE)
270 || !launcher.getDeviceProfile().shouldFadeAdjacentWorkspaceScreens()) {
Sunny Goyalbc683e92017-12-06 10:25:07 -0800271 return DEFAULT_ALPHA_PROVIDER;
272 }
Sunny Goyal228153d2018-01-04 15:35:22 -0800273 final int centerPage = launcher.getWorkspace().getNextPage();
Sunny Goyal0c723352017-12-12 12:02:29 -0800274 return new PageAlphaProvider(ACCEL_2) {
275 @Override
276 public float getPageAlpha(int pageIndex) {
Samuel Fufa2ea01e42020-12-02 13:48:18 -0600277 return pageIndex != centerPage ? 0 : 1f;
Sunny Goyal0c723352017-12-12 12:02:29 -0800278 }
279 };
Sunny Goyalbc683e92017-12-06 10:25:07 -0800280 }
281
Sunny Goyal35e7d382020-05-08 13:37:58 -0700282 @Override
Sunny Goyal49bcf342018-01-11 13:59:53 -0800283 public LauncherState getHistoryForState(LauncherState previousState) {
284 // No history is supported
285 return NORMAL;
286 }
287
Sunny Goyal35e7d382020-05-08 13:37:58 -0700288 @Override
289 public String toString() {
Tony Wickhamf844ee92020-05-27 15:41:32 -0500290 return TestProtocol.stateOrdinalToString(ordinal);
Sunny Goyal35e7d382020-05-08 13:37:58 -0700291 }
292
Sunny Goyale39690b2018-08-02 13:35:07 -0700293 public void onBackPressed(Launcher launcher) {
294 if (this != NORMAL) {
Sunny Goyal35e7d382020-05-08 13:37:58 -0700295 StateManager<LauncherState> lsm = launcher.getStateManager();
Sunny Goyale39690b2018-08-02 13:35:07 -0700296 LauncherState lastState = lsm.getLastState();
Sunny Goyale39690b2018-08-02 13:35:07 -0700297 lsm.goToState(lastState);
298 }
299 }
300
Sunny Goyal0c723352017-12-12 12:02:29 -0800301 public static abstract class PageAlphaProvider {
Sunny Goyalbc683e92017-12-06 10:25:07 -0800302
Sunny Goyal0c723352017-12-12 12:02:29 -0800303 public final Interpolator interpolator;
304
305 public PageAlphaProvider(Interpolator interpolator) {
306 this.interpolator = interpolator;
307 }
308
309 public abstract float getPageAlpha(int pageIndex);
Sunny Goyalbc683e92017-12-06 10:25:07 -0800310 }
Tonybc234402019-03-19 13:30:25 -0500311
312 public static class ScaleAndTranslation {
313 public float scale;
314 public float translationX;
315 public float translationY;
316
317 public ScaleAndTranslation(float scale, float translationX, float translationY) {
318 this.scale = scale;
319 this.translationX = translationX;
320 this.translationY = translationY;
321 }
322 }
Sunny Goyal4c7f2152017-10-17 17:17:16 -0700323}