#[repr(C)]pub enum TextureFormat {
Show 76 variants
    R8Unorm,
    R8Snorm,
    R8Uint,
    R8Sint,
    R16Uint,
    R16Sint,
    R16Unorm,
    R16Snorm,
    R16Float,
    Rg8Unorm,
    Rg8Snorm,
    Rg8Uint,
    Rg8Sint,
    R32Uint,
    R32Sint,
    R32Float,
    Rg16Uint,
    Rg16Sint,
    Rg16Unorm,
    Rg16Snorm,
    Rg16Float,
    Rgba8Unorm,
    Rgba8UnormSrgb,
    Rgba8Snorm,
    Rgba8Uint,
    Rgba8Sint,
    Bgra8Unorm,
    Bgra8UnormSrgb,
    Rgb9e5Ufloat,
    Rgb10a2Uint,
    Rgb10a2Unorm,
    Rg11b10Ufloat,
    R64Uint,
    Rg32Uint,
    Rg32Sint,
    Rg32Float,
    Rgba16Uint,
    Rgba16Sint,
    Rgba16Unorm,
    Rgba16Snorm,
    Rgba16Float,
    Rgba32Uint,
    Rgba32Sint,
    Rgba32Float,
    Stencil8,
    Depth16Unorm,
    Depth24Plus,
    Depth24PlusStencil8,
    Depth32Float,
    Depth32FloatStencil8,
    NV12,
    Bc1RgbaUnorm,
    Bc1RgbaUnormSrgb,
    Bc2RgbaUnorm,
    Bc2RgbaUnormSrgb,
    Bc3RgbaUnorm,
    Bc3RgbaUnormSrgb,
    Bc4RUnorm,
    Bc4RSnorm,
    Bc5RgUnorm,
    Bc5RgSnorm,
    Bc6hRgbUfloat,
    Bc6hRgbFloat,
    Bc7RgbaUnorm,
    Bc7RgbaUnormSrgb,
    Etc2Rgb8Unorm,
    Etc2Rgb8UnormSrgb,
    Etc2Rgb8A1Unorm,
    Etc2Rgb8A1UnormSrgb,
    Etc2Rgba8Unorm,
    Etc2Rgba8UnormSrgb,
    EacR11Unorm,
    EacR11Snorm,
    EacRg11Unorm,
    EacRg11Snorm,
    Astc {
        block: AstcBlock,
        channel: AstcChannel,
    },
}Expand description
Format in which a texture’s texels are stored in GPU memory.
Certain formats additionally specify a conversion. When these formats are used in a shader, the conversion automatically takes place when loading from or storing to the texture.
- Unormformats linearly scale the integer range of the storage format to a floating-point range of 0 to 1, inclusive.
- Snormformats linearly scale the integer range of the storage format to a floating-point range of −1 to 1, inclusive, except that the most negative value (−128 for 8-bit, −32768 for 16-bit) is excluded; on conversion, it is treated as identical to the second most negative (−127 for 8-bit, −32767 for 16-bit), so that the positive and negative ranges are symmetric.
- UnormSrgbformats apply the sRGB transfer function so that the storage is sRGB encoded while the shader works with linear intensity values.
- Uint,- Sint, and- Floatformats perform no conversion.
Corresponds to WebGPU GPUTextureFormat.
Variants§
R8Unorm
Red channel only. 8 bit integer per channel. [0, 255] converted to/from float [0, 1] in shader.
R8Snorm
Red channel only. 8 bit integer per channel. [−127, 127] converted to/from float [−1, 1] in shader.
R8Uint
Red channel only. 8 bit integer per channel. Unsigned in shader.
R8Sint
Red channel only. 8 bit integer per channel. Signed in shader.
R16Uint
Red channel only. 16 bit integer per channel. Unsigned in shader.
R16Sint
Red channel only. 16 bit integer per channel. Signed in shader.
R16Unorm
Red channel only. 16 bit integer per channel. [0, 65535] converted to/from float [0, 1] in shader.
Features::TEXTURE_FORMAT_16BIT_NORM must be enabled to use this texture format.
R16Snorm
Red channel only. 16 bit integer per channel. [−32767, 32767] converted to/from float [−1, 1] in shader.
Features::TEXTURE_FORMAT_16BIT_NORM must be enabled to use this texture format.
R16Float
Red channel only. 16 bit float per channel. Float in shader.
Rg8Unorm
Red and green channels. 8 bit integer per channel. [0, 255] converted to/from float [0, 1] in shader.
Rg8Snorm
Red and green channels. 8 bit integer per channel. [−127, 127] converted to/from float [−1, 1] in shader.
Rg8Uint
Red and green channels. 8 bit integer per channel. Unsigned in shader.
Rg8Sint
Red and green channels. 8 bit integer per channel. Signed in shader.
R32Uint
Red channel only. 32 bit integer per channel. Unsigned in shader.
R32Sint
Red channel only. 32 bit integer per channel. Signed in shader.
R32Float
Red channel only. 32 bit float per channel. Float in shader.
Rg16Uint
Red and green channels. 16 bit integer per channel. Unsigned in shader.
Rg16Sint
Red and green channels. 16 bit integer per channel. Signed in shader.
Rg16Unorm
Red and green channels. 16 bit integer per channel. [0, 65535] converted to/from float [0, 1] in shader.
Features::TEXTURE_FORMAT_16BIT_NORM must be enabled to use this texture format.
Rg16Snorm
Red and green channels. 16 bit integer per channel. [−32767, 32767] converted to/from float [−1, 1] in shader.
Features::TEXTURE_FORMAT_16BIT_NORM must be enabled to use this texture format.
Rg16Float
Red and green channels. 16 bit float per channel. Float in shader.
Rgba8Unorm
Red, green, blue, and alpha channels. 8 bit integer per channel. [0, 255] converted to/from float [0, 1] in shader.
Rgba8UnormSrgb
Red, green, blue, and alpha channels. 8 bit integer per channel. Srgb-color [0, 255] converted to/from linear-color float [0, 1] in shader.
Rgba8Snorm
Red, green, blue, and alpha channels. 8 bit integer per channel. [−127, 127] converted to/from float [−1, 1] in shader.
Rgba8Uint
Red, green, blue, and alpha channels. 8 bit integer per channel. Unsigned in shader.
Rgba8Sint
Red, green, blue, and alpha channels. 8 bit integer per channel. Signed in shader.
Bgra8Unorm
Blue, green, red, and alpha channels. 8 bit integer per channel. [0, 255] converted to/from float [0, 1] in shader.
Bgra8UnormSrgb
Blue, green, red, and alpha channels. 8 bit integer per channel. Srgb-color [0, 255] converted to/from linear-color float [0, 1] in shader.
Rgb9e5Ufloat
Packed unsigned float with 9 bits mantisa for each RGB component, then a common 5 bits exponent
Rgb10a2Uint
Red, green, blue, and alpha channels. 10 bit integer for RGB channels, 2 bit integer for alpha channel. Unsigned in shader.
Rgb10a2Unorm
Red, green, blue, and alpha channels. 10 bit integer for RGB channels, 2 bit integer for alpha channel. [0, 1023] ([0, 3] for alpha) converted to/from float [0, 1] in shader.
Rg11b10Ufloat
Red, green, and blue channels. 11 bit float with no sign bit for RG channels. 10 bit float with no sign bit for blue channel. Float in shader.
R64Uint
Red channel only. 64 bit integer per channel. Unsigned in shader.
Features::TEXTURE_INT64_ATOMIC must be enabled to use this texture format.
Rg32Uint
Red and green channels. 32 bit integer per channel. Unsigned in shader.
Rg32Sint
Red and green channels. 32 bit integer per channel. Signed in shader.
Rg32Float
Red and green channels. 32 bit float per channel. Float in shader.
Rgba16Uint
Red, green, blue, and alpha channels. 16 bit integer per channel. Unsigned in shader.
Rgba16Sint
Red, green, blue, and alpha channels. 16 bit integer per channel. Signed in shader.
Rgba16Unorm
Red, green, blue, and alpha channels. 16 bit integer per channel. [0, 65535] converted to/from float [0, 1] in shader.
Features::TEXTURE_FORMAT_16BIT_NORM must be enabled to use this texture format.
Rgba16Snorm
Red, green, blue, and alpha. 16 bit integer per channel. [−32767, 32767] converted to/from float [−1, 1] in shader.
Features::TEXTURE_FORMAT_16BIT_NORM must be enabled to use this texture format.
Rgba16Float
Red, green, blue, and alpha channels. 16 bit float per channel. Float in shader.
Rgba32Uint
Red, green, blue, and alpha channels. 32 bit integer per channel. Unsigned in shader.
Rgba32Sint
Red, green, blue, and alpha channels. 32 bit integer per channel. Signed in shader.
Rgba32Float
Red, green, blue, and alpha channels. 32 bit float per channel. Float in shader.
Stencil8
Stencil format with 8 bit integer stencil.
Depth16Unorm
Special depth format with 16 bit integer depth.
Depth24Plus
Special depth format with at least 24 bit integer depth.
Depth24PlusStencil8
Special depth/stencil format with at least 24 bit integer depth and 8 bits integer stencil.
Depth32Float
Special depth format with 32 bit floating point depth.
Depth32FloatStencil8
Special depth/stencil format with 32 bit floating point depth and 8 bits integer stencil.
Features::DEPTH32FLOAT_STENCIL8 must be enabled to use this texture format.
NV12
YUV 4:2:0 chroma subsampled format.
Contains two planes:
- 0: Single 8 bit channel luminance.
- 1: Dual 8 bit channel chrominance at half width and half height.
Valid view formats for luminance are TextureFormat::R8Unorm.
Valid view formats for chrominance are TextureFormat::Rg8Unorm.
Width and height must be even.
Features::TEXTURE_FORMAT_NV12 must be enabled to use this texture format.
Bc1RgbaUnorm
4x4 block compressed texture. 8 bytes per block (4 bit/px). 4 color + alpha pallet. 5 bit R + 6 bit G + 5 bit B + 1 bit alpha. [0, 63] ([0, 1] for alpha) converted to/from float [0, 1] in shader.
Also known as DXT1.
Features::TEXTURE_COMPRESSION_BC must be enabled to use this texture format.
Features::TEXTURE_COMPRESSION_BC_SLICED_3D must be enabled to use this texture format with 3D dimension.
Bc1RgbaUnormSrgb
4x4 block compressed texture. 8 bytes per block (4 bit/px). 4 color + alpha pallet. 5 bit R + 6 bit G + 5 bit B + 1 bit alpha. Srgb-color [0, 63] ([0, 1] for alpha) converted to/from linear-color float [0, 1] in shader.
Also known as DXT1.
Features::TEXTURE_COMPRESSION_BC must be enabled to use this texture format.
Features::TEXTURE_COMPRESSION_BC_SLICED_3D must be enabled to use this texture format with 3D dimension.
Bc2RgbaUnorm
4x4 block compressed texture. 16 bytes per block (8 bit/px). 4 color pallet. 5 bit R + 6 bit G + 5 bit B + 4 bit alpha. [0, 63] ([0, 15] for alpha) converted to/from float [0, 1] in shader.
Also known as DXT3.
Features::TEXTURE_COMPRESSION_BC must be enabled to use this texture format.
Features::TEXTURE_COMPRESSION_BC_SLICED_3D must be enabled to use this texture format with 3D dimension.
Bc2RgbaUnormSrgb
4x4 block compressed texture. 16 bytes per block (8 bit/px). 4 color pallet. 5 bit R + 6 bit G + 5 bit B + 4 bit alpha. Srgb-color [0, 63] ([0, 255] for alpha) converted to/from linear-color float [0, 1] in shader.
Also known as DXT3.
Features::TEXTURE_COMPRESSION_BC must be enabled to use this texture format.
Features::TEXTURE_COMPRESSION_BC_SLICED_3D must be enabled to use this texture format with 3D dimension.
Bc3RgbaUnorm
4x4 block compressed texture. 16 bytes per block (8 bit/px). 4 color pallet + 8 alpha pallet. 5 bit R + 6 bit G + 5 bit B + 8 bit alpha. [0, 63] ([0, 255] for alpha) converted to/from float [0, 1] in shader.
Also known as DXT5.
Features::TEXTURE_COMPRESSION_BC must be enabled to use this texture format.
Features::TEXTURE_COMPRESSION_BC_SLICED_3D must be enabled to use this texture format with 3D dimension.
Bc3RgbaUnormSrgb
4x4 block compressed texture. 16 bytes per block (8 bit/px). 4 color pallet + 8 alpha pallet. 5 bit R + 6 bit G + 5 bit B + 8 bit alpha. Srgb-color [0, 63] ([0, 255] for alpha) converted to/from linear-color float [0, 1] in shader.
Also known as DXT5.
Features::TEXTURE_COMPRESSION_BC must be enabled to use this texture format.
Features::TEXTURE_COMPRESSION_BC_SLICED_3D must be enabled to use this texture format with 3D dimension.
Bc4RUnorm
4x4 block compressed texture. 8 bytes per block (4 bit/px). 8 color pallet. 8 bit R. [0, 255] converted to/from float [0, 1] in shader.
Also known as RGTC1.
Features::TEXTURE_COMPRESSION_BC must be enabled to use this texture format.
Features::TEXTURE_COMPRESSION_BC_SLICED_3D must be enabled to use this texture format with 3D dimension.
Bc4RSnorm
4x4 block compressed texture. 8 bytes per block (4 bit/px). 8 color pallet. 8 bit R. [−127, 127] converted to/from float [−1, 1] in shader.
Also known as RGTC1.
Features::TEXTURE_COMPRESSION_BC must be enabled to use this texture format.
Features::TEXTURE_COMPRESSION_BC_SLICED_3D must be enabled to use this texture format with 3D dimension.
Bc5RgUnorm
4x4 block compressed texture. 16 bytes per block (8 bit/px). 8 color red pallet + 8 color green pallet. 8 bit RG. [0, 255] converted to/from float [0, 1] in shader.
Also known as RGTC2.
Features::TEXTURE_COMPRESSION_BC must be enabled to use this texture format.
Features::TEXTURE_COMPRESSION_BC_SLICED_3D must be enabled to use this texture format with 3D dimension.
Bc5RgSnorm
4x4 block compressed texture. 16 bytes per block (8 bit/px). 8 color red pallet + 8 color green pallet. 8 bit RG. [−127, 127] converted to/from float [−1, 1] in shader.
Also known as RGTC2.
Features::TEXTURE_COMPRESSION_BC must be enabled to use this texture format.
Features::TEXTURE_COMPRESSION_BC_SLICED_3D must be enabled to use this texture format with 3D dimension.
Bc6hRgbUfloat
4x4 block compressed texture. 16 bytes per block (8 bit/px). Variable sized pallet. 16 bit unsigned float RGB. Float in shader.
Also known as BPTC (float).
Features::TEXTURE_COMPRESSION_BC must be enabled to use this texture format.
Features::TEXTURE_COMPRESSION_BC_SLICED_3D must be enabled to use this texture format with 3D dimension.
Bc6hRgbFloat
4x4 block compressed texture. 16 bytes per block (8 bit/px). Variable sized pallet. 16 bit signed float RGB. Float in shader.
Also known as BPTC (float).
Features::TEXTURE_COMPRESSION_BC must be enabled to use this texture format.
Features::TEXTURE_COMPRESSION_BC_SLICED_3D must be enabled to use this texture format with 3D dimension.
Bc7RgbaUnorm
4x4 block compressed texture. 16 bytes per block (8 bit/px). Variable sized pallet. 8 bit integer RGBA. [0, 255] converted to/from float [0, 1] in shader.
Also known as BPTC (unorm).
Features::TEXTURE_COMPRESSION_BC must be enabled to use this texture format.
Features::TEXTURE_COMPRESSION_BC_SLICED_3D must be enabled to use this texture format with 3D dimension.
Bc7RgbaUnormSrgb
4x4 block compressed texture. 16 bytes per block (8 bit/px). Variable sized pallet. 8 bit integer RGBA. Srgb-color [0, 255] converted to/from linear-color float [0, 1] in shader.
Also known as BPTC (unorm).
Features::TEXTURE_COMPRESSION_BC must be enabled to use this texture format.
Features::TEXTURE_COMPRESSION_BC_SLICED_3D must be enabled to use this texture format with 3D dimension.
Etc2Rgb8Unorm
4x4 block compressed texture. 8 bytes per block (4 bit/px). Complex pallet. 8 bit integer RGB. [0, 255] converted to/from float [0, 1] in shader.
Features::TEXTURE_COMPRESSION_ETC2 must be enabled to use this texture format.
Etc2Rgb8UnormSrgb
4x4 block compressed texture. 8 bytes per block (4 bit/px). Complex pallet. 8 bit integer RGB. Srgb-color [0, 255] converted to/from linear-color float [0, 1] in shader.
Features::TEXTURE_COMPRESSION_ETC2 must be enabled to use this texture format.
Etc2Rgb8A1Unorm
4x4 block compressed texture. 8 bytes per block (4 bit/px). Complex pallet. 8 bit integer RGB + 1 bit alpha. [0, 255] ([0, 1] for alpha) converted to/from float [0, 1] in shader.
Features::TEXTURE_COMPRESSION_ETC2 must be enabled to use this texture format.
Etc2Rgb8A1UnormSrgb
4x4 block compressed texture. 8 bytes per block (4 bit/px). Complex pallet. 8 bit integer RGB + 1 bit alpha. Srgb-color [0, 255] ([0, 1] for alpha) converted to/from linear-color float [0, 1] in shader.
Features::TEXTURE_COMPRESSION_ETC2 must be enabled to use this texture format.
Etc2Rgba8Unorm
4x4 block compressed texture. 16 bytes per block (8 bit/px). Complex pallet. 8 bit integer RGB + 8 bit alpha. [0, 255] converted to/from float [0, 1] in shader.
Features::TEXTURE_COMPRESSION_ETC2 must be enabled to use this texture format.
Etc2Rgba8UnormSrgb
4x4 block compressed texture. 16 bytes per block (8 bit/px). Complex pallet. 8 bit integer RGB + 8 bit alpha. Srgb-color [0, 255] converted to/from linear-color float [0, 1] in shader.
Features::TEXTURE_COMPRESSION_ETC2 must be enabled to use this texture format.
EacR11Unorm
4x4 block compressed texture. 8 bytes per block (4 bit/px). Complex pallet. 11 bit integer R. [0, 255] converted to/from float [0, 1] in shader.
Features::TEXTURE_COMPRESSION_ETC2 must be enabled to use this texture format.
EacR11Snorm
4x4 block compressed texture. 8 bytes per block (4 bit/px). Complex pallet. 11 bit integer R. [−127, 127] converted to/from float [−1, 1] in shader.
Features::TEXTURE_COMPRESSION_ETC2 must be enabled to use this texture format.
EacRg11Unorm
4x4 block compressed texture. 16 bytes per block (8 bit/px). Complex pallet. 11 bit integer R + 11 bit integer G. [0, 255] converted to/from float [0, 1] in shader.
Features::TEXTURE_COMPRESSION_ETC2 must be enabled to use this texture format.
EacRg11Snorm
4x4 block compressed texture. 16 bytes per block (8 bit/px). Complex pallet. 11 bit integer R + 11 bit integer G. [−127, 127] converted to/from float [−1, 1] in shader.
Features::TEXTURE_COMPRESSION_ETC2 must be enabled to use this texture format.
Astc
block compressed texture. 16 bytes per block.
Features TEXTURE_COMPRESSION_ASTC or TEXTURE_COMPRESSION_ASTC_HDR
must be enabled to use this texture format.
Implementations§
Source§impl TextureFormat
 
