Use new OverlayManager categories
Using this, we split overlays based on their category, so that cutout emulation and theme overlays no longer clash in their respective settings. Bug: 72436677 Test: make ROBOTEST_FILTER=EmulateDisplayCutoutPreferenceControllerTest RunSettingsRoboTests Change-Id: I23f22113351b3948beb9e3a1fb969700852539cc
This commit is contained in:
@@ -14,8 +14,6 @@
|
||||
package com.android.settings.display;
|
||||
|
||||
import android.content.Context;
|
||||
import android.content.om.IOverlayManager;
|
||||
import android.content.om.OverlayInfo;
|
||||
import android.content.pm.PackageInfo;
|
||||
import android.content.pm.PackageManager;
|
||||
import android.content.pm.PackageManager.NameNotFoundException;
|
||||
@@ -30,6 +28,8 @@ import android.text.TextUtils;
|
||||
import com.android.settings.R;
|
||||
import com.android.settings.core.PreferenceControllerMixin;
|
||||
import com.android.settings.overlay.FeatureFactory;
|
||||
import com.android.settings.wrapper.OverlayManagerWrapper;
|
||||
import com.android.settings.wrapper.OverlayManagerWrapper.OverlayInfo;
|
||||
import com.android.settingslib.core.AbstractPreferenceController;
|
||||
import com.android.settingslib.core.instrumentation.MetricsFeatureProvider;
|
||||
|
||||
@@ -46,16 +46,16 @@ public class ThemePreferenceController extends AbstractPreferenceController impl
|
||||
private static final String KEY_THEME = "theme";
|
||||
|
||||
private final MetricsFeatureProvider mMetricsFeatureProvider;
|
||||
private final OverlayManager mOverlayService;
|
||||
private final OverlayManagerWrapper mOverlayService;
|
||||
private final PackageManager mPackageManager;
|
||||
|
||||
public ThemePreferenceController(Context context) {
|
||||
this(context, ServiceManager.getService(Context.OVERLAY_SERVICE) != null
|
||||
? new OverlayManager() : null);
|
||||
? new OverlayManagerWrapper() : null);
|
||||
}
|
||||
|
||||
@VisibleForTesting
|
||||
ThemePreferenceController(Context context, OverlayManager overlayManager) {
|
||||
ThemePreferenceController(Context context, OverlayManagerWrapper overlayManager) {
|
||||
super(context);
|
||||
mOverlayService = overlayManager;
|
||||
mPackageManager = context.getPackageManager();
|
||||
@@ -114,17 +114,16 @@ public class ThemePreferenceController extends AbstractPreferenceController impl
|
||||
if (Objects.equal(newValue, current)) {
|
||||
return true;
|
||||
}
|
||||
try {
|
||||
mOverlayService.setEnabledExclusive((String) newValue, true, UserHandle.myUserId());
|
||||
} catch (RemoteException e) {
|
||||
return false;
|
||||
}
|
||||
mOverlayService.setEnabledExclusiveInCategory((String) newValue, UserHandle.myUserId());
|
||||
return true;
|
||||
}
|
||||
|
||||
private boolean isChangeableOverlay(String packageName) {
|
||||
private boolean isTheme(OverlayInfo oi) {
|
||||
if (!OverlayInfo.CATEGORY_THEME.equals(oi.category)) {
|
||||
return false;
|
||||
}
|
||||
try {
|
||||
PackageInfo pi = mPackageManager.getPackageInfo(packageName, 0);
|
||||
PackageInfo pi = mPackageManager.getPackageInfo(oi.packageName, 0);
|
||||
return pi != null && !pi.isStaticOverlayPackage();
|
||||
} catch (PackageManager.NameNotFoundException e) {
|
||||
return false;
|
||||
@@ -132,16 +131,12 @@ public class ThemePreferenceController extends AbstractPreferenceController impl
|
||||
}
|
||||
|
||||
private String getTheme() {
|
||||
try {
|
||||
List<OverlayInfo> infos = mOverlayService.getOverlayInfosForTarget("android",
|
||||
UserHandle.myUserId());
|
||||
for (int i = 0, size = infos.size(); i < size; i++) {
|
||||
if (infos.get(i).isEnabled() &&
|
||||
isChangeableOverlay(infos.get(i).packageName)) {
|
||||
return infos.get(i).packageName;
|
||||
}
|
||||
List<OverlayInfo> infos = mOverlayService.getOverlayInfosForTarget("android",
|
||||
UserHandle.myUserId());
|
||||
for (int i = 0, size = infos.size(); i < size; i++) {
|
||||
if (infos.get(i).isEnabled() && isTheme(infos.get(i))) {
|
||||
return infos.get(i).packageName;
|
||||
}
|
||||
} catch (RemoteException e) {
|
||||
}
|
||||
return null;
|
||||
}
|
||||
@@ -161,37 +156,14 @@ public class ThemePreferenceController extends AbstractPreferenceController impl
|
||||
|
||||
@VisibleForTesting
|
||||
String[] getAvailableThemes() {
|
||||
try {
|
||||
List<OverlayInfo> infos = mOverlayService.getOverlayInfosForTarget("android",
|
||||
UserHandle.myUserId());
|
||||
List<String> pkgs = new ArrayList(infos.size());
|
||||
for (int i = 0, size = infos.size(); i < size; i++) {
|
||||
if (isChangeableOverlay(infos.get(i).packageName)) {
|
||||
pkgs.add(infos.get(i).packageName);
|
||||
}
|
||||
List<OverlayInfo> infos = mOverlayService.getOverlayInfosForTarget("android",
|
||||
UserHandle.myUserId());
|
||||
List<String> pkgs = new ArrayList<>(infos.size());
|
||||
for (int i = 0, size = infos.size(); i < size; i++) {
|
||||
if (isTheme(infos.get(i))) {
|
||||
pkgs.add(infos.get(i).packageName);
|
||||
}
|
||||
return pkgs.toArray(new String[pkgs.size()]);
|
||||
} catch (RemoteException e) {
|
||||
}
|
||||
return new String[0];
|
||||
}
|
||||
|
||||
public static class OverlayManager {
|
||||
private final IOverlayManager mService;
|
||||
|
||||
public OverlayManager() {
|
||||
mService = IOverlayManager.Stub.asInterface(
|
||||
ServiceManager.getService(Context.OVERLAY_SERVICE));
|
||||
}
|
||||
|
||||
public void setEnabledExclusive(String pkg, boolean enabled, int userId)
|
||||
throws RemoteException {
|
||||
mService.setEnabledExclusive(pkg, enabled, userId);
|
||||
}
|
||||
|
||||
public List<OverlayInfo> getOverlayInfosForTarget(String target, int userId)
|
||||
throws RemoteException {
|
||||
return mService.getOverlayInfosForTarget(target, userId);
|
||||
}
|
||||
return pkgs.toArray(new String[pkgs.size()]);
|
||||
}
|
||||
}
|
||||
|
Reference in New Issue
Block a user