Vertex buffer for use with MGeometry.
This class represents a vertex buffer with attributes described by the descriptor member.
When retrieving a vertex buffer for binding to custom shaders (MPxShaderOverride), resourceHandle() may be called to get the device dependent handle to the vertex buffer on the GPU.
When creating a vertex buffer to supply geometric data to Maya (MPxGeometryOverride), acquire() may be called to get a pointer to a block of memory to fill with said data. Once filled, commit() must be called to apply the data to the buffer.
cgfxShaderNode.cpp, hwColorPerVertexShader.cpp, and hwPhongShader.cpp.
#include <MHWGeometry.h>
Public Member Functions |
|
const MVertexBufferDescriptor & | descriptor () const |
Get the the buffer descriptor. |
|
void * | resourceHandle () const |
Gets a graphics device dependent handle to a
vertex buffer. |
|
void * | acquire (unsigned int size) |
Get a pointer to memory for the buffer.
|
|
void | commit (void *buffer) |
Commit the data stored in the memory given
by acquire() to
the buffer. |
|
Static Public Member Functions |
|
static const char * | className () |
Returns the name of this class. |
|
Friends |
|
class | MGeometry |
const MVertexBufferDescriptor & descriptor | ( | ) | const |
Get the the buffer descriptor.
void * resourceHandle | ( | ) | const |
Gets a graphics device dependent handle to a vertex buffer.
For OpenGL the return value is a pointer to an OpenGL identifier (GLuint) to an vertex buffer containing the data. Buffers can be set via the OpenGL API for drawing purposes. (e.g. using glBindBuffer).
A NULL pointer will be returned if the graphics device dependent handle is not yet available.
If the pointer is not NULL, the value is only guaranteed to exist during the current draw. The value should never be cached or modified.
void * acquire | ( | unsigned int | size | ) |
Get a pointer to memory for the buffer.
This method is meant to be used in MPxGeometryOverride::populateGeometry() in order to provide data to Maya for drawing the associated object. The size of the buffer returned will be (size * descriptor.dataTypeSize() * descriptor.dimension()) bytes. The memory for the buffer is managed internally.
[in] | size | The size of the buffer to acquire. |
void commit | ( | void * | buffer | ) |
const char * className | ( | ) | [static] |