CallControlCallback
interface CallControlCallback
| android.telecom.CallControlCallback | 
CallControlCallback relays call updates (that require a response) from the Telecom framework out to the application.This can include operations which the app must implement on a Call due to the presence of other calls on the device, requests relayed from a Bluetooth device, or from another calling surface.
 All CallControlCallbacks are transactional, meaning that a client must complete the Consumer via Consumer.accept(Object) in order to complete the CallControlCallbacks. If a CallControlCallbacks can be completed, the Consumer.accept(Object) should be called with Boolean.TRUE. Otherwise, Consumer.accept(Object) should be called with Boolean.FALSE to represent the CallControlCallbacks cannot be completed on the client side. 
 Note: Each CallEventCallback has a timeout of 5000 milliseconds. Failing to complete the Consumer before the timeout will result in a failed transaction.
Summary
| Public methods | |
|---|---|
| abstract Unit | Telecom is informing the client to answer an incoming call and set it to active. | 
| abstract Unit | onCallStreamingStarted(wasCompleted: Consumer<Boolean!>)Telecom is informing the client to set the call in streaming. | 
| abstract Unit | onDisconnect(disconnectCause: DisconnectCause, wasCompleted: Consumer<Boolean!>)Telecom is informing the client to disconnect the call | 
| abstract Unit | onSetActive(wasCompleted: Consumer<Boolean!>)Telecom is informing the client to set the call active | 
| abstract Unit | onSetInactive(wasCompleted: Consumer<Boolean!>)Telecom is informing the client to set the call inactive. | 
Public methods
onAnswer
abstract fun onAnswer(
videoState: Int,
wasCompleted: Consumer<Boolean!>
): Unit
Telecom is informing the client to answer an incoming call and set it to active.
| Parameters | |
|---|---|
| videoState | Int: the video state Value is android.telecom.CallAttributes#AUDIO_CALL, orandroid.telecom.CallAttributes#VIDEO_CALL | 
| wasCompleted | Consumer<Boolean!>: The Consumerto be completed. If the client can answer the call on their end,Consumer.accept(Object)should be called withBoolean.TRUE. Otherwise,Consumer.accept(Object)should be called withBoolean.FALSE. However, Telecom will still disconnect the call and remove it from tracking. This value cannot benull. | 
onCallStreamingStarted
abstract fun onCallStreamingStarted(wasCompleted: Consumer<Boolean!>): Unit
Telecom is informing the client to set the call in streaming.
| Parameters | |
|---|---|
| wasCompleted | Consumer<Boolean!>: The Consumerto be completed. If the client can stream the call on their end,Consumer.accept(Object)should be called withBoolean.TRUE. Otherwise,Consumer.accept(Object)should be called withBoolean.FALSE. This value cannot benull. | 
onDisconnect
abstract fun onDisconnect(
disconnectCause: DisconnectCause,
wasCompleted: Consumer<Boolean!>
): Unit
Telecom is informing the client to disconnect the call
| Parameters | |
|---|---|
| disconnectCause | DisconnectCause: represents the cause for disconnecting the call. This value cannot be null. | 
| wasCompleted | Consumer<Boolean!>: The Consumerto be completed. If the client can disconnect the call on their end,Consumer.accept(Object)should be called withBoolean.TRUE. Otherwise,Consumer.accept(Object)should be called withBoolean.FALSE. However, Telecom will still disconnect the call and remove it from tracking. This value cannot benull. | 
onSetActive
abstract fun onSetActive(wasCompleted: Consumer<Boolean!>): Unit
Telecom is informing the client to set the call active
| Parameters | |
|---|---|
| wasCompleted | Consumer<Boolean!>: The Consumerto be completed. If the client can set the call active on their end, theConsumer.accept(Object)should be called withBoolean.TRUE. Otherwise,Consumer.accept(Object)should be called withBoolean.FALSE. Telecom will effectively ignore the remote setActive request and the call will remain in whatever state it is in. This value cannot benull. | 
onSetInactive
abstract fun onSetInactive(wasCompleted: Consumer<Boolean!>): Unit
Telecom is informing the client to set the call inactive. This is the same as holding a call for two endpoints but can be extended to setting a meeting inactive.
| Parameters | |
|---|---|
| wasCompleted | Consumer<Boolean!>: The Consumerto be completed. If the client can set the call inactive on their end, theConsumer.accept(Object)should be called withBoolean.TRUE. Otherwise,Consumer.accept(Object)should be called withBoolean.FALSE. Telecom will effectively ignore the remote setInactive request and the call will remain in whatever state it is in. This value cannot benull. | 
