VideoKitRecorder

View Source Code

namespace VideoKit {
    /// <summary>
    /// Unity component for recording video and audio files.
    /// </summary>
    class VideoKitRecorder : MonoBehaviour { ... }
}

This component manages recording videos. The component can be added to any game object in the scene.


Format Settings

The recorder's format settings dictate what types of media can be recorded, and how the resulting recording is handled:

Specifying the Recording Format

/// <summary>
/// Recording format.
/// </summary>
Format format { get; set; }

The format dictates what type of file gets recorded in a given recording session.

Preparing on Awake

/// <summary>
/// Prepare the hardware encoders on awake.
/// </summary>
bool prepareOnAwake { get; set; }

Preparing the recorder on Awake prevents a noticeable stutter that occurs on the very first recording.

Specifying the Recording Action

/// <summary>
/// Recording action.
/// </summary>
RecordingAction recordingAction { get; set; }

The recordingAction is used to specify what happens once a recording session is completed. The following actions are currently supported:

/// <summary>
/// Recording action.
/// </summary>
[Flags]
enum RecordingAction : int {
    /// <summary>
    /// Nothing.
    /// </summary>
    None        = 0,
    /// <summary>
    /// Save the media asset to the camera roll.
    /// </summary>
    CameraRoll  = 2,
    /// <summary>
    /// Prompt the user to share the media asset with the native sharing UI.
    /// </summary>
    Share       = 4,
    /// <summary>
    /// Playback the video with the platform default media player.
    /// </summary>
    Playback    = 8,
    /// <summary>
    /// Define a custom callback to receive the media asset.
    /// </summary>
    Custom      = 32,
}

Specifying a Recording Callback

/// <summary>
/// Event raised when a recording session is completed.
/// </summary>
UnityEvent<MediaAsset> OnRecordingCompleted { get; }

The OnRecordingCompleted event can be used to register a callback to be invoked with the recorded MediaAsset.


Video Settings

The video settings are used to configure the video stream of recordings.

Specifying the Video Mode

/// <summary>
/// Video recording mode.
/// </summary>
VideoMode videoMode { get; set; }

The videoMode defines how pixel buffers will be recorded. The following video modes are supported:

/// <summary>
/// Video recording mode.
/// </summary>
enum VideoMode : int {
    /// <summary>
    /// Don't record video.
    /// </summary>
    None          = 0,
    /// <summary>
    /// Record pixel buffers from one or more game cameras.
    /// </summary>
    Camera        = 1,
    /// <summary>
    /// Record pixel buffers from the screen.
    /// </summary>
    Screen        = 2,
    /// <summary>
    /// Record pixel buffers from a texture.
    /// </summary>
    Texture       = 3,
    /// <summary>
    /// Record pixel buffers from a camera device.
    /// </summary>
    CameraDevice  = 4,
}

Specifying the Video Resolution

/// <summary>
/// Video recording resolution.
/// </summary>
Resolution resolution { get; set; }

The resolution determines the video resolution of recorded videos or images. The following resolution presets are supported:

/// <summary>
/// Video recording resolution presets.
/// </summary>
enum Resolution : int {
    /// <summary>
    /// QVGA resolution.
    /// </summary>
    _240xAuto   = 11,
    /// <summary>
    /// QVGA resolution.
    /// </summary>
    _320xAuto   = 5,
    /// <summary>
    /// Portrait SD (480p) resolution.
    /// </summary>
    _480xAuto   = 6,
    /// <summary>
    /// SD (480p) resolution.
    /// </summary>
    _640xAuto   = 0,
    /// <summary>
    /// Potrait HD (720p) resolution.
    /// </summary>
    _720xAuto   = 7,
    /// <summary>
    /// HD (720p) resolution.
    /// </summary>
    _1280xAuto  = 1,
    /// <summary>
    /// Portrait Full HD (1080p) resolution.
    /// </summary>
    _1080xAuto  = 12,
    /// <summary>
    /// Full HD (1080p) resolution.
    /// </summary>
    _1920xAuto  = 2,
    /// <summary>
    /// Portrait 2K WQHD resolution.
    /// </summary>
    _1440xAuto = 13,
    /// <summary>
    /// 2K WQHD resolution.
    /// </summary>
    _2560xAuto  = 3,
    /// <summary>
    /// Portrait 4K UHD resolution.
    /// </summary>
    _2160xAuto = 14,
    /// <summary>
    /// 4K UHD resolution.
    /// </summary>
    _3840xAuto  = 4,
    /// <summary>
    /// Screen resolution.
    /// </summary>
    Screen      = 9,
    /// <summary>
    /// Half of the screen resolution.
    /// </summary>
    HalfScreen  = 10,
    /// <summary>
    /// Custom resolution.
    /// </summary>
    Custom      = 8,
}

Specifying a Custom Resolution

/// <summary>
/// Video recording custom resolution.
/// </summary>
Vector2Int customResolution { get; set; }

