diff options
| author | Wei Sheng Shih <wilsonshih@google.com> | 2020-12-21 01:39:04 +0000 |
|---|---|---|
| committer | Android (Google) Code Review <android-gerrit@google.com> | 2020-12-21 01:39:04 +0000 |
| commit | 612dbde32af63fe0b33d82deb455e65f5fe869eb (patch) | |
| tree | 8a4f323695a1f263463cc7d88a69fea03f065383 /core/java/android | |
| parent | ea470d5ca8b080c5a9ef8b63ac957976ee550d3d (diff) | |
| parent | 285feba16858c65c33f7d18b133b5f3ada9caad1 (diff) | |
Merge "Mirror TaskSnapshotSurface to WMShell(2/N)"
Diffstat (limited to 'core/java/android')
| -rw-r--r-- | core/java/android/window/ITaskOrganizer.aidl | 7 | ||||
| -rw-r--r-- | core/java/android/window/StartingWindowInfo.aidl | 20 | ||||
| -rw-r--r-- | core/java/android/window/StartingWindowInfo.java | 150 | ||||
| -rw-r--r-- | core/java/android/window/TaskOrganizer.java | 16 |
4 files changed, 183 insertions, 10 deletions
diff --git a/core/java/android/window/ITaskOrganizer.aidl b/core/java/android/window/ITaskOrganizer.aidl index b503184f4c51..88b2257a55b1 100644 --- a/core/java/android/window/ITaskOrganizer.aidl +++ b/core/java/android/window/ITaskOrganizer.aidl @@ -18,6 +18,7 @@ package android.window; import android.view.SurfaceControl; import android.app.ActivityManager; +import android.window.StartingWindowInfo; import android.window.WindowContainerToken; /** @@ -30,15 +31,15 @@ oneway interface ITaskOrganizer { * application is starting. The client is responsible to add/remove the starting window if it * has create a starting window for the Task. * - * @param taskInfo The information about the Task that's available + * @param info The information about the Task that's available * @param appToken Token of the application being started. */ - void addStartingWindow(in ActivityManager.RunningTaskInfo taskInfo, IBinder appToken); + void addStartingWindow(in StartingWindowInfo info, IBinder appToken); /** * Called when the Task want to remove the starting window. */ - void removeStartingWindow(in ActivityManager.RunningTaskInfo taskInfo); + void removeStartingWindow(int taskId); /** * A callback when the Task is available for the registered organizer. The client is responsible diff --git a/core/java/android/window/StartingWindowInfo.aidl b/core/java/android/window/StartingWindowInfo.aidl new file mode 100644 index 000000000000..69b18f05fa8c --- /dev/null +++ b/core/java/android/window/StartingWindowInfo.aidl @@ -0,0 +1,20 @@ +/** + * 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 android.window; + +/** @hide */ +parcelable StartingWindowInfo;
\ No newline at end of file diff --git a/core/java/android/window/StartingWindowInfo.java b/core/java/android/window/StartingWindowInfo.java new file mode 100644 index 000000000000..2282cc567936 --- /dev/null +++ b/core/java/android/window/StartingWindowInfo.java @@ -0,0 +1,150 @@ +/* + * 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 android.window; + +import android.annotation.IntDef; +import android.annotation.NonNull; +import android.annotation.Nullable; +import android.annotation.TestApi; +import android.app.ActivityManager; +import android.app.TaskInfo; +import android.os.Parcel; +import android.os.Parcelable; +import android.view.InsetsState; +import android.view.WindowManager; + +/** + * Information you can retrieve about a starting window of a particular task that is currently + * start in the system. + * @hide + */ +@TestApi +public final class StartingWindowInfo implements Parcelable { + /** + * The {@link TaskInfo} from this task. + * @hide + */ + @NonNull + public ActivityManager.RunningTaskInfo taskInfo; + + /** + * InsetsState of TopFullscreenOpaqueWindow + * @hide + */ + @Nullable + public InsetsState topOpaqueWindowInsetsState; + + /** + * LayoutParams of TopFullscreenOpaqueWindow + * @hide + */ + @Nullable + public WindowManager.LayoutParams topOpaqueWindowLayoutParams; + + /** + * LayoutParams of MainWindow + * @hide + */ + @Nullable + public WindowManager.LayoutParams mainWindowLayoutParams; + + /** + * @hide + */ + @IntDef(flag = true, prefix = "TYPE_PARAMETER_", value = { + TYPE_PARAMETER_NEW_TASK, + TYPE_PARAMETER_TASK_SWITCH, + TYPE_PARAMETER_PROCESS_RUNNING, + TYPE_PARAMETER_ALLOW_TASK_SNAPSHOT, + TYPE_PARAMETER_ACTIVITY_CREATED + }) + public @interface StartingTypeParams {} + + /** + * The parameters of the starting window... + * @hide + */ + public static final int TYPE_PARAMETER_NEW_TASK = 0x00000001; + /** @hide */ + public static final int TYPE_PARAMETER_TASK_SWITCH = 0x00000002; + /** @hide */ + public static final int TYPE_PARAMETER_PROCESS_RUNNING = 0x00000004; + /** @hide */ + public static final int TYPE_PARAMETER_ALLOW_TASK_SNAPSHOT = 0x00000008; + /** @hide */ + public static final int TYPE_PARAMETER_ACTIVITY_CREATED = 0x00000010; + + /** + * The parameters which effect the starting window type. + * @see android.window.StartingWindowInfo.StartingTypeParams + * @hide + */ + public int startingWindowTypeParameter; + + public StartingWindowInfo() { + + } + + private StartingWindowInfo(@NonNull Parcel source) { + readFromParcel(source); + } + + @Override + public int describeContents() { + return 0; + } + + @Override + public void writeToParcel(@NonNull Parcel dest, int flags) { + dest.writeTypedObject(taskInfo, flags); + dest.writeInt(startingWindowTypeParameter); + dest.writeTypedObject(topOpaqueWindowInsetsState, flags); + dest.writeTypedObject(topOpaqueWindowLayoutParams, flags); + dest.writeTypedObject(mainWindowLayoutParams, flags); + } + + void readFromParcel(@NonNull Parcel source) { + taskInfo = source.readTypedObject(ActivityManager.RunningTaskInfo.CREATOR); + startingWindowTypeParameter = source.readInt(); + topOpaqueWindowInsetsState = source.readTypedObject(InsetsState.CREATOR); + topOpaqueWindowLayoutParams = source.readTypedObject( + WindowManager.LayoutParams.CREATOR); + mainWindowLayoutParams = source.readTypedObject(WindowManager.LayoutParams.CREATOR); + } + + @Override + public String toString() { + return "StartingWindowInfo{taskId=" + taskInfo.taskId + + " displayId=" + taskInfo.displayId + + " topActivityType=" + taskInfo.topActivityType + + " preferredStartingWindowType=" + + Integer.toHexString(startingWindowTypeParameter) + + " insetsState=" + topOpaqueWindowInsetsState + + " topWindowLayoutParams=" + topOpaqueWindowLayoutParams + + " mainWindowLayoutParams=" + mainWindowLayoutParams; + } + + public static final @android.annotation.NonNull Creator<StartingWindowInfo> CREATOR = + new Creator<StartingWindowInfo>() { + public StartingWindowInfo createFromParcel(@NonNull Parcel source) { + return new StartingWindowInfo(source); + } + public StartingWindowInfo[] newArray(int size) { + return new StartingWindowInfo[size]; + } + }; +} diff --git a/core/java/android/window/TaskOrganizer.java b/core/java/android/window/TaskOrganizer.java index 12c4b5b7794a..73b2fe1ff4d5 100644 --- a/core/java/android/window/TaskOrganizer.java +++ b/core/java/android/window/TaskOrganizer.java @@ -89,19 +89,19 @@ public class TaskOrganizer extends WindowOrganizer { * application is starting. The client is responsible to add/remove the starting window if it * has create a starting window for the Task. * - * @param taskInfo The information about the Task that's available + * @param info The information about the Task that's available * @param appToken Token of the application being started. * context to for resources */ @BinderThread - public void addStartingWindow(@NonNull ActivityManager.RunningTaskInfo taskInfo, + public void addStartingWindow(@NonNull StartingWindowInfo info, @NonNull IBinder appToken) {} /** * Called when the Task want to remove the starting window. */ @BinderThread - public void removeStartingWindow(@NonNull ActivityManager.RunningTaskInfo taskInfo) {} + public void removeStartingWindow(int taskId) {} /** * Called when a task with the registered windowing mode can be controlled by this task @@ -221,13 +221,15 @@ public class TaskOrganizer extends WindowOrganizer { private final ITaskOrganizer mInterface = new ITaskOrganizer.Stub() { @Override - public void addStartingWindow(ActivityManager.RunningTaskInfo taskInfo, IBinder appToken) { - mExecutor.execute(() -> TaskOrganizer.this.addStartingWindow(taskInfo, appToken)); + + public void addStartingWindow(StartingWindowInfo windowInfo, + IBinder appToken) { + mExecutor.execute(() -> TaskOrganizer.this.addStartingWindow(windowInfo, appToken)); } @Override - public void removeStartingWindow(ActivityManager.RunningTaskInfo taskInfo) { - mExecutor.execute(() -> TaskOrganizer.this.removeStartingWindow(taskInfo)); + public void removeStartingWindow(int taskId) { + mExecutor.execute(() -> TaskOrganizer.this.removeStartingWindow(taskId)); } @Override |
