FVideoRenderingTracingInfo

Indicators during video frame rendering progress.

USTRUCT(BlueprintType)
struct FVideoRenderingTracingInfo {
	GENERATED_BODY()
public: 
	UPROPERTY(VisibleAnywhere, BlueprintReadWrite, Category = "Agora|VideoRenderingTracingInfo")
	int elapsedTime = 0;
	UPROPERTY(VisibleAnywhere, BlueprintReadWrite, Category = "Agora|VideoRenderingTracingInfo")
	int start2JoinChannel = 0;
	UPROPERTY(VisibleAnywhere, BlueprintReadWrite, Category = "Agora|VideoRenderingTracingInfo")
	int join2JoinSuccess = 0;
	UPROPERTY(VisibleAnywhere, BlueprintReadWrite, Category = "Agora|VideoRenderingTracingInfo")
	int joinSuccess2RemoteJoined = 0;
	UPROPERTY(VisibleAnywhere, BlueprintReadWrite, Category = "Agora|VideoRenderingTracingInfo")
	int remoteJoined2SetView = 0;
	UPROPERTY(VisibleAnywhere, BlueprintReadWrite, Category = "Agora|VideoRenderingTracingInfo")
	int remoteJoined2UnmuteVideo = 0;
	UPROPERTY(VisibleAnywhere, BlueprintReadWrite, Category = "Agora|VideoRenderingTracingInfo")
	int remoteJoined2PacketReceived = 0;
	FVideoRenderingTracingInfo() {}
	FVideoRenderingTracingInfo(const agora::rtc::VideoRenderingTracingInfo& AgoraData) {
		elapsedTime = AgoraData.elapsedTime;
		start2JoinChannel = AgoraData.start2JoinChannel;
		join2JoinSuccess = AgoraData.join2JoinSuccess;
		joinSuccess2RemoteJoined = AgoraData.joinSuccess2RemoteJoined;
		remoteJoined2SetView = AgoraData.remoteJoined2SetView;
		remoteJoined2UnmuteVideo = AgoraData.remoteJoined2UnmuteVideo;
		remoteJoined2PacketReceived = AgoraData.remoteJoined2PacketReceived;
	}
	agora::rtc::VideoRenderingTracingInfo CreateAgoraData() const {
		agora::rtc::VideoRenderingTracingInfo AgoraData;
		AgoraData.elapsedTime = elapsedTime;
		AgoraData.start2JoinChannel = start2JoinChannel;
		AgoraData.join2JoinSuccess = join2JoinSuccess;
		AgoraData.joinSuccess2RemoteJoined = joinSuccess2RemoteJoined;
		AgoraData.remoteJoined2SetView = remoteJoined2SetView;
		AgoraData.remoteJoined2UnmuteVideo = remoteJoined2UnmuteVideo;
		AgoraData.remoteJoined2PacketReceived = remoteJoined2PacketReceived;
		return AgoraData;
	}
	void FreeAgoraData(agora::rtc::VideoRenderingTracingInfo& AgoraData) const {
			}
};

Attributes

elapsedTime
The time interval (ms) from StartMediaRenderingTracing to SDK triggering the OnVideoRenderingTracingResult callback. Agora recommends you call StartMediaRenderingTracing before joining a channel.
start2JoinChannel
The time interval (ms) from StartMediaRenderingTracing to JoinChannelWithOptions. A negative number indicates that StartMediaRenderingTracing is called after calling JoinChannelWithOptions.
join2JoinSuccess
The time interval (ms) from JoinChannel or JoinChannelWithOptions to successfully joining the channel.
joinSuccess2RemoteJoined
  • If the local user calls StartMediaRenderingTracing before successfully joining the channel, this value is the time interval (ms) from the local user successfully joining the channel to the remote user joining the channel.
  • If the local user calls StartMediaRenderingTracing after successfully joining the channel, the value is the time interval (ms) from StartMediaRenderingTracing to when the remote user joins the channel.
Note:
  • If the local user calls StartMediaRenderingTracing after the remote user joins the channel, the value is 0 and meaningless.
  • In order to reduce the time of rendering the first frame for remote users, Agora recommends that the local user joins the channel when the remote user is in the channel to reduce this value.
remoteJoined2SetView
  • If the local user calls StartMediaRenderingTracing before the remote user joins the channel, this value is the time interval (ms) from when the remote user joins the channel to when the local user sets the remote view.
  • If the local user calls StartMediaRenderingTracing after the remote user joins the channel, this value is the time interval (ms) from calling StartMediaRenderingTracing to setting the remote view.
Note:
  • If the local user calls StartMediaRenderingTracing after setting the remote view, the value is 0 and has no effect.
  • In order to reduce the time of rendering the first frame for remote users, Agora recommends that the local user sets the remote view before the remote user joins the channel, or sets the remote view immediately after the remote user joins the channel to reduce this value.
remoteJoined2UnmuteVideo
  • If the local user calls StartMediaRenderingTracing before the remote user joins the channel, this value is the time interval (ms) from the remote user joining the channel to subscribing to the remote video stream.
  • If the local user calls StartMediaRenderingTracing after the remote user joins the channel, this value is the time interval (ms) from StartMediaRenderingTracing to subscribing to the remote video stream.
Note:
  • If the local user calls StartMediaRenderingTracing after subscribing to the remote video stream, the value is 0 and has no effect.
  • In order to reduce the time of rendering the first frame for remote users, Agora recommends that after the remote user joins the channel, the local user immediately subscribes to the remote video stream to reduce this value.
remoteJoined2PacketReceived
  • If the local user calls StartMediaRenderingTracing before the remote user joins the channel, this value is the time interval (ms) from when the remote user joins the channel to when the local user receives the remote video stream.
  • If the local user calls StartMediaRenderingTracing after the remote user joins the channel, this value is the time interval (ms) from StartMediaRenderingTracing to receiving the remote video stream.
Note:
  • If the local user calls StartMediaRenderingTracing after receiving the remote video stream, the value is 0 and has no effect.
  • In order to reduce the time of rendering the first frame for remote users, Agora recommends that the remote user publishes video streams immediately after joining the channel, and the local user immediately subscribes to remote video streams to reduce this value.