diff options
author | Tom Marshall <tdm.code@gmail.com> | 2013-10-03 20:49:37 +0000 |
---|---|---|
committer | Gerrit Code Review <gerrit@cyanogenmod.org> | 2015-11-25 17:00:30 -0800 |
commit | e94a36df3be936622c06d8fc1488caff7f995d4b (patch) | |
tree | 407dae22a11166900deb1e5a8fc85768e263e614 | |
parent | 23cdfe87c0e35340278fbbea0fa06a4a1db55030 (diff) | |
download | packages_apps_Settings-e94a36df3be936622c06d8fc1488caff7f995d4b.zip packages_apps_Settings-e94a36df3be936622c06d8fc1488caff7f995d4b.tar.gz packages_apps_Settings-e94a36df3be936622c06d8fc1488caff7f995d4b.tar.bz2 |
Add LCD density setting
Change-Id: I3d55615127cc735ea0443d519520d0cb6cfbfb38
-rw-r--r-- | res/values/cm_strings.xml | 7 | ||||
-rw-r--r-- | res/xml/display_settings.xml | 5 | ||||
-rw-r--r-- | src/com/android/settings/DisplaySettings.java | 95 |
3 files changed, 107 insertions, 0 deletions
diff --git a/res/values/cm_strings.xml b/res/values/cm_strings.xml index 156d9e8..1429ae6 100644 --- a/res/values/cm_strings.xml +++ b/res/values/cm_strings.xml @@ -547,6 +547,13 @@ <string name="high_touch_sensitivity_title">High touch sensitivity</string> <string name="high_touch_sensitivity_summary">Increase touchscreen sensitivity so it can be used while wearing gloves</string> + <!-- Display & Lights screen, setting options for LCD density --> + <string name="lcd_density">LCD density</string> + <string name="dialog_title_lcd_density">LCD density</string> + <string name="lcd_density_value_format">%d DPI</string> + <string name="lcd_density_default_value_format">%d DPI (default)</string> + <string name="restarting_ui">Restarting UI\u2026</string> + <!-- Stylus Icon --> <string name="stylus_icon_enabled_title">Show icon when using stylus</string> <string name="stylus_icon_enabled_summary">Show the pointer icon when hovering or drawing with the stylus</string> diff --git a/res/xml/display_settings.xml b/res/xml/display_settings.xml index c7dd2ae..a196460 100644 --- a/res/xml/display_settings.xml +++ b/res/xml/display_settings.xml @@ -109,6 +109,11 @@ android:summary="@string/double_tap_to_sleep_summary" android:defaultValue="true" /> + <ListPreference + android:key="lcd_density" + android:title="@string/lcd_density" + android:persistent="false" /> + <PreferenceScreen android:key="wifi_display" android:title="@string/wifi_display_settings_title" diff --git a/src/com/android/settings/DisplaySettings.java b/src/com/android/settings/DisplaySettings.java index f4503f2..7d8b5e2 100644 --- a/src/com/android/settings/DisplaySettings.java +++ b/src/com/android/settings/DisplaySettings.java @@ -38,6 +38,8 @@ import static android.provider.Settings.System.SCREEN_OFF_TIMEOUT; import android.app.Activity; import android.app.ActivityManagerNative; import android.app.Dialog; +import android.app.IActivityManager; +import android.app.ProgressDialog; import android.app.UiModeManager; import android.app.admin.DevicePolicyManager; import android.content.ContentResolver; @@ -48,11 +50,13 @@ import android.content.res.Configuration; import android.content.res.Resources; import android.hardware.Sensor; import android.hardware.SensorManager; +import android.os.AsyncTask; import android.os.Build; import android.database.ContentObserver; import android.os.Bundle; import android.os.Handler; import android.os.RemoteException; +import android.os.ServiceManager; import android.os.SystemProperties; import android.preference.ListPreference; import android.preference.Preference; @@ -65,6 +69,7 @@ import android.preference.SwitchPreference; import android.provider.SearchIndexableResource; import android.provider.Settings; import android.text.TextUtils; +import android.util.DisplayMetrics; import android.util.Log; import java.util.ArrayList; @@ -81,6 +86,7 @@ public class DisplaySettings extends SettingsPreferenceFragment implements private static final int FALLBACK_SCREEN_TIMEOUT_VALUE = 30000; private static final String KEY_SCREEN_TIMEOUT = "screen_timeout"; + private static final String KEY_LCD_DENSITY = "lcd_density"; private static final String KEY_FONT_SIZE = "font_size"; private static final String KEY_SCREEN_SAVER = "screensaver"; private static final String KEY_LIFT_TO_WAKE = "lift_to_wake"; @@ -98,6 +104,7 @@ public class DisplaySettings extends SettingsPreferenceFragment implements private static final int DLG_GLOBAL_CHANGE_WARNING = 1; + private ListPreference mLcdDensityPreference; private FontDialogPreference mFontSizePref; private PreferenceScreen mDisplayRotationPreference; @@ -160,6 +167,41 @@ public class DisplaySettings extends SettingsPreferenceFragment implements updateTimeoutPreferenceDescription(currentTimeout); updateDisplayRotationPreferenceDescription(); + mLcdDensityPreference = (ListPreference) findPreference(KEY_LCD_DENSITY); + if (mLcdDensityPreference != null) { + int defaultDensity = DisplayMetrics.DENSITY_DEVICE; + int currentDensity = DisplayMetrics.DENSITY_CURRENT; + if (currentDensity < 10 || currentDensity >= 1000) { + // Unsupported value, force default + currentDensity = defaultDensity; + } + + int factor = defaultDensity >= 480 ? 40 : 20; + int minimumDensity = defaultDensity - 4 * factor; + int currentIndex = -1; + String[] densityEntries = new String[7]; + String[] densityValues = new String[7]; + for (int idx = 0; idx < 7; ++idx) { + int val = minimumDensity + factor * idx; + int valueFormatResId = val == defaultDensity + ? R.string.lcd_density_default_value_format + : R.string.lcd_density_value_format; + + densityEntries[idx] = getString(valueFormatResId, val); + densityValues[idx] = Integer.toString(val); + if (currentDensity == val) { + currentIndex = idx; + } + } + mLcdDensityPreference.setEntries(densityEntries); + mLcdDensityPreference.setEntryValues(densityValues); + if (currentIndex != -1) { + mLcdDensityPreference.setValueIndex(currentIndex); + } + mLcdDensityPreference.setOnPreferenceChangeListener(this); + updateLcdDensityPreferenceDescription(currentDensity); + } + mFontSizePref = (FontDialogPreference) findPreference(KEY_FONT_SIZE); mFontSizePref.setOnPreferenceChangeListener(this); mFontSizePref.setOnPreferenceClickListener(this); @@ -337,6 +379,12 @@ public class DisplaySettings extends SettingsPreferenceFragment implements preference.setSummary(summary); } + private void updateLcdDensityPreferenceDescription(int currentDensity) { + final int summaryResId = currentDensity == DisplayMetrics.DENSITY_DEVICE + ? R.string.lcd_density_default_value_format : R.string.lcd_density_value_format; + mLcdDensityPreference.setSummary(getString(summaryResId, currentDensity)); + } + private void disableUnusableTimeouts(ListPreference screenTimeoutPreference) { final DevicePolicyManager dpm = (DevicePolicyManager) getActivity().getSystemService( @@ -479,6 +527,44 @@ public class DisplaySettings extends SettingsPreferenceFragment implements } } + private void writeLcdDensityPreference(final Context context, int value) { + try { + SystemProperties.set("persist.sys.lcd_density", Integer.toString(value)); + } catch (RuntimeException e) { + Log.e(TAG, "Unable to save LCD density"); + return; + } + final IActivityManager am = ActivityManagerNative.asInterface( + ServiceManager.checkService("activity")); + AsyncTask<Void, Void, Void> task = new AsyncTask<Void, Void, Void>() { + @Override + protected void onPreExecute() { + ProgressDialog dialog = new ProgressDialog(context); + dialog.setMessage(getResources().getString(R.string.restarting_ui)); + dialog.setCancelable(false); + dialog.setIndeterminate(true); + dialog.show(); + } + @Override + protected Void doInBackground(Void... params) { + // Give the user a second to see the dialog + try { + Thread.sleep(1000); + } catch (InterruptedException e) { + // Ignore + } + // Restart the UI + try { + am.restart(); + } catch (RemoteException e) { + Log.e(TAG, "Failed to restart"); + } + return null; + } + }; + task.execute(); + } + /** * Reads the current font size and sets the value in the summary text */ @@ -528,6 +614,15 @@ public class DisplaySettings extends SettingsPreferenceFragment implements Log.e(TAG, "could not persist screen timeout setting", e); } } + if (KEY_LCD_DENSITY.equals(key)) { + try { + int value = Integer.parseInt((String) objValue); + writeLcdDensityPreference(preference.getContext(), value); + updateLcdDensityPreferenceDescription(value); + } catch (NumberFormatException e) { + Log.e(TAG, "could not persist display density setting", e); + } + } if (KEY_FONT_SIZE.equals(key)) { writeFontSizePreference(objValue); } |