summaryrefslogtreecommitdiffstats
path: root/src/com/android/settings/SoundSettings.java
diff options
context:
space:
mode:
authorDaniel Sandler <dsandler@android.com>2010-04-21 15:24:24 -0400
committerDaniel Sandler <dsandler@android.com>2010-04-21 15:29:34 -0400
commit2c917847f520c59af84837d4514855ea01f0316c (patch)
treea6aa84a40dcbca16a89974a305f5da660399d62d /src/com/android/settings/SoundSettings.java
parent8ad849ca26f472d1243130392186c435b98454ef (diff)
downloadpackages_apps_settings-2c917847f520c59af84837d4514855ea01f0316c.zip
packages_apps_settings-2c917847f520c59af84837d4514855ea01f0316c.tar.gz
packages_apps_settings-2c917847f520c59af84837d4514855ea01f0316c.tar.bz2
Redesign vibration settings.
Under the hood there remain three axes: 1. Are we in silent mode now? | RINGER_MODE_{VIBRATE,SILENT} 2. Do we vibrate in silent mode? | VIBRATE_IN_SILENT == 1 3. Do calls vibrate: | getVibrateSetting(VIBRATE_TYPE_RINGER) - always | == VIBRATE_SETTING_ON - never | == VIBRATE_SETTING_OFF - only in silent | == VIBRATE_SETTING_ONLY_SILENT We now expose this to the user much more simply by collapsing (2) and (3) above, and discarding states that don't make sense: - VIBRATE_SETTING_OFF + VIBRATE_IN_SILENT - VIBRATE_SETTING_ONLY_SILENT + !VIBRATE_IN_SILENT Now we offer the user four choices: Phone vibrate: * "Never" --> VIBRATE_IN_SILENT=0, VIBRATE_SETTING_OFF * "Always" --> VIBRATE_IN_SILENT=1, VIBRATE_SETTING_ON * "Only in silent mode" --> VIBRATE_IN_SILENT=1, VIBRATE_SETTING_ONLY_SILENT * "Only when not in silent mode" --> VIBRATE_IN_SILENT=0, VIBRATE_SETTING_ON This should make it easier to choose exactly the behavior the user wants as well as avoid nonsensical combinations of settings. Bug: 2598014 Change-Id: I9244d25ec97a3e2b572b71b521049debd22fa4e0
Diffstat (limited to 'src/com/android/settings/SoundSettings.java')
-rw-r--r--src/com/android/settings/SoundSettings.java132
1 files changed, 91 insertions, 41 deletions
diff --git a/src/com/android/settings/SoundSettings.java b/src/com/android/settings/SoundSettings.java
index ca7a1f3..bfb5566 100644
--- a/src/com/android/settings/SoundSettings.java
+++ b/src/com/android/settings/SoundSettings.java
@@ -49,7 +49,6 @@ public class SoundSettings extends PreferenceActivity implements
private static final String KEY_SILENT = "silent";
private static final String KEY_VIBRATE = "vibrate";
- private static final String KEY_VIBRATE_IN_SILENT = "vibrate_in_silent";
private static final String KEY_DTMF_TONE = "dtmf_tone";
private static final String KEY_SOUND_EFFECTS = "sound_effects";
private static final String KEY_HAPTIC_FEEDBACK = "haptic_feedback";
@@ -58,6 +57,11 @@ public class SoundSettings extends PreferenceActivity implements
private static final String KEY_NOTIFICATION_PULSE = "notification_pulse";
private static final String KEY_LOCK_SOUNDS = "lock_sounds";
+ private static final String VALUE_VIBRATE_NEVER = "never";
+ private static final String VALUE_VIBRATE_ALWAYS = "always";
+ private static final String VALUE_VIBRATE_ONLY_SILENT = "silent";
+ private static final String VALUE_VIBRATE_UNLESS_SILENT = "notsilent";
+
private CheckBoxPreference mSilent;
/*
@@ -67,8 +71,7 @@ public class SoundSettings extends PreferenceActivity implements
* Otherwise, it will adjust the normal ringer mode's ring or ring+vibrate
* setting.
*/
- private ListPreference mPhoneVibrate;
- private CheckBoxPreference mVibrateInSilent;
+ private ListPreference mVibrate;
private CheckBoxPreference mDtmfTone;
private CheckBoxPreference mSoundEffects;
private CheckBoxPreference mHapticFeedback;
@@ -105,10 +108,9 @@ public class SoundSettings extends PreferenceActivity implements
mSilent = (CheckBoxPreference) findPreference(KEY_SILENT);
- mPhoneVibrate = (ListPreference) findPreference(KEY_VIBRATE);
- mPhoneVibrate.setOnPreferenceChangeListener(this);
+ mVibrate = (ListPreference) findPreference(KEY_VIBRATE);
+ mVibrate.setOnPreferenceChangeListener(this);
- mVibrateInSilent = (CheckBoxPreference) findPreference(KEY_VIBRATE_IN_SILENT);
mDtmfTone = (CheckBoxPreference) findPreference(KEY_DTMF_TONE);
mDtmfTone.setPersistent(false);
mDtmfTone.setChecked(Settings.System.getInt(resolver,
@@ -169,6 +171,78 @@ public class SoundSettings extends PreferenceActivity implements
unregisterReceiver(mReceiver);
}
+ private String getPhoneVibrateSettingValue() {
+ boolean vibeInSilent = (Settings.System.getInt(
+ getContentResolver(),
+ Settings.System.VIBRATE_IN_SILENT,
+ 1) == 1);
+
+ // Control phone vibe independent of silent mode
+ int callsVibrateSetting =
+ mAudioManager.getVibrateSetting(AudioManager.VIBRATE_TYPE_RINGER);
+
+ if (vibeInSilent) {
+ if (callsVibrateSetting == AudioManager.VIBRATE_SETTING_OFF) {
+ // this state does not make sense; fix it up for the user
+ mAudioManager.setVibrateSetting(
+ AudioManager.VIBRATE_TYPE_RINGER,
+ AudioManager.VIBRATE_SETTING_ONLY_SILENT);
+ }
+ if (callsVibrateSetting == AudioManager.VIBRATE_SETTING_ON) {
+ return VALUE_VIBRATE_ALWAYS;
+ } else {
+ return VALUE_VIBRATE_ONLY_SILENT;
+ }
+ } else {
+ if (callsVibrateSetting == AudioManager.VIBRATE_SETTING_ONLY_SILENT) {
+ // this state does not make sense; fix it up
+ mAudioManager.setVibrateSetting(
+ AudioManager.VIBRATE_TYPE_RINGER,
+ AudioManager.VIBRATE_SETTING_OFF);
+ }
+ if (callsVibrateSetting == AudioManager.VIBRATE_SETTING_ON) {
+ return VALUE_VIBRATE_UNLESS_SILENT;
+ } else {
+ return VALUE_VIBRATE_NEVER;
+ }
+ }
+ }
+
+ private void setPhoneVibrateSettingValue(String value) {
+ boolean vibeInSilent;
+ int callsVibrateSetting;
+
+ if (value.equals(VALUE_VIBRATE_UNLESS_SILENT)) {
+ callsVibrateSetting = AudioManager.VIBRATE_SETTING_ON;
+ vibeInSilent = false;
+ } else if (value.equals(VALUE_VIBRATE_NEVER)) {
+ callsVibrateSetting = AudioManager.VIBRATE_SETTING_OFF;
+ vibeInSilent = false;
+ } else if (value.equals(VALUE_VIBRATE_ONLY_SILENT)) {
+ callsVibrateSetting = AudioManager.VIBRATE_SETTING_ONLY_SILENT;
+ vibeInSilent = true;
+ } else { //VALUE_VIBRATE_ALWAYS
+ callsVibrateSetting = AudioManager.VIBRATE_SETTING_ON;
+ vibeInSilent = true;
+ }
+
+ Settings.System.putInt(getContentResolver(),
+ Settings.System.VIBRATE_IN_SILENT,
+ vibeInSilent ? 1 : 0);
+
+ // might need to switch the ringer mode from one kind of "silent" to
+ // another
+ if (mSilent.isChecked()) {
+ mAudioManager.setRingerMode(
+ vibeInSilent ? AudioManager.RINGER_MODE_VIBRATE
+ : AudioManager.RINGER_MODE_SILENT);
+ }
+
+ mAudioManager.setVibrateSetting(
+ AudioManager.VIBRATE_TYPE_RINGER,
+ callsVibrateSetting);
+ }
+
// updateState in fact updates the UI to reflect the system state
private void updateState(boolean force) {
final int ringerMode = mAudioManager.getRingerMode();
@@ -183,18 +257,12 @@ public class SoundSettings extends PreferenceActivity implements
mSilent.setChecked(silentOrVibrateMode);
}
- mVibrateInSilent.setChecked(Settings.System.getInt(
- getContentResolver(),
- Settings.System.VIBRATE_IN_SILENT,
- 1) == 1);
-
- // Control phone vibe independent of silent mode
- String phoneVibrateSetting = String.valueOf(
- mAudioManager.getVibrateSetting(AudioManager.VIBRATE_TYPE_RINGER));
+ String phoneVibrateSetting = getPhoneVibrateSettingValue();
- if (! phoneVibrateSetting.equals(mPhoneVibrate.getValue()) || force) {
- mPhoneVibrate.setValue(phoneVibrateSetting);
+ if (! phoneVibrateSetting.equals(mVibrate.getValue()) || force) {
+ mVibrate.setValue(phoneVibrateSetting);
}
+ mVibrate.setSummary(mVibrate.getEntry());
int silentModeStreams = Settings.System.getInt(getContentResolver(),
Settings.System.MODE_RINGER_STREAMS_AFFECTED, 0);
@@ -202,14 +270,16 @@ public class SoundSettings extends PreferenceActivity implements
mSilent.setSummary(isAlarmInclSilentMode ?
R.string.silent_mode_incl_alarm_summary :
R.string.silent_mode_summary);
-
}
@Override
public boolean onPreferenceTreeClick(PreferenceScreen preferenceScreen, Preference preference) {
if (preference == mSilent) {
if (mSilent.isChecked()) {
- boolean vibeInSilent = mVibrateInSilent.isChecked();
+ boolean vibeInSilent = (1 == Settings.System.getInt(
+ getContentResolver(),
+ Settings.System.VIBRATE_IN_SILENT,
+ 1));
mAudioManager.setRingerMode(
vibeInSilent ? AudioManager.RINGER_MODE_VIBRATE
: AudioManager.RINGER_MODE_SILENT);
@@ -217,17 +287,6 @@ public class SoundSettings extends PreferenceActivity implements
mAudioManager.setRingerMode(AudioManager.RINGER_MODE_NORMAL);
}
updateState(false);
- } else if (preference == mVibrateInSilent) {
- boolean vibeInSilent = mVibrateInSilent.isChecked();
- Settings.System.putInt(getContentResolver(),
- Settings.System.VIBRATE_IN_SILENT,
- vibeInSilent ? 1 : 0);
- int ringerMode = mAudioManager.getRingerMode();
- if (ringerMode != AudioManager.RINGER_MODE_NORMAL) {
- mAudioManager.setRingerMode(vibeInSilent
- ? AudioManager.RINGER_MODE_VIBRATE
- : AudioManager.RINGER_MODE_SILENT);
- }
} else if (preference == mDtmfTone) {
Settings.System.putInt(getContentResolver(), Settings.System.DTMF_TONE_WHEN_DIALING,
mDtmfTone.isChecked() ? 1 : 0);
@@ -268,18 +327,9 @@ public class SoundSettings extends PreferenceActivity implements
} catch (NumberFormatException e) {
Log.e(TAG, "could not persist emergency tone setting", e);
}
- } else if (preference == mPhoneVibrate) {
- int vibeSetting = new Integer(objValue.toString()).intValue();
- switch (vibeSetting) {
- case AudioManager.VIBRATE_SETTING_ON:
- case AudioManager.VIBRATE_SETTING_OFF:
- case AudioManager.VIBRATE_SETTING_ONLY_SILENT:
- mAudioManager.setVibrateSetting(
- AudioManager.VIBRATE_TYPE_RINGER,
- vibeSetting);
- updateState(false);
- break;
- }
+ } else if (preference == mVibrate) {
+ setPhoneVibrateSettingValue(objValue.toString());
+ updateState(false);
}
return true;