pub struct UniformBuffer<T: ShaderType> { /* private fields */ }
Expand description
Stores data to be transferred to the GPU and made accessible to shaders as a uniform buffer.
Uniform buffers are available to shaders on a read-only basis. Uniform buffers are commonly used to make available to shaders parameters that are constant during shader execution, and are best used for data that is relatively small in size as they are only guaranteed to support up to 16kB per binding.
The contained data is stored in system RAM. write_buffer
queues
copying of the data from system RAM to VRAM. Data in uniform buffers must follow std140 alignment/padding requirements,
which is automatically enforced by this structure. Per the WGPU spec, uniform buffers cannot store runtime-sized array
(vectors), or structures with fields that are vectors.
Other options for storing GPU-accessible data are:
Implementations§
source§impl<T: ShaderType + WriteInto> UniformBuffer<T>
impl<T: ShaderType + WriteInto> UniformBuffer<T>
pub fn buffer(&self) -> Option<&Buffer>
pub fn binding(&self) -> Option<BindingResource<'_>>
pub fn get(&self) -> &T
pub fn get_mut(&mut self) -> &mut T
pub fn set_label(&mut self, label: Option<&str>)
pub fn get_label(&self) -> Option<&str>
sourcepub fn add_usages(&mut self, usage: BufferUsages)
pub fn add_usages(&mut self, usage: BufferUsages)
Add more BufferUsages
to the buffer.
This method only allows addition of flags to the default usage flags.
The default values for buffer usage are BufferUsages::COPY_DST
and BufferUsages::UNIFORM
.
sourcepub fn write_buffer(&mut self, device: &RenderDevice, queue: &RenderQueue)
pub fn write_buffer(&mut self, device: &RenderDevice, queue: &RenderQueue)
Queues writing of data from system RAM to VRAM using the RenderDevice
and the provided RenderQueue
, if a GPU-side backing buffer already exists.
If a GPU-side buffer does not already exist for this data, such a buffer is initialized with currently available data.
Trait Implementations§
source§impl<T: ShaderType + Default> Default for UniformBuffer<T>
impl<T: ShaderType + Default> Default for UniformBuffer<T>
source§impl<T: ShaderType> From<T> for UniformBuffer<T>
impl<T: ShaderType> From<T> for UniformBuffer<T>
source§impl<'a, T: ShaderType + WriteInto> IntoBinding<'a> for &'a UniformBuffer<T>
impl<'a, T: ShaderType + WriteInto> IntoBinding<'a> for &'a UniformBuffer<T>
fn into_binding(self) -> BindingResource<'a>
Auto Trait Implementations§
impl<T> Freeze for UniformBuffer<T>where
T: Freeze,
impl<T> !RefUnwindSafe for UniformBuffer<T>
impl<T> Send for UniformBuffer<T>where
T: Send,
impl<T> Sync for UniformBuffer<T>where
T: Sync,
impl<T> Unpin for UniformBuffer<T>where
T: Unpin,
impl<T> !UnwindSafe for UniformBuffer<T>
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> 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>
. Box<dyn Any>
can
then be further downcast
into Box<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>
. Rc<Any>
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> DowncastSync for T
impl<T> DowncastSync for T
source§impl<T> FromWorld for Twhere
T: Default,
impl<T> FromWorld for Twhere
T: Default,
source§fn from_world(_world: &mut World) -> T
fn from_world(_world: &mut World) -> T
Creates Self
using default()
.
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