From dcea34350673491a49597d2b5a8c33d273e2b1f4 Mon Sep 17 00:00:00 2001 From: Kaiming Hu Date: Fri, 12 Apr 2024 10:30:01 +0800 Subject: [PATCH] Fix incorrect capture when using DisplayManager API --- .../com/genymobile/scrcpy/ScreenCapture.java | 20 +++++++++++++------ 1 file changed, 14 insertions(+), 6 deletions(-) diff --git a/server/src/main/java/com/genymobile/scrcpy/ScreenCapture.java b/server/src/main/java/com/genymobile/scrcpy/ScreenCapture.java index 9521418837..6f9c4d3380 100644 --- a/server/src/main/java/com/genymobile/scrcpy/ScreenCapture.java +++ b/server/src/main/java/com/genymobile/scrcpy/ScreenCapture.java @@ -39,10 +39,6 @@ public void start(Surface surface) { SurfaceControl.destroyDisplay(display); display = null; } - if (virtualDisplay != null) { - virtualDisplay.release(); - virtualDisplay = null; - } try { display = createDisplay(); @@ -51,8 +47,20 @@ public void start(Surface surface) { } catch (Exception surfaceControlException) { Rect videoRect = screenInfo.getVideoSize().toRect(); try { - virtualDisplay = ServiceManager.getDisplayManager() - .createVirtualDisplay("scrcpy", videoRect.width(), videoRect.height(), device.getDisplayId(), surface); + if (virtualDisplay == null) { + // Do not release virtual display, to avoid displayId increase + virtualDisplay = ServiceManager.getDisplayManager() + .createVirtualDisplay("scrcpy", videoRect.width(), videoRect.height(), device.getDisplayId(), surface); + } else { + // Density doesn't matter since this virtual display is only used for mirroring. + virtualDisplay.resize(videoRect.width(), videoRect.height(), 1); + virtualDisplay.setSurface(surface); + } + // 'createVirtualDisplay' will copy the configuration of the original display (including the rotation), + // but 'videoRect' is already rotated according to the device rotation, + // so we need to freeze the rotation to 0 to avoid a double rotation + int displayId = virtualDisplay.getDisplay().getDisplayId(); + ServiceManager.getWindowManager().freezeRotation(displayId, 0); Ln.d("Display: using DisplayManager API"); } catch (Exception displayManagerException) { Ln.e("Could not create display using SurfaceControl", surfaceControlException);