Merge "Single volume control when config_useMasterVolume is true"
This commit is contained in:
@@ -80,6 +80,13 @@ public class RingerVolumePreference extends VolumePreference {
|
||||
R.id.alarm_mute_button
|
||||
};
|
||||
|
||||
private static final int[] SEEKBAR_SECTION_ID = new int[] {
|
||||
R.id.media_section,
|
||||
R.id.ringer_section,
|
||||
R.id.notification_section,
|
||||
R.id.alarm_section
|
||||
};
|
||||
|
||||
private static final int[] SEEKBAR_MUTED_RES_ID = new int[] {
|
||||
com.android.internal.R.drawable.ic_audio_vol_mute,
|
||||
com.android.internal.R.drawable.ic_audio_ring_notif_mute,
|
||||
@@ -198,15 +205,33 @@ public class RingerVolumePreference extends VolumePreference {
|
||||
getContext().registerReceiver(mRingModeChangedReceiver, filter);
|
||||
}
|
||||
|
||||
// Disable either ringer+notifications or notifications
|
||||
int id;
|
||||
if (!Utils.isVoiceCapable(getContext())) {
|
||||
id = R.id.ringer_section;
|
||||
boolean useMasterVolume = getContext().getResources().
|
||||
getBoolean(com.android.internal.R.bool.config_useMasterVolume);
|
||||
if (useMasterVolume) {
|
||||
// If config_useMasterVolume is true, all streams are treated as STREAM_MASTER.
|
||||
// So hide all except a stream.
|
||||
int id;
|
||||
if (Utils.isVoiceCapable(getContext())) {
|
||||
id = R.id.ringer_section;
|
||||
} else {
|
||||
id = R.id.media_section;
|
||||
}
|
||||
for (int i = 0; i < SEEKBAR_SECTION_ID.length; i++) {
|
||||
if (SEEKBAR_SECTION_ID[i] != id) {
|
||||
view.findViewById(SEEKBAR_SECTION_ID[i]).setVisibility(View.GONE);
|
||||
}
|
||||
}
|
||||
} else {
|
||||
id = R.id.notification_section;
|
||||
// Disable either ringer+notifications or notifications
|
||||
int id;
|
||||
if (!Utils.isVoiceCapable(getContext())) {
|
||||
id = R.id.ringer_section;
|
||||
} else {
|
||||
id = R.id.notification_section;
|
||||
}
|
||||
View hideSection = view.findViewById(id);
|
||||
hideSection.setVisibility(View.GONE);
|
||||
}
|
||||
View hideSection = view.findViewById(id);
|
||||
hideSection.setVisibility(View.GONE);
|
||||
}
|
||||
|
||||
private Uri getMediaVolumeUri(Context context) {
|
||||
|
Reference in New Issue
Block a user