impl TextureFormat
Sourcepub const MAX_TARGET_PIXEL_BYTE_COST: u32 = 16u32
 
pub const MAX_TARGET_PIXEL_BYTE_COST: u32 = 16u32
The largest number that can be returned by Self::target_pixel_byte_cost.
Sourcepub fn aspect_specific_format(
    &self,
    aspect: TextureAspect,
) -> Option<TextureFormat>
 
pub fn aspect_specific_format( &self, aspect: TextureAspect, ) -> Option<TextureFormat>
Returns the aspect-specific format of the original format
see https://gpuweb.github.io/gpuweb/#abstract-opdef-resolving-gputextureaspect
Sourcepub fn is_depth_stencil_component(&self, combined_format: TextureFormat) -> bool
 
pub fn is_depth_stencil_component(&self, combined_format: TextureFormat) -> bool
Returns true if self is a depth or stencil component of the given
combined depth-stencil format
Sourcepub fn is_depth_stencil_format(&self) -> bool
 
pub fn is_depth_stencil_format(&self) -> bool
Returns true if the format is a depth and/or stencil format
Sourcepub fn is_combined_depth_stencil_format(&self) -> bool
 
pub fn is_combined_depth_stencil_format(&self) -> bool
Returns true if the format is a combined depth-stencil format
see https://gpuweb.github.io/gpuweb/#combined-depth-stencil-format
Sourcepub fn is_multi_planar_format(&self) -> bool
 
