VideoFrameObserver

The IVideoFrameObserver class.

You can call registerVideoFrameObserver to register or unregister an VideoFrameObserver object.

onCaptureVideoFrame

Occurs each time the SDK receives a video frame captured by local devices.

final void Function(VideoSourceType sourceType, VideoFrame videoFrame)?
      onCaptureVideoFrame;

After you successfully register the video frame observer, the SDK triggers this callback each time it receives a video frame. In this callback, you can get the video data captured by local devices. You can then pre-process the data according to your scenarios.

Attention:
  • The video data that this callback gets has not been pre-processed such as watermarking, cropping, and rotating.
  • If the video data type you get is RGBA, the SDK does not support processing the data of the alpha channel.
  • Due to the limitations of Flutter, this callback does not support sending processed video data back to the SDK.

Parameters

sourceType
Video source types, including cameras, screens, or media player. See VideoSourceType.
videoFrame
The video frame. See VideoFrame.
Note: The default value of the video frame data format obtained through this callback is as follows:
  • Android: I420 or RGB (GLES20.GL_TEXTURE_2D)
  • iOS: I420 or CVPixelBufferRef
  • macOS: I420 or CVPixelBufferRef
  • Windows: YUV420

onPreEncodeVideoFrame

Occurs each time the SDK receives a video frame before encoding.

final void Function(VideoFrame videoFrame)? onPreEncodeVideoFrame;

After you successfully register the video frame observer, the SDK triggers this callback each time it receives a video frame. In this callback, you can get the video data before encoding and then process the data according to your particular scenarios.

Attention:
  • Due to the limitations of Flutter, this callback does not support sending processed video data back to the SDK.
  • The video data that this callback gets has been preprocessed, with its content cropped and rotated, and the image enhanced.

Parameters

sourceType

The type of the video source. See VideoSourceType.

videoFrame
The video frame. See VideoFrame.
Note: The default value of the video frame data format obtained through this callback is as follows:
  • Android: I420 or RGB (GLES20.GL_TEXTURE_2D)
  • iOS: I420 or CVPixelBufferRef
  • macOS: I420 or CVPixelBufferRef
  • Windows: YUV420

onRenderVideoFrame

Occurs each time the SDK receives a video frame sent by the remote user.

final void Function(String channelId, int remoteUid, VideoFrame videoFrame)?
      onRenderVideoFrame;

After you successfully register the video frame observer, the SDK triggers this callback each time it receives a video frame. In this callback, you can get the video data sent from the remote end before rendering, and then process it according to the particular scenarios.

Attention:
  • If the video data type you get is RGBA, the SDK does not support processing the data of the alpha channel.
  • Due to the limitations of Flutter, this callback does not support sending processed video data back to the SDK.

Parameters

remoteUid
The user ID of the remote user who sends the current video frame.
videoFrame
The video frame. See VideoFrame.
Note: The default value of the video frame data format obtained through this callback is as follows:
  • Android: I420 or RGB (GLES20.GL_TEXTURE_2D)
  • iOS: I420 or CVPixelBufferRef
  • macOS: I420 or CVPixelBufferRef
  • Windows: YUV420
channelId
The channel ID.