blob: 7985ab5ad34e8edab61615c1da3e7d1a0781d41f [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;
Tony Wickhamc5d168d2021-03-25 09:28:19 -070020import static com.android.launcher3.logging.StatsLogManager.LAUNCHER_STATE_OVERVIEW;
Sunny Goyalab3963d2019-05-23 00:50:08 -070021import static com.android.launcher3.testing.TestProtocol.ALL_APPS_STATE_ORDINAL;
22import static com.android.launcher3.testing.TestProtocol.BACKGROUND_APP_STATE_ORDINAL;
Tony Wickham4fdba142019-11-04 16:23:51 -080023import static com.android.launcher3.testing.TestProtocol.HINT_STATE_ORDINAL;
Tony Wickhamc5d168d2021-03-25 09:28:19 -070024import static com.android.launcher3.testing.TestProtocol.HINT_STATE_TWO_BUTTON_ORDINAL;
Sunny Goyalab3963d2019-05-23 00:50:08 -070025import static com.android.launcher3.testing.TestProtocol.NORMAL_STATE_ORDINAL;
Zak Cohena39544d2020-04-27 16:26:55 -070026import static com.android.launcher3.testing.TestProtocol.OVERVIEW_MODAL_TASK_STATE_ORDINAL;
Vinit Nayakd987a822021-02-22 14:49:27 -080027import static com.android.launcher3.testing.TestProtocol.OVERVIEW_SPLIT_SELECT_ORDINAL;
Sunny Goyalab3963d2019-05-23 00:50:08 -070028import static com.android.launcher3.testing.TestProtocol.OVERVIEW_STATE_ORDINAL;
29import static com.android.launcher3.testing.TestProtocol.QUICK_SWITCH_STATE_ORDINAL;
30import static com.android.launcher3.testing.TestProtocol.SPRING_LOADED_STATE_ORDINAL;
Sunny Goyal0c723352017-12-12 12:02:29 -080031
Winson Chung8687bc22020-02-27 23:34:24 -080032import android.content.Context;
Zak Cohen4d35ac32021-04-23 16:28:12 -070033import android.graphics.Color;
Sunny Goyal0c723352017-12-12 12:02:29 -080034import android.view.animation.Interpolator;
Sunny Goyalbe93f262017-10-20 17:05:27 -070035
Sunny Goyal35e7d382020-05-08 13:37:58 -070036import com.android.launcher3.statemanager.BaseState;
37import com.android.launcher3.statemanager.StateManager;
Tony Wickham4fdba142019-11-04 16:23:51 -080038import com.android.launcher3.states.HintState;
Sunny Goyalc99cb172017-10-19 16:15:09 -070039import com.android.launcher3.states.SpringLoadedState;
Tony Wickhamf844ee92020-05-27 15:41:32 -050040import com.android.launcher3.testing.TestProtocol;
Tonye06fef42019-03-22 15:44:28 -050041import com.android.launcher3.uioverrides.states.AllAppsState;
42import com.android.launcher3.uioverrides.states.OverviewState;
Sunny Goyal4c7f2152017-10-17 17:17:16 -070043
Sunny Goyalcd7c0aa2017-10-19 12:36:27 -070044import java.util.Arrays;
45
Sunny Goyal4c7f2152017-10-17 17:17:16 -070046/**
Sunny Goyalbe93f262017-10-20 17:05:27 -070047 * Base state for various states used for the Launcher
Sunny Goyal4c7f2152017-10-17 17:17:16 -070048 */
Sunny Goyal35e7d382020-05-08 13:37:58 -070049public abstract class LauncherState implements BaseState<LauncherState> {
Sunny Goyal4c7f2152017-10-17 17:17:16 -070050
Sunny Goyal7185dd62018-03-14 17:51:49 -070051 /**
52 * Set of elements indicating various workspace elements which change visibility across states
53 * Note that workspace is not included here as in that case, we animate individual pages
54 */
55 public static final int NONE = 0;
Tony Wickhambd6f05e2018-03-21 08:16:33 -070056 public static final int HOTSEAT_ICONS = 1 << 0;
Sunny Goyalc373e1c2021-03-09 17:27:53 -080057 public static final int ALL_APPS_CONTENT = 1 << 1;
58 public static final int VERTICAL_SWIPE_INDICATOR = 1 << 2;
59 public static final int OVERVIEW_ACTIONS = 1 << 3;
60 public static final int TASKBAR = 1 << 4;
61 public static final int CLEAR_ALL_BUTTON = 1 << 5;
62 public static final int WORKSPACE_PAGE_INDICATOR = 1 << 6;
63 public static final int SPLIT_PLACHOLDER_VIEW = 1 << 7;
Zak Cohen43a16152020-02-25 14:29:37 -080064
Sunny Goyal8f965462020-04-23 19:00:36 -070065 // Flag indicating workspace has multiple pages visible.
Sunny Goyal35e7d382020-05-08 13:37:58 -070066 public static final int FLAG_MULTI_PAGE = BaseState.getFlag(0);
Sunny Goyal8f965462020-04-23 19:00:36 -070067 // Flag indicating that workspace and its contents are not accessible
Sunny Goyal35e7d382020-05-08 13:37:58 -070068 public static final int FLAG_WORKSPACE_INACCESSIBLE = BaseState.getFlag(1);
Sunny Goyal8f965462020-04-23 19:00:36 -070069
Sunny Goyal8f965462020-04-23 19:00:36 -070070 // Flag indicating the state allows workspace icons to be dragged.
Sunny Goyal35e7d382020-05-08 13:37:58 -070071 public static final int FLAG_WORKSPACE_ICONS_CAN_BE_DRAGGED = BaseState.getFlag(2);
Sunny Goyal8f965462020-04-23 19:00:36 -070072 // Flag to indicate that workspace should draw page background
Sunny Goyal35e7d382020-05-08 13:37:58 -070073 public static final int FLAG_WORKSPACE_HAS_BACKGROUNDS = BaseState.getFlag(3);
Sunny Goyal8f965462020-04-23 19:00:36 -070074 // True if the back button should be hidden when in this state (assuming no floating views are
75 // open, launcher has window focus, etc).
Sunny Goyal35e7d382020-05-08 13:37:58 -070076 public static final int FLAG_HIDE_BACK_BUTTON = BaseState.getFlag(4);
Sunny Goyal8f965462020-04-23 19:00:36 -070077 // Flag to indicate if the state would have scrim over sysui region: statu sbar and nav bar
Sunny Goyal35e7d382020-05-08 13:37:58 -070078 public static final int FLAG_HAS_SYS_UI_SCRIM = BaseState.getFlag(5);
Sunny Goyal8f965462020-04-23 19:00:36 -070079 // Flag to inticate that all popups should be closed when this state is enabled.
Sunny Goyal35e7d382020-05-08 13:37:58 -070080 public static final int FLAG_CLOSE_POPUPS = BaseState.getFlag(6);
81 public static final int FLAG_OVERVIEW_UI = BaseState.getFlag(7);
Sunny Goyal8f965462020-04-23 19:00:36 -070082
Sunny Goyal6c6c2f42018-03-02 14:57:46 -080083
Sunny Goyalf2393f12020-04-01 20:13:12 -070084 public static final float NO_OFFSET = 0;
85 public static final float NO_SCALE = 1;
86
Sunny Goyal0c723352017-12-12 12:02:29 -080087 protected static final PageAlphaProvider DEFAULT_ALPHA_PROVIDER =
88 new PageAlphaProvider(ACCEL_2) {
89 @Override
90 public float getPageAlpha(int pageIndex) {
91 return 1;
92 }
93 };
Sunny Goyalcd7c0aa2017-10-19 12:36:27 -070094
Tony Wickhamc5d168d2021-03-25 09:28:19 -070095 private static final LauncherState[] sAllStates = new LauncherState[10];
Sunny Goyalcd7c0aa2017-10-19 12:36:27 -070096
Sunny Goyal75c59ac2018-01-15 14:23:11 -080097 /**
98 * TODO: Create a separate class for NORMAL state.
99 */
vadimt6895e402019-02-15 16:42:14 -0800100 public static final LauncherState NORMAL = new LauncherState(NORMAL_STATE_ORDINAL,
Winson Chungf9935182020-10-23 09:26:44 -0700101 LAUNCHER_STATE_HOME,
Sunny Goyal5d1873a2018-05-08 11:10:44 -0700102 FLAG_DISABLE_RESTORE | FLAG_WORKSPACE_ICONS_CAN_BE_DRAGGED | FLAG_HIDE_BACK_BUTTON |
Tony Wickhamc7203ad2020-02-03 18:36:06 -0800103 FLAG_HAS_SYS_UI_SCRIM) {
104 @Override
Sunny Goyal8f965462020-04-23 19:00:36 -0700105 public int getTransitionDuration(Context context) {
Tony Wickhamc7203ad2020-02-03 18:36:06 -0800106 // Arbitrary duration, when going to NORMAL we use the state we're coming from instead.
107 return 0;
108 }
109 };
Sunny Goyalcd7c0aa2017-10-19 12:36:27 -0700110
Sunny Goyal7185dd62018-03-14 17:51:49 -0700111 /**
112 * Various Launcher states arranged in the increasing order of UI layers
113 */
vadimt2a648aa2019-02-14 17:47:11 -0800114 public static final LauncherState SPRING_LOADED = new SpringLoadedState(
115 SPRING_LOADED_STATE_ORDINAL);
vadimt2a648aa2019-02-14 17:47:11 -0800116 public static final LauncherState ALL_APPS = new AllAppsState(ALL_APPS_STATE_ORDINAL);
Tony Wickham4fdba142019-11-04 16:23:51 -0800117 public static final LauncherState HINT_STATE = new HintState(HINT_STATE_ORDINAL);
Tony Wickhamc5d168d2021-03-25 09:28:19 -0700118 public static final LauncherState HINT_STATE_TWO_BUTTON = new HintState(
119 HINT_STATE_TWO_BUTTON_ORDINAL, LAUNCHER_STATE_OVERVIEW);
Tony1787ee92019-03-20 12:38:35 -0500120
121 public static final LauncherState OVERVIEW = new OverviewState(OVERVIEW_STATE_ORDINAL);
Zak Cohena39544d2020-04-27 16:26:55 -0700122 public static final LauncherState OVERVIEW_MODAL_TASK = OverviewState.newModalTaskState(
123 OVERVIEW_MODAL_TASK_STATE_ORDINAL);
Tonye4c2e2b2019-03-25 10:23:39 -0500124 public static final LauncherState QUICK_SWITCH =
125 OverviewState.newSwitchState(QUICK_SWITCH_STATE_ORDINAL);
Tony1787ee92019-03-20 12:38:35 -0500126 public static final LauncherState BACKGROUND_APP =
127 OverviewState.newBackgroundState(BACKGROUND_APP_STATE_ORDINAL);
Vinit Nayakd987a822021-02-22 14:49:27 -0800128 public static final LauncherState OVERVIEW_SPLIT_SELECT =
129 OverviewState.newSplitSelectState(OVERVIEW_SPLIT_SELECT_ORDINAL);
Tony Wickham6becf7c2018-04-19 11:39:34 -0700130
Sunny Goyalcd7c0aa2017-10-19 12:36:27 -0700131 public final int ordinal;
132
Sunny Goyalf9403d92017-10-18 10:55:56 -0700133 /**
Winson Chungf9935182020-10-23 09:26:44 -0700134 * Used for {@link com.android.launcher3.logging.StatsLogManager}
Sunny Goyalf9403d92017-10-18 10:55:56 -0700135 */
Winson Chungf9935182020-10-23 09:26:44 -0700136 public final int statsLogOrdinal;
Sunny Goyal4c7f2152017-10-17 17:17:16 -0700137
Sunny Goyalf9403d92017-10-18 10:55:56 -0700138 /**
Sunny Goyal6c6c2f42018-03-02 14:57:46 -0800139 * True if the state has overview panel visible.
140 */
141 public final boolean overviewUi;
142
Sunny Goyal8f965462020-04-23 19:00:36 -0700143 private final int mFlags;
Sunny Goyal5d1873a2018-05-08 11:10:44 -0700144
Winson Chungf9935182020-10-23 09:26:44 -0700145 public LauncherState(int id, int statsLogOrdinal, int flags) {
146 this.statsLogOrdinal = statsLogOrdinal;
Sunny Goyal8f965462020-04-23 19:00:36 -0700147 this.mFlags = flags;
Sunny Goyal6c6c2f42018-03-02 14:57:46 -0800148 this.overviewUi = (flags & FLAG_OVERVIEW_UI) != 0;
Sunny Goyalcd7c0aa2017-10-19 12:36:27 -0700149 this.ordinal = id;
150 sAllStates[id] = this;
151 }
152
Sunny Goyal8f965462020-04-23 19:00:36 -0700153 /**
154 * Returns if the state has the provided flag
155 */
Sunny Goyal35e7d382020-05-08 13:37:58 -0700156 @Override
Sunny Goyal8f965462020-04-23 19:00:36 -0700157 public final boolean hasFlag(int mask) {
158 return (mFlags & mask) != 0;
159 }
160
Sunny Goyalcd7c0aa2017-10-19 12:36:27 -0700161 public static LauncherState[] values() {
162 return Arrays.copyOf(sAllStates, sAllStates.length);
Sunny Goyal4c7f2152017-10-17 17:17:16 -0700163 }
Sunny Goyalc99cb172017-10-19 16:15:09 -0700164
Tonybc234402019-03-19 13:30:25 -0500165 public ScaleAndTranslation getWorkspaceScaleAndTranslation(Launcher launcher) {
Sunny Goyalf2393f12020-04-01 20:13:12 -0700166 return new ScaleAndTranslation(NO_SCALE, NO_OFFSET, NO_OFFSET);
Sunny Goyalc99cb172017-10-19 16:15:09 -0700167 }
168
Tonybc234402019-03-19 13:30:25 -0500169 public ScaleAndTranslation getHotseatScaleAndTranslation(Launcher launcher) {
Tony Wickham57e489c2019-03-04 14:57:07 -0800170 // For most states, treat the hotseat as if it were part of the workspace.
171 return getWorkspaceScaleAndTranslation(launcher);
Tony4bb4b892019-03-03 15:32:12 -0800172 }
173
Sunny Goyalf2393f12020-04-01 20:13:12 -0700174 /**
Tony Wickham82d5a062021-05-14 14:37:12 -0700175 * Returns an array of two elements.
Samuel Fufa2ea01e42020-12-02 13:48:18 -0600176 * The first specifies the scale for the overview
177 * The second is the factor ([0, 1], 0 => center-screen; 1 => offscreen) by which overview
178 * should be shifted horizontally.
Sunny Goyalf2393f12020-04-01 20:13:12 -0700179 */
180 public float[] getOverviewScaleAndOffset(Launcher launcher) {
181 return launcher.getNormalOverviewScaleAndOffset();
Tony3bb5e8e2018-03-14 12:05:00 +0000182 }
183
Tony54068172019-05-12 13:24:51 -0500184 public float getOverviewFullscreenProgress() {
185 return 0;
186 }
187
Sunny Goyal7185dd62018-03-14 17:51:49 -0700188 public int getVisibleElements(Launcher launcher) {
Tony Wickham9ce3b252021-03-22 14:43:58 -0700189 return HOTSEAT_ICONS | WORKSPACE_PAGE_INDICATOR | VERTICAL_SWIPE_INDICATOR | TASKBAR;
Sunny Goyal7185dd62018-03-14 17:51:49 -0700190 }
191
Sunny Goyal228153d2018-01-04 15:35:22 -0800192 /**
Tony Wickhama29a0462021-03-02 12:28:25 -0800193 * A shorthand for checking getVisibleElements() & elements == elements.
194 * @return Whether all of the given elements are visible.
195 */
196 public boolean areElementsVisible(Launcher launcher, int elements) {
197 return (getVisibleElements(launcher) & elements) == elements;
198 }
199
200 /**
Sunny Goyal228153d2018-01-04 15:35:22 -0800201 * Fraction shift in the vertical translation UI and related properties
202 *
203 * @see com.android.launcher3.allapps.AllAppsTransitionController
204 */
205 public float getVerticalProgress(Launcher launcher) {
206 return 1f;
207 }
208
Sunny Goyalc82916f2021-04-06 13:03:54 -0700209 public float getWorkspaceBackgroundAlpha(Launcher launcher) {
Sunny Goyal927447e2018-05-04 13:19:29 -0700210 return 0;
211 }
212
Zak Cohen4d35ac32021-04-23 16:28:12 -0700213 /**
214 * What color should the workspace scrim be in when at rest in this state.
215 * Return {@link Color#TRANSPARENT} for no scrim.
216 */
217 public int getWorkspaceScrimColor(Launcher launcher) {
218 return Color.TRANSPARENT;
Tony Wickhamc0880512019-07-24 17:32:08 -0700219 }
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 Nayakf4f0c4d2021-05-05 10:28:05 -0700230 * For this state, how much additional translation there should be for each of the
231 * child TaskViews. Note that the translation can be its primary or secondary dimension.
Vinit Nayakd987a822021-02-22 14:49:27 -0800232 */
Vinit Nayakf4f0c4d2021-05-05 10:28:05 -0700233 public float getSplitSelectTranslation(Launcher launcher) {
Vinit Nayakd987a822021-02-22 14:49:27 -0800234 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}