Agora C++ API Reference for All Platforms
agora::rtc::DataStreamConfig Struct Reference

#include <IAgoraRtcEngine.h>

Public Attributes

bool syncWithAudio
 
bool ordered
 

Detailed Description

The configurations for the data stream.

Since
v3.3.0
syncWithAudio ordered SDK behaviors
false false The SDK triggers the onStreamMessage callback immediately after the receiver receives a data packet
true false

If the data packet delay is within the audio delay, the SDK triggers the onStreamMessage callback when the synchronized audio packet is played out.

If the data packet delay exceeds the audio delay, the SDK triggers the onStreamMessage callback as soon as the data packet is received. In this case, the data packet is not synchronized with the audio packet.

false true

If the delay of a data packet is within five seconds, the SDK corrects the order of the data packet.

If the delay of a data packet exceeds five seconds, the SDK discards the data packet.

true true

If the delay of a data packet is within the audio delay, the SDK corrects the order of the data packet.

If the delay of a data packet exceeds the audio delay, the SDK discards this data packet.

Member Data Documentation

◆ syncWithAudio

bool agora::rtc::DataStreamConfig::syncWithAudio

Whether to synchronize the data packet with the published audio packet.

  • true: Synchronize the data packet with the audio packet.
  • false: Do not synchronize the data packet with the audio packet.

When you set the data packet to synchronize with the audio, then if the data packet delay is within the audio delay, the SDK triggers the onStreamMessage callback when the synchronized audio packet is played out. Do not set this parameter as true if you need the receiver to receive the data packet immediately. Agora recommends that you set this parameter to true only when you need to implement specific functions, for example lyric synchronization.

◆ ordered

bool agora::rtc::DataStreamConfig::ordered

Whether the SDK guarantees that the receiver receives the data in the sent order.

  • true: Guarantee that the receiver receives the data in the sent order.
  • false: Do not guarantee that the receiver receives the data in the sent order.

Do not set this parameter to true if you need the receiver to receive the data immediately.