Struct demo_vk::graphics::BindlessTextureAtlas

source ·
pub struct BindlessTextureAtlas { /* private fields */ }
Expand description

Maintains descriptors for a list of texture images. Textures can be accessed by their index in shaders when the descriptor is bound. e.g. “bindless” textures.

The descriptor set provided by the atlas expects the following bindings in shader code for descriptor set 0:

  1. [vk_binding(0, 0)] SamplerState samplers[3];
  2. [vk_binding(1, 0)] texture2D textures[];

Samplers have the following properties (by index):

  1. samplers[0] - Linear filtering, linear mipmaps, no anisotropic filtering
  2. samplers[1] - Linear filtering, linear mipmaps, with anisotropic filtering
  3. samplers[2] - Nearest filtering, nearest mipmap, no anisotropic filtering

§Why Descriptor Set 0?

Because the BindlessTextureAtlas can be bound a single time at the beginning of the renderpass for the frame and ignored after that. If a higher index is used, then switching to different graphics pipelines could require rebinding.

This works only so long as any subsequently bound pipelines have a compatible layout (e.g. they use the BindlessTextureAtlas’s descriptor_set_layout as descriptor 0).

Implementations§

source§

impl BindlessTextureAtlas

source

pub fn new( ctx: Arc<VulkanContext>, max_textures: u32, frames_in_flight: &FramesInFlight, ) -> Result<Self>

Creates a new atlas that can hold up to max_textures total textures.

source

pub fn add_texture(&mut self, texture: Arc<Texture>) -> u32

Adds a texture to the atlas. The returned texture number can be used to index in to the textures array in a shader.

This function is safe to call at any time. The new texture will be available in the shader in the next frame.

source

pub fn descriptor_set_layout(&self) -> &DescriptorSetLayout

Borrows the descriptor set layout for the atlas. Useful when creating pipelines.

source

pub fn bind_frame_descriptor(&mut self, frame: &Frame) -> Result<()>

Binds the descriptor for the given frame.

Conditionally updates the descriptor if any new textures have been added since the last frame.

Auto Trait Implementations§

Blanket Implementations§

source§

impl<T> Any for T
where T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

impl<T> Borrow<T> for T
where T: ?Sized,

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<T, U> Into<U> for T
where U: From<T>,

source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

source§

impl<T> IntoEither for T

source§

fn into_either(self, into_left: bool) -> Either<Self, Self>

Converts 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 more
source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

Converts 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
source§

impl<T> Pointable for T

source§

const ALIGN: usize = _

The alignment of pointer.
source§

type Init = T

The type for initializers.
source§

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
source§

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
source§

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
source§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. Read more
source§

impl<T> Same for T

source§

type Output = T

Should always be Self
source§

impl<SS, SP> SupersetOf<SS> for SP
where SS: SubsetOf<SP>,

source§

fn to_subset(&self) -> Option<SS>

The inverse inclusion map: attempts to construct self from the equivalent element of its superset. Read more
source§

fn is_in_subset(&self) -> bool

Checks if self is actually part of its subset T (and can be converted to it).
source§

fn to_subset_unchecked(&self) -> SS

Use with care! Same as self.to_subset but without any property checks. Always succeeds.
source§

fn from_subset(element: &SS) -> SP

The inclusion map: converts self to the equivalent element of its superset.
source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

source§

type Error = Infallible

The type returned in the event of a conversion error.
source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.