Support AOD in the Universal Settings API
Bug: 67997452 Test: make -j RunSettingsRoboTests Change-Id: I609ac74f70bf040bd9033f421b4bb7c02bf33440
This commit is contained in:
@@ -40,23 +40,23 @@ import java.util.List;
|
||||
*/
|
||||
public class AmbientDisplaySettings extends DashboardFragment {
|
||||
|
||||
public static final String KEY_AMBIENT_DISPLAY_ALWAYS_ON = "ambient_display_always_on";
|
||||
|
||||
private static final String TAG = "AmbientDisplaySettings";
|
||||
private static final int MY_USER_ID = UserHandle.myUserId();
|
||||
|
||||
private static final String KEY_AMBIENT_DISPLAY_ALWAYS_ON = "ambient_display_always_on";
|
||||
private static final String KEY_AMBIENT_DISPLAY_DOUBLE_TAP = "ambient_display_double_tap";
|
||||
private static final String KEY_AMBIENT_DISPLAY_PICK_UP = "ambient_display_pick_up";
|
||||
private static final String KEY_AMBIENT_DISPLAY_NOTIFICATION = "ambient_display_notification";
|
||||
|
||||
private AmbientDisplayConfiguration mConfig;
|
||||
|
||||
private static List<AbstractPreferenceController> buildPreferenceControllers(Context context,
|
||||
Lifecycle lifecycle, AmbientDisplayConfiguration config,
|
||||
MetricsFeatureProvider metricsFeatureProvider,
|
||||
AmbientDisplayAlwaysOnPreferenceController.OnPreferenceChangedCallback aodCallback) {
|
||||
MetricsFeatureProvider metricsFeatureProvider) {
|
||||
final List<AbstractPreferenceController> controllers = new ArrayList<>();
|
||||
controllers.add(new AmbientDisplayNotificationsPreferenceController(context, config,
|
||||
metricsFeatureProvider));
|
||||
controllers.add(new AmbientDisplayAlwaysOnPreferenceController(context, config,
|
||||
aodCallback));
|
||||
controllers.add(new DoubleTapScreenPreferenceController(context, lifecycle, config,
|
||||
MY_USER_ID, KEY_AMBIENT_DISPLAY_DOUBLE_TAP));
|
||||
controllers.add(new PickupGesturePreferenceController(context, lifecycle, config,
|
||||
@@ -64,6 +64,14 @@ public class AmbientDisplaySettings extends DashboardFragment {
|
||||
return controllers;
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onAttach(Context context) {
|
||||
super.onAttach(context);
|
||||
final AmbientDisplayAlwaysOnPreferenceController controller = use(
|
||||
AmbientDisplayAlwaysOnPreferenceController.class);
|
||||
controller.setConfig(getConfig(context));
|
||||
controller.setCallback(this::updatePreferenceStates);
|
||||
}
|
||||
|
||||
@Override
|
||||
protected String getLogTag() {
|
||||
@@ -78,8 +86,7 @@ public class AmbientDisplaySettings extends DashboardFragment {
|
||||
@Override
|
||||
protected List<AbstractPreferenceController> createPreferenceControllers(Context context) {
|
||||
return buildPreferenceControllers(context, getLifecycle(),
|
||||
new AmbientDisplayConfiguration(context), mMetricsFeatureProvider,
|
||||
this::updatePreferenceStates);
|
||||
getConfig(context), mMetricsFeatureProvider);
|
||||
}
|
||||
|
||||
@Override
|
||||
@@ -104,7 +111,14 @@ public class AmbientDisplaySettings extends DashboardFragment {
|
||||
public List<AbstractPreferenceController> createPreferenceControllers(
|
||||
Context context) {
|
||||
return buildPreferenceControllers(context, null,
|
||||
new AmbientDisplayConfiguration(context), null, null);
|
||||
new AmbientDisplayConfiguration(context), null);
|
||||
}
|
||||
};
|
||||
|
||||
private AmbientDisplayConfiguration getConfig(Context context) {
|
||||
if (mConfig == null) {
|
||||
mConfig = new AmbientDisplayConfiguration(context);
|
||||
}
|
||||
return mConfig;
|
||||
}
|
||||
}
|
||||
|
Reference in New Issue
Block a user