Merge "Add call volume in sound settings" into pi-dev
This commit is contained in:
@@ -0,0 +1,55 @@
|
||||
/*
|
||||
* Copyright (C) 2018 The Android Open Source Project
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
|
||||
package com.android.settings.notification;
|
||||
|
||||
import android.content.Context;
|
||||
import android.media.AudioManager;
|
||||
|
||||
import com.android.settings.R;
|
||||
|
||||
|
||||
public class CallVolumePreferenceController extends VolumeSeekBarPreferenceController {
|
||||
|
||||
private AudioManager mAudioManager;
|
||||
|
||||
public CallVolumePreferenceController(Context context, String key) {
|
||||
super(context, key);
|
||||
mAudioManager = context.getSystemService(AudioManager.class);
|
||||
}
|
||||
|
||||
@Override
|
||||
public int getAvailabilityStatus() {
|
||||
return mContext.getResources().getBoolean(R.bool.config_show_call_volume)
|
||||
&& !mHelper.isSingleVolume() ? AVAILABLE : UNSUPPORTED_ON_DEVICE;
|
||||
}
|
||||
|
||||
@Override
|
||||
public int getAudioStream() {
|
||||
if (mAudioManager.isBluetoothScoOn()) {
|
||||
return AudioManager.STREAM_BLUETOOTH_SCO;
|
||||
}
|
||||
return AudioManager.STREAM_VOICE_CALL;
|
||||
}
|
||||
|
||||
@Override
|
||||
public int getMuteIcon() {
|
||||
// User will not be allowed to fully mute the call volume, use original
|
||||
// icon for mute icon.
|
||||
return R.drawable.ic_local_phone_24_lib;
|
||||
}
|
||||
|
||||
}
|
||||
@@ -151,6 +151,7 @@ public class SoundSettings extends DashboardFragment {
|
||||
volumeControllers.add(use(MediaVolumePreferenceController.class));
|
||||
volumeControllers.add(use(RingVolumePreferenceController.class));
|
||||
volumeControllers.add(use(NotificationVolumePreferenceController.class));
|
||||
volumeControllers.add(use(CallVolumePreferenceController.class));
|
||||
|
||||
for (VolumeSeekBarPreferenceController controller : volumeControllers) {
|
||||
controller.setCallback(mVolumeCallback);
|
||||
|
||||
@@ -83,7 +83,9 @@ public class VolumeSeekBarPreference extends SeekBarPreference {
|
||||
public void setStream(int stream) {
|
||||
mStream = stream;
|
||||
setMax(mAudioManager.getStreamMaxVolume(mStream));
|
||||
setMin(mAudioManager.getStreamMinVolume(mStream));
|
||||
// Use getStreamMinVolumeInt for non-public stream type
|
||||
// eg: AudioManager.STREAM_BLUETOOTH_SCO
|
||||
setMin(mAudioManager.getStreamMinVolumeInt(mStream));
|
||||
setProgress(mAudioManager.getStreamVolume(mStream));
|
||||
}
|
||||
|
||||
@@ -108,10 +110,6 @@ public class VolumeSeekBarPreference extends SeekBarPreference {
|
||||
@Override
|
||||
public void onBindViewHolder(PreferenceViewHolder view) {
|
||||
super.onBindViewHolder(view);
|
||||
if (mStream == 0) {
|
||||
Log.w(TAG, "No stream found, not binding volumizer");
|
||||
return;
|
||||
}
|
||||
mSeekBar = (SeekBar) view.findViewById(com.android.internal.R.id.seekbar);
|
||||
mIconView = (ImageView) view.findViewById(com.android.internal.R.id.icon);
|
||||
mSuppressionTextView = (TextView) view.findViewById(R.id.suppression_text);
|
||||
|
||||
Reference in New Issue
Block a user