این راهنما برنامههای ارتباطی مانند Voice over Internet Protocol (VoIP) را پوشش میدهد که میخواهند وضعیت دستگاه صوتی و شنیدنی خود را خود مدیریت کنند.
ثبت تماس صوتی
ابتدا یک AudioDeviceCallback
ایجاد کنید، که برنامه شما را هنگام اتصال یا قطع شدن دستگاه های صوتی از دستگاه مطلع می کند.
val audioDeviceCallback: AudioDeviceCallback = object : AudioDeviceCallback() {
override fun onAudioDevicesAdded(addedDevices: Array
final AudioDeviceCallback audioDeviceCallback = new AudioDeviceCallback() {
@Override
public void onAudioDevicesAdded(AudioDeviceInfo[] addedDevices) {
}
@Override
public void onAudioDevicesRemoved(AudioDeviceInfo[] removedDevices) {
// Handle device removal
}
};
audioManager.registerAudioDeviceCallback(audioDeviceCallback);
دستگاه ارتباطی فعال را بررسی کنید
مدیر صدا به شما امکان می دهد بدانید کدام دستگاه ارتباطی در حال حاضر فعال است.
val currentCommunicationDevice: AudioDeviceInfo? = audioManager.communicationDevice
AudioDeviceInfo currentCommunicationDevice = audioManager.getCommunicationDevice();
گوش دادن به زمانی که یک دستگاه ارتباطی تغییر کرده است، به برنامه شما امکان میدهد متوجه شود که مسیریابی اعمال میشود و دستگاهی که انتخاب کردهاید فعال است.
val listener =
OnCommunicationDeviceChangedListener { device -> // Handle changes
currentCommunicationDevice = device
}
audioManager.addOnCommunicationDeviceChangedListener(executor, listener)
AudioManager.OnCommunicationDeviceChangedListener listener =
new AudioManager.OnCommunicationDeviceChangedListener() {
@Override
void onCommunicationDeviceChanged(AudioDeviceInfo device) {
// Handle changes
currentCommunicationDevice = device;
}
};
AudioManager.addOnCommunicationDeviceChangedListener(executor, listener);
دستگاه صوتی BLE را پیدا کنید
از getAvailableCommuncationDevices()
استفاده کنید تا ببینید کدام دستگاه ها برای تماس VoIP در دسترس هستند. از AudioDeviceInfo
استفاده کنید تا ببینید آیا دستگاه یک هدست BLE است یا خیر. این مثال به دنبال اولین دستگاهی است که از صدای BLE پشتیبانی میکند، اما ممکن است در نظر داشته باشید که همه دستگاههای پشتیبانیشده را بیابید و به کاربران اجازه انتخاب بدهید.
// Get list of currently available devices
val devices = audioManager.availableCommunicationDevices
// User choose one of the devices, let's say, TYPE_BLE_HEADSET
val userSelectedDeviceType = AudioDeviceInfo.TYPE_BLE_HEADSET
//for the device from the list
var selectedDevice: AudioDeviceInfo? = null
for (device in devices) {
if (device.type == userSelectedDeviceType) {
selectedDevice = device
break
}
}
// Get list of currently available devices
List
دستگاه ارتباطی را تنظیم کنید
پس از یافتن دستگاه سازگار، از setCommunicationDevice
برای تنظیم دستگاهی که می خواهید به آن مسیریابی کنید، استفاده کنید. بررسی نتیجه به برنامه شما اطلاع میدهد که آیا مدیر صدا سعی دارد دستگاه را تنظیم کند یا با خطا مواجه شده است.
val result = audioManager.setCommunicationDevice(selectedDevice)
if (!result) {
// Handle error.
}
// Wait for currentCommunicationDevice to become selectedDevice with a timeout (e.g. 30s)
boolean result = audioManager.setCommunicationDevice(selectedDevice);
if (!result) {
// Handle error.
}
// Wait for currentCommunicationDevice to become selectedDevice with a timeout (e.g. 30s)
اکنون که دستگاه صوتی BLE تنظیم شده است، هنگام برقراری تماس، جریان صوتی مسیریابی صحیح صوتی را خواهد داشت.
جلسه را تمام کنید
پس از اتمام تماس یا جلسه برنامه، دستگاه ارتباط فعال را پاک کنید. این کمک می کند تا اطمینان حاصل شود که کاربر در هنگام جابجایی بین برنامه های مختلف تجربه خوبی دارد.
// Clear the selection, ready for next call
audioManager.clearCommunicationDevice()
// Clear the selection, ready for next call
audioManager.clearCommunicationDevice();