pub fn is_multi_planar_format(&self) -> bool
Returns true if the format is a multi-planar format
Sourcepub fn has_color_aspect(&self) -> bool
 
pub fn has_color_aspect(&self) -> bool
Returns true if the format has a color aspect
Sourcepub fn has_depth_aspect(&self) -> bool
 
pub fn has_depth_aspect(&self) -> bool
Returns true if the format has a depth aspect
Sourcepub fn has_stencil_aspect(&self) -> bool
 
pub fn has_stencil_aspect(&self) -> bool
Returns true if the format has a stencil aspect
Sourcepub fn size_multiple_requirement(&self) -> (u32, u32)
 
pub fn size_multiple_requirement(&self) -> (u32, u32)
Returns the size multiple requirement for a texture using this format.
Sourcepub fn block_dimensions(&self) -> (u32, u32)
 
pub fn block_dimensions(&self) -> (u32, u32)
Returns the dimension of a block of texels.
Uncompressed formats have a block dimension of (1, 1).
Sourcepub fn is_compressed(&self) -> bool
 
pub fn is_compressed(&self) -> bool
Returns true for compressed formats.
Sourcepub fn required_features(&self) -> Features
 
pub fn required_features(&self) -> Features
Returns the required features (if any) in order to use the texture.
Sourcepub fn guaranteed_format_features(
    &self,
    device_features: Features,
) -> TextureFormatFeatures
 
