summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAmith Yamasani <yamasani@google.com>2011-11-29 16:38:14 -0800
committerAmith Yamasani <yamasani@google.com>2011-11-30 18:46:54 -0800
commitdfb654367d4b65fb45089cd8d7d0905e3cd68ae3 (patch)
treeb24de480c3bf8aa9ee3a2c0ab3623fd7081cacbc
parent2fa017f874d20a5b037ebe57f3fc0c53964080bc (diff)
downloadpackages_apps_settings-dfb654367d4b65fb45089cd8d7d0905e3cd68ae3.zip
packages_apps_settings-dfb654367d4b65fb45089cd8d7d0905e3cd68ae3.tar.gz
packages_apps_settings-dfb654367d4b65fb45089cd8d7d0905e3cd68ae3.tar.bz2
Overhaul vibrate and silent settings to match hard keys.
We go back to the old style of toggling between Mute/Vibrate/Normal. There is an addition of a checkbox to indicate Vibrate on ring/notif. Icons in volume dialogs are no longer touchable. Bug: 5586083 This simplifies the logic in SoundSettings quite a bit, since there's a 1-1 mapping with ringer mode. Don't disable volume sliders when muted, so you can go to zero and back up by sliding your finger. This is because the icons are not clickable anymore. Change-Id: Ia7ce7e1bf108419eb107f03b7720101efe1598b1
-rw-r--r--res/values/arrays.xml22
-rw-r--r--res/values/strings.xml2
-rw-r--r--res/xml/sound_settings.xml17
-rw-r--r--src/com/android/settings/RingerVolumePreference.java23
-rw-r--r--src/com/android/settings/Settings.java6
-rw-r--r--src/com/android/settings/SoundSettings.java169
6 files changed, 73 insertions, 166 deletions
diff --git a/res/values/arrays.xml b/res/values/arrays.xml
index 0b8d7bb..97c6d99 100644
--- a/res/values/arrays.xml
+++ b/res/values/arrays.xml
@@ -550,20 +550,18 @@
<item>auto</item>
</string-array>
- <!-- New incoming call vibrate options. -->
- <string-array name="vibrate_entries">
- <item>Always</item>
- <item>Never</item>
- <item>Only in Silent mode</item>
- <item>Only when not in Silent mode</item>
+ <!-- Silent mode options. -->
+ <string-array name="silent_mode_entries">
+ <item>Off</item>
+ <item>Vibrate</item>
+ <item>Mute</item>
</string-array>
- <!-- Values for vibrate_entries matching constants in SoundSettings. Do not translate. -->
- <string-array name="vibrate_values" translatable="false">
- <item>always</item>
- <item>never</item>
- <item>silent</item>
- <item>notsilent</item>
+ <!-- Values for Silent mode. Do not translate. -->
+ <string-array name="silent_mode_values" translatable="false">
+ <item>off</item>
+ <item>vibrate</item>
+ <item>mute</item>
</string-array>
<!-- Titles for the list of long press timeout options. -->
diff --git a/res/values/strings.xml b/res/values/strings.xml
index fcecb8f..bca1d09 100644
--- a/res/values/strings.xml
+++ b/res/values/strings.xml
@@ -1511,7 +1511,7 @@
<!-- Sound settings screen, setting option name checkbox -->
<string name="vibrate_in_silent_title">Vibrate when silent</string>
<!-- Sound settings screen, setting option name checkbox -->
- <string name="vibrate_title">Vibrate</string>
+ <string name="vibrate_on_ring_title">Vibrate and ring</string>
<!-- Sound settings screen, setting option name -->
<string name="notification_sound_title">Default notification</string>
<!-- Sound settings screen, notification light repeat pulsing title -->
diff --git a/res/xml/sound_settings.xml b/res/xml/sound_settings.xml
index fc6fdf5..a61e0e1 100644
--- a/res/xml/sound_settings.xml
+++ b/res/xml/sound_settings.xml
@@ -27,16 +27,10 @@
android:streamType="ring" />
<ListPreference
- android:key="vibrate"
- android:title="@string/vibrate_title"
- android:entries="@array/vibrate_entries"
- android:entryValues="@array/vibrate_values" />
-
- <CheckBoxPreference
- android:key="silent"
+ android:key="silent_mode"
android:title="@string/silent_mode_title"
- android:persistent="false"
- />
+ android:entries="@array/silent_mode_entries"
+ android:entryValues="@array/silent_mode_values" />
<Preference
android:key="musicfx"
@@ -64,6 +58,11 @@
android:persistent="false"
android:ringtoneType="notification" />
+ <CheckBoxPreference
+ android:key="vibrate_on_ring"
+ android:title="@string/vibrate_on_ring_title"
+ android:defaultValue="false" />
+
<PreferenceCategory
android:title="@string/sound_category_feedback_title"/>
diff --git a/src/com/android/settings/RingerVolumePreference.java b/src/com/android/settings/RingerVolumePreference.java
index 59605c9..5845c8f 100644
--- a/src/com/android/settings/RingerVolumePreference.java
+++ b/src/com/android/settings/RingerVolumePreference.java
@@ -53,7 +53,7 @@ import android.widget.TextView;
* Special preference type that allows configuration of both the ring volume and
* notification volume.
*/
-public class RingerVolumePreference extends VolumePreference implements OnClickListener {
+public class RingerVolumePreference extends VolumePreference {
private static final String TAG = "RingerVolumePreference";
private static final int MSG_RINGER_MODE_CHANGED = 101;
@@ -126,7 +126,6 @@ public class RingerVolumePreference extends VolumePreference implements OnClickL
}
}
if (mSeekBars[i] != null) {
- mSeekBars[i].setEnabled(!muted);
final int volume = muted ? mAudioManager.getLastAudibleStreamVolume(streamType)
: mAudioManager.getStreamVolume(streamType);
mSeekBars[i].setProgress(volume);
@@ -176,9 +175,6 @@ public class RingerVolumePreference extends VolumePreference implements OnClickL
// Register callbacks for mute/unmute buttons
for (int i = 0; i < mCheckBoxes.length; i++) {
ImageView checkbox = (ImageView) view.findViewById(CHECKBOX_VIEW_ID[i]);
- if ((silentableStreams & (1 << SEEKBAR_TYPE[i])) != 0) {
- checkbox.setOnClickListener(this);
- }
mCheckBoxes[i] = checkbox;
}
@@ -363,21 +359,4 @@ public class RingerVolumePreference extends VolumePreference implements OnClickL
}
};
}
-
- public void onClick(View v) {
- // Touching any of the mute buttons causes us to get the state from the system and toggle it
- switch(mAudioManager.getRingerMode()) {
- case AudioManager.RINGER_MODE_NORMAL:
- mAudioManager.setRingerMode(
- (Settings.System.getInt(getContext().getContentResolver(),
- Settings.System.VIBRATE_IN_SILENT, 1) == 1)
- ? AudioManager.RINGER_MODE_VIBRATE
- : AudioManager.RINGER_MODE_SILENT);
- break;
- case AudioManager.RINGER_MODE_VIBRATE:
- case AudioManager.RINGER_MODE_SILENT:
- mAudioManager.setRingerMode(AudioManager.RINGER_MODE_NORMAL);
- break;
- }
- }
}
diff --git a/src/com/android/settings/Settings.java b/src/com/android/settings/Settings.java
index 6e0ce4c..c9f5c73 100644
--- a/src/com/android/settings/Settings.java
+++ b/src/com/android/settings/Settings.java
@@ -541,11 +541,11 @@ public class Settings extends PreferenceActivity implements ButtonBarHandler {
@Override
public boolean onPreferenceStartFragment(PreferenceFragment caller, Preference pref) {
// Override the fragment title for Wallpaper settings
- CharSequence title = pref.getTitle();
+ int titleRes = pref.getTitleRes();
if (pref.getFragment().equals(WallpaperTypeSettings.class.getName())) {
- title = getString(R.string.wallpaper_settings_fragment_title);
+ titleRes = R.string.wallpaper_settings_fragment_title;
}
- startPreferencePanel(pref.getFragment(), pref.getExtras(), 0, title, null, 0);
+ startPreferencePanel(pref.getFragment(), pref.getExtras(), titleRes, null, null, 0);
return true;
}
diff --git a/src/com/android/settings/SoundSettings.java b/src/com/android/settings/SoundSettings.java
index f73460b..d0e0e94 100644
--- a/src/com/android/settings/SoundSettings.java
+++ b/src/com/android/settings/SoundSettings.java
@@ -55,8 +55,8 @@ public class SoundSettings extends SettingsPreferenceFragment implements
/** If there is no setting in the provider, use this. */
private static final int FALLBACK_EMERGENCY_TONE_VALUE = 0;
- private static final String KEY_SILENT = "silent";
- private static final String KEY_VIBRATE = "vibrate";
+ private static final String KEY_SILENT_MODE = "silent_mode";
+ private static final String KEY_VIBRATE = "vibrate_on_ring";
private static final String KEY_RING_VOLUME = "ring_volume";
private static final String KEY_MUSICFX = "musicfx";
private static final String KEY_DTMF_TONE = "dtmf_tone";
@@ -69,10 +69,9 @@ public class SoundSettings extends SettingsPreferenceFragment implements
private static final String KEY_NOTIFICATION_SOUND = "notification_sound";
private static final String KEY_CATEGORY_CALLS = "category_calls";
- 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 static final String SILENT_MODE_OFF = "off";
+ private static final String SILENT_MODE_VIBRATE = "vibrate";
+ private static final String SILENT_MODE_MUTE = "mute";
private static final String[] NEED_VOICE_CAPABILITY = {
KEY_RINGTONE, KEY_DTMF_TONE, KEY_CATEGORY_CALLS,
@@ -82,16 +81,8 @@ public class SoundSettings extends SettingsPreferenceFragment implements
private static final int MSG_UPDATE_RINGTONE_SUMMARY = 1;
private static final int MSG_UPDATE_NOTIFICATION_SUMMARY = 2;
- private CheckBoxPreference mSilent;
-
- /*
- * If we are currently in one of the silent modes (the ringer mode is set to either
- * "silent mode" or "vibrate mode"), then toggling the "Phone vibrate"
- * preference will switch between "silent mode" and "vibrate mode".
- * Otherwise, it will adjust the normal ringer mode's ring or ring+vibrate
- * setting.
- */
- private ListPreference mVibrate;
+ private CheckBoxPreference mVibrateOnRing;
+ private ListPreference mSilentMode;
private CheckBoxPreference mDtmfTone;
private CheckBoxPreference mSoundEffects;
private CheckBoxPreference mHapticFeedback;
@@ -143,14 +134,16 @@ public class SoundSettings extends SettingsPreferenceFragment implements
getPreferenceScreen().removePreference(findPreference(KEY_EMERGENCY_TONE));
}
- mSilent = (CheckBoxPreference) findPreference(KEY_SILENT);
+ mSilentMode = (ListPreference) findPreference(KEY_SILENT_MODE);
if (!getResources().getBoolean(R.bool.has_silent_mode)) {
- getPreferenceScreen().removePreference(mSilent);
+ getPreferenceScreen().removePreference(mSilentMode);
findPreference(KEY_RING_VOLUME).setDependency(null);
+ } else {
+ mSilentMode.setOnPreferenceChangeListener(this);
}
- mVibrate = (ListPreference) findPreference(KEY_VIBRATE);
- mVibrate.setOnPreferenceChangeListener(this);
+ mVibrateOnRing = (CheckBoxPreference) findPreference(KEY_VIBRATE);
+ mVibrateOnRing.setOnPreferenceChangeListener(this);
mDtmfTone = (CheckBoxPreference) findPreference(KEY_DTMF_TONE);
mDtmfTone.setPersistent(false);
@@ -173,7 +166,7 @@ public class SoundSettings extends SettingsPreferenceFragment implements
mNotificationPreference = findPreference(KEY_NOTIFICATION_SOUND);
if (!((Vibrator) getSystemService(Context.VIBRATOR_SERVICE)).hasVibrator()) {
- getPreferenceScreen().removePreference(mVibrate);
+ getPreferenceScreen().removePreference(mVibrateOnRing);
getPreferenceScreen().removePreference(mHapticFeedback);
}
@@ -241,100 +234,50 @@ public class SoundSettings extends SettingsPreferenceFragment implements
getActivity().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;
- }
- }
+ /**
+ * Put the audio system into the correct vibrate setting
+ */
+ private void setPhoneVibrateSettingValue(boolean vibeOnRing) {
+ // If vibrate-on-ring is checked, use VIBRATE_SETTING_ON
+ // Otherwise vibrate is off when ringer is silent
+ int vibrateMode = vibeOnRing ? AudioManager.VIBRATE_SETTING_ON
+ : AudioManager.VIBRATE_SETTING_ONLY_SILENT;
+ mAudioManager.setVibrateSetting(AudioManager.VIBRATE_TYPE_RINGER, vibrateMode);
}
- 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;
+ private void setPhoneSilentSettingValue(String value) {
+ int ringerMode = AudioManager.RINGER_MODE_NORMAL;
+ if (value.equals(SILENT_MODE_MUTE)) {
+ ringerMode = AudioManager.RINGER_MODE_SILENT;
+ } else if (value.equals(SILENT_MODE_VIBRATE)) {
+ ringerMode = AudioManager.RINGER_MODE_VIBRATE;
}
+ mAudioManager.setRingerMode(ringerMode);
+ }
- 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);
+ private String getPhoneSilentModeSettingValue() {
+ switch (mAudioManager.getRingerMode()) {
+ case AudioManager.RINGER_MODE_NORMAL:
+ return SILENT_MODE_OFF;
+ case AudioManager.RINGER_MODE_VIBRATE:
+ return SILENT_MODE_VIBRATE;
+ case AudioManager.RINGER_MODE_SILENT:
+ return SILENT_MODE_MUTE;
}
-
- mAudioManager.setVibrateSetting(
- AudioManager.VIBRATE_TYPE_RINGER,
- callsVibrateSetting);
+ // Shouldn't happen
+ return SILENT_MODE_OFF;
}
// updateState in fact updates the UI to reflect the system state
private void updateState(boolean force) {
if (getActivity() == null) return;
- final int ringerMode = mAudioManager.getRingerMode();
-
- // NB: in the UI we now simply call this "silent mode". A separate
- // setting controls whether we're in RINGER_MODE_SILENT or
- // RINGER_MODE_VIBRATE.
- final boolean silentOrVibrateMode =
- ringerMode != AudioManager.RINGER_MODE_NORMAL;
+ final int vibrateMode = mAudioManager.getVibrateSetting(AudioManager.VIBRATE_TYPE_RINGER);
- if (silentOrVibrateMode != mSilent.isChecked() || force) {
- mSilent.setChecked(silentOrVibrateMode);
- }
-
- String phoneVibrateSetting = getPhoneVibrateSettingValue();
+ mVibrateOnRing.setChecked(vibrateMode == AudioManager.VIBRATE_SETTING_ON);
+ mSilentMode.setValue(getPhoneSilentModeSettingValue());
- if (! phoneVibrateSetting.equals(mVibrate.getValue()) || force) {
- mVibrate.setValue(phoneVibrateSetting);
- }
- mVibrate.setSummary(mVibrate.getEntry());
+ mSilentMode.setSummary(mSilentMode.getEntry());
}
private void updateRingtoneName(int type, Preference preference, int msg) {
@@ -370,20 +313,7 @@ public class SoundSettings extends SettingsPreferenceFragment implements
@Override
public boolean onPreferenceTreeClick(PreferenceScreen preferenceScreen, Preference preference) {
- if (preference == mSilent) {
- if (mSilent.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);
- } else {
- mAudioManager.setRingerMode(AudioManager.RINGER_MODE_NORMAL);
- }
- updateState(false);
- } else if (preference == mDtmfTone) {
+ if (preference == mDtmfTone) {
Settings.System.putInt(getContentResolver(), Settings.System.DTMF_TONE_WHEN_DIALING,
mDtmfTone.isChecked() ? 1 : 0);
@@ -422,9 +352,10 @@ public class SoundSettings extends SettingsPreferenceFragment implements
} catch (NumberFormatException e) {
Log.e(TAG, "could not persist emergency tone setting", e);
}
- } else if (preference == mVibrate) {
- setPhoneVibrateSettingValue(objValue.toString());
- updateState(false);
+ } else if (preference == mVibrateOnRing) {
+ setPhoneVibrateSettingValue((Boolean) objValue);
+ } else if (preference == mSilentMode) {
+ setPhoneSilentSettingValue(objValue.toString());
}
return true;