The customResolution is used to specify a custom recording resolution.

Specifying the Recording Cameras

/// <summary>
/// Game cameras to record.
/// </summary>
Camera[] cameras { get; set; }

The cameras property holds an array of game cameras to record in a given recording session.

Specifying the Recording Texture

/// <summary>
/// Texture to record.
/// </summary>
Texture? texture { get; set; }

The texture property is used to record pixel buffers from a Texture.

Specifying the Camera View

/// <summary>
/// Camera view for recording from a camera device.
/// </summary>
VideoKitCameraView? cameraView { get; set; }

The cameraView property is used to record pixel buffers from a CameraDevice.

Specifying the GIF Frame Rate

/// <summary>
/// Frame rate for animated GIF images.
/// </summary>
float _frameRate { get; set; } = 10;

When recording animated GIF images, the frame duration must be specified ahead of time using this property.

Specifying the Video Bitrate

/// <summary>
/// Video bit rate in bits per second.
/// </summary>
int videoBitRate { get; set; } = 20_000_000;

The videoBitRate is used when recording to a format that supports variable bitrate recording like MP4 and HEVC. This setting strongly influences the visual quality and file size of recorded videos.

Specifying the Keyframe Interval

/// <summary>
/// Video keyframe interval in seconds.
/// </summary>
int keyframeInterval { get; set; } = 2;

The keyframeInterval is used by some formats to control visual quality of recorded videos.

Skipping Frames

/// <summary>
/// Number of successive camera frames to skip while recording.
/// </summary>
int frameSkip { get; set; }

The frameSkip property is used to record at a fraction of the realtime frame rate. This is particularly useful for recording animated GIF images which have a lower frame rate.


Audio Settings

The audio settings are used to configure the audio stream of recordings.

Specifying the Audio Mode

/// <summary>
/// Audio recording mode.
/// </summary>
AudioMode audioMode { get; set; }

The audioMode defines how audio buffers will be recorded. The following audio modes are supported:

/// <summary>
/// Audio recording mode.
/// </summary>
enum AudioMode : int {
    /// <summary>
    /// Don't record audio.
    /// </summary>
    None            = 0,
    /// <summary>
    /// Record audio from an audio listener.
    /// </summary>
    AudioListener   = 1,
    /// <summary>
    /// Record audio from an audio device.
    /// </summary>
    AudioDevice     = 2,
    /// <summary>
    /// Record audio from an audio source.
    /// </summary>
    AudioSource     = 4,
}

Specifying the Audio Listener

/// <summary>
/// Audio listener for recording audio from an audio listener.
/// </summary>
AudioListener? audioListener { get; set; }

The audioListener property is used to specify a scene AudioListener to record game audio from.

Specifying the Audio Manager

/// <summary>
/// Audio manager for recording audio from an audio device.
/// </summary>
VideoKitAudioManager? audioManager { get; set; }

The audioManager property is used to specify a VideoKitAudioManager for recording audio buffers from an AudioDevice.

Specifying the Audio Source

/// <summary>
/// Audio source for recording audio from an audio source.
/// </summary>
AudioSource? audioSource { get; set; }

The audioSource property is used to specify a scene AudioSource to record game audio from.


Managing Sessions

The recorder component records a video or audio file in a recording session.

Inspecting the Recording Status

/// <summary>
/// Recorder status.
/// </summary>
Status status { get; }

The recording status reports the current state of recording.

/// <summary>
/// Recorder status.
/// </summary>
enum Status : int {
    /// <summary>
    /// No recording session is in progress.
    /// </summary>
    Idle        = 0,
    /// <summary>
    /// Recording session is in progress.
    /// </summary>
    Recording   = 1,
    /// <summary>
    /// Recording session is in progress but is paused.
    /// </summary>
    Paused      = 2,
}

Starting a Recording Session

/// <summary>
/// Start recording.
/// </summary>
void StartRecording ();

A recording session is started by calling the StartRecording method. This method can be invoked directly from UI elements. There is also the StartRecordingAsync method to wait for the recording session to asynchronously start, and catch any exceptions that might be raised:

/// <summary>
/// Start recording.
/// </summary>
Task StartRecordingAsync ();

Pausing a Recording Session

/// <summary>
/// Pause recording.
/// </summary>
void PauseRecording ();

A recording session can be paused. This will stop appending pixel buffers and audio buffers to the recorder until the session is resumed.

Resuming a Recording Session

/// <summary>
/// Resume recording.
/// </summary>
void ResumeRecording ();

A paused recording session can be resumed with this method.

Finishing a Recording Session

/// <summary>
/// Stop recording.
/// </summary>
void StopRecording ();

A recording session is stopped by calling the StopRecording method. The recordingAction will be invoked once recording is completed. There is also the StopRecordingAsync method to wait for the recording session to asynchronously complete, and catch any exceptions that might be raised:

/// <summary>
/// Stop recording.
/// </summary>
Task StopRecordingAsync ();

Was this page helpful?