pub fn guaranteed_format_features( &self, device_features: Features, ) -> TextureFormatFeatures
Returns the format features guaranteed by the WebGPU spec.
Additional features are available if Features::TEXTURE_ADAPTER_SPECIFIC_FORMAT_FEATURES is enabled.
Sourcepub fn sample_type(
    &self,
    aspect: Option<TextureAspect>,
    device_features: Option<Features>,
) -> Option<TextureSampleType>
 
pub fn sample_type( &self, aspect: Option<TextureAspect>, device_features: Option<Features>, ) -> Option<TextureSampleType>
Returns the sample type compatible with this format and aspect.
Returns None only if this is a combined depth-stencil format or a multi-planar format
and TextureAspect::All or no aspect was provided.
Sourcepub fn block_size(&self, aspect: Option<TextureAspect>) -> Option<u32>
 👎Deprecated since 0.19.0: Use block_copy_size instead.
pub fn block_size(&self, aspect: Option<TextureAspect>) -> Option<u32>
block_copy_size instead.The number of bytes one texel block occupies during an image copy, if applicable.
Known as the texel block copy footprint.
Note that for uncompressed formats this is the same as the size of a single texel, since uncompressed formats have a block size of 1x1.
Returns None if any of the following are true:
- the format is a combined depth-stencil and no aspectwas provided
- the format is a multi-planar format and no aspectwas provided
- the format is Depth24Plus
- the format is Depth24PlusStencil8andaspectis depth.
Sourcepub fn block_copy_size(&self, aspect: Option<TextureAspect>) -> Option<u32>
 
