Skip to main content

VideoEncoder

Struct VideoEncoder 

Source
pub struct VideoEncoder { /* private fields */ }
Expand description

Encodes video frames (and optional audio) and writes them to a file or stream.

Frames are provided as Direct3D surfaces or raw BGRA buffers. Audio can be pushed as interleaved PCM bytes.

ยงExample

use windows_capture::encoder::{
    AudioSettingsBuilder, ContainerSettingsBuilder, VideoEncoder, VideoSettingsBuilder,
};

// Create an encoder that outputs H.265 in an MP4 container
let mut encoder = VideoEncoder::new(
    VideoSettingsBuilder::new(1920, 1080),
    AudioSettingsBuilder::new().disabled(true),
    ContainerSettingsBuilder::new(),
    "capture.mp4",
)
.unwrap();

// In your capture loop, push frames:
// encoder.send_frame(&frame).unwrap();

// When done:
// encoder.finish().unwrap();

Implementationsยง

Sourceยง

impl VideoEncoder

Source

pub fn new<P: AsRef<Path>>( video_settings: VideoSettingsBuilder, audio_settings: AudioSettingsBuilder, container_settings: ContainerSettingsBuilder, path: P, ) -> Result<Self, VideoEncoderError>

Constructs a new VideoEncoder that writes to a file path.

Source

pub fn new_from_stream( video_settings: VideoSettingsBuilder, audio_settings: AudioSettingsBuilder, container_settings: ContainerSettingsBuilder, stream: IRandomAccessStream, ) -> Result<Self, VideoEncoderError>

Constructs a new VideoEncoder that writes to the given stream.

Unlike VideoEncoder::new, which writes directly to a file, this constructor writes encoded output into any [IRandomAccessStream]. Use [InMemoryRandomAccessStream] to keep the encoded video in memory (e.g., for network streaming or further processing).

ยงExample
use windows::Storage::Streams::InMemoryRandomAccessStream;
use windows::core::Interface;
use windows_capture::encoder::{
    AudioSettingsBuilder, ContainerSettingsBuilder, VideoEncoder, VideoSettingsBuilder,
};

let stream = InMemoryRandomAccessStream::new().unwrap();

let encoder = VideoEncoder::new_from_stream(
    VideoSettingsBuilder::new(1920, 1080),
    AudioSettingsBuilder::new().disabled(true),
    ContainerSettingsBuilder::new(),
    stream.cast().unwrap(),
)
.unwrap();
Source

pub fn send_frame(&mut self, frame: &Frame<'_>) -> Result<(), VideoEncoderError>

Sends a video frame (DirectX). Returns immediately.

Source

pub fn send_frame_with_audio( &mut self, frame: &mut Frame<'_>, audio_buffer: &[u8], ) -> Result<(), VideoEncoderError>

Sends a video frame and an audio buffer (owned). Returns immediately. Audio timestamp is derived from total samples sent so far (monotonic).

Source

pub fn send_frame_buffer( &mut self, buffer: &[u8], timestamp: i64, ) -> Result<(), VideoEncoderError>

Sends a raw frame buffer (owned inside). Returns immediately. Windows expects BGRA and bottom-to-top layout for this path.

Source

pub fn send_audio_buffer( &mut self, buffer: &[u8], _timestamp: i64, ) -> Result<(), VideoEncoderError>

Sends an audio buffer (owned inside). Returns immediately. NOTE: The provided timestamp is ignored; we use a monotonic audio clock.

Source

pub fn finish(self) -> Result<(), VideoEncoderError>

Finishes the encoding and performs any necessary cleanup.

Trait Implementationsยง

Sourceยง

impl Drop for VideoEncoder

Sourceยง

fn drop(&mut self)

Executes the destructor for this type. Read more
Sourceยง

impl Send for VideoEncoder

Auto Trait Implementationsยง

Blanket Implementationsยง

Sourceยง

impl<T> Any for T
where T: 'static + ?Sized,

Sourceยง

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Sourceยง

impl<T> Borrow<T> for T
where T: ?Sized,

Sourceยง

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Sourceยง

impl<T> BorrowMut<T> for T
where T: ?Sized,

Sourceยง

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Sourceยง

impl<T> From<T> for T

Sourceยง

fn from(t: T) -> T

Returns the argument unchanged.

Sourceยง

impl<T, U> Into<U> for T
where U: From<T>,

Sourceยง

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Sourceยง

impl<T> IntoEither for T

Sourceยง

fn into_either(self, into_left: bool) -> Either<Self, Self>

Converts self into a Left variant of Either<Self, Self> if into_left is true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
Sourceยง

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

Converts self into a Left variant of Either<Self, Self> if into_left(&self) returns true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
Sourceยง

impl<T> Pointable for T

Sourceยง

const ALIGN: usize

The alignment of pointer.
Sourceยง

type Init = T

The type for initializers.
Sourceยง

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
Sourceยง

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
Sourceยง

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
Sourceยง

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. Read more
Sourceยง

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Sourceยง

type Error = Infallible

The type returned in the event of a conversion error.
Sourceยง

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Sourceยง

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Sourceยง

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Sourceยง

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.