Skip to main content
Android
iOS
macOS
Web
Windows
Electron
Flutter
React Native
React JS
Unity
Unreal Engine
Unreal (Blueprint)

Device management

Audio routing refers to selection of the audio output device used for playback by your game. This can include a variety of devices such as earpieces, headphones, speakers, and Bluetooth devices capable of playing audio.

This page shows you how to change audio routing in your game.

Understand the tech

Audio routing enables you to change the playback device from the default device to a selected device.

info

This guide is applicable to Android and iOS only.

Default audio routing

The routing employed by the device itself, such as the speakers on a mobile device, is called the default audio routing of that device.

The SDK uses the following default audio routing in different use-cases:

  • Voice call: Earpiece
  • Video call: Speaker
  • Live voice call: Speaker
  • Live video streaming: Speaker

Change audio routing

Depending on your role, you can change audio routing in the following ways:

  • Device user: Add or remove external devices, such as headphones or Bluetooth devices.
  • App developer:
    • Before joining a channel, call SetDefaultAudioRouteToSpeakerphone to change the default audio routing.
    • After joining a channel, call SetEnableSpeakerphone to set the current audio routing.

Regardless of the method used to make changes to audio routing, the priority for the changes to take effect follows these principles:

  1. User behavior has the highest priority for audio routing changes. When a user connects an external device such as a wired headset, or a Bluetooth headset, audio routing automatically switches to the external device. If the user connects multiple external devices successively, audio routing will automatically switch to the last connected device.

  2. When no external device is connected, the SDK uses the default audio routing. Call SetDefaultAudioRouteToSpeakerphone to change this default setting. If the current audio route is the device itself, SetDefaultAudioRouteToSpeakerphone modifies the current audio route.

  3. Without system limitations, calling SetEnableSpeakerphone switches the current audio routing regardless of whether the current audio routing is an external device, a speaker, or an earpiece. However, this method only works for the current channel, it does not change the default audio routing of the device. If the user leaves the current channel and joins a new channel, the SDK still uses the default audio route.

Information

Due to iOS system limitations, some audio routing is not recognized in call volume mode. Therefore, if you need to use an external sound card, it is recommended to set the audio application scenario to the high quality scenario AUDIO_SCENARIO_GAME_STREAMING. In this scenario, the SDK switches to the media volume to circumvent this issue.

Any changes to the audio route trigger the OnAudioRoutingChanged callback. Use this callback to get the current audio route.

Plug and unplug devices to change audio routing

Audio routing changes when the user connects an audio device. For example, when headphones are plugged in, audio routing automatically switches to headphones. When multiple devices are connected, audio routing switches to the last connected device.

Refer to the following example to see how plugging and unplugging a device changes the audio routing:

  1. A user joins the channel. Audio is routed to speakers.

  2. The user plugs in headphones. Audio routing changes to headphones.

  3. The user connects the mobile device to a Bluetooth audio device without unplugging the headset. Audio routing changes to the Bluetooth audio device.

  4. The user disconnects the Bluetooth audio device from the mobile device. Audio routing changes back to headphones.

Change the default audio routing

Before joining a channel, call the SetDefaultAudioRouteToSpeakerphone method to switch the default audio routing to either the handset or the speakerphone. Set the defaultToSpeaker parameter of this method to true to set the default audio route to speakerphone, and to false to set the default audio route to handset. The setting remains valid until you destroy the engine.

Refer to the following example to understand how to change the default audio routing:

  1. The user plugs in the headset. Audio is routed to the headset.

  2. The user unplugs the headset. Audio routing is changed to the default audio routing of the mobile device, depending on your usage scenario.

  3. Call SetDefaultAudioRouteToSpeakerphone(true) in the game. Audio routing is changed to speakerphone.

  4. User plugs in headphones. Audio routing changes to headphones.

  5. Call SetDefaultAudioRouteToSpeakerphone(true). The audio is still routed to the headset because SetDefaultAudioRouteToSpeakerphone only works for the audio routing of the device.

  6. The user unplugs the headphones. The audio routing is changed to speakerphone.

Changing the current audio routing

If the operating system allows it, call the SetEnableSpeakerphone method to change the current audio routing to speaker.

Refer to the following example to understand how to change the current audio routing:

  • Example 1:

    1. User joins a channel. Audio is routed to the speaker.
    2. User plugs in headphones. Audio routing is changed to headphones.
    3. App calls SetEnableSpeakerphone(true). Audio is still routed to headphones.
  • Example 2:

    1. A user joins a voice call channel. Audio is routed to the speakerphone.
    2. App calls SetEnableSpeakerphone(true). Audio routing is changed to speakerphone.
    3. User plugs in headset. Audio routing changes to headset.
    4. User unplugs the headset. Audio routing changes to earpiece.
Information

If the user uses an external audio playback device, such as a Bluetooth headset or a wired headset, setting SetEnableSpeakerphone(true) is invalid and the audio is played through the external device.

Reference

This section contains content that completes the information on this page, or points you to documentation that explains other aspects to this product.

Sample project

Agora provides the AudioCallRoute open-source sample project for your reference. Download the project or view the source code for a more detailed example.

API reference

vundefined