[LE Unicast]UI can Enable/Disable VCP and CSIP am: 9144681d4c
Original change: https://googleplex-android-review.googlesource.com/c/platform/packages/apps/Settings/+/20271144 Change-Id: Id451b0052152a0274dac97e65f2747f78860def8 Signed-off-by: Automerger Merge Worker <android-build-automerger-merge-worker@system.gserviceaccount.com>
This commit is contained in:
@@ -341,7 +341,7 @@ public class BluetoothDetailsProfilesController extends BluetoothDetailsControll
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* When user disable the Le Audio profile, the system needs to do two things.
|
* When user disable the Le Audio profile, the system needs to do two things.
|
||||||
* 1) Disable the Le Audio profile for each of the Le Audio devices.
|
* 1) Disable the Le Audio profile, VCP and CSIP for each of the Le Audio devices.
|
||||||
* 2) Enable the A2dp profile and Headset profile for the associated device. The system
|
* 2) Enable the A2dp profile and Headset profile for the associated device. The system
|
||||||
* can't enable the A2dp profile and Headset profile if the Le Audio profile is enabled.
|
* can't enable the A2dp profile and Headset profile if the Le Audio profile is enabled.
|
||||||
*
|
*
|
||||||
@@ -352,14 +352,23 @@ public class BluetoothDetailsProfilesController extends BluetoothDetailsControll
|
|||||||
Log.e(TAG, "There is no the LE profile or no device in mProfileDeviceMap. Do nothing.");
|
Log.e(TAG, "There is no the LE profile or no device in mProfileDeviceMap. Do nothing.");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
LocalBluetoothProfile vcp = mProfileManager.getVolumeControlProfile();
|
||||||
|
LocalBluetoothProfile csip = mProfileManager.getCsipSetCoordinatorProfile();
|
||||||
|
LocalBluetoothProfile a2dp = mProfileManager.getA2dpProfile();
|
||||||
|
LocalBluetoothProfile headset = mProfileManager.getHeadsetProfile();
|
||||||
|
|
||||||
for (CachedBluetoothDevice leAudioDevice : mProfileDeviceMap.get(profile.toString())) {
|
for (CachedBluetoothDevice leAudioDevice : mProfileDeviceMap.get(profile.toString())) {
|
||||||
Log.d(TAG,
|
Log.d(TAG,
|
||||||
"User disable LE device: " + leAudioDevice.getDevice().getAnonymizedAddress());
|
"User disable LE device: " + leAudioDevice.getDevice().getAnonymizedAddress());
|
||||||
profile.setEnabled(leAudioDevice.getDevice(), false);
|
profile.setEnabled(leAudioDevice.getDevice(), false);
|
||||||
|
if (vcp != null) {
|
||||||
|
vcp.setEnabled(leAudioDevice.getDevice(), false);
|
||||||
|
}
|
||||||
|
if (csip != null) {
|
||||||
|
csip.setEnabled(leAudioDevice.getDevice(), false);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
LocalBluetoothProfile a2dp = mProfileManager.getA2dpProfile();
|
|
||||||
LocalBluetoothProfile headset = mProfileManager.getHeadsetProfile();
|
|
||||||
enableProfileAfterUserDisablesLeAudio(a2dp);
|
enableProfileAfterUserDisablesLeAudio(a2dp);
|
||||||
enableProfileAfterUserDisablesLeAudio(headset);
|
enableProfileAfterUserDisablesLeAudio(headset);
|
||||||
}
|
}
|
||||||
@@ -368,7 +377,7 @@ public class BluetoothDetailsProfilesController extends BluetoothDetailsControll
|
|||||||
* When user enable the Le Audio profile, the system needs to do two things.
|
* When user enable the Le Audio profile, the system needs to do two things.
|
||||||
* 1) Disable the A2dp profile and Headset profile for the associated device. The system
|
* 1) Disable the A2dp profile and Headset profile for the associated device. The system
|
||||||
* can't enable the Le Audio if the A2dp profile and Headset profile are enabled.
|
* can't enable the Le Audio if the A2dp profile and Headset profile are enabled.
|
||||||
* 2) Enable the Le Audio profile for each of the Le Audio devices.
|
* 2) Enable the Le Audio profile, VCP and CSIP for each of the Le Audio devices.
|
||||||
*
|
*
|
||||||
* @param profile the LeAudio profile
|
* @param profile the LeAudio profile
|
||||||
*/
|
*/
|
||||||
@@ -379,6 +388,9 @@ public class BluetoothDetailsProfilesController extends BluetoothDetailsControll
|
|||||||
}
|
}
|
||||||
LocalBluetoothProfile a2dp = mProfileManager.getA2dpProfile();
|
LocalBluetoothProfile a2dp = mProfileManager.getA2dpProfile();
|
||||||
LocalBluetoothProfile headset = mProfileManager.getHeadsetProfile();
|
LocalBluetoothProfile headset = mProfileManager.getHeadsetProfile();
|
||||||
|
LocalBluetoothProfile vcp = mProfileManager.getVolumeControlProfile();
|
||||||
|
LocalBluetoothProfile csip = mProfileManager.getCsipSetCoordinatorProfile();
|
||||||
|
|
||||||
disableProfileBeforeUserEnablesLeAudio(a2dp);
|
disableProfileBeforeUserEnablesLeAudio(a2dp);
|
||||||
disableProfileBeforeUserEnablesLeAudio(headset);
|
disableProfileBeforeUserEnablesLeAudio(headset);
|
||||||
|
|
||||||
@@ -386,6 +398,12 @@ public class BluetoothDetailsProfilesController extends BluetoothDetailsControll
|
|||||||
Log.d(TAG,
|
Log.d(TAG,
|
||||||
"User enable LE device: " + leAudioDevice.getDevice().getAnonymizedAddress());
|
"User enable LE device: " + leAudioDevice.getDevice().getAnonymizedAddress());
|
||||||
profile.setEnabled(leAudioDevice.getDevice(), true);
|
profile.setEnabled(leAudioDevice.getDevice(), true);
|
||||||
|
if (vcp != null) {
|
||||||
|
vcp.setEnabled(leAudioDevice.getDevice(), true);
|
||||||
|
}
|
||||||
|
if (csip != null) {
|
||||||
|
csip.setEnabled(leAudioDevice.getDevice(), true);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user