1 /** 2 * Copyright (c) 2014, 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 android.app; 18 19 import android.app.ActivityManager; 20 import android.content.ComponentName; 21 22 /** @hide */ 23 oneway interface ITaskStackListener { 24 /** Activity was resized to be displayed in split-screen. */ 25 const int FORCED_RESIZEABLE_REASON_SPLIT_SCREEN = 1; 26 /** Activity was resized to be displayed on a secondary display. */ 27 const int FORCED_RESIZEABLE_REASON_SECONDARY_DISPLAY = 2; 28 29 /** Called whenever there are changes to the state of tasks in a stack. */ onTaskStackChanged()30 void onTaskStackChanged(); 31 32 /** Called whenever an Activity is moved to the pinned stack from another stack. */ onActivityPinned(String packageName, int userId, int taskId, int stackId)33 void onActivityPinned(String packageName, int userId, int taskId, int stackId); 34 35 /** Called whenever an Activity is moved from the pinned stack to another stack. */ onActivityUnpinned()36 void onActivityUnpinned(); 37 38 /** 39 * Called whenever IActivityManager.startActivity is called on an activity that is already 40 * running in the pinned stack and the activity is not actually started, but the task is either 41 * brought to the front or a new Intent is delivered to it. 42 * 43 * @param clearedTask whether or not the launch activity also cleared the task as a part of 44 * starting 45 */ onPinnedActivityRestartAttempt(boolean clearedTask)46 void onPinnedActivityRestartAttempt(boolean clearedTask); 47 48 /** 49 * Called whenever the pinned stack is starting animating a resize. 50 */ onPinnedStackAnimationStarted()51 void onPinnedStackAnimationStarted(); 52 53 /** 54 * Called whenever the pinned stack is done animating a resize. 55 */ onPinnedStackAnimationEnded()56 void onPinnedStackAnimationEnded(); 57 58 /** 59 * Called when we launched an activity that we forced to be resizable. 60 * 61 * @param packageName Package name of the top activity in the task. 62 * @param taskId Id of the task. 63 * @param reason {@link #FORCED_RESIZEABLE_REASON_SPLIT_SCREEN} or 64 * {@link #FORCED_RESIZEABLE_REASON_SECONDARY_DISPLAY}. 65 */ onActivityForcedResizable(String packageName, int taskId, int reason)66 void onActivityForcedResizable(String packageName, int taskId, int reason); 67 68 /** 69 * Called when we launched an activity that dismissed the docked stack. 70 */ onActivityDismissingDockedStack()71 void onActivityDismissingDockedStack(); 72 73 /** 74 * Called when an activity was requested to be launched on a secondary display but was not 75 * allowed there. 76 */ onActivityLaunchOnSecondaryDisplayFailed()77 void onActivityLaunchOnSecondaryDisplayFailed(); 78 79 /** 80 * Called when a task is added. 81 * 82 * @param taskId id of the task. 83 * @param componentName of the activity that the task is being started with. 84 */ onTaskCreated(int taskId, in ComponentName componentName)85 void onTaskCreated(int taskId, in ComponentName componentName); 86 87 /** 88 * Called when a task is removed. 89 * 90 * @param taskId id of the task. 91 */ onTaskRemoved(int taskId)92 void onTaskRemoved(int taskId); 93 94 /** 95 * Called when a task is moved to the front of its stack. 96 * 97 * @param taskId id of the task. 98 */ onTaskMovedToFront(int taskId)99 void onTaskMovedToFront(int taskId); 100 101 /** 102 * Called when a task’s description is changed due to an activity calling 103 * ActivityManagerService.setTaskDescription 104 * 105 * @param taskId id of the task. 106 * @param td the new TaskDescription. 107 */ onTaskDescriptionChanged(int taskId, in ActivityManager.TaskDescription td)108 void onTaskDescriptionChanged(int taskId, in ActivityManager.TaskDescription td); 109 110 /** 111 * Called when a activity’s orientation is changed due to it calling 112 * ActivityManagerService.setRequestedOrientation 113 * 114 * @param taskId id of the task that the activity is in. 115 * @param requestedOrientation the new requested orientation. 116 */ onActivityRequestedOrientationChanged(int taskId, int requestedOrientation)117 void onActivityRequestedOrientationChanged(int taskId, int requestedOrientation); 118 119 /** 120 * Called when the task is about to be finished but before its surfaces are 121 * removed from the window manager. This allows interested parties to 122 * perform relevant animations before the window disappears. 123 */ onTaskRemovalStarted(int taskId)124 void onTaskRemovalStarted(int taskId); 125 126 /** 127 * Called when the task has been put in a locked state because one or more of the 128 * activities inside it belong to a managed profile user, and that user has just 129 * been locked. 130 */ onTaskProfileLocked(int taskId, int userId)131 void onTaskProfileLocked(int taskId, int userId); 132 133 /** 134 * Called when a task snapshot got updated. 135 */ onTaskSnapshotChanged(int taskId, in ActivityManager.TaskSnapshot snapshot)136 void onTaskSnapshotChanged(int taskId, in ActivityManager.TaskSnapshot snapshot); 137 } 138