pub struct VertexBufferAny { /* private fields */ }
Expand description

A list of vertices loaded in the graphics card’s memory.

Contrary to VertexBuffer, this struct doesn’t know about the type of data inside the buffer. Therefore you can’t map or read it.

This struct is provided for convenience, so that you can have a Vec<VertexBufferAny>, or return a VertexBufferAny instead of a VertexBuffer<MyPrivateVertexType>.

Implementations§

source§

impl VertexBufferAny

source

pub fn get_elements_size(&self) -> usize

Returns the number of bytes between two consecutive elements in the buffer.

source

pub fn len(&self) -> usize

Returns the number of elements in the buffer.

source

pub fn get_bindings(&self) -> &VertexFormat

Returns the associated VertexFormat.

source

pub unsafe fn into_vertex_buffer<T: Copy>(self) -> VertexBuffer<T>

Turns the vertex buffer into a VertexBuffer without checking the type.

source

pub fn per_instance(&self) -> Result<PerInstance<'_>, InstancingNotSupported>

Creates a marker that instructs glium to use multiple instances.

Instead of calling surface.draw(&vertex_buffer, ...) you can call surface.draw(vertex_buffer.per_instance(), ...). This will draw one instance of the geometry for each element in this buffer. The attributes are still passed to the vertex shader, but each entry is passed for each different instance.

Methods from Deref<Target = BufferAny>§

source

pub fn as_slice_any(&self) -> BufferAnySlice<'_>

Builds a slice-any containing the whole subbuffer.

source

pub unsafe fn as_typed_slice_mut<T: ?Sized + Content>( &mut self ) -> BufferMutSlice<'_, T>

Builds a mutable typed slice containing the whole subbuffer, without checking the type.

source

pub unsafe fn as_typed_slice<T: ?Sized + Content>(&self) -> BufferSlice<'_, T>

Builds a typed slice containing the whole subbuffer, without checking the type.

source

pub fn get_elements_size(&self) -> usize

Returns the size in bytes of each element in the buffer.

source

pub fn get_elements_count(&self) -> usize

Returns the number of elements in the buffer.

source

pub fn get_context(&self) -> &Rc<Context>

Returns the context corresponding to this buffer.

source

pub fn get_size(&self) -> usize

Returns the number of bytes in this subbuffer.

source

pub fn invalidate(&self)

Invalidates the content of the buffer. The data becomes undefined.

This operation is a no-op if the backend doesn’t support it and for persistent-mapped buffers.

source

pub unsafe fn read<T>(&self) -> Result<T::Owned, ReadError>where T: Content,

UNSTABLE. This function can be removed at any moment without any further notice.

Considers that the buffer is filled with elements of type T and reads them.

Panic

Panics if the size of the buffer is not a multiple of the size of the data. For example, trying to read some (u8, u8, u8, u8)s from a buffer of 7 bytes will panic.

Trait Implementations§

source§

impl Debug for VertexBufferAny

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
source§

impl Deref for VertexBufferAny

§

type Target = BufferAny

The resulting type after dereferencing.
source§

fn deref(&self) -> &BufferAny

Dereferences the value.
source§

impl DerefMut for VertexBufferAny

source§

fn deref_mut(&mut self) -> &mut BufferAny

Mutably dereferences the value.
source§

impl<T> From<Buffer<[T]>> for VertexBufferAnywhere T: Vertex + Copy + Send + 'static,

source§

fn from(buf: Buffer<[T]>) -> VertexBufferAny

Converts to this type from the input type.
source§

impl<T> From<VertexBuffer<T>> for VertexBufferAnywhere T: Copy + Send + 'static,

source§

fn from(buf: VertexBuffer<T>) -> VertexBufferAny

Converts to this type from the input type.
source§

impl<'a> Into<VerticesSource<'a>> for &'a VertexBufferAny

source§

fn into(self) -> VerticesSource<'a>

Converts this type into the (usually inferred) input type.

Auto Trait Implementations§

Blanket Implementations§

source§

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

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

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

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for Twhere 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 Twhere 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, U> TryFrom<U> for Twhere U: Into<T>,

§

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 Twhere U: TryFrom<T>,

§

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.