#[non_exhaustive]pub enum ImageFormat {
Show 15 variants
Png,
Jpeg,
Gif,
WebP,
Pnm,
Tiff,
Tga,
Dds,
Bmp,
Ico,
Hdr,
OpenExr,
Farbfeld,
Avif,
Qoi,
}
Expand description
An enumeration of supported image formats. Not all formats support both encoding and decoding.
Variants (Non-exhaustive)§
This enum is marked as non-exhaustive
Png
An Image in PNG Format
Jpeg
An Image in JPEG Format
Gif
An Image in GIF Format
WebP
An Image in WEBP Format
Pnm
An Image in general PNM Format
Tiff
An Image in TIFF Format
Tga
An Image in TGA Format
Dds
An Image in DDS Format
Bmp
An Image in BMP Format
Ico
An Image in ICO Format
Hdr
An Image in Radiance HDR Format
OpenExr
An Image in OpenEXR Format
Farbfeld
An Image in farbfeld Format
Avif
An Image in AVIF format.
Qoi
An Image in QOI format.
Implementations§
source§impl ImageFormat
impl ImageFormat
sourcepub fn from_extension<S>(ext: S) -> Option<Self>
pub fn from_extension<S>(ext: S) -> Option<Self>
Return the image format specified by a path’s file extension.
§Example
use image::ImageFormat;
let format = ImageFormat::from_extension("jpg");
assert_eq!(format, Some(ImageFormat::Jpeg));
sourcepub fn from_path<P>(path: P) -> ImageResult<Self>
pub fn from_path<P>(path: P) -> ImageResult<Self>
Return the image format specified by the path’s file extension.
§Example
use image::ImageFormat;
let format = ImageFormat::from_path("images/ferris.png")?;
assert_eq!(format, ImageFormat::Png);
sourcepub fn from_mime_type<M>(mime_type: M) -> Option<Self>
pub fn from_mime_type<M>(mime_type: M) -> Option<Self>
Return the image format specified by a MIME type.
§Example
use image::ImageFormat;
let format = ImageFormat::from_mime_type("image/png").unwrap();
assert_eq!(format, ImageFormat::Png);
sourcepub fn to_mime_type(&self) -> &'static str
pub fn to_mime_type(&self) -> &'static str
Return the MIME type for this image format or “application/octet-stream” if no MIME type exists for the format.
Some notes on a few of the MIME types:
- The portable anymap format has a separate MIME type for the pixmap, graymap and bitmap formats, but this method returns the general “image/x-portable-anymap” MIME type.
- The Targa format has two common MIME types, “image/x-targa” and “image/x-tga”; this method returns “image/x-targa” for that format.
- The QOI MIME type is still a work in progress. This method returns “image/x-qoi” for that format.
§Example
use image::ImageFormat;
let mime_type = ImageFormat::Png.to_mime_type();
assert_eq!(mime_type, "image/png");
sourcepub fn extensions_str(self) -> &'static [&'static str]
pub fn extensions_str(self) -> &'static [&'static str]
Return a list of applicable extensions for this format.
All currently recognized image formats specify at least on extension but for future compatibility you should not rely on this fact. The list may be empty if the format has no recognized file representation, for example in case it is used as a purely transient memory format.
The method name extensions
remains reserved for introducing another method in the future
that yields a slice of OsStr
which is blocked by several features of const evaluation.
sourcepub fn reading_enabled(&self) -> bool
pub fn reading_enabled(&self) -> bool
Return the ImageFormats which are enabled for reading.
sourcepub fn writing_enabled(&self) -> bool
pub fn writing_enabled(&self) -> bool
Return the ImageFormats which are enabled for writing.
sourcepub fn all() -> impl Iterator<Item = ImageFormat>
pub fn all() -> impl Iterator<Item = ImageFormat>
Return all ImageFormats
Trait Implementations§
source§impl Clone for ImageFormat
impl Clone for ImageFormat
source§fn clone(&self) -> ImageFormat
fn clone(&self) -> ImageFormat
1.0.0 · source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source
. Read moresource§impl Debug for ImageFormat
impl Debug for ImageFormat
source§impl From<ImageFormat> for ImageFormatHint
impl From<ImageFormat> for ImageFormatHint
source§fn from(format: ImageFormat) -> Self
fn from(format: ImageFormat) -> Self
source§impl From<ImageFormat> for ImageOutputFormat
impl From<ImageFormat> for ImageOutputFormat
source§fn from(fmt: ImageFormat) -> Self
fn from(fmt: ImageFormat) -> Self
source§impl Hash for ImageFormat
impl Hash for ImageFormat
source§impl PartialEq for ImageFormat
impl PartialEq for ImageFormat
impl Copy for ImageFormat
impl Eq for ImageFormat
impl StructuralPartialEq for ImageFormat
Auto Trait Implementations§
impl Freeze for ImageFormat
impl RefUnwindSafe for ImageFormat
impl Send for ImageFormat
impl Sync for ImageFormat
impl Unpin for ImageFormat
impl UnwindSafe for ImageFormat
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> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
source§unsafe fn clone_to_uninit(&self, dst: *mut T)
unsafe fn clone_to_uninit(&self, dst: *mut T)
clone_to_uninit
)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 more