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 DerefMut for VertexBufferAny

source§

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

Mutably dereferences the value.
source§

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

source§

fn from(this: &VertexBufferAny) -> VerticesSource<'_>

Converts to this type from the input type.
source§

impl<T> From<Buffer<[T]>> for VertexBufferAny
where 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 VertexBufferAny
where T: Copy + Send + 'static,

source§

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

Converts to this type from the input type.
source§

impl Deref for VertexBufferAny

§

type Target = BufferAny

The resulting type after dereferencing.
source§

fn deref(&self) -> &BufferAny

Dereferences the value.

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
§

impl<T> Downcast for T
where T: Any,

§

fn into_any(self: Box<T>) -> Box<dyn Any>

Convert 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>

Convert 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)

Convert &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)

Convert &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> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

§

impl<T> Instrument for T

§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided [Span], returning an Instrumented wrapper. Read more
§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
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, U> TryFrom<U> for T
where 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 T
where 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.
§

impl<T> WithSubscriber for T

§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a [WithDispatch] wrapper. Read more
§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a [WithDispatch] wrapper. Read more