diff options
author | Yi Jiang <eejiang@google.com> | 2021-04-02 11:46:53 -0700 |
---|---|---|
committer | Yi Jiang <eejiang@google.com> | 2021-04-29 01:28:35 -0700 |
commit | 20d1da2b6298ade2a2390a66f98a1d12381e5e8f (patch) | |
tree | 145ba7d26d5212a9a97aa7ff4380bd3f41f081a1 /src/com/android/settings/display/AdaptiveSleepPreferenceController.java | |
parent | 9246f6f8b05ec9d97ab084de6d36e351f36d1648 (diff) | |
download | packages_apps_Settings-20d1da2b6298ade2a2390a66f98a1d12381e5e8f.tar.gz packages_apps_Settings-20d1da2b6298ade2a2390a66f98a1d12381e5e8f.tar.bz2 packages_apps_Settings-20d1da2b6298ade2a2390a66f98a1d12381e5e8f.zip |
Fixes 'no ripple effect' issue for screen attention setting
Preferences shouldn't be initialized at onAttach() because the settings
style hasn't been loaded yet. This change defers the preferences
initialization so that they comply with the settings style.
Test: manually
Test: make RunSettingsRoboTests ROBOTEST_FILTER=com.android.settings.display
Bug: 183909540
Change-Id: I4dc4503924a1dcd5b8d41f7d27e576befb11f976
Diffstat (limited to 'src/com/android/settings/display/AdaptiveSleepPreferenceController.java')
-rw-r--r-- | src/com/android/settings/display/AdaptiveSleepPreferenceController.java | 39 |
1 files changed, 22 insertions, 17 deletions
diff --git a/src/com/android/settings/display/AdaptiveSleepPreferenceController.java b/src/com/android/settings/display/AdaptiveSleepPreferenceController.java index 70d8a79f39..aa02ce51c8 100644 --- a/src/com/android/settings/display/AdaptiveSleepPreferenceController.java +++ b/src/com/android/settings/display/AdaptiveSleepPreferenceController.java @@ -49,10 +49,10 @@ public class AdaptiveSleepPreferenceController { public static final String PREFERENCE_KEY = "adaptive_sleep"; private static final int DEFAULT_VALUE = 0; private final SensorPrivacyManager mPrivacyManager; - private RestrictionUtils mRestrictionUtils; - private PackageManager mPackageManager; - private Context mContext; - private MetricsFeatureProvider mMetricsFeatureProvider; + private final RestrictionUtils mRestrictionUtils; + private final PackageManager mPackageManager; + private final Context mContext; + private final MetricsFeatureProvider mMetricsFeatureProvider; @VisibleForTesting RestrictedSwitchPreference mPreference; @@ -62,19 +62,6 @@ public class AdaptiveSleepPreferenceController { mRestrictionUtils = restrictionUtils; mMetricsFeatureProvider = FeatureFactory.getFactory(context).getMetricsFeatureProvider(); mPrivacyManager = SensorPrivacyManager.getInstance(context); - mPreference = new RestrictedSwitchPreference(context); - mPreference.setTitle(R.string.adaptive_sleep_title); - mPreference.setSummary(R.string.adaptive_sleep_description); - mPreference.setChecked(isChecked()); - mPreference.setKey(PREFERENCE_KEY); - mPreference.setOnPreferenceClickListener(preference -> { - final boolean isChecked = ((RestrictedSwitchPreference) preference).isChecked(); - mMetricsFeatureProvider.action(context, SettingsEnums.ACTION_SCREEN_ATTENTION_CHANGED, - isChecked); - Settings.Secure.putInt(context.getContentResolver(), - Settings.Secure.ADAPTIVE_SLEEP, isChecked ? 1 : DEFAULT_VALUE); - return true; - }); mPackageManager = context.getPackageManager(); } @@ -86,6 +73,7 @@ public class AdaptiveSleepPreferenceController { * Adds the controlled preference to the provided preference screen. */ public void addToScreen(PreferenceScreen screen) { + initializePreference(); updatePreference(); screen.addPreference(mPreference); } @@ -104,6 +92,23 @@ public class AdaptiveSleepPreferenceController { } @VisibleForTesting + void initializePreference() { + mPreference = new RestrictedSwitchPreference(mContext); + mPreference.setTitle(R.string.adaptive_sleep_title); + mPreference.setSummary(R.string.adaptive_sleep_description); + mPreference.setChecked(isChecked()); + mPreference.setKey(PREFERENCE_KEY); + mPreference.setOnPreferenceChangeListener((preference, value) -> { + final boolean isChecked = (Boolean) value; + mMetricsFeatureProvider.action(mContext, SettingsEnums.ACTION_SCREEN_ATTENTION_CHANGED, + isChecked); + Settings.Secure.putInt(mContext.getContentResolver(), + Settings.Secure.ADAPTIVE_SLEEP, isChecked ? 1 : DEFAULT_VALUE); + return true; + }); + } + + @VisibleForTesting boolean isChecked() { return hasSufficientPermission(mContext.getPackageManager()) && !isCameraLocked() && Settings.Secure.getInt(mContext.getContentResolver(), |