• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 /*
2  * Copyright (C) 2024 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  */
16 
17 package com.android.wm.shell.common.pip;
18 
19 import static android.view.WindowManager.LayoutParams.FLAG_NOT_TOUCHABLE;
20 import static android.view.WindowManager.LayoutParams.FLAG_SLIPPERY;
21 import static android.view.WindowManager.LayoutParams.FLAG_WATCH_OUTSIDE_TOUCH;
22 import static android.view.WindowManager.LayoutParams.PRIVATE_FLAG_TRUSTED_OVERLAY;
23 import static android.view.WindowManager.LayoutParams.TYPE_APPLICATION_OVERLAY;
24 
25 import android.annotation.Nullable;
26 import android.app.ActivityManager.RunningTaskInfo;
27 import android.app.RemoteAction;
28 import android.content.Context;
29 import android.graphics.PixelFormat;
30 import android.graphics.Rect;
31 import android.view.SurfaceControl;
32 import android.view.WindowManager;
33 
34 import com.android.wm.shell.R;
35 import com.android.wm.shell.ShellTaskOrganizer;
36 
37 import java.util.List;
38 
39 /**
40  *  Interface to interact with PiP menu when certain events happen
41  *  (task appear/vanish, PiP move, etc.).
42  */
43 public interface PipMenuController {
44 
45     String MENU_WINDOW_TITLE = "PipMenuView";
46 
47     /**
48      * Used with
49      * {@link PipMenuController#movePipMenu(SurfaceControl, SurfaceControl.Transaction, Rect,
50      * float)} to indicate that we don't want to affect the alpha value of the menu surfaces.
51      */
52     float ALPHA_NO_CHANGE = -1f;
53 
54     /**
55      * Called when out implementation of
56      * {@link ShellTaskOrganizer.TaskListener#onTaskAppeared(RunningTaskInfo, SurfaceControl)}
57      * is called.
58      */
attach(SurfaceControl leash)59     void attach(SurfaceControl leash);
60 
61     /**
62      * Called when our implementation of
63      * {@link ShellTaskOrganizer.TaskListener#onTaskVanished(RunningTaskInfo)} is called.
64      */
detach()65     void detach();
66 
67     /**
68      * Check if menu is visible or not.
69      */
isMenuVisible()70     boolean isMenuVisible();
71 
72     /**
73      * Show the PIP menu.
74      */
showMenu()75     void showMenu();
76 
77     /**
78      * Given a set of actions, update the menu.
79      */
setAppActions(List<RemoteAction> appActions, RemoteAction closeAction)80     void setAppActions(List<RemoteAction> appActions, RemoteAction closeAction);
81 
82     /**
83      * Resize the PiP menu with the given bounds. The PiP SurfaceControl is given if there is a
84      * need to synchronize the movements on the same frame as PiP.
85      */
resizePipMenu(@ullable SurfaceControl pipLeash, @Nullable SurfaceControl.Transaction t, Rect destinationBounds)86     default void resizePipMenu(@Nullable SurfaceControl pipLeash,
87             @Nullable SurfaceControl.Transaction t,
88             Rect destinationBounds) {}
89 
90     /**
91      * Move the PiP menu with the given bounds. The PiP SurfaceControl is given if there is a
92      * need to synchronize the movements on the same frame as PiP.
93      */
movePipMenu(@ullable SurfaceControl pipLeash, @Nullable SurfaceControl.Transaction t, Rect destinationBounds, float alpha)94     default void movePipMenu(@Nullable SurfaceControl pipLeash,
95             @Nullable SurfaceControl.Transaction t, Rect destinationBounds, float alpha) {
96     }
97 
98     /**
99      * Update the PiP menu with the given bounds for re-layout purposes.
100      */
updateMenuBounds(Rect destinationBounds)101     default void updateMenuBounds(Rect destinationBounds) {}
102 
103     /**
104      * Returns a default LayoutParams for the PIP Menu.
105      * @param context the context.
106      * @param width the PIP stack width.
107      * @param height the PIP stack height.
108      */
getPipMenuLayoutParams(Context context, String title, int width, int height)109     default WindowManager.LayoutParams getPipMenuLayoutParams(Context context, String title,
110             int width, int height) {
111         final WindowManager.LayoutParams lp = new WindowManager.LayoutParams(width, height,
112                 TYPE_APPLICATION_OVERLAY,
113                 FLAG_WATCH_OUTSIDE_TOUCH | FLAG_SLIPPERY | FLAG_NOT_TOUCHABLE,
114                 PixelFormat.TRANSLUCENT);
115         lp.privateFlags |= PRIVATE_FLAG_TRUSTED_OVERLAY;
116         lp.setTitle(title);
117         lp.accessibilityTitle = context.getResources().getString(
118                 R.string.pip_menu_accessibility_title);
119         return lp;
120     }
121 }
122