Enum rerun::external::image::ImageFormat
#[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§
§impl ImageFormat
impl ImageFormat
pub fn from_extension<S>(ext: S) -> Option<ImageFormat>
pub fn from_extension<S>(ext: S) -> Option<ImageFormat>
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));
pub fn from_path<P>(path: P) -> Result<ImageFormat, ImageError>
pub fn from_path<P>(path: P) -> Result<ImageFormat, ImageError>
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);
pub fn from_mime_type<M>(mime_type: M) -> Option<ImageFormat>
pub fn from_mime_type<M>(mime_type: M) -> Option<ImageFormat>
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);
pub 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");
pub 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.
pub fn reading_enabled(&self) -> bool
pub fn reading_enabled(&self) -> bool
Return the ImageFormat
s which are enabled for reading.
pub fn writing_enabled(&self) -> bool
pub fn writing_enabled(&self) -> bool
Return the ImageFormat
s which are enabled for writing.
pub fn all() -> impl Iterator<Item = ImageFormat>
pub fn all() -> impl Iterator<Item = ImageFormat>
Return all ImageFormat
s
Trait Implementations§
§impl Clone for ImageFormat
impl Clone for ImageFormat
§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 more§impl Debug for ImageFormat
impl Debug for ImageFormat
§impl From<ImageFormat> for ImageFormatHint
impl From<ImageFormat> for ImageFormatHint
§fn from(format: ImageFormat) -> ImageFormatHint
fn from(format: ImageFormat) -> ImageFormatHint
§impl Hash for ImageFormat
impl Hash for ImageFormat
§impl PartialEq for ImageFormat
impl PartialEq for ImageFormat
§fn eq(&self, other: &ImageFormat) -> bool
fn eq(&self, other: &ImageFormat) -> bool
self
and other
values to be equal, and is used
by ==
.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> 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<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
key
and return true
if they are equal.source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
source§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
key
and return true
if they are equal.§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