pub fn block_copy_size(&self, aspect: Option<TextureAspect>) -> Option<u32>
The number of bytes one texel block occupies during an image copy, if applicable.
Known as the texel block copy footprint.
Note that for uncompressed formats this is the same as the size of a single texel, since uncompressed formats have a block size of 1x1.
Returns None if any of the following are true:
- the format is a combined depth-stencil and no aspectwas provided
- the format is a multi-planar format and no aspectwas provided
- the format is Depth24Plus
- the format is Depth24PlusStencil8andaspectis depth.
Sourcepub fn target_pixel_byte_cost(&self) -> Option<u32>
 
pub fn target_pixel_byte_cost(&self) -> Option<u32>
The number of bytes occupied per pixel in a color attachment https://gpuweb.github.io/gpuweb/#render-target-pixel-byte-cost
Sourcepub fn target_component_alignment(&self) -> Option<u32>
 
pub fn target_component_alignment(&self) -> Option<u32>
Sourcepub fn components(&self) -> u8
 
pub fn components(&self) -> u8
Returns the number of components this format has.
Sourcepub fn components_with_aspect(&self, aspect: TextureAspect) -> u8
 
pub fn components_with_aspect(&self, aspect: TextureAspect) -> u8
Returns the number of components this format has taking into account the aspect.
The aspect is only relevant for combined depth-stencil formats and multi-planar formats.
Sourcepub fn remove_srgb_suffix(&self) -> TextureFormat
 
