Struct epaint::image::ColorImage

source ·
pub struct ColorImage {
    pub size: [usize; 2],
    pub pixels: Vec<Color32>,
}
Expand description

A 2D RGBA color image in RAM.

Fields§

§size: [usize; 2]

width, height.

§pixels: Vec<Color32>

The pixels, row by row, from top to bottom.

Implementations§

source§

impl ColorImage

source

pub fn new(size: [usize; 2], color: Color32) -> Self

Create an image filled with the given color.

source

pub fn from_rgba_unmultiplied(size: [usize; 2], rgba: &[u8]) -> Self

Create a ColorImage from flat un-multiplied RGBA data.

This is usually what you want to use after having loaded an image file.

Panics if size[0] * size[1] * 4 != rgba.len().

§Example using the image crate:
fn load_image_from_path(path: &std::path::Path) -> Result<egui::ColorImage, image::ImageError> {
    let image = image::io::Reader::open(path)?.decode()?;
    let size = [image.width() as _, image.height() as _];
    let image_buffer = image.to_rgba8();
    let pixels = image_buffer.as_flat_samples();
    Ok(egui::ColorImage::from_rgba_unmultiplied(
        size,
        pixels.as_slice(),
    ))
}

fn load_image_from_memory(image_data: &[u8]) -> Result<ColorImage, image::ImageError> {
    let image = image::load_from_memory(image_data)?;
    let size = [image.width() as _, image.height() as _];
    let image_buffer = image.to_rgba8();
    let pixels = image_buffer.as_flat_samples();
    Ok(ColorImage::from_rgba_unmultiplied(
        size,
        pixels.as_slice(),
    ))
}
source

pub fn from_rgba_premultiplied(size: [usize; 2], rgba: &[u8]) -> Self

source

pub fn from_gray(size: [usize; 2], gray: &[u8]) -> Self

Create a ColorImage from flat opaque gray data.

Panics if size[0] * size[1] != gray.len().

source

pub fn from_gray_iter( size: [usize; 2], gray_iter: impl Iterator<Item = u8>, ) -> Self

Alternative method to from_gray. Create a ColorImage from iterator over flat opaque gray data.

Panics if size[0] * size[1] != gray_iter.len().

source

pub fn as_raw(&self) -> &[u8]

A view of the underlying data as &[u8]

source

pub fn as_raw_mut(&mut self) -> &mut [u8]

A view of the underlying data as &mut [u8]

source

pub fn region(&self, region: &Rect, pixels_per_point: Option<f32>) -> Self

Create a new Image from a patch of the current image. This method is especially convenient for screenshotting a part of the app since region can be interpreted as screen coordinates of the entire screenshot if pixels_per_point is provided for the native application. The floats of emath::Rect are cast to usize, rounding them down in order to interpret them as indices to the image data.

Panics if region.min.x > region.max.x || region.min.y > region.max.y, or if a region larger than the image is passed.

source

pub fn from_rgb(size: [usize; 2], rgb: &[u8]) -> Self

Create a ColorImage from flat RGB data.

This is what you want to use after having loaded an image file (and if you are ignoring the alpha channel - considering it to always be 0xff)

Panics if size[0] * size[1] * 3 != rgb.len().

source

pub fn example() -> Self

An example color image, useful for tests.

source

pub fn width(&self) -> usize

source

pub fn height(&self) -> usize

Trait Implementations§

source§

impl Clone for ColorImage

source§

fn clone(&self) -> ColorImage

Returns a copy of the value. Read more
1.0.0 · source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
source§

impl Debug for ColorImage

source§

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

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

impl Default for ColorImage

source§

fn default() -> ColorImage

Returns the “default value” for a type. Read more
source§

impl From<ColorImage> for ImageData

source§

fn from(image: ColorImage) -> Self

Converts to this type from the input type.
source§

impl Index<(usize, usize)> for ColorImage

source§

type Output = Color32

The returned type after indexing.
source§

fn index(&self, (x, y): (usize, usize)) -> &Color32

Performs the indexing (container[index]) operation. Read more
source§

impl IndexMut<(usize, usize)> for ColorImage

source§

fn index_mut(&mut self, (x, y): (usize, usize)) -> &mut Color32

Performs the mutable indexing (container[index]) operation. Read more
source§

impl PartialEq for ColorImage

source§

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

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

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

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

impl Eq for ColorImage

source§

impl StructuralPartialEq for ColorImage

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> CloneToUninit for T
where T: Clone,

source§

unsafe fn clone_to_uninit(&self, dst: *mut T)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dst. 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> ToOwned for T
where T: Clone,

source§

type Owned = T

The resulting type after obtaining ownership.
source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. 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.