Enum rerun::external::image::DynamicImage
#[non_exhaustive]pub enum DynamicImage {
ImageLuma8(ImageBuffer<Luma<u8>, Vec<u8>>),
ImageLumaA8(ImageBuffer<LumaA<u8>, Vec<u8>>),
ImageRgb8(ImageBuffer<Rgb<u8>, Vec<u8>>),
ImageRgba8(ImageBuffer<Rgba<u8>, Vec<u8>>),
ImageLuma16(ImageBuffer<Luma<u16>, Vec<u16>>),
ImageLumaA16(ImageBuffer<LumaA<u16>, Vec<u16>>),
ImageRgb16(ImageBuffer<Rgb<u16>, Vec<u16>>),
ImageRgba16(ImageBuffer<Rgba<u16>, Vec<u16>>),
ImageRgb32F(ImageBuffer<Rgb<f32>, Vec<f32>>),
ImageRgba32F(ImageBuffer<Rgba<f32>, Vec<f32>>),
}
Expand description
A Dynamic Image
This represents a matrix of pixels which are convertible from and to an RGBA representation. More variants that adhere to these principles may get added in the future, in particular to cover other combinations typically used.
§Usage
This type can act as a converter between specific ImageBuffer
instances.
use image::{DynamicImage, GrayImage, RgbImage};
let rgb: RgbImage = RgbImage::new(10, 10);
let luma: GrayImage = DynamicImage::ImageRgb8(rgb).into_luma8();
§Design
There is no goal to provide an all-encompassing type with all possible memory layouts. This would hardly be feasible as a simple enum, due to the sheer number of combinations of channel kinds, channel order, and bit depth. Rather, this type provides an opinionated selection with normalized channel order which can store common pixel values without loss.
Variants (Non-exhaustive)§
This enum is marked as non-exhaustive
ImageLuma8(ImageBuffer<Luma<u8>, Vec<u8>>)
Each pixel in this image is 8-bit Luma
ImageLumaA8(ImageBuffer<LumaA<u8>, Vec<u8>>)
Each pixel in this image is 8-bit Luma with alpha
ImageRgb8(ImageBuffer<Rgb<u8>, Vec<u8>>)
Each pixel in this image is 8-bit Rgb
ImageRgba8(ImageBuffer<Rgba<u8>, Vec<u8>>)
Each pixel in this image is 8-bit Rgb with alpha
ImageLuma16(ImageBuffer<Luma<u16>, Vec<u16>>)
Each pixel in this image is 16-bit Luma
ImageLumaA16(ImageBuffer<LumaA<u16>, Vec<u16>>)
Each pixel in this image is 16-bit Luma with alpha
ImageRgb16(ImageBuffer<Rgb<u16>, Vec<u16>>)
Each pixel in this image is 16-bit Rgb
ImageRgba16(ImageBuffer<Rgba<u16>, Vec<u16>>)
Each pixel in this image is 16-bit Rgb with alpha
ImageRgb32F(ImageBuffer<Rgb<f32>, Vec<f32>>)
Each pixel in this image is 32-bit float Rgb
ImageRgba32F(ImageBuffer<Rgba<f32>, Vec<f32>>)
Each pixel in this image is 32-bit float Rgb with alpha
Implementations§
§impl DynamicImage
impl DynamicImage
pub fn new(w: u32, h: u32, color: ColorType) -> DynamicImage
pub fn new(w: u32, h: u32, color: ColorType) -> DynamicImage
Creates a dynamic image backed by a buffer depending on the color type given.
pub fn new_luma8(w: u32, h: u32) -> DynamicImage
pub fn new_luma8(w: u32, h: u32) -> DynamicImage
Creates a dynamic image backed by a buffer of gray pixels.
pub fn new_luma_a8(w: u32, h: u32) -> DynamicImage
pub fn new_luma_a8(w: u32, h: u32) -> DynamicImage
Creates a dynamic image backed by a buffer of gray pixels with transparency.
pub fn new_rgb8(w: u32, h: u32) -> DynamicImage
pub fn new_rgb8(w: u32, h: u32) -> DynamicImage
Creates a dynamic image backed by a buffer of RGB pixels.
pub fn new_rgba8(w: u32, h: u32) -> DynamicImage
pub fn new_rgba8(w: u32, h: u32) -> DynamicImage
Creates a dynamic image backed by a buffer of RGBA pixels.
pub fn new_luma16(w: u32, h: u32) -> DynamicImage
pub fn new_luma16(w: u32, h: u32) -> DynamicImage
Creates a dynamic image backed by a buffer of gray pixels.
pub fn new_luma_a16(w: u32, h: u32) -> DynamicImage
pub fn new_luma_a16(w: u32, h: u32) -> DynamicImage
Creates a dynamic image backed by a buffer of gray pixels with transparency.
pub fn new_rgb16(w: u32, h: u32) -> DynamicImage
pub fn new_rgb16(w: u32, h: u32) -> DynamicImage
Creates a dynamic image backed by a buffer of RGB pixels.
pub fn new_rgba16(w: u32, h: u32) -> DynamicImage
pub fn new_rgba16(w: u32, h: u32) -> DynamicImage
Creates a dynamic image backed by a buffer of RGBA pixels.
pub fn new_rgb32f(w: u32, h: u32) -> DynamicImage
pub fn new_rgb32f(w: u32, h: u32) -> DynamicImage
Creates a dynamic image backed by a buffer of RGB pixels.
pub fn new_rgba32f(w: u32, h: u32) -> DynamicImage
pub fn new_rgba32f(w: u32, h: u32) -> DynamicImage
Creates a dynamic image backed by a buffer of RGBA pixels.
pub fn from_decoder(
decoder: impl ImageDecoder,
) -> Result<DynamicImage, ImageError>
pub fn from_decoder( decoder: impl ImageDecoder, ) -> Result<DynamicImage, ImageError>
Decodes an encoded image into a dynamic image.
pub fn to_rgb16(&self) -> ImageBuffer<Rgb<u16>, Vec<u16>>
pub fn to_rgb16(&self) -> ImageBuffer<Rgb<u16>, Vec<u16>>
Returns a copy of this image as an RGB image.
pub fn to_rgb32f(&self) -> ImageBuffer<Rgb<f32>, Vec<f32>>
pub fn to_rgb32f(&self) -> ImageBuffer<Rgb<f32>, Vec<f32>>
Returns a copy of this image as an RGB image.
pub fn to_rgba8(&self) -> ImageBuffer<Rgba<u8>, Vec<u8>>
pub fn to_rgba8(&self) -> ImageBuffer<Rgba<u8>, Vec<u8>>
Returns a copy of this image as an RGBA image.
pub fn to_rgba16(&self) -> ImageBuffer<Rgba<u16>, Vec<u16>>
pub fn to_rgba16(&self) -> ImageBuffer<Rgba<u16>, Vec<u16>>
Returns a copy of this image as an RGBA image.
pub fn to_rgba32f(&self) -> ImageBuffer<Rgba<f32>, Vec<f32>>
pub fn to_rgba32f(&self) -> ImageBuffer<Rgba<f32>, Vec<f32>>
Returns a copy of this image as an RGBA image.
pub fn to_luma8(&self) -> ImageBuffer<Luma<u8>, Vec<u8>>
pub fn to_luma8(&self) -> ImageBuffer<Luma<u8>, Vec<u8>>
Returns a copy of this image as a Luma image.
pub fn to_luma16(&self) -> ImageBuffer<Luma<u16>, Vec<u16>>
pub fn to_luma16(&self) -> ImageBuffer<Luma<u16>, Vec<u16>>
Returns a copy of this image as a Luma image.
pub fn to_luma32f(&self) -> ImageBuffer<Luma<f32>, Vec<f32>>
pub fn to_luma32f(&self) -> ImageBuffer<Luma<f32>, Vec<f32>>
Returns a copy of this image as a Luma image.
pub fn to_luma_alpha8(&self) -> ImageBuffer<LumaA<u8>, Vec<u8>>
pub fn to_luma_alpha8(&self) -> ImageBuffer<LumaA<u8>, Vec<u8>>
Returns a copy of this image as a LumaA
image.
pub fn to_luma_alpha16(&self) -> ImageBuffer<LumaA<u16>, Vec<u16>>
pub fn to_luma_alpha16(&self) -> ImageBuffer<LumaA<u16>, Vec<u16>>
Returns a copy of this image as a LumaA
image.
pub fn to_luma_alpha32f(&self) -> ImageBuffer<LumaA<f32>, Vec<f32>>
pub fn to_luma_alpha32f(&self) -> ImageBuffer<LumaA<f32>, Vec<f32>>
Returns a copy of this image as a LumaA
image.
pub fn into_rgb8(self) -> ImageBuffer<Rgb<u8>, Vec<u8>>
pub fn into_rgb8(self) -> ImageBuffer<Rgb<u8>, Vec<u8>>
Consume the image and returns a RGB image.
If the image was already the correct format, it is returned as is. Otherwise, a copy is created.
pub fn into_rgb16(self) -> ImageBuffer<Rgb<u16>, Vec<u16>>
pub fn into_rgb16(self) -> ImageBuffer<Rgb<u16>, Vec<u16>>
Consume the image and returns a RGB image.
If the image was already the correct format, it is returned as is. Otherwise, a copy is created.
pub fn into_rgb32f(self) -> ImageBuffer<Rgb<f32>, Vec<f32>>
pub fn into_rgb32f(self) -> ImageBuffer<Rgb<f32>, Vec<f32>>
Consume the image and returns a RGB image.
If the image was already the correct format, it is returned as is. Otherwise, a copy is created.
pub fn into_rgba8(self) -> ImageBuffer<Rgba<u8>, Vec<u8>>
pub fn into_rgba8(self) -> ImageBuffer<Rgba<u8>, Vec<u8>>
Consume the image and returns a RGBA image.
If the image was already the correct format, it is returned as is. Otherwise, a copy is created.
pub fn into_rgba16(self) -> ImageBuffer<Rgba<u16>, Vec<u16>>
pub fn into_rgba16(self) -> ImageBuffer<Rgba<u16>, Vec<u16>>
Consume the image and returns a RGBA image.
If the image was already the correct format, it is returned as is. Otherwise, a copy is created.
pub fn into_rgba32f(self) -> ImageBuffer<Rgba<f32>, Vec<f32>>
pub fn into_rgba32f(self) -> ImageBuffer<Rgba<f32>, Vec<f32>>
Consume the image and returns a RGBA image.
If the image was already the correct format, it is returned as is. Otherwise, a copy is created.
pub fn into_luma8(self) -> ImageBuffer<Luma<u8>, Vec<u8>>
pub fn into_luma8(self) -> ImageBuffer<Luma<u8>, Vec<u8>>
Consume the image and returns a Luma image.
If the image was already the correct format, it is returned as is. Otherwise, a copy is created.
pub fn into_luma16(self) -> ImageBuffer<Luma<u16>, Vec<u16>>
pub fn into_luma16(self) -> ImageBuffer<Luma<u16>, Vec<u16>>
Consume the image and returns a Luma image.
If the image was already the correct format, it is returned as is. Otherwise, a copy is created.
pub fn into_luma_alpha8(self) -> ImageBuffer<LumaA<u8>, Vec<u8>>
pub fn into_luma_alpha8(self) -> ImageBuffer<LumaA<u8>, Vec<u8>>
Consume the image and returns a LumaA
image.
If the image was already the correct format, it is returned as is. Otherwise, a copy is created.
pub fn into_luma_alpha16(self) -> ImageBuffer<LumaA<u16>, Vec<u16>>
pub fn into_luma_alpha16(self) -> ImageBuffer<LumaA<u16>, Vec<u16>>
Consume the image and returns a LumaA
image.
If the image was already the correct format, it is returned as is. Otherwise, a copy is created.
pub fn crop(&mut self, x: u32, y: u32, width: u32, height: u32) -> DynamicImage
pub fn crop(&mut self, x: u32, y: u32, width: u32, height: u32) -> DynamicImage
Return a cut-out of this image delimited by the bounding rectangle.
Note: this method does not modify the object,
and its signature will be replaced with crop_imm()
’s in the 0.24 release
pub fn crop_imm(&self, x: u32, y: u32, width: u32, height: u32) -> DynamicImage
pub fn crop_imm(&self, x: u32, y: u32, width: u32, height: u32) -> DynamicImage
Return a cut-out of this image delimited by the bounding rectangle.
pub fn as_rgb8(&self) -> Option<&ImageBuffer<Rgb<u8>, Vec<u8>>>
pub fn as_rgb8(&self) -> Option<&ImageBuffer<Rgb<u8>, Vec<u8>>>
Return a reference to an 8bit RGB image
pub fn as_mut_rgb8(&mut self) -> Option<&mut ImageBuffer<Rgb<u8>, Vec<u8>>>
pub fn as_mut_rgb8(&mut self) -> Option<&mut ImageBuffer<Rgb<u8>, Vec<u8>>>
Return a mutable reference to an 8bit RGB image
pub fn as_rgba8(&self) -> Option<&ImageBuffer<Rgba<u8>, Vec<u8>>>
pub fn as_rgba8(&self) -> Option<&ImageBuffer<Rgba<u8>, Vec<u8>>>
Return a reference to an 8bit RGBA image
pub fn as_mut_rgba8(&mut self) -> Option<&mut ImageBuffer<Rgba<u8>, Vec<u8>>>
pub fn as_mut_rgba8(&mut self) -> Option<&mut ImageBuffer<Rgba<u8>, Vec<u8>>>
Return a mutable reference to an 8bit RGBA image
pub fn as_luma8(&self) -> Option<&ImageBuffer<Luma<u8>, Vec<u8>>>
pub fn as_luma8(&self) -> Option<&ImageBuffer<Luma<u8>, Vec<u8>>>
Return a reference to an 8bit Grayscale image
pub fn as_mut_luma8(&mut self) -> Option<&mut ImageBuffer<Luma<u8>, Vec<u8>>>
pub fn as_mut_luma8(&mut self) -> Option<&mut ImageBuffer<Luma<u8>, Vec<u8>>>
Return a mutable reference to an 8bit Grayscale image
pub fn as_luma_alpha8(&self) -> Option<&ImageBuffer<LumaA<u8>, Vec<u8>>>
pub fn as_luma_alpha8(&self) -> Option<&ImageBuffer<LumaA<u8>, Vec<u8>>>
Return a reference to an 8bit Grayscale image with an alpha channel
pub fn as_mut_luma_alpha8(
&mut self,
) -> Option<&mut ImageBuffer<LumaA<u8>, Vec<u8>>>
pub fn as_mut_luma_alpha8( &mut self, ) -> Option<&mut ImageBuffer<LumaA<u8>, Vec<u8>>>
Return a mutable reference to an 8bit Grayscale image with an alpha channel
pub fn as_rgb16(&self) -> Option<&ImageBuffer<Rgb<u16>, Vec<u16>>>
pub fn as_rgb16(&self) -> Option<&ImageBuffer<Rgb<u16>, Vec<u16>>>
Return a reference to an 16bit RGB image
pub fn as_mut_rgb16(&mut self) -> Option<&mut ImageBuffer<Rgb<u16>, Vec<u16>>>
pub fn as_mut_rgb16(&mut self) -> Option<&mut ImageBuffer<Rgb<u16>, Vec<u16>>>
Return a mutable reference to an 16bit RGB image
pub fn as_rgba16(&self) -> Option<&ImageBuffer<Rgba<u16>, Vec<u16>>>
pub fn as_rgba16(&self) -> Option<&ImageBuffer<Rgba<u16>, Vec<u16>>>
Return a reference to an 16bit RGBA image
pub fn as_mut_rgba16(&mut self) -> Option<&mut ImageBuffer<Rgba<u16>, Vec<u16>>>
pub fn as_mut_rgba16(&mut self) -> Option<&mut ImageBuffer<Rgba<u16>, Vec<u16>>>
Return a mutable reference to an 16bit RGBA image
pub fn as_rgb32f(&self) -> Option<&ImageBuffer<Rgb<f32>, Vec<f32>>>
pub fn as_rgb32f(&self) -> Option<&ImageBuffer<Rgb<f32>, Vec<f32>>>
Return a reference to an 32bit RGB image
pub fn as_mut_rgb32f(&mut self) -> Option<&mut ImageBuffer<Rgb<f32>, Vec<f32>>>
pub fn as_mut_rgb32f(&mut self) -> Option<&mut ImageBuffer<Rgb<f32>, Vec<f32>>>
Return a mutable reference to an 32bit RGB image
pub fn as_rgba32f(&self) -> Option<&ImageBuffer<Rgba<f32>, Vec<f32>>>
pub fn as_rgba32f(&self) -> Option<&ImageBuffer<Rgba<f32>, Vec<f32>>>
Return a reference to an 32bit RGBA image
pub fn as_mut_rgba32f(
&mut self,
) -> Option<&mut ImageBuffer<Rgba<f32>, Vec<f32>>>
pub fn as_mut_rgba32f( &mut self, ) -> Option<&mut ImageBuffer<Rgba<f32>, Vec<f32>>>
Return a mutable reference to an 16bit RGBA image
pub fn as_luma16(&self) -> Option<&ImageBuffer<Luma<u16>, Vec<u16>>>
pub fn as_luma16(&self) -> Option<&ImageBuffer<Luma<u16>, Vec<u16>>>
Return a reference to an 16bit Grayscale image
pub fn as_mut_luma16(&mut self) -> Option<&mut ImageBuffer<Luma<u16>, Vec<u16>>>
pub fn as_mut_luma16(&mut self) -> Option<&mut ImageBuffer<Luma<u16>, Vec<u16>>>
Return a mutable reference to an 16bit Grayscale image
pub fn as_luma_alpha16(&self) -> Option<&ImageBuffer<LumaA<u16>, Vec<u16>>>
pub fn as_luma_alpha16(&self) -> Option<&ImageBuffer<LumaA<u16>, Vec<u16>>>
Return a reference to an 16bit Grayscale image with an alpha channel
pub fn as_mut_luma_alpha16(
&mut self,
) -> Option<&mut ImageBuffer<LumaA<u16>, Vec<u16>>>
pub fn as_mut_luma_alpha16( &mut self, ) -> Option<&mut ImageBuffer<LumaA<u16>, Vec<u16>>>
Return a mutable reference to an 16bit Grayscale image with an alpha channel
pub fn as_flat_samples_u8(&self) -> Option<FlatSamples<&[u8]>>
pub fn as_flat_samples_u8(&self) -> Option<FlatSamples<&[u8]>>
Return a view on the raw sample buffer for 8 bit per channel images.
pub fn as_flat_samples_u16(&self) -> Option<FlatSamples<&[u16]>>
pub fn as_flat_samples_u16(&self) -> Option<FlatSamples<&[u16]>>
Return a view on the raw sample buffer for 16 bit per channel images.
pub fn as_flat_samples_f32(&self) -> Option<FlatSamples<&[f32]>>
pub fn as_flat_samples_f32(&self) -> Option<FlatSamples<&[f32]>>
Return a view on the raw sample buffer for 32bit per channel images.
pub fn into_bytes(self) -> Vec<u8> ⓘ
pub fn into_bytes(self) -> Vec<u8> ⓘ
Return this image’s pixels as a byte vector. If the ImageBuffer
container is Vec<u8>
, this operation is free. Otherwise, a copy
is returned.
pub fn grayscale(&self) -> DynamicImage
pub fn grayscale(&self) -> DynamicImage
Return a grayscale version of this image.
Returns Luma
images in most cases. However, for f32
images,
this will return a grayscale Rgb/Rgba
image instead.
pub fn invert(&mut self)
pub fn invert(&mut self)
Invert the colors of this image. This method operates inplace.
pub fn resize(
&self,
nwidth: u32,
nheight: u32,
filter: FilterType,
) -> DynamicImage
pub fn resize( &self, nwidth: u32, nheight: u32, filter: FilterType, ) -> DynamicImage
Resize this image using the specified filter algorithm.
Returns a new image. The image’s aspect ratio is preserved.
The image is scaled to the maximum possible size that fits
within the bounds specified by nwidth
and nheight
.
pub fn resize_exact(
&self,
nwidth: u32,
nheight: u32,
filter: FilterType,
) -> DynamicImage
pub fn resize_exact( &self, nwidth: u32, nheight: u32, filter: FilterType, ) -> DynamicImage
Resize this image using the specified filter algorithm.
Returns a new image. Does not preserve aspect ratio.
nwidth
and nheight
are the new image’s dimensions
pub fn thumbnail(&self, nwidth: u32, nheight: u32) -> DynamicImage
pub fn thumbnail(&self, nwidth: u32, nheight: u32) -> DynamicImage
Scale this image down to fit within a specific size.
Returns a new image. The image’s aspect ratio is preserved.
The image is scaled to the maximum possible size that fits
within the bounds specified by nwidth
and nheight
.
This method uses a fast integer algorithm where each source pixel contributes to exactly one target pixel. May give aliasing artifacts if new size is close to old size.
pub fn thumbnail_exact(&self, nwidth: u32, nheight: u32) -> DynamicImage
pub fn thumbnail_exact(&self, nwidth: u32, nheight: u32) -> DynamicImage
Scale this image down to a specific size.
Returns a new image. Does not preserve aspect ratio.
nwidth
and nheight
are the new image’s dimensions.
This method uses a fast integer algorithm where each source
pixel contributes to exactly one target pixel.
May give aliasing artifacts if new size is close to old size.
pub fn resize_to_fill(
&self,
nwidth: u32,
nheight: u32,
filter: FilterType,
) -> DynamicImage
pub fn resize_to_fill( &self, nwidth: u32, nheight: u32, filter: FilterType, ) -> DynamicImage
Resize this image using the specified filter algorithm.
Returns a new image. The image’s aspect ratio is preserved.
The image is scaled to the maximum possible size that fits
within the larger (relative to aspect ratio) of the bounds
specified by nwidth
and nheight
, then cropped to
fit within the other bound.
pub fn blur(&self, sigma: f32) -> DynamicImage
pub fn blur(&self, sigma: f32) -> DynamicImage
Performs a Gaussian blur on this image.
sigma
is a measure of how much to blur by.
Use DynamicImage::fast_blur() for a faster but less
accurate version.
pub fn fast_blur(&self, sigma: f32) -> DynamicImage
pub fn fast_blur(&self, sigma: f32) -> DynamicImage
Performs a fast blur on this image.
sigma
is the standard deviation of the
(approximated) Gaussian
pub fn unsharpen(&self, sigma: f32, threshold: i32) -> DynamicImage
pub fn unsharpen(&self, sigma: f32, threshold: i32) -> DynamicImage
Performs an unsharpen mask on this image.
sigma
is the amount to blur the image by.
threshold
is a control of how much to sharpen.
See https://en.wikipedia.org/wiki/Unsharp_masking#Digital_unsharp_masking
pub fn filter3x3(&self, kernel: &[f32]) -> DynamicImage
pub fn filter3x3(&self, kernel: &[f32]) -> DynamicImage
Filters this image with the specified 3x3 kernel.
pub fn adjust_contrast(&self, c: f32) -> DynamicImage
pub fn adjust_contrast(&self, c: f32) -> DynamicImage
Adjust the contrast of this image.
contrast
is the amount to adjust the contrast by.
Negative values decrease the contrast and positive values increase the contrast.
pub fn brighten(&self, value: i32) -> DynamicImage
pub fn brighten(&self, value: i32) -> DynamicImage
Brighten the pixels of this image.
value
is the amount to brighten each pixel by.
Negative values decrease the brightness and positive values increase it.
pub fn huerotate(&self, value: i32) -> DynamicImage
pub fn huerotate(&self, value: i32) -> DynamicImage
Hue rotate the supplied image.
value
is the degrees to rotate each pixel by.
0 and 360 do nothing, the rest rotates by the given degree value.
just like the css webkit filter hue-rotate(180)
pub fn flipv(&self) -> DynamicImage
pub fn flipv(&self) -> DynamicImage
Flip this image vertically
Use apply_orientation
if you want to flip the image in-place instead.
pub fn fliph(&self) -> DynamicImage
pub fn fliph(&self) -> DynamicImage
Flip this image horizontally
Use apply_orientation
if you want to flip the image in-place.
pub fn rotate90(&self) -> DynamicImage
pub fn rotate90(&self) -> DynamicImage
Rotate this image 90 degrees clockwise.
pub fn rotate180(&self) -> DynamicImage
pub fn rotate180(&self) -> DynamicImage
Rotate this image 180 degrees.
Use apply_orientation
if you want to rotate the image in-place.
pub fn rotate270(&self) -> DynamicImage
pub fn rotate270(&self) -> DynamicImage
Rotate this image 270 degrees clockwise.
pub fn apply_orientation(&mut self, orientation: Orientation)
pub fn apply_orientation(&mut self, orientation: Orientation)
Rotates and/or flips the image as indicated by Orientation.
This can be used to apply Exif orientation to an image, e.g. to correctly display a photo taken by a smartphone camera:
use image::{DynamicImage, ImageReader, ImageDecoder};
let mut decoder = ImageReader::open("file.jpg")?.into_decoder()?;
let orientation = decoder.orientation()?;
let mut image = DynamicImage::from_decoder(decoder)?;
image.apply_orientation(orientation);
Note that for some orientations cannot be efficiently applied in-place. In that case this function will make a copy of the image internally.
If this matters to you, please see the documentation on the variants of Orientation to learn which orientations can and cannot be applied without copying.
pub fn write_to<W>(
&self,
w: &mut W,
format: ImageFormat,
) -> Result<(), ImageError>
pub fn write_to<W>( &self, w: &mut W, format: ImageFormat, ) -> Result<(), ImageError>
Encode this image and write it to w
.
Assumes the writer is buffered. In most cases,
you should wrap your writer in a BufWriter
for best performance.
pub fn write_with_encoder(
&self,
encoder: impl ImageEncoder,
) -> Result<(), ImageError>
pub fn write_with_encoder( &self, encoder: impl ImageEncoder, ) -> Result<(), ImageError>
Encode this image with the provided encoder.
pub fn save<Q>(&self, path: Q) -> Result<(), ImageError>
pub fn save<Q>(&self, path: Q) -> Result<(), ImageError>
Saves the buffer to a file at the path specified.
The image format is derived from the file extension.
pub fn save_with_format<Q>(
&self,
path: Q,
format: ImageFormat,
) -> Result<(), ImageError>
pub fn save_with_format<Q>( &self, path: Q, format: ImageFormat, ) -> Result<(), ImageError>
Saves the buffer to a file at the specified path in the specified format.
See save_buffer_with_format
for
supported types.
Trait Implementations§
§impl Clone for DynamicImage
impl Clone for DynamicImage
§fn clone(&self) -> DynamicImage
fn clone(&self) -> DynamicImage
§fn clone_from(&mut self, source: &DynamicImage)
fn clone_from(&mut self, source: &DynamicImage)
source
. Read more§impl Debug for DynamicImage
impl Debug for DynamicImage
§impl Default for DynamicImage
impl Default for DynamicImage
§fn default() -> DynamicImage
fn default() -> DynamicImage
§impl From<DynamicImage> for ImageBuffer<Luma<u16>, Vec<u16>>
impl From<DynamicImage> for ImageBuffer<Luma<u16>, Vec<u16>>
§fn from(value: DynamicImage) -> ImageBuffer<Luma<u16>, Vec<u16>>
fn from(value: DynamicImage) -> ImageBuffer<Luma<u16>, Vec<u16>>
§impl From<DynamicImage> for ImageBuffer<Luma<u8>, Vec<u8>>
impl From<DynamicImage> for ImageBuffer<Luma<u8>, Vec<u8>>
§fn from(value: DynamicImage) -> ImageBuffer<Luma<u8>, Vec<u8>>
fn from(value: DynamicImage) -> ImageBuffer<Luma<u8>, Vec<u8>>
§impl From<DynamicImage> for ImageBuffer<LumaA<u16>, Vec<u16>>
impl From<DynamicImage> for ImageBuffer<LumaA<u16>, Vec<u16>>
§fn from(value: DynamicImage) -> ImageBuffer<LumaA<u16>, Vec<u16>>
fn from(value: DynamicImage) -> ImageBuffer<LumaA<u16>, Vec<u16>>
§impl From<DynamicImage> for ImageBuffer<LumaA<u8>, Vec<u8>>
impl From<DynamicImage> for ImageBuffer<LumaA<u8>, Vec<u8>>
§fn from(value: DynamicImage) -> ImageBuffer<LumaA<u8>, Vec<u8>>
fn from(value: DynamicImage) -> ImageBuffer<LumaA<u8>, Vec<u8>>
§impl From<DynamicImage> for ImageBuffer<Rgb<u16>, Vec<u16>>
impl From<DynamicImage> for ImageBuffer<Rgb<u16>, Vec<u16>>
§fn from(value: DynamicImage) -> ImageBuffer<Rgb<u16>, Vec<u16>>
fn from(value: DynamicImage) -> ImageBuffer<Rgb<u16>, Vec<u16>>
§impl From<DynamicImage> for ImageBuffer<Rgb<u8>, Vec<u8>>
impl From<DynamicImage> for ImageBuffer<Rgb<u8>, Vec<u8>>
§fn from(value: DynamicImage) -> ImageBuffer<Rgb<u8>, Vec<u8>>
fn from(value: DynamicImage) -> ImageBuffer<Rgb<u8>, Vec<u8>>
§impl From<DynamicImage> for ImageBuffer<Rgba<f32>, Vec<f32>>
impl From<DynamicImage> for ImageBuffer<Rgba<f32>, Vec<f32>>
§fn from(value: DynamicImage) -> ImageBuffer<Rgba<f32>, Vec<f32>>
fn from(value: DynamicImage) -> ImageBuffer<Rgba<f32>, Vec<f32>>
§impl From<DynamicImage> for ImageBuffer<Rgba<u16>, Vec<u16>>
impl From<DynamicImage> for ImageBuffer<Rgba<u16>, Vec<u16>>
§fn from(value: DynamicImage) -> ImageBuffer<Rgba<u16>, Vec<u16>>
fn from(value: DynamicImage) -> ImageBuffer<Rgba<u16>, Vec<u16>>
§impl From<DynamicImage> for ImageBuffer<Rgba<u8>, Vec<u8>>
impl From<DynamicImage> for ImageBuffer<Rgba<u8>, Vec<u8>>
§fn from(value: DynamicImage) -> ImageBuffer<Rgba<u8>, Vec<u8>>
fn from(value: DynamicImage) -> ImageBuffer<Rgba<u8>, Vec<u8>>
§impl From<ImageBuffer<Luma<f32>, Vec<f32>>> for DynamicImage
impl From<ImageBuffer<Luma<f32>, Vec<f32>>> for DynamicImage
§fn from(image: ImageBuffer<Luma<f32>, Vec<f32>>) -> DynamicImage
fn from(image: ImageBuffer<Luma<f32>, Vec<f32>>) -> DynamicImage
§impl From<ImageBuffer<Luma<u16>, Vec<u16>>> for DynamicImage
impl From<ImageBuffer<Luma<u16>, Vec<u16>>> for DynamicImage
§fn from(image: ImageBuffer<Luma<u16>, Vec<u16>>) -> DynamicImage
fn from(image: ImageBuffer<Luma<u16>, Vec<u16>>) -> DynamicImage
§impl From<ImageBuffer<Luma<u8>, Vec<u8>>> for DynamicImage
impl From<ImageBuffer<Luma<u8>, Vec<u8>>> for DynamicImage
§fn from(image: ImageBuffer<Luma<u8>, Vec<u8>>) -> DynamicImage
fn from(image: ImageBuffer<Luma<u8>, Vec<u8>>) -> DynamicImage
§impl From<ImageBuffer<LumaA<f32>, Vec<f32>>> for DynamicImage
impl From<ImageBuffer<LumaA<f32>, Vec<f32>>> for DynamicImage
§fn from(image: ImageBuffer<LumaA<f32>, Vec<f32>>) -> DynamicImage
fn from(image: ImageBuffer<LumaA<f32>, Vec<f32>>) -> DynamicImage
§impl From<ImageBuffer<LumaA<u16>, Vec<u16>>> for DynamicImage
impl From<ImageBuffer<LumaA<u16>, Vec<u16>>> for DynamicImage
§fn from(image: ImageBuffer<LumaA<u16>, Vec<u16>>) -> DynamicImage
fn from(image: ImageBuffer<LumaA<u16>, Vec<u16>>) -> DynamicImage
§impl From<ImageBuffer<LumaA<u8>, Vec<u8>>> for DynamicImage
impl From<ImageBuffer<LumaA<u8>, Vec<u8>>> for DynamicImage
§fn from(image: ImageBuffer<LumaA<u8>, Vec<u8>>) -> DynamicImage
fn from(image: ImageBuffer<LumaA<u8>, Vec<u8>>) -> DynamicImage
§impl From<ImageBuffer<Rgb<f32>, Vec<f32>>> for DynamicImage
impl From<ImageBuffer<Rgb<f32>, Vec<f32>>> for DynamicImage
§fn from(image: ImageBuffer<Rgb<f32>, Vec<f32>>) -> DynamicImage
fn from(image: ImageBuffer<Rgb<f32>, Vec<f32>>) -> DynamicImage
§impl From<ImageBuffer<Rgb<u16>, Vec<u16>>> for DynamicImage
impl From<ImageBuffer<Rgb<u16>, Vec<u16>>> for DynamicImage
§fn from(image: ImageBuffer<Rgb<u16>, Vec<u16>>) -> DynamicImage
fn from(image: ImageBuffer<Rgb<u16>, Vec<u16>>) -> DynamicImage
§impl From<ImageBuffer<Rgb<u8>, Vec<u8>>> for DynamicImage
impl From<ImageBuffer<Rgb<u8>, Vec<u8>>> for DynamicImage
§fn from(image: ImageBuffer<Rgb<u8>, Vec<u8>>) -> DynamicImage
fn from(image: ImageBuffer<Rgb<u8>, Vec<u8>>) -> DynamicImage
§impl From<ImageBuffer<Rgba<f32>, Vec<f32>>> for DynamicImage
impl From<ImageBuffer<Rgba<f32>, Vec<f32>>> for DynamicImage
§fn from(image: ImageBuffer<Rgba<f32>, Vec<f32>>) -> DynamicImage
fn from(image: ImageBuffer<Rgba<f32>, Vec<f32>>) -> DynamicImage
§impl From<ImageBuffer<Rgba<u16>, Vec<u16>>> for DynamicImage
impl From<ImageBuffer<Rgba<u16>, Vec<u16>>> for DynamicImage
§fn from(image: ImageBuffer<Rgba<u16>, Vec<u16>>) -> DynamicImage
fn from(image: ImageBuffer<Rgba<u16>, Vec<u16>>) -> DynamicImage
§impl From<ImageBuffer<Rgba<u8>, Vec<u8>>> for DynamicImage
impl From<ImageBuffer<Rgba<u8>, Vec<u8>>> for DynamicImage
§fn from(image: ImageBuffer<Rgba<u8>, Vec<u8>>) -> DynamicImage
fn from(image: ImageBuffer<Rgba<u8>, Vec<u8>>) -> DynamicImage
§impl GenericImage for DynamicImage
impl GenericImage for DynamicImage
§fn get_pixel_mut(&mut self, _: u32, _: u32) -> &mut Rgba<u8>
👎Deprecated since 0.24.0: Use get_pixel
and put_pixel
instead.
fn get_pixel_mut(&mut self, _: u32, _: u32) -> &mut Rgba<u8>
get_pixel
and put_pixel
instead.Do not use is function: It is unimplemented!
§fn put_pixel(&mut self, x: u32, y: u32, pixel: Rgba<u8>)
fn put_pixel(&mut self, x: u32, y: u32, pixel: Rgba<u8>)
§fn blend_pixel(&mut self, x: u32, y: u32, pixel: Rgba<u8>)
fn blend_pixel(&mut self, x: u32, y: u32, pixel: Rgba<u8>)
pixels_mut
to blend the pixels directly§unsafe fn unsafe_put_pixel(&mut self, x: u32, y: u32, pixel: Self::Pixel)
unsafe fn unsafe_put_pixel(&mut self, x: u32, y: u32, pixel: Self::Pixel)
§fn copy_from<O>(&mut self, other: &O, x: u32, y: u32) -> Result<(), ImageError>where
O: GenericImageView<Pixel = Self::Pixel>,
fn copy_from<O>(&mut self, other: &O, x: u32, y: u32) -> Result<(), ImageError>where
O: GenericImageView<Pixel = Self::Pixel>,
§fn copy_within(&mut self, source: Rect, x: u32, y: u32) -> bool
fn copy_within(&mut self, source: Rect, x: u32, y: u32) -> bool
§fn sub_image(
&mut self,
x: u32,
y: u32,
width: u32,
height: u32,
) -> SubImage<&mut Self>where
Self: Sized,
fn sub_image(
&mut self,
x: u32,
y: u32,
width: u32,
height: u32,
) -> SubImage<&mut Self>where
Self: Sized,
GenericImageView::view
The coordinates set the position of the top left corner of the SubImage
.§impl GenericImageView for DynamicImage
impl GenericImageView for DynamicImage
§fn dimensions(&self) -> (u32, u32)
fn dimensions(&self) -> (u32, u32)
§fn get_pixel(&self, x: u32, y: u32) -> Rgba<u8>
fn get_pixel(&self, x: u32, y: u32) -> Rgba<u8>
§fn in_bounds(&self, x: u32, y: u32) -> bool
fn in_bounds(&self, x: u32, y: u32) -> bool
§unsafe fn unsafe_get_pixel(&self, x: u32, y: u32) -> Self::Pixel
unsafe fn unsafe_get_pixel(&self, x: u32, y: u32) -> Self::Pixel
§impl PartialEq for DynamicImage
impl PartialEq for DynamicImage
§fn eq(&self, other: &DynamicImage) -> bool
fn eq(&self, other: &DynamicImage) -> bool
self
and other
values to be equal, and is used
by ==
.source§impl TryFrom<DynamicImage> for TensorData
impl TryFrom<DynamicImage> for TensorData
§type Error = TensorImageLoadError
type Error = TensorImageLoadError
source§fn try_from(
value: DynamicImage,
) -> Result<TensorData, <TensorData as TryFrom<DynamicImage>>::Error>
fn try_from( value: DynamicImage, ) -> Result<TensorData, <TensorData as TryFrom<DynamicImage>>::Error>
impl StructuralPartialEq for DynamicImage
Auto Trait Implementations§
impl Freeze for DynamicImage
impl RefUnwindSafe for DynamicImage
impl Send for DynamicImage
impl Sync for DynamicImage
impl Unpin for DynamicImage
impl UnwindSafe for DynamicImage
Blanket Implementations§
source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
source§impl<T> CheckedAs for T
impl<T> CheckedAs for T
source§fn checked_as<Dst>(self) -> Option<Dst>where
T: CheckedCast<Dst>,
fn checked_as<Dst>(self) -> Option<Dst>where
T: CheckedCast<Dst>,
source§impl<Src, Dst> CheckedCastFrom<Src> for Dstwhere
Src: CheckedCast<Dst>,
impl<Src, Dst> CheckedCastFrom<Src> for Dstwhere
Src: CheckedCast<Dst>,
source§fn checked_cast_from(src: Src) -> Option<Dst>
fn checked_cast_from(src: Src) -> Option<Dst>
§impl<T> Downcast for Twhere
T: Any,
impl<T> Downcast for Twhere
T: Any,
§fn into_any(self: Box<T>) -> Box<dyn Any>
fn into_any(self: Box<T>) -> Box<dyn Any>
Box<dyn Trait>
(where Trait: Downcast
) to Box<dyn Any>
. Box<dyn Any>
can
then be further downcast
into Box<ConcreteType>
where ConcreteType
implements Trait
.§fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
Rc<Trait>
(where Trait: Downcast
) to Rc<Any>
. Rc<Any>
can then be
further downcast
into Rc<ConcreteType>
where ConcreteType
implements Trait
.§fn as_any(&self) -> &(dyn Any + 'static)
fn as_any(&self) -> &(dyn Any + 'static)
&Trait
(where Trait: Downcast
) to &Any
. This is needed since Rust cannot
generate &Any
’s vtable from &Trait
’s.§fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
&mut Trait
(where Trait: Downcast
) to &Any
. This is needed since Rust cannot
generate &mut Any
’s vtable from &mut Trait
’s.§impl<T> DowncastSync for T
impl<T> DowncastSync for T
§impl<T> Instrument for T
impl<T> Instrument for T
§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
source§impl<T> IntoEither for T
impl<T> IntoEither for T
source§fn into_either(self, into_left: bool) -> Either<Self, Self> ⓘ
fn into_either(self, into_left: bool) -> Either<Self, Self> ⓘ
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 moresource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self> ⓘ
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self> ⓘ
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 moresource§impl<T> IntoRequest<T> for T
impl<T> IntoRequest<T> for T
source§fn into_request(self) -> Request<T>
fn into_request(self) -> Request<T>
T
in a tonic::Request