396441545f
desktopCarouselDetachProgress: - Controls whether desktop and fullscreen carousel is attached (RecentsView..DESKTOP_CAROUSEL_DETACH_PROGRESS) - When fully detached (progress==1), hide the carousel (RecentsView.applyAttachAlpha) - As the detach progress increase, we animate the other carousel away by using `getMaxHorizontalOffsetSize`, with additional maxOverscroll to make sure the other carousel won't be seen even if user overscroll RecentsView (RecentsView.updatePageOffsets) min/max scroll changes - When desktop and fullscreen carousel detaches, disallow scrolling to the detached carousel. This avoids quickswitching or scroll to the other carousel (RecentsView.getFirstViewIndex and RecentsView.getLastViewIndex) State machine changes: - On Overview states, desktop and fullscreen carousel is attached. Otherwise, they're detached, including in quick switch and home. (BaseState, RecentsState, OverviewState, BackgroundAppState) - StateController set/animate desktopCarouselDetachProgress between the above states (BaseRecentsViewStateController, FallbackRecentsStateController) - On swipe up gesture release and going to Overview, animate attaching back the 2 carousels (RecentsView.onPrepareGestureEndAnimation) Bug: 353948100 Test: quick switch; swipe from home/app; scroll in Overview; with normal/3p launcher Flag: com.android.launcher3.enable_large_desktop_windowing_tile Change-Id: Ic4217efb07db079825a3210afd306d9ef627c873
89 lines
2.6 KiB
Java
89 lines
2.6 KiB
Java
/*
|
|
* Copyright (C) 2020 The Android Open Source Project
|
|
*
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
* you may not use this file except in compliance with the License.
|
|
* You may obtain a copy of the License at
|
|
*
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
*
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
* See the License for the specific language governing permissions and
|
|
* limitations under the License.
|
|
*/
|
|
package com.android.launcher3.statemanager;
|
|
|
|
import android.content.Context;
|
|
|
|
import com.android.launcher3.DeviceProfile;
|
|
import com.android.launcher3.views.ActivityContext;
|
|
|
|
/**
|
|
* Interface representing a state of a StatefulContainer
|
|
*/
|
|
public interface BaseState<T extends BaseState> {
|
|
|
|
// Flag to indicate that Launcher is non-interactive in this state
|
|
int FLAG_NON_INTERACTIVE = 1 << 0;
|
|
int FLAG_DISABLE_RESTORE = 1 << 1;
|
|
|
|
static int getFlag(int index) {
|
|
// reserve few spots to base flags
|
|
return 1 << (index + 2);
|
|
}
|
|
|
|
/**
|
|
* @return How long the animation to this state should take (or from this state to NORMAL).
|
|
*/
|
|
<DEVICE_PROFILE_CONTEXT extends Context & ActivityContext>
|
|
int getTransitionDuration(DEVICE_PROFILE_CONTEXT context, boolean isToState);
|
|
|
|
/**
|
|
* Returns the state to go back to from this state
|
|
*/
|
|
T getHistoryForState(T previousState);
|
|
|
|
/**
|
|
* @return true if the state can be persisted across activity restarts.
|
|
*/
|
|
default boolean shouldDisableRestore() {
|
|
return hasFlag(FLAG_DISABLE_RESTORE);
|
|
}
|
|
|
|
/**
|
|
* Returns if the state has the provided flag
|
|
*/
|
|
boolean hasFlag(int flagMask);
|
|
|
|
/**
|
|
* For this state, whether tasks should layout as a grid rather than a list.
|
|
*/
|
|
default boolean displayOverviewTasksAsGrid(DeviceProfile deviceProfile) {
|
|
return false;
|
|
}
|
|
|
|
/**
|
|
* For this state, whether tasks should show the thumbnail splash.
|
|
*/
|
|
default boolean showTaskThumbnailSplash() {
|
|
return false;
|
|
}
|
|
|
|
/**
|
|
* For this state, whether fullscreen and desktop quickswitch carousel are detached.
|
|
*/
|
|
default boolean detachDesktopCarousel() {
|
|
return true;
|
|
}
|
|
|
|
/**
|
|
* For this state, whether member variables and other forms of data state should be preserved
|
|
* or wiped when the state is reapplied. (See {@link StateManager#reapplyState()})
|
|
*/
|
|
default boolean shouldPreserveDataStateOnReapply() {
|
|
return false;
|
|
}
|
|
}
|