pub fn remove_srgb_suffix(&self) -> TextureFormat
Strips the Srgb suffix from the given texture format.
Sourcepub fn add_srgb_suffix(&self) -> TextureFormat
 
pub fn add_srgb_suffix(&self) -> TextureFormat
Adds an Srgb suffix to the given texture format, if the format supports it.
Sourcepub fn theoretical_memory_footprint(&self, size: Extent3d) -> u64
 
pub fn theoretical_memory_footprint(&self, size: Extent3d) -> u64
Returns the theoretical memory footprint of a texture with the given format and dimensions.
Actual memory usage may greatly exceed this value due to alignment and padding.
Trait Implementations§
Source§impl BevyDefault for TextureFormat
 
impl BevyDefault for TextureFormat
Source§fn bevy_default() -> TextureFormat
 
fn bevy_default() -> TextureFormat
Source§impl Clone for TextureFormat
 
impl Clone for TextureFormat
Source§fn clone(&self) -> TextureFormat
 
fn clone(&self) -> TextureFormat
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
 
fn clone_from(&mut self, source: &Self)
source. Read moreSource§impl Debug for TextureFormat
 
impl Debug for TextureFormat
Source§impl From<TextureFormat> for ColorTargetState
 
impl From<TextureFormat> for ColorTargetState
Source§fn from(format: TextureFormat) -> ColorTargetState
 
