pub struct VideoVBIEncoder { /* private fields */ }
Expand description

An encoder for writing ancillary data to the Vertical Blanking Interval lines of component signals.

Implementations§

source§

impl VideoVBIEncoder

source

pub fn try_new( format: VideoFormat, pixel_width: u32 ) -> Result<VideoVBIEncoder, VideoVBIError>

source

pub fn add_did_ancillary( &mut self, adf_mode: VideoAFDDescriptionMode, did: VideoAncillaryDID, block_number: u8, data: &[u8] ) -> Result<(), VideoVBIError>

Adds the provided ancillary data as a DID and block number AFD.

source

pub fn add_did16_ancillary( &mut self, adf_mode: VideoAFDDescriptionMode, did16: VideoAncillaryDID16, data: &[u8] ) -> Result<(), VideoVBIError>

Adds the provided ancillary data as a DID16 (DID & SDID) AFD.

source

pub fn add_ancillary( &mut self, adf_mode: VideoAFDDescriptionMode, did: u8, sdid_block_number: u8, data: &[u8] ) -> Result<(), VideoVBIError>

Stores Video Ancillary data, according to SMPTE-291M specification.

Note that the contents of the data are always read as 8bit data (i.e. do not contain the parity check bits).

§composite

true if composite ADF should be created, component otherwise

§DID

The Data Identifier

§SDID_block_number

The Secondary Data Identifier (if type 2) or the Data Block Number (if type 1)

§data

The user data content of the Ancillary packet. Does not contain the ADF, DID, SDID nor CS.

§Returns

true if enough space was left in the current line, false otherwise.

source

pub fn line_buffer_len(&self) -> usize

Returns the buffer length needed to store the line.

source

pub fn write_line(&mut self, data: &mut [u8]) -> Result<usize, VideoVBIError>

Writes the ancillaries encoded for VBI to the provided buffer.

Use Self::line_buffer_len to get the expected buffer length.

Resets the internal state, so this VideoVBIEncoder can be reused for subsequent VBI encodings.

§Returns

Trait Implementations§

source§

impl Debug for VideoVBIEncoder

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
source§

impl Hash for VideoVBIEncoder

source§

fn hash<__H: Hasher>(&self, state: &mut __H)

Feeds this value into the given Hasher. Read more
1.3.0 · source§

fn hash_slice<H>(data: &[Self], state: &mut H)
where H: Hasher, Self: Sized,

Feeds a slice of this type into the given Hasher. Read more
source§

impl Ord for VideoVBIEncoder

source§

fn cmp(&self, other: &VideoVBIEncoder) -> Ordering

This method returns an Ordering between self and other. Read more
1.21.0 · source§

fn max(self, other: Self) -> Self
where Self: Sized,

Compares and returns the maximum of two values. Read more
1.21.0 · source§

fn min(self, other: Self) -> Self
where Self: Sized,

Compares and returns the minimum of two values. Read more
1.50.0 · source§

fn clamp(self, min: Self, max: Self) -> Self
where Self: Sized + PartialOrd,

Restrict a value to a certain interval. Read more
source§

impl PartialEq for VideoVBIEncoder

source§

fn eq(&self, other: &VideoVBIEncoder) -> bool

This method tests for self and other values to be equal, and is used by ==.
1.0.0 · source§

fn ne(&self, other: &Rhs) -> bool

This method tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
source§

impl PartialOrd for VideoVBIEncoder

source§

fn partial_cmp(&self, other: &VideoVBIEncoder) -> Option<Ordering>

This method returns an ordering between self and other values if one exists. Read more
1.0.0 · source§

fn lt(&self, other: &Rhs) -> bool

This method tests less than (for self and other) and is used by the < operator. Read more
1.0.0 · source§

fn le(&self, other: &Rhs) -> bool

This method tests less than or equal to (for self and other) and is used by the <= operator. Read more
1.0.0 · source§

fn gt(&self, other: &Rhs) -> bool

This method tests greater than (for self and other) and is used by the > operator. Read more
1.0.0 · source§

fn ge(&self, other: &Rhs) -> bool

This method tests greater than or equal to (for self and other) and is used by the >= operator. Read more
source§

impl<'a> TryFrom<&'a VideoInfo> for VideoVBIEncoder

§

type Error = VideoVBIError

The type returned in the event of a conversion error.
source§

fn try_from(info: &'a VideoInfo) -> Result<VideoVBIEncoder, VideoVBIError>

Performs the conversion.
source§

impl Eq for VideoVBIEncoder

source§

impl Send for VideoVBIEncoder

source§

impl StructuralPartialEq for VideoVBIEncoder

source§

impl Sync for VideoVBIEncoder

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, U> TryFrom<U> for T
where U: Into<T>,

§

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>,

§

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.