diff options
| author | 2018-09-28 11:40:38 +0800 | |
|---|---|---|
| committer | 2018-10-26 18:57:58 +0800 | |
| commit | e9467b21e76f85e0633d2aad1cf34e5a0e888e05 (patch) | |
| tree | eceb0af28600dbc0d3de151b44aa0925eee96dfb | |
| parent | 4807b6b226bf9ed03b2070cb1cd75e90cfb1a081 (diff) | |
Enable the AM shell command to support the secondary display
Modify the the get-config command with display id
Bug: 112338741
Test: atest ActivityManagerGetConfigTests
Change-Id: If8206c82181668b511383528db3a0f097f69d866
| -rw-r--r-- | services/core/java/com/android/server/am/ActivityManagerShellCommand.java | 40 |
1 files changed, 26 insertions, 14 deletions
diff --git a/services/core/java/com/android/server/am/ActivityManagerShellCommand.java b/services/core/java/com/android/server/am/ActivityManagerShellCommand.java index 96601a20471b..3a4ad7c6ed8e 100644 --- a/services/core/java/com/android/server/am/ActivityManagerShellCommand.java +++ b/services/core/java/com/android/server/am/ActivityManagerShellCommand.java @@ -58,7 +58,6 @@ import android.content.pm.UserInfo; import android.content.res.AssetManager; import android.content.res.Configuration; import android.content.res.Resources; -import android.graphics.Point; import android.graphics.Rect; import android.hardware.display.DisplayManager; import android.opengl.GLES10; @@ -735,7 +734,6 @@ final class ActivityManagerShellCommand extends ShellCommand { return -1; } - ; if (!mInterface.stopBinderTrackingAndDump(fd)) { err.println("STOP TRACE FAILED."); return -1; @@ -2024,19 +2022,20 @@ final class ActivityManagerShellCommand extends ShellCommand { } private void writeDeviceConfig(ProtoOutputStream protoOutputStream, long fieldId, - PrintWriter pw, Configuration config, DisplayManager dm) { - Point stableSize = dm.getStableDisplaySize(); + PrintWriter pw, Configuration config, DisplayMetrics displayMetrics) { long token = -1; if (protoOutputStream != null) { token = protoOutputStream.start(fieldId); - protoOutputStream.write(DeviceConfigurationProto.STABLE_SCREEN_WIDTH_PX, stableSize.x); - protoOutputStream.write(DeviceConfigurationProto.STABLE_SCREEN_HEIGHT_PX, stableSize.y); + protoOutputStream.write(DeviceConfigurationProto.STABLE_SCREEN_WIDTH_PX, + displayMetrics.widthPixels); + protoOutputStream.write(DeviceConfigurationProto.STABLE_SCREEN_HEIGHT_PX, + displayMetrics.heightPixels); protoOutputStream.write(DeviceConfigurationProto.STABLE_DENSITY_DPI, DisplayMetrics.DENSITY_DEVICE_STABLE); } if (pw != null) { - pw.print("stable-width-px: "); pw.println(stableSize.x); - pw.print("stable-height-px: "); pw.println(stableSize.y); + pw.print("stable-width-px: "); pw.println(displayMetrics.widthPixels); + pw.print("stable-height-px: "); pw.println(displayMetrics.heightPixels); pw.print("stable-density-dpi: "); pw.println(DisplayMetrics.DENSITY_DEVICE_STABLE); } @@ -2125,11 +2124,12 @@ final class ActivityManagerShellCommand extends ShellCommand { int runGetConfig(PrintWriter pw) throws RemoteException { int days = -1; + int displayId = Display.DEFAULT_DISPLAY; boolean asProto = false; boolean inclDevice = false; String opt; - while ((opt=getNextOption()) != null) { + while ((opt = getNextOption()) != null) { if (opt.equals("--days")) { days = Integer.parseInt(getNextArgRequired()); if (days <= 0) { @@ -2139,6 +2139,11 @@ final class ActivityManagerShellCommand extends ShellCommand { asProto = true; } else if (opt.equals("--device")) { inclDevice = true; + } else if (opt.equals("--display")) { + displayId = Integer.parseInt(getNextArgRequired()); + if (displayId < 0) { + throw new IllegalArgumentException("--display must be a non-negative integer"); + } } else { getErrPrintWriter().println("Error: Unknown option: " + opt); return -1; @@ -2152,7 +2157,13 @@ final class ActivityManagerShellCommand extends ShellCommand { } DisplayManager dm = mInternal.mContext.getSystemService(DisplayManager.class); - Display display = dm.getDisplay(Display.DEFAULT_DISPLAY); + Display display = dm.getDisplay(displayId); + + if (display == null) { + getErrPrintWriter().println("Error: Display does not exist: " + displayId); + return -1; + } + DisplayMetrics metrics = new DisplayMetrics(); display.getMetrics(metrics); @@ -2160,15 +2171,14 @@ final class ActivityManagerShellCommand extends ShellCommand { final ProtoOutputStream proto = new ProtoOutputStream(getOutFileDescriptor()); config.writeResConfigToProto(proto, GlobalConfigurationProto.RESOURCES, metrics); if (inclDevice) { - writeDeviceConfig(proto, GlobalConfigurationProto.DEVICE, null, config, dm); + writeDeviceConfig(proto, GlobalConfigurationProto.DEVICE, null, config, metrics); } proto.flush(); - } else { pw.println("config: " + Configuration.resourceQualifierString(config, metrics)); pw.println("abi: " + TextUtils.join(",", Build.SUPPORTED_ABIS)); if (inclDevice) { - writeDeviceConfig(null, -1, pw, config, dm); + writeDeviceConfig(null, -1, pw, config, metrics); } if (days >= 0) { @@ -3023,11 +3033,13 @@ final class ActivityManagerShellCommand extends ShellCommand { pw.println(" Gets the process state of an app given its <UID>."); pw.println(" attach-agent <PROCESS> <FILE>"); pw.println(" Attach an agent to the specified <PROCESS>, which may be either a process name or a PID."); - pw.println(" get-config [--days N] [--device] [--proto]"); + pw.println(" get-config [--days N] [--device] [--proto] [--display <DISPLAY_ID>]"); pw.println(" Retrieve the configuration and any recent configurations of the device."); pw.println(" --days: also return last N days of configurations that have been seen."); pw.println(" --device: also output global device configuration info."); pw.println(" --proto: return result as a proto; does not include --days info."); + pw.println(" --display: Specify for which display to run the command; if not "); + pw.println(" specified then run for the default display."); pw.println(" supports-multiwindow"); pw.println(" Returns true if the device supports multiwindow."); pw.println(" supports-split-screen-multi-window"); |