diff options
| author | TreeHugger Robot <treehugger-gerrit@google.com> | 2021-05-11 19:13:05 +0000 |
|---|---|---|
| committer | Android (Google) Code Review <android-gerrit@google.com> | 2021-05-11 19:13:05 +0000 |
| commit | ab367ab510cc804b370611d4e8e40ffef2c6e379 (patch) | |
| tree | cd78e69fd948c05168cdca5947fe7e8ca42950c3 /core/java | |
| parent | 3a8ea8727d703d8f0b790874cd6e63c87cc3f56b (diff) | |
| parent | 599f912e4e3611ca5d537b6780c026bcf44e8395 (diff) | |
Merge "AttachedSurfaceControl: Respond to API feedback." into sc-dev
Diffstat (limited to 'core/java')
| -rw-r--r-- | core/java/android/view/AttachedSurfaceControl.java (renamed from core/java/android/view/ViewRoot.java) | 21 | ||||
| -rw-r--r-- | core/java/android/view/View.java | 20 | ||||
| -rw-r--r-- | core/java/android/view/ViewRootImpl.java | 3 | ||||
| -rw-r--r-- | core/java/android/view/Window.java | 7 | ||||
| -rw-r--r-- | core/java/com/android/internal/policy/PhoneWindow.java | 4 |
5 files changed, 30 insertions, 25 deletions
diff --git a/core/java/android/view/ViewRoot.java b/core/java/android/view/AttachedSurfaceControl.java index 3c755981a440..bcc5b56459bb 100644 --- a/core/java/android/view/ViewRoot.java +++ b/core/java/android/view/AttachedSurfaceControl.java @@ -22,16 +22,19 @@ import android.annotation.UiThread; /** * Provides an interface to the root-Surface of a View Hierarchy or Window. This * is used in combination with the {@link android.view.SurfaceControl} API to enable - * attaching app created SurfaceControl to the ViewRoot's surface hierarchy, and enable - * SurfaceTransactions to be performed in sync with the ViewRoot drawing. This object - * is obtained from {@link android.view.View#getViewRoot} and - * {@link android.view.Window#getViewRoot}. It must be used from the UI thread of + * attaching app created SurfaceControl to the SurfaceControl hierarchy used + * by the app, and enable SurfaceTransactions to be performed in sync with the + * View hierarchy drawing. + * + * This object is obtained from {@link android.view.View#getRootSurfaceControl} and + * {@link android.view.Window#getRootSurfaceControl}. It must be used from the UI thread of * the object it was obtained from. */ @UiThread -public interface ViewRoot { +public interface AttachedSurfaceControl { /** - * Create a transaction which will reparent {@param child} to the ViewRoot. See + * Create a transaction which will reparent {@param child} to the View hierarchy + * root SurfaceControl. See * {@link SurfaceControl.Transaction#reparent}. This transacton must be applied * or merged in to another transaction by the caller, otherwise it will have * no effect. @@ -42,9 +45,9 @@ public interface ViewRoot { @Nullable SurfaceControl.Transaction buildReparentTransaction(@NonNull SurfaceControl child); /** - * Consume the passed in transaction, and request the ViewRoot to apply it with the - * next draw. This transaction will be merged with the buffer transaction from the ViewRoot - * and they will show up on-screen atomically synced. + * Consume the passed in transaction, and request the View hierarchy to apply it atomically + * with the next draw. This transaction will be merged with the buffer transaction from the + * ViewRoot and they will show up on-screen atomically synced. * * This will not cause a draw to be scheduled, and if there are no other changes * to the View hierarchy you may need to call {@link android.view.View#invalidate} diff --git a/core/java/android/view/View.java b/core/java/android/view/View.java index c1c892c98653..e0c26cb0e5f0 100644 --- a/core/java/android/view/View.java +++ b/core/java/android/view/View.java @@ -29599,7 +29599,7 @@ public class View implements Drawable.Callback, KeyEvent.Callback, return mScrollCaptureInternal; } - ViewRoot getViewRoot() { + AttachedSurfaceControl getRootSurfaceControl() { return mViewRootImpl; } @@ -31043,17 +31043,17 @@ public class View implements Drawable.Callback, KeyEvent.Callback, } /** - * @return The {@link android.view.ViewRoot} interface for this View. This will only - * return a non-null value when called between {@link #onAttachedToWindow} and - * {@link #onDetachedFromWindow}. - * - * The ViewRoot itself is not a View, it is just the interface to the windowing-system - * object that contains the entire view hierarchy. For the root View of a given hierarchy - * see {@link #getRootView}. + * The AttachedSurfaceControl itself is not a View, it is just the interface to the + * windowing-system object that contains the entire view hierarchy. + * For the root View of a given hierarchy see {@link #getRootView}. + + * @return The {@link android.view.AttachedSurfaceControl} interface for this View. + * This will only return a non-null value when called between {@link #onAttachedToWindow} + * and {@link #onDetachedFromWindow}. */ - public @Nullable ViewRoot getViewRoot() { + public @Nullable AttachedSurfaceControl getRootSurfaceControl() { if (mAttachInfo != null) { - return mAttachInfo.getViewRoot(); + return mAttachInfo.getRootSurfaceControl(); } return null; } diff --git a/core/java/android/view/ViewRootImpl.java b/core/java/android/view/ViewRootImpl.java index a06f193255b2..4d1c66619819 100644 --- a/core/java/android/view/ViewRootImpl.java +++ b/core/java/android/view/ViewRootImpl.java @@ -224,7 +224,8 @@ import java.util.concurrent.CountDownLatch; */ @SuppressWarnings({"EmptyCatchBlock", "PointlessBooleanExpression"}) public final class ViewRootImpl implements ViewParent, - View.AttachInfo.Callbacks, ThreadedRenderer.DrawCallbacks, ViewRoot { + View.AttachInfo.Callbacks, ThreadedRenderer.DrawCallbacks, + AttachedSurfaceControl { private static final String TAG = "ViewRootImpl"; private static final boolean DBG = false; private static final boolean LOCAL_LOGV = false; diff --git a/core/java/android/view/Window.java b/core/java/android/view/Window.java index 52a09701803d..5fb4e705c831 100644 --- a/core/java/android/view/Window.java +++ b/core/java/android/view/Window.java @@ -2722,11 +2722,12 @@ public abstract class Window { /** * This will be null before a content view is added, e.g. via - * {@link #setContentView} or {@link #addContentView}. + * {@link #setContentView} or {@link #addContentView}. See + * {@link android.view.View#getRootSurfaceControl}. * - * @return The {@link android.view.ViewRoot} interface for this Window + * @return The {@link android.view.AttachedSurfaceControl} interface for this Window */ - public @Nullable ViewRoot getViewRoot() { + public @Nullable AttachedSurfaceControl getRootSurfaceControl() { return null; } } diff --git a/core/java/com/android/internal/policy/PhoneWindow.java b/core/java/com/android/internal/policy/PhoneWindow.java index a6dc4e04bf36..0ea299ddef01 100644 --- a/core/java/com/android/internal/policy/PhoneWindow.java +++ b/core/java/com/android/internal/policy/PhoneWindow.java @@ -70,12 +70,12 @@ import android.transition.TransitionInflater; import android.transition.TransitionManager; import android.transition.TransitionSet; import android.util.AndroidRuntimeException; +import android.view.AttachedSurfaceControl; import android.util.EventLog; import android.util.Log; import android.util.Pair; import android.util.SparseArray; import android.util.TypedValue; -import android.view.ViewRoot; import android.view.ContextThemeWrapper; import android.view.CrossWindowBlurListeners; import android.view.Gravity; @@ -3984,7 +3984,7 @@ public class PhoneWindow extends Window implements MenuBuilder.Callback { } @Override - public ViewRoot getViewRoot() { + public AttachedSurfaceControl getRootSurfaceControl() { return getViewRootImplOrNull(); } } |
