Struct gif::encoder::Encoder

source ·
pub struct Encoder<W: Write> {
    w: Option<W>,
    global_palette: bool,
    width: u16,
    height: u16,
    buffer: Vec<u8>,
}
Expand description

GIF encoder.

Fields§

§w: Option<W>§global_palette: bool§width: u16§height: u16§buffer: Vec<u8>

Implementations§

source§

impl<W: Write> Encoder<W>

source

pub fn new( w: W, width: u16, height: u16, global_palette: &[u8], ) -> Result<Self, EncodingError>

Creates a new encoder.

global_palette gives the global color palette in the format [r, g, b, ...], if no global palette shall be used an empty slice may be supplied.

source

pub fn set_repeat(&mut self, repeat: Repeat) -> Result<(), EncodingError>

Write an extension block that signals a repeat behaviour.

source

fn write_global_palette(self, palette: &[u8]) -> Result<Self, EncodingError>

Writes the global color palette.

source

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

Writes a frame to the image.

Note: This function also writes a control extension if necessary.

source

fn write_frame_header(&mut self, frame: &Frame<'_>) -> Result<(), EncodingError>

source

fn write_image_block(&mut self, data: &[u8]) -> Result<(), EncodingError>

source

fn write_encoded_image_block( writer: &mut W, data_with_min_code_size: &[u8], ) -> Result<(), EncodingError>

source

fn write_color_table( writer: &mut W, table: &[u8], padding: usize, ) -> Result<(), EncodingError>

source

fn check_color_table(table: &[u8]) -> Result<(&[u8], usize, u8), EncodingError>

returns rounded palette size, number of missing colors, and table size flag

source

pub fn write_extension( &mut self, extension: ExtensionData, ) -> Result<(), EncodingError>

Writes an extension to the image.

It is normally not necessary to call this method manually.

source

pub fn write_raw_extension( &mut self, func: AnyExtension, data: &[&[u8]], ) -> Result<()>

Writes a raw extension to the image.

This method can be used to write an unsupported extension to the file. func is the extension identifier (e.g. Extension::Application as u8). data are the extension payload blocks. If any contained slice has a lenght > 255 it is automatically divided into sub-blocks.

source

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

Writes a frame to the image, but expects Frame.buffer to contain LZW-encoded data from Frame::make_lzw_pre_encoded.

Note: This function also writes a control extension if necessary.

source

fn write_screen_desc(&mut self, flags: u8) -> Result<()>

Writes the logical screen desriptor

source

pub fn get_ref(&self) -> &W

Gets a reference to the writer instance used by this encoder.

source

pub fn get_mut(&mut self) -> &mut W

Gets a mutable reference to the writer instance used by this encoder.

It is inadvisable to directly write to the underlying writer.

source

pub fn into_inner(self) -> Result<W>

Finishes writing, and returns the io::Write instance used by this encoder

source

fn write_trailer(&mut self) -> Result<()>

Write the final tailer.

source

fn writer(&mut self) -> Result<&mut W>

Trait Implementations§

source§

impl<W: Write> Drop for Encoder<W>

source§

fn drop(&mut self)

Executes the destructor for this type. Read more

Auto Trait Implementations§

§

impl<W> Freeze for Encoder<W>
where W: Freeze,

§

impl<W> RefUnwindSafe for Encoder<W>
where W: RefUnwindSafe,

§

impl<W> Send for Encoder<W>
where W: Send,

§

impl<W> Sync for Encoder<W>
where W: Sync,

§

impl<W> Unpin for Encoder<W>
where W: Unpin,

§

impl<W> UnwindSafe for Encoder<W>
where W: UnwindSafe,

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.