BluetoothA2dp
class BluetoothA2dp : BluetoothProfile
| kotlin.Any | |
| ↳ | android.bluetooth.BluetoothA2dp | 
This class provides the public APIs to control the Bluetooth A2DP profile.
BluetoothA2dp is a proxy object for controlling the Bluetooth A2DP Service via IPC. Use android.bluetooth.BluetoothAdapter#getProfileProxy to get the BluetoothA2dp proxy object. 
Android only supports one connected Bluetooth A2dp device at a time. Each method is protected with its appropriate permission.
Summary
| Constants | |
|---|---|
| static String | Intent used to broadcast the change in connection state of the A2DP profile. | 
| static String | Intent used to broadcast the change in the Playing state of the A2DP profile. | 
| static Int | A2DP sink device is NOT streaming music. | 
| static Int | A2DP sink device is streaming music. | 
| Inherited constants | |
|---|---|
| Public methods | |
|---|---|
| Unit | finalize() | 
| MutableList<BluetoothDevice!>! | Get connected devices for this specific profile. | 
| Int | getConnectionState(device: BluetoothDevice!)Get the current connection state of the profile  | 
| MutableList<BluetoothDevice!>! | getDevicesMatchingConnectionStates(states: IntArray!)Get a list of devices that match any of the given connection states. | 
| MutableCollection<BluetoothCodecType!> | Returns the list of source codecs that are supported by the current platform. | 
| Boolean | isA2dpPlaying(device: BluetoothDevice!)Check if A2DP profile is streaming music. | 
Constants
ACTION_CONNECTION_STATE_CHANGED
static val ACTION_CONNECTION_STATE_CHANGED: String
Intent used to broadcast the change in connection state of the A2DP profile.
This intent will have 3 extras:
- EXTRA_STATE- The current state of the profile.
- EXTRA_PREVIOUS_STATE- The previous state of the profile.
- BluetoothDevice.EXTRA_DEVICE- The remote device.
- EXTRA_DISCONNECTED_REASON - The reason for the profile disconnection in case the new state is STATE_DISCONNECTED.
EXTRA_STATE or EXTRA_PREVIOUS_STATE can be any of STATE_DISCONNECTED, STATE_CONNECTING, STATE_CONNECTED, STATE_DISCONNECTING. 
 For apps targeting Build.VERSION_CODES.R or lower, this requires the Manifest.permission.BLUETOOTH permission which can be gained with a simple <uses-permission> manifest tag. 
 For apps targeting Build.VERSION_CODES.S or or higher, this requires the Manifest.permission.BLUETOOTH_CONNECT permission which can be gained with android.app.Activity#requestPermissions(String[], int). 
 Requires android.Manifest.permission#BLUETOOTH_CONNECT
Value: "android.bluetooth.a2dp.profile.action.CONNECTION_STATE_CHANGED"ACTION_PLAYING_STATE_CHANGED
static val ACTION_PLAYING_STATE_CHANGED: String
Intent used to broadcast the change in the Playing state of the A2DP profile.
This intent will have 3 extras:
- EXTRA_STATE- The current state of the profile.
- EXTRA_PREVIOUS_STATE- The previous state of the profile.
- BluetoothDevice.EXTRA_DEVICE- The remote device.
EXTRA_STATE or EXTRA_PREVIOUS_STATE can be any of STATE_PLAYING, STATE_NOT_PLAYING, 
 For apps targeting Build.VERSION_CODES.R or lower, this requires the Manifest.permission.BLUETOOTH permission which can be gained with a simple <uses-permission> manifest tag. 
 For apps targeting Build.VERSION_CODES.S or or higher, this requires the Manifest.permission.BLUETOOTH_CONNECT permission which can be gained with android.app.Activity#requestPermissions(String[], int). 
 Requires android.Manifest.permission#BLUETOOTH_CONNECT
