pub struct TextureManager2D {
white_texture_unorm: GpuTexture2D,
zeroed_texture_float: GpuTexture2D,
zeroed_texture_sint: GpuTexture2D,
zeroed_texture_uint: GpuTexture2D,
inner: Mutex<Inner>,
}
Expand description
Texture manager for 2D textures.
The scope is intentionally limited to particular kinds of textures that currently require this kind of handle abstraction/management. More complex textures types are typically handled within renderer which utilize the texture pool directly. This manager in contrast, deals with user provided texture data! We might revisit this later and make this texture manager more general purpose.
Has intertior mutability.
Fields§
§white_texture_unorm: GpuTexture2D
§zeroed_texture_float: GpuTexture2D
§zeroed_texture_sint: GpuTexture2D
§zeroed_texture_uint: GpuTexture2D
§inner: Mutex<Inner>
The mutable part of the manager.
Implementations§
source§impl TextureManager2D
impl TextureManager2D
pub(crate) fn new( device: &Device, queue: &Queue, texture_pool: &GpuTexturePool ) -> Self
sourcepub fn create(
&self,
render_ctx: &RenderContext,
creation_desc: ImageDataDesc<'_>
) -> Result<GpuTexture2D, ImageDataToTextureError>
pub fn create( &self, render_ctx: &RenderContext, creation_desc: ImageDataDesc<'_> ) -> Result<GpuTexture2D, ImageDataToTextureError>
Creates a new 2D texture resource and schedules data upload to the GPU.
TODO(jleibs): All usages of this should be replaced with get_or_create
, which is strictly preferable
sourcepub fn get_or_create(
&self,
key: u64,
render_ctx: &RenderContext,
texture_desc: ImageDataDesc<'_>
) -> Result<GpuTexture2D, ImageDataToTextureError>
pub fn get_or_create( &self, key: u64, render_ctx: &RenderContext, texture_desc: ImageDataDesc<'_> ) -> Result<GpuTexture2D, ImageDataToTextureError>
Creates a new 2D texture resource and schedules data upload to the GPU if a texture wasn’t already created using the same key.
sourcepub fn get_or_create_with<'a>(
&self,
key: u64,
render_ctx: &RenderContext,
create_texture_desc: impl FnOnce() -> ImageDataDesc<'a>
) -> Result<GpuTexture2D, ImageDataToTextureError>
pub fn get_or_create_with<'a>( &self, key: u64, render_ctx: &RenderContext, create_texture_desc: impl FnOnce() -> ImageDataDesc<'a> ) -> Result<GpuTexture2D, ImageDataToTextureError>
Creates a new 2D texture resource and schedules data upload to the GPU if a texture wasn’t already created using the same key.
sourcepub fn get_or_try_create_with<'a, Err: Display>(
&self,
key: u64,
render_ctx: &RenderContext,
try_create_texture_desc: impl FnOnce() -> Result<ImageDataDesc<'a>, Err>
) -> Result<GpuTexture2D, TextureManager2DError<Err>>
pub fn get_or_try_create_with<'a, Err: Display>( &self, key: u64, render_ctx: &RenderContext, try_create_texture_desc: impl FnOnce() -> Result<ImageDataDesc<'a>, Err> ) -> Result<GpuTexture2D, TextureManager2DError<Err>>
Creates a new 2D texture resource and schedules data upload to the GPU if a texture wasn’t already created using the same key.
sourcepub fn white_texture_unorm_handle(&self) -> &GpuTexture2D
pub fn white_texture_unorm_handle(&self) -> &GpuTexture2D
Returns a single pixel white pixel with an rgba8unorm format.
sourcepub fn white_texture_unorm(
&self
) -> &Arc<DynamicResource<GpuTextureHandle, TextureDesc, GpuTextureInternal>>
pub fn white_texture_unorm( &self ) -> &Arc<DynamicResource<GpuTextureHandle, TextureDesc, GpuTextureInternal>>
Returns a single pixel white pixel with an rgba8unorm format.
sourcepub fn zeroed_texture_float(
&self
) -> &Arc<DynamicResource<GpuTextureHandle, TextureDesc, GpuTextureInternal>>
pub fn zeroed_texture_float( &self ) -> &Arc<DynamicResource<GpuTextureHandle, TextureDesc, GpuTextureInternal>>
Returns a single zero pixel with format [wgpu::TextureFormat::Rgba8Unorm
].
sourcepub fn zeroed_texture_sint(
&self
) -> &Arc<DynamicResource<GpuTextureHandle, TextureDesc, GpuTextureInternal>>
pub fn zeroed_texture_sint( &self ) -> &Arc<DynamicResource<GpuTextureHandle, TextureDesc, GpuTextureInternal>>
Returns a single zero pixel with format [wgpu::TextureFormat::Rgba8Sint
].
sourcepub fn zeroed_texture_uint(
&self
) -> &Arc<DynamicResource<GpuTextureHandle, TextureDesc, GpuTextureInternal>>
pub fn zeroed_texture_uint( &self ) -> &Arc<DynamicResource<GpuTextureHandle, TextureDesc, GpuTextureInternal>>
Returns a single zero pixel with format [wgpu::TextureFormat::Rgba8Uint
].
pub(crate) fn begin_frame(&self, _frame_index: u64)
Auto Trait Implementations§
impl !Freeze for TextureManager2D
impl !RefUnwindSafe for TextureManager2D
impl Send for TextureManager2D
impl Sync for TextureManager2D
impl Unpin for TextureManager2D
impl !UnwindSafe for TextureManager2D
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
§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 more