diff options
author | Jim Miller <jaggies@google.com> | 2010-03-30 13:51:43 -0700 |
---|---|---|
committer | Android (Google) Code Review <android-gerrit@google.com> | 2010-03-30 13:51:43 -0700 |
commit | 43630806bbe4dab6509fe825938ce28b0b4b76c8 (patch) | |
tree | 621e734bf4f36251eb6b970c90d359b0a68f2529 /src | |
parent | c0b5624ccc3b88b6b22fb39da30eed227b87785b (diff) | |
parent | d90b5a84d8261a30db573de5a722722d6a37391e (diff) | |
download | packages_apps_settings-43630806bbe4dab6509fe825938ce28b0b4b76c8.zip packages_apps_settings-43630806bbe4dab6509fe825938ce28b0b4b76c8.tar.gz packages_apps_settings-43630806bbe4dab6509fe825938ce28b0b4b76c8.tar.bz2 |
Merge "Fix 2527411: Remove unusable display timeouts from Settings." into froyo
Diffstat (limited to 'src')
-rw-r--r-- | src/com/android/settings/DisplaySettings.java | 38 |
1 files changed, 30 insertions, 8 deletions
diff --git a/src/com/android/settings/DisplaySettings.java b/src/com/android/settings/DisplaySettings.java index 72a0741..813df00 100644 --- a/src/com/android/settings/DisplaySettings.java +++ b/src/com/android/settings/DisplaySettings.java @@ -18,14 +18,11 @@ package com.android.settings; import static android.provider.Settings.System.SCREEN_OFF_TIMEOUT; -import com.android.settings.bluetooth.DockEventReceiver; +import java.util.ArrayList; -import android.content.BroadcastReceiver; +import android.app.admin.DevicePolicyManager; import android.content.ContentResolver; import android.content.Context; -import android.content.Intent; -import android.content.IntentFilter; -import android.media.AudioManager; import android.os.Bundle; import android.os.RemoteException; import android.os.ServiceManager; @@ -33,11 +30,8 @@ import android.preference.CheckBoxPreference; import android.preference.ListPreference; import android.preference.Preference; import android.preference.PreferenceActivity; -import android.preference.PreferenceGroup; import android.preference.PreferenceScreen; import android.provider.Settings; -import android.provider.Settings.SettingNotFoundException; -import android.telephony.TelephonyManager; import android.util.Log; import android.view.IWindowManager; @@ -76,7 +70,35 @@ public class DisplaySettings extends PreferenceActivity implements screenTimeoutPreference.setValue(String.valueOf(Settings.System.getInt( resolver, SCREEN_OFF_TIMEOUT, FALLBACK_SCREEN_TIMEOUT_VALUE))); screenTimeoutPreference.setOnPreferenceChangeListener(this); + disableUnusableTimeouts(screenTimeoutPreference); + } + private void disableUnusableTimeouts(ListPreference screenTimeoutPreference) { + DevicePolicyManager dpm = + (DevicePolicyManager) getSystemService(Context.DEVICE_POLICY_SERVICE); + long maxTimeout = dpm != null ? dpm.getMaximumTimeToLock(null) : 0; + if (maxTimeout == 0) { + return; // policy not enforced + } + final CharSequence[] entries = screenTimeoutPreference.getEntries(); + final CharSequence[] values = screenTimeoutPreference.getEntryValues(); + ArrayList<CharSequence> revisedEntries = new ArrayList<CharSequence>(); + ArrayList<CharSequence> revisedValues = new ArrayList<CharSequence>(); + for (int i = 0; i < values.length; i++) { + long timeout = Long.valueOf(values[i].toString()); + if (timeout <= maxTimeout) { + revisedEntries.add(entries[i]); + revisedValues.add(values[i]); + } + } + if (revisedEntries.size() != entries.length || revisedValues.size() != values.length) { + screenTimeoutPreference.setEntries( + revisedEntries.toArray(new CharSequence[revisedEntries.size()])); + screenTimeoutPreference.setEntryValues( + revisedValues.toArray(new CharSequence[revisedValues.size()])); + screenTimeoutPreference.setValue(String.valueOf(maxTimeout)); + } + screenTimeoutPreference.setEnabled(revisedEntries.size() > 0); } @Override |