/* * Copyright (C) 2019 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.systemui.plugins.shared; import android.app.Activity; import android.app.Application; import android.os.Bundle; import java.io.PrintWriter; /** * Interface to control the overlay on Launcher */ public interface LauncherOverlayManager extends Application.ActivityLifecycleCallbacks { default void onDeviceProvideChanged() { } default void onAttachedToWindow() { } default void onDetachedFromWindow() { } default void dump(String prefix, PrintWriter w) { } default void openOverlay() { } default void hideOverlay(boolean animate) { hideOverlay(animate ? 200 : 0); } default void hideOverlay(int duration) { } default boolean startSearch(byte[] config, Bundle extras) { return false; } @Override default void onActivityCreated(Activity activity, Bundle bundle) { } @Override default void onActivityStarted(Activity activity) { } @Override default void onActivityResumed(Activity activity) { } @Override default void onActivityPaused(Activity activity) { } @Override default void onActivityStopped(Activity activity) { } @Override default void onActivitySaveInstanceState(Activity activity, Bundle bundle) { } @Override default void onActivityDestroyed(Activity activity) { } interface LauncherOverlay { /** * Touch interaction leading to overscroll has begun */ void onScrollInteractionBegin(); /** * Touch interaction related to overscroll has ended */ void onScrollInteractionEnd(); /** * Scroll progress, between 0 and 100, when the user scrolls beyond the leftmost * screen (or in the case of RTL, the rightmost screen). */ void onScrollChange(float progress, boolean rtl); /** * Called when the launcher is ready to use the overlay * @param callbacks A set of callbacks provided by Launcher in relation to the overlay */ void setOverlayCallbacks(LauncherOverlayCallbacks callbacks); } interface LauncherOverlayCallbacks { void onScrollChanged(float progress); } }