Settings changes for Android Dreams (now Screen Candy).
- new preference design - remove candy-specific timeout - use new settings keys Requires Change I31f31b3 Bug: 5591015 Change-Id: I45cb6ea5c68f9932c6d4e65e2b219331d48a62d6
This commit is contained in:
@@ -1619,19 +1619,24 @@
|
||||
<!-- Wallpaper settings fragment title [CHAR LIMIT=30] -->
|
||||
<string name="wallpaper_settings_fragment_title">Choose wallpaper from</string>
|
||||
<!-- Display settings screen, trigger for screen saver options -->
|
||||
<string name="dream_settings_title">Android Dreams</string>
|
||||
<!-- Display settings screen, summary for screen saver options -->
|
||||
<string name="dream_settings_summary">Screen savers and other idle diversions</string>
|
||||
<string name="screensaver_settings_title">Screen Candy</string>
|
||||
<!-- Display settings screen, summary for screen saver options, screen saver is turned on -->
|
||||
<string name="screensaver_settings_summary_on">Will start upon sleep if connected to power</string>
|
||||
<!-- Display settings screen, summary for screen saver options, screen saver is turned off -->
|
||||
<string name="screensaver_settings_summary_off">Disabled</string>
|
||||
<!-- Screen saver settings, setting option name to select a module -->
|
||||
<string name="dream_component_title">Selected dream</string>
|
||||
<string name="screensaver_component_title">Selected candy</string>
|
||||
<!-- Screen saver settings, setting option name to change activation timeout -->
|
||||
<string name="dream_timeout_title">When to activate</string>
|
||||
<string name="screensaver_timeout_title">When to activate</string>
|
||||
<!-- Screen saver settings, setting option summary to change activation timeout -->
|
||||
<string name="dream_timeout_summary">After <xliff:g id="timeout_description">%1$s</xliff:g> spent idle</string>
|
||||
<string name="screensaver_timeout_summary">After <xliff:g id="timeout_description">%1$s</xliff:g> spent idle</string>
|
||||
<!-- Screen saver settings, setting option summary to change activation timeout, shown when disabled -->
|
||||
<string name="dream_timeout_zero_summary">Never</string>
|
||||
<string name="screensaver_timeout_zero_summary">Never</string>
|
||||
<!-- Screen saver settings, button allowing the user to test/try the current module -->
|
||||
<string name="dream_test">Try it!</string>
|
||||
<string name="screensaver_test">Try it!</string>
|
||||
<!-- Screen saver settings, checkbox allowing the screen saver to activate automatically when
|
||||
the device is docked -->
|
||||
<string name="screensaver_activate_on_dock_title">Also start when docked</string>
|
||||
<!-- Sound & display settings screen, setting option name to change whether the screen adjusts automatically based on lighting conditions -->
|
||||
<string name="automatic_brightness">Automatic brightness</string>
|
||||
<!-- [CHAR LIMIT=30] Sound & display settings screen, setting option name to change font size -->
|
||||
|
@@ -41,8 +41,8 @@
|
||||
android:entryValues="@array/screen_timeout_values" />
|
||||
|
||||
<PreferenceScreen
|
||||
android:title="@string/dream_settings_title"
|
||||
android:summary="@string/dream_settings_summary"
|
||||
android:key="screensaver"
|
||||
android:title="@string/screensaver_settings_title"
|
||||
android:fragment="com.android.settings.DreamSettings" />
|
||||
|
||||
<ListPreference
|
||||
|
@@ -15,27 +15,25 @@
|
||||
-->
|
||||
|
||||
<PreferenceScreen xmlns:android="http://schemas.android.com/apk/res/android"
|
||||
android:title="@string/dream_settings_title"
|
||||
android:title="@string/screensaver_settings_title"
|
||||
xmlns:settings="http://schemas.android.com/apk/res/com.android.settings">
|
||||
|
||||
<com.android.settings.DreamComponentPreference
|
||||
android:key="dream_component"
|
||||
android:title="@string/dream_component_title"
|
||||
android:key="screensaver_component"
|
||||
android:title="@string/screensaver_component_title"
|
||||
android:persistent="false"
|
||||
/>
|
||||
|
||||
<ListPreference
|
||||
android:key="dream_timeout"
|
||||
android:title="@string/dream_timeout_title"
|
||||
android:summary="@string/dream_timeout_summary"
|
||||
android:persistent="false"
|
||||
android:entries="@array/dream_timeout_entries"
|
||||
android:entryValues="@array/dream_timeout_values" />
|
||||
|
||||
<com.android.settings.DreamTesterPreference
|
||||
android:key="dream_test"
|
||||
android:title="@string/dream_test"
|
||||
android:key="test"
|
||||
android:title="@string/screensaver_test"
|
||||
android:persistent="false"
|
||||
/>
|
||||
|
||||
<CheckBoxPreference
|
||||
android:key="activate_on_dock"
|
||||
android:persistent="false"
|
||||
android:title="@string/screensaver_activate_on_dock_title"
|
||||
android:defaultValue="true" />
|
||||
|
||||
</PreferenceScreen>
|
||||
|
@@ -39,6 +39,8 @@ import android.util.Log;
|
||||
import android.view.IWindowManager;
|
||||
import android.view.Surface;
|
||||
|
||||
import com.android.settings.DreamSettings;
|
||||
|
||||
import java.util.ArrayList;
|
||||
|
||||
public class DisplaySettings extends SettingsPreferenceFragment implements
|
||||
@@ -52,6 +54,7 @@ public class DisplaySettings extends SettingsPreferenceFragment implements
|
||||
private static final String KEY_ACCELEROMETER = "accelerometer";
|
||||
private static final String KEY_FONT_SIZE = "font_size";
|
||||
private static final String KEY_NOTIFICATION_PULSE = "notification_pulse";
|
||||
private static final String KEY_SCREEN_SAVER = "screensaver";
|
||||
|
||||
private CheckBoxPreference mAccelerometer;
|
||||
private ListPreference mFontSizePref;
|
||||
@@ -60,6 +63,7 @@ public class DisplaySettings extends SettingsPreferenceFragment implements
|
||||
private final Configuration mCurConfig = new Configuration();
|
||||
|
||||
private ListPreference mScreenTimeoutPreference;
|
||||
private Preference mScreenSaverPreference;
|
||||
|
||||
private ContentObserver mAccelerometerRotationObserver = new ContentObserver(new Handler()) {
|
||||
@Override
|
||||
@@ -78,6 +82,8 @@ public class DisplaySettings extends SettingsPreferenceFragment implements
|
||||
mAccelerometer = (CheckBoxPreference) findPreference(KEY_ACCELEROMETER);
|
||||
mAccelerometer.setPersistent(false);
|
||||
|
||||
mScreenSaverPreference = findPreference(KEY_SCREEN_SAVER);
|
||||
|
||||
mScreenTimeoutPreference = (ListPreference) findPreference(KEY_SCREEN_TIMEOUT);
|
||||
final long currentTimeout = Settings.System.getLong(resolver, SCREEN_OFF_TIMEOUT,
|
||||
FALLBACK_SCREEN_TIMEOUT_VALUE);
|
||||
@@ -213,6 +219,14 @@ public class DisplaySettings extends SettingsPreferenceFragment implements
|
||||
private void updateState() {
|
||||
updateAccelerometerRotationCheckbox();
|
||||
readFontSizePreference(mFontSizePref);
|
||||
updateScreenSaverSummary();
|
||||
}
|
||||
|
||||
private void updateScreenSaverSummary() {
|
||||
mScreenSaverPreference.setSummary(
|
||||
DreamSettings.isScreenSaverEnabled(mScreenSaverPreference.getContext())
|
||||
? R.string.screensaver_settings_summary_on
|
||||
: R.string.screensaver_settings_summary_off);
|
||||
}
|
||||
|
||||
private void updateAccelerometerRotationCheckbox() {
|
||||
|
@@ -16,7 +16,7 @@
|
||||
|
||||
package com.android.settings;
|
||||
|
||||
import static android.provider.Settings.Secure.DREAM_COMPONENT;
|
||||
import static android.provider.Settings.Secure.SCREENSAVER_COMPONENT;
|
||||
|
||||
import android.app.AlertDialog;
|
||||
import android.content.Context;
|
||||
@@ -65,7 +65,7 @@ public class DreamComponentPreference extends Preference {
|
||||
}
|
||||
|
||||
private void refreshFromSettings() {
|
||||
String component = Settings.Secure.getString(resolver, DREAM_COMPONENT);
|
||||
String component = Settings.Secure.getString(resolver, SCREENSAVER_COMPONENT);
|
||||
if (component == null) {
|
||||
component = getContext().getResources().getString(
|
||||
com.android.internal.R.string.config_defaultDreamComponent);
|
||||
@@ -168,7 +168,7 @@ public class DreamComponentPreference extends Preference {
|
||||
setSummary(ri.loadLabel(pm));
|
||||
//getContext().startActivity(intent);
|
||||
|
||||
Settings.Secure.putString(resolver, DREAM_COMPONENT, cn.flattenToString());
|
||||
Settings.Secure.putString(resolver, SCREENSAVER_COMPONENT, cn.flattenToString());
|
||||
}
|
||||
})
|
||||
.create();
|
||||
|
@@ -16,8 +16,11 @@
|
||||
|
||||
package com.android.settings;
|
||||
|
||||
import static android.provider.Settings.Secure.DREAM_TIMEOUT;
|
||||
import static android.provider.Settings.Secure.SCREENSAVER_ENABLED;
|
||||
import static android.provider.Settings.Secure.SCREENSAVER_ACTIVATE_ON_DOCK;
|
||||
|
||||
import android.app.ActionBar;
|
||||
import android.app.Activity;
|
||||
import android.app.ActivityManagerNative;
|
||||
import android.app.admin.DevicePolicyManager;
|
||||
import android.content.ContentResolver;
|
||||
@@ -31,98 +34,125 @@ import android.os.ServiceManager;
|
||||
import android.preference.CheckBoxPreference;
|
||||
import android.preference.ListPreference;
|
||||
import android.preference.Preference;
|
||||
import android.preference.PreferenceActivity;
|
||||
import android.preference.PreferenceScreen;
|
||||
import android.provider.Settings;
|
||||
import android.util.Log;
|
||||
import android.view.Gravity;
|
||||
import android.view.IWindowManager;
|
||||
import android.widget.CompoundButton;
|
||||
import android.widget.Switch;
|
||||
|
||||
import java.util.ArrayList;
|
||||
|
||||
public class DreamSettings extends SettingsPreferenceFragment implements
|
||||
Preference.OnPreferenceChangeListener {
|
||||
public class DreamSettings extends SettingsPreferenceFragment {
|
||||
private static final String TAG = "DreamSettings";
|
||||
|
||||
private static final String KEY_DREAM_TIMEOUT = "dream_timeout";
|
||||
private static final String KEY_ACTIVATE_ON_DOCK = "activate_on_dock";
|
||||
|
||||
private ListPreference mScreenTimeoutPreference;
|
||||
private ListPreference mDreamTimeoutPreference;
|
||||
private CheckBoxPreference mActivateOnDockPreference;
|
||||
|
||||
private Switch mEnableSwitch;
|
||||
private Enabler mEnabler;
|
||||
|
||||
@Override
|
||||
public void onCreate(Bundle savedInstanceState) {
|
||||
super.onCreate(savedInstanceState);
|
||||
ContentResolver resolver = getActivity().getContentResolver();
|
||||
public void onActivityCreated(Bundle savedInstanceState) {
|
||||
super.onActivityCreated(savedInstanceState);
|
||||
|
||||
addPreferencesFromResource(R.xml.dream_settings);
|
||||
|
||||
mDreamTimeoutPreference = (ListPreference) findPreference(KEY_DREAM_TIMEOUT);
|
||||
final long currentSaverTimeout = Settings.Secure.getLong(resolver, DREAM_TIMEOUT,
|
||||
0);
|
||||
mDreamTimeoutPreference.setValue(String.valueOf(currentSaverTimeout));
|
||||
mDreamTimeoutPreference.setOnPreferenceChangeListener(this);
|
||||
updateTimeoutPreferenceDescription(resolver, mDreamTimeoutPreference,
|
||||
R.string.dream_timeout_summary,
|
||||
R.string.dream_timeout_zero_summary,
|
||||
currentSaverTimeout);
|
||||
mActivateOnDockPreference = (CheckBoxPreference) findPreference(KEY_ACTIVATE_ON_DOCK);
|
||||
|
||||
final Activity activity = getActivity();
|
||||
|
||||
mEnableSwitch = new Switch(activity);
|
||||
|
||||
if (activity instanceof PreferenceActivity) {
|
||||
PreferenceActivity preferenceActivity = (PreferenceActivity) activity;
|
||||
if (preferenceActivity.onIsHidingHeaders() || !preferenceActivity.onIsMultiPane()) {
|
||||
final int padding = activity.getResources().getDimensionPixelSize(
|
||||
R.dimen.action_bar_switch_padding);
|
||||
mEnableSwitch.setPadding(0, 0, padding, 0);
|
||||
activity.getActionBar().setDisplayOptions(ActionBar.DISPLAY_SHOW_CUSTOM,
|
||||
ActionBar.DISPLAY_SHOW_CUSTOM);
|
||||
activity.getActionBar().setCustomView(mEnableSwitch, new ActionBar.LayoutParams(
|
||||
ActionBar.LayoutParams.WRAP_CONTENT,
|
||||
ActionBar.LayoutParams.WRAP_CONTENT,
|
||||
Gravity.CENTER_VERTICAL | Gravity.RIGHT));
|
||||
activity.getActionBar().setTitle(R.string.screensaver_settings_title);
|
||||
}
|
||||
}
|
||||
|
||||
private void updateTimeoutPreferenceDescription(
|
||||
ContentResolver resolver,
|
||||
ListPreference pref,
|
||||
int summaryStrings,
|
||||
long currentTimeout) {
|
||||
updateTimeoutPreferenceDescription(resolver, pref, summaryStrings, 0, currentTimeout);
|
||||
mEnabler = new Enabler(activity, mEnableSwitch);
|
||||
}
|
||||
private void updateTimeoutPreferenceDescription(
|
||||
ContentResolver resolver,
|
||||
ListPreference pref,
|
||||
int summaryStrings,
|
||||
int zeroString,
|
||||
long currentTimeout) {
|
||||
String summary;
|
||||
if (currentTimeout == 0) {
|
||||
summary = pref.getContext().getString(zeroString);
|
||||
} else {
|
||||
final CharSequence[] entries = pref.getEntries();
|
||||
final CharSequence[] values = pref.getEntryValues();
|
||||
int best = 0;
|
||||
for (int i = 0; i < values.length; i++) {
|
||||
long timeout = Long.valueOf(values[i].toString());
|
||||
if (currentTimeout >= timeout) {
|
||||
best = i;
|
||||
|
||||
public static boolean isScreenSaverEnabled(Context context) {
|
||||
return 0 != Settings.Secure.getInt(
|
||||
context.getContentResolver(), SCREENSAVER_ENABLED, 1);
|
||||
}
|
||||
|
||||
public static void setScreenSaverEnabled(Context context, boolean enabled) {
|
||||
Settings.Secure.putInt(
|
||||
context.getContentResolver(), SCREENSAVER_ENABLED, enabled ? 1 : 0);
|
||||
}
|
||||
summary = pref.getContext().getString(summaryStrings, entries[best]);
|
||||
|
||||
public static class Enabler implements CompoundButton.OnCheckedChangeListener {
|
||||
private final Context mContext;
|
||||
private Switch mSwitch;
|
||||
|
||||
public Enabler(Context context, Switch switch_) {
|
||||
mContext = context;
|
||||
setSwitch(switch_);
|
||||
}
|
||||
@Override
|
||||
public void onCheckedChanged(CompoundButton buttonView, boolean isChecked) {
|
||||
setScreenSaverEnabled(mContext, isChecked);
|
||||
}
|
||||
public void setSwitch(Switch switch_) {
|
||||
if (mSwitch == switch_) return;
|
||||
if (mSwitch != null) mSwitch.setOnCheckedChangeListener(null);
|
||||
mSwitch = switch_;
|
||||
mSwitch.setOnCheckedChangeListener(this);
|
||||
|
||||
final boolean enabled = isScreenSaverEnabled(mContext);
|
||||
mSwitch.setChecked(enabled);
|
||||
}
|
||||
public void pause() {
|
||||
mSwitch.setOnCheckedChangeListener(null);
|
||||
}
|
||||
public void resume() {
|
||||
mSwitch.setOnCheckedChangeListener(this);
|
||||
}
|
||||
pref.setSummary(summary);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onResume() {
|
||||
if (mEnabler != null) {
|
||||
mEnabler.resume();
|
||||
}
|
||||
|
||||
final boolean currentActivateOnDock = 0 != Settings.Secure.getInt(getContentResolver(),
|
||||
SCREENSAVER_ACTIVATE_ON_DOCK, 1);
|
||||
mActivateOnDockPreference.setChecked(currentActivateOnDock);
|
||||
super.onResume();
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onPause() {
|
||||
if (mEnabler != null) {
|
||||
mEnabler.pause();
|
||||
}
|
||||
|
||||
super.onPause();
|
||||
}
|
||||
|
||||
public boolean onPreferenceChange(Preference preference, Object objValue) {
|
||||
final String key = preference.getKey();
|
||||
if (KEY_DREAM_TIMEOUT.equals(key)) {
|
||||
int value = Integer.parseInt((String) objValue);
|
||||
try {
|
||||
@Override
|
||||
public boolean onPreferenceTreeClick(PreferenceScreen preferenceScreen, Preference preference) {
|
||||
if (preference == mActivateOnDockPreference) {
|
||||
Settings.Secure.putInt(getContentResolver(),
|
||||
DREAM_TIMEOUT, value);
|
||||
updateTimeoutPreferenceDescription(getContentResolver(),
|
||||
mDreamTimeoutPreference,
|
||||
R.string.dream_timeout_summary,
|
||||
R.string.dream_timeout_zero_summary,
|
||||
value);
|
||||
} catch (NumberFormatException e) {
|
||||
Log.e(TAG, "could not persist dream timeout setting", e);
|
||||
}
|
||||
}
|
||||
|
||||
return true;
|
||||
SCREENSAVER_ACTIVATE_ON_DOCK,
|
||||
mActivateOnDockPreference.isChecked() ? 1 : 0);
|
||||
}
|
||||
return super.onPreferenceTreeClick(preferenceScreen, preference);
|
||||
}
|
||||
}
|
||||
|
@@ -16,7 +16,7 @@
|
||||
|
||||
package com.android.settings;
|
||||
|
||||
import static android.provider.Settings.Secure.DREAM_COMPONENT;
|
||||
import static android.provider.Settings.Secure.SCREENSAVER_COMPONENT;
|
||||
|
||||
import android.app.AlertDialog;
|
||||
import android.content.Context;
|
||||
@@ -60,13 +60,15 @@ public class DreamTesterPreference extends Preference {
|
||||
|
||||
@Override
|
||||
protected void onClick() {
|
||||
String component = Settings.Secure.getString(resolver, DREAM_COMPONENT);
|
||||
String component = Settings.Secure.getString(resolver, SCREENSAVER_COMPONENT);
|
||||
Log.v(TAG, "component=" + component);
|
||||
if (component != null) {
|
||||
ComponentName cn = ComponentName.unflattenFromString(component);
|
||||
Log.v(TAG, "cn=" + cn);
|
||||
Intent intent = new Intent(Intent.ACTION_MAIN)
|
||||
.setComponent(cn)
|
||||
.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK
|
||||
| Intent.FLAG_ACTIVITY_EXCLUDE_FROM_RECENTS
|
||||
.addFlags(
|
||||
Intent.FLAG_ACTIVITY_EXCLUDE_FROM_RECENTS
|
||||
)
|
||||
.putExtra("android.dreams.TEST", true);
|
||||
getContext().startActivity(intent);
|
||||
|
Reference in New Issue
Block a user