fn from(format: TextureFormat) -> ColorTargetState
Source§impl Hash for TextureFormat
 
impl Hash for TextureFormat
Source§impl PartialEq for TextureFormat
 
impl PartialEq for TextureFormat
Source§impl TextureFormatExt for TextureFormat
 
impl TextureFormatExt for TextureFormat
Source§fn from_storage_format(storage_format: StorageFormat) -> TextureFormat
 
fn from_storage_format(storage_format: StorageFormat) -> TextureFormat
Source§fn to_storage_format(&self) -> Option<StorageFormat>
 
fn to_storage_format(&self) -> Option<StorageFormat>
StorageFormat corresponding to the given TextureFormat.
Returns None if there is no matching storage format,
which typically indicates this format is not supported
for storage textures. Read moreSource§impl TextureFormatPixelInfo for TextureFormat
 
impl TextureFormatPixelInfo for TextureFormat
Source§fn pixel_size(&self) -> Result<usize, TextureAccessError>
 
fn pixel_size(&self) -> Result<usize, TextureAccessError>
TextureAccessError::UnsupportedTextureFormat if the format is compressed.impl Copy for TextureFormat
impl Eq for TextureFormat
impl StructuralPartialEq for TextureFormat
Auto Trait Implementations§
impl Freeze for TextureFormat
impl RefUnwindSafe for TextureFormat
impl Send for TextureFormat
impl Sync for TextureFormat
impl Unpin for TextureFormat
impl UnwindSafe for TextureFormat
Blanket Implementations§
Source§impl<T, U> AsBindGroupShaderType<U> for T
 
impl<T, U> AsBindGroupShaderType<U> for T
Source§fn as_bind_group_shader_type(&self, _images: &RenderAssets<GpuImage>) -> U
 
fn as_bind_group_shader_type(&self, _images: &RenderAssets<GpuImage>) -> U
T ShaderType for self. When used in AsBindGroup
derives, it is safe to assume that all images in self exist.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§impl<T> Downcast for Twhere
    T: Any,
 
impl<T> Downcast for Twhere
    T: Any,
Source§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>, which can then be
downcast into Box<dyn ConcreteType> where ConcreteType implements Trait.Source§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>, which can then be further
downcast into Rc<ConcreteType> where ConcreteType implements Trait.Source§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.Source§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.Source§impl<T> DowncastSend for T
 
impl<T> DowncastSend for T
Source§impl<T> DowncastSync for T
 
impl<T> DowncastSync for T
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.Source§impl<T, W> HasTypeWitness<W> for Twhere
    W: MakeTypeWitness<Arg = T>,
    T: ?Sized,
 
impl<T, W> HasTypeWitness<W> for Twhere
    W: MakeTypeWitness<Arg = T>,
    T: ?Sized,
Source§impl<T> Identity for Twhere
    T: ?Sized,
 
impl<T> Identity for Twhere
    T: ?Sized,
Source§impl<T> Instrument for T
 
impl<T> Instrument for T
Source§fn instrument(self, span: Span) -> Instrumented<Self>
 
fn instrument(self, span: Span) -> Instrumented<Self>
Source§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 more