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

Volume control and mute

This page shows you how to configure volume settings for audio recording, audio playback, and for the playback of music files.

Understand the tech

Agora Video SDK supports adjusting the audio volume for both recording and playback to meet practical application scenarios. For example, during a two-person call, you can mute a remote user by adjusting the playback volume setting to 0.

The figure below shows the workflow of adjusting the volume. VolumeControlMute

Playback refers to transmitting an audio signal from a sender to a recipient, where it is played back through a playback device.

In-ear monitoring refers to the process of playing audio captured by a device.

Recording refers to the process in which audio signals are captured by a recording device and then sent to the transmitter.

Caution
If you set the volume too high using the signal volume adjustment methods, it may lead to audio distortion on some devices.

Prerequisites

Ensure that you have implemented the SDK quickstart in your project.

Implement volume control

Use one or more of the following volume control methods to adjust volume settings.

Adjust the playback volume

Call adjustPlaybackSignalVolume or adjustUserPlaybackSignalVolume to adjust the volume of the audio playback signal.

int volume = 50;s
int uid = 123456;
// Set the local playback volume for all remote users
mRtcEngine.adjustPlaybackSignalVolume(volume);
// Set the local playback volume for a specific remote user. For example, a user with uid=123
mRtcEngine.adjustUserPlaybackSignalVolume(uid, volume)
Copy

Adjust the in-ear monitoring volume

During the process of audio capture, mixing, and playback, Agora enables you to adjust the in-ear monitoring volume. Enable and set the volume using enableInEarMonitoring and setInEarMonitoringVolume.

// Enable in-ear monitoring
mRtcEngine.enableInEarMonitoring(true);
int volume = 50;
// Adjust in-ear monitoring volume
mRtcEngine.setInEarMonitoringVolume(volume);
Copy

Adjust the recording volume

Call adjustRecordingSignalVolume to adjust the volume of the audio recording signal.

ChannelMediaOptions options = new ChannelMediaOptions();
options.clientRoleType = Constants.CLIENT_ROLE_BROADCASTER;
mRtcEngine.joinChannel(token, channelName, 1234, options);
// Adjust the recording signal volume to 50
int vol = 50;
mRtcEngine.adjustRecordingSignalVolume(vol);
Copy

When configuring audio settings, it's essential to understand the default behavior and the options available. Here are the key points to keep in mind:

  • The SDK defaults to a device volume of 85 when using the recording device to capture audio signals.
  • A volume of 0 means mute, and a volume of 255 represents the maximum volume of the device.
  • If the SDK detects that the recording volume is too low in the current environment, it automatically increases the volume of the recording device.
  • The volume of the recording device directly influences the global volume of the device.
  • If the default recording device volume does not meet your requirements, adjust it by regulating the signal amplitude captured by the microphone or sound card.

Mute and unmute users

To mute or unmute the local audio stream, call muteLocalAudioStream:

// Stop publishing the local audio stream
mRtcEngine.muteLocalAudioStream(true);

// Resume publishing the local audio stream
mRtcEngine.muteLocalAudioStream(false);
Copy

To mute or unmute a remote user, call muteRemoteAudioStream with the uid of the remote user:

// Stop subscribing to the audio stream of the remote user
mRtcEngine.muteRemoteAudioStream(remoteUid, true);

// Resume subscribing to the audio stream of the remote user
mRtcEngine.muteRemoteAudioStream(remoteUid, false);
Copy

Get volume information of users

Video SDK enables you to obtain the user IDs and corresponding volumes of the three users with the highest instantaneous volumes in a channel during the process of audio recording, mixing, and playback. You use the onAudioVolumeIndication callback to obtain this information. A returned uid of 0 in the callback indicates the local user.

private final IRtcEngineEventHandler mRtcEventHandler = new IRtcEngineEventHandler()
{
...
// Retrieve the user IDs of the three users with the highest instantaneous speaking volume,
// their respective volumes, and determine whether the local user is speaking.
@Override
public void onAudioVolumeIndication(AudioVolumeInfo[] speakers, int totalVolume) {
}
};
Copy
Note
Call enableAudioVolumeIndication to enable reporting of the users' volume in the callback.
// Enable the onAudioVolumeIndication callback
mRtcEngine.enableAudioVolumeIndication(true);
Copy

Reference

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

Video Calling