Merge "Support scaling with SurfaceControl when using WindowlessWindow APIs" into rvc-dev am: 705e25deb1

Change-Id: Ieae8c115fe57bc95db4ecd6ca2ba417f5ac50c12
This commit is contained in:
Automerger Merge Worker
2020-03-10 09:35:08 +00:00
2 changed files with 30 additions and 5 deletions

View File

@@ -20,6 +20,7 @@ import android.content.Context;
import android.graphics.PixelFormat;
import android.os.Bundle;
import android.os.IBinder;
import android.util.Size;
import android.view.SurfaceControl;
import android.view.SurfaceControlViewHost;
import android.view.View;
@@ -43,13 +44,27 @@ public class SurfaceViewRequestReceiver {
mOpacity = opacity;
}
/** Called whenever a surface view request is received. */
/** See {@link #onReceive(Context, Bundle, View, Size)}. */
public void onReceive(Context context, Bundle bundle, View view) {
onReceive(context, bundle, view, null);
}
/**
* Called whenever a surface view request is received.
* @param view the view rendering content, on the receiver end of the surface request.
* @param viewSize when {@param viewSize} is not specified, we will use the surface control size
* to attach the view to the window.
*/
public void onReceive(Context context, Bundle bundle, View view, Size viewSize) {
if (mSurfaceControlViewHost != null) {
mSurfaceControlViewHost.die();
}
SurfaceControl surfaceControl = SurfaceViewRequestUtils.getSurfaceControl(bundle);
if (surfaceControl != null) {
if (viewSize == null) {
viewSize = new Size(surfaceControl.getWidth(), surfaceControl.getHeight());
}
IBinder hostToken = SurfaceViewRequestUtils.getHostToken(bundle);
WindowlessWindowManager windowlessWindowManager =
@@ -59,12 +74,22 @@ public class SurfaceViewRequestReceiver {
context.getDisplayNoVerify(), windowlessWindowManager);
WindowManager.LayoutParams layoutParams =
new WindowManager.LayoutParams(
surfaceControl.getWidth(),
surfaceControl.getHeight(),
viewSize.getWidth(),
viewSize.getHeight(),
WindowManager.LayoutParams.TYPE_APPLICATION,
WindowManager.LayoutParams.FLAG_HARDWARE_ACCELERATED,
mOpacity);
// This aspect scales the view to fit in the surface and centers it
final float scale = Math.min(surfaceControl.getWidth() / (float) viewSize.getWidth(),
surfaceControl.getHeight() / (float) viewSize.getHeight());
view.setScaleX(scale);
view.setScaleY(scale);
view.setPivotX(0);
view.setPivotY(0);
view.setTranslationX((surfaceControl.getWidth() - scale * viewSize.getWidth()) / 2);
view.setTranslationY((surfaceControl.getHeight() - scale * viewSize.getHeight()) / 2);
mSurfaceControlViewHost.addView(view, layoutParams);
}
}

View File

@@ -36,7 +36,7 @@ public class SurfaceViewRequestUtils {
}
/**
* Retrieves the SurfaceControl from an Intent created by
* Retrieves the SurfaceControl from a bundle created by
* {@link #createSurfaceBundle(SurfaceView)}.
**/
public static SurfaceControl getSurfaceControl(Bundle bundle) {
@@ -44,7 +44,7 @@ public class SurfaceViewRequestUtils {
}
/**
* Retrieves the input token from an Intent created by
* Retrieves the input token from a bundle created by
* {@link #createSurfaceBundle(SurfaceView)}.
**/
public static @Nullable IBinder getHostToken(Bundle bundle) {