Value: "android.bluetooth.a2dp.profile.action.PLAYING_STATE_CHANGED"STATE_NOT_PLAYING
static val STATE_NOT_PLAYING: Int
A2DP sink device is NOT streaming music. This state can be one of EXTRA_STATE or EXTRA_PREVIOUS_STATE of ACTION_PLAYING_STATE_CHANGED intent.
Value: 11STATE_PLAYING
static val STATE_PLAYING: Int
A2DP sink device is streaming music. This state can be one of EXTRA_STATE or EXTRA_PREVIOUS_STATE of ACTION_PLAYING_STATE_CHANGED intent.
Value: 10Public methods
finalize
fun finalize(): Unit
| Exceptions | |
|---|---|
| java.lang.Throwable | the Exceptionraised by this method | 
getConnectedDevices
fun getConnectedDevices(): MutableList<BluetoothDevice!>!
Get connected devices for this specific profile.
Return the set of devices which are in state STATE_CONNECTED 
 For apps targeting Build.VERSION_CODES.S or or higher, this requires the Manifest.permission.BLUETOOTH_CONNECT permission which can be gained with android.app.Activity#requestPermissions(String[], int). 
 Requires android.Manifest.permission#BLUETOOTH_CONNECT
| Return | |
|---|---|
| MutableList<BluetoothDevice!>! | List of devices. The list will be empty on error. | 
getConnectionState
fun getConnectionState(device: BluetoothDevice!): Int
Get the current connection state of the profile 
 For apps targeting Build.VERSION_CODES.S or or higher, this requires the Manifest.permission.BLUETOOTH_CONNECT permission which can be gained with android.app.Activity#requestPermissions(String[], int). 
 Requires android.Manifest.permission#BLUETOOTH_CONNECT
| Parameters | |
|---|---|
| device | BluetoothDevice!: Remote bluetooth device. | 
getDevicesMatchingConnectionStates
fun getDevicesMatchingConnectionStates(states: IntArray!): MutableList<BluetoothDevice!>!
Get a list of devices that match any of the given connection states.
If none of the devices match any of the given states, an empty list will be returned. 
 For apps targeting Build.VERSION_CODES.S or or higher, this requires the Manifest.permission.BLUETOOTH_CONNECT permission which can be gained with android.app.Activity#requestPermissions(String[], int). 
 Requires android.Manifest.permission#BLUETOOTH_CONNECT
| Parameters | |
|---|---|
| states | IntArray!: Array of states. States can be one of STATE_CONNECTED,STATE_CONNECTING,STATE_DISCONNECTED,STATE_DISCONNECTING, | 
| Return | |
|---|---|
| MutableList<BluetoothDevice!>! | List of devices. The list will be empty on error. | 
getSupportedCodecTypes
fun getSupportedCodecTypes(): MutableCollection<BluetoothCodecType!>
Returns the list of source codecs that are supported by the current platform.
The list always includes the mandatory SBC codec, and may include optional proprietary codecs. 
 For apps targeting Build.VERSION_CODES.R or lower, this requires the Manifest.permission.BLUETOOTH permission which can be gained with a simple <uses-permission> manifest tag. 
 Requires android.Manifest.permission#BLUETOOTH_PRIVILEGED
| Return | |
|---|---|
| MutableCollection<BluetoothCodecType!> | list of supported source codec types This value cannot be null. | 
isA2dpPlaying
fun isA2dpPlaying(device: BluetoothDevice!): Boolean
Check if A2DP profile is streaming music. 
 For apps targeting Build.VERSION_CODES.R or lower, this requires the Manifest.permission.BLUETOOTH permission which can be gained with a simple <uses-permission> manifest tag. 
 For apps targeting Build.VERSION_CODES.S or or higher, this requires the Manifest.permission.BLUETOOTH_CONNECT permission which can be gained with android.app.Activity#requestPermissions(String[], int). 
 Requires android.Manifest.permission#BLUETOOTH_CONNECT
| Parameters | |
|---|---|
| device | BluetoothDevice!: BluetoothDevice device | 
