OGRE
14.2
Object-Oriented Graphics Rendering Engine
|
Records the state of all the vertex buffer bindings required to provide a vertex declaration with the input data it needs for the vertex elements. More...
#include <OgreHardwareVertexBuffer.h>
Public Types | |
typedef std::map< ushort, ushort > | BindingIndexMap |
typedef std::map< unsigned short, HardwareVertexBufferSharedPtr > | VertexBufferBindingMap |
Defines the vertex buffer bindings used as source for vertex declarations. More... | |
Public Member Functions | |
VertexBufferBinding () | |
Constructor, should not be called direct, use HardwareBufferManager::createVertexBufferBinding. More... | |
~VertexBufferBinding () | |
void | closeGaps (BindingIndexMap &bindingIndexMap) |
Remove any gaps in the bindings. More... | |
const VertexBufferBindingMap & | getBindings (void) const |
Gets a read-only version of the buffer bindings. More... | |
const HardwareVertexBufferSharedPtr & | getBuffer (unsigned short index) const |
Gets the buffer bound to the given source index. More... | |
size_t | getBufferCount (void) const |
unsigned short | getLastBoundIndex (void) const |
Gets the last bound index. More... | |
unsigned short | getNextIndex (void) const |
Gets the highest index which has already been set, plus 1. More... | |
bool | hasGaps (void) const |
Check whether any gaps in the bindings. More... | |
bool | hasInstanceData () const |
Returns true if this binding has an element that contains instance data. More... | |
bool | isBufferBound (unsigned short index) const |
Gets whether a buffer is bound to the given source index. More... | |
void | setBinding (unsigned short index, const HardwareVertexBufferSharedPtr &buffer) |
Set a binding, associating a vertex buffer with a given index. More... | |
void | unsetAllBindings (void) |
Removes all the bindings. More... | |
void | unsetBinding (unsigned short index) |
Removes an existing binding. More... | |
Records the state of all the vertex buffer bindings required to provide a vertex declaration with the input data it needs for the vertex elements.
Why do we have this binding list rather than just have VertexElement referring to the vertex buffers direct? Well, in the underlying APIs, binding the vertex buffers to an index (or 'stream') is the way that vertex data is linked, so this structure better reflects the realities of that. In addition, by separating the vertex declaration from the list of vertex buffer bindings, it becomes possible to reuse bindings between declarations and vice versa, giving opportunities to reduce the state changes required to perform rendering.
typedef std::map<unsigned short, HardwareVertexBufferSharedPtr> Ogre::VertexBufferBinding::VertexBufferBindingMap |
Defines the vertex buffer bindings used as source for vertex declarations.
typedef std::map<ushort, ushort> Ogre::VertexBufferBinding::BindingIndexMap |
Ogre::VertexBufferBinding::VertexBufferBinding | ( | ) |
Constructor, should not be called direct, use HardwareBufferManager::createVertexBufferBinding.
Ogre::VertexBufferBinding::~VertexBufferBinding | ( | ) |
void Ogre::VertexBufferBinding::setBinding | ( | unsigned short | index, |
const HardwareVertexBufferSharedPtr & | buffer | ||
) |
Set a binding, associating a vertex buffer with a given index.
If the index is already associated with a vertex buffer, the association will be replaced. This may cause the old buffer to be destroyed if nothing else is referring to it. You should assign bindings from 0 and not leave gaps, although you can bind them in any order.
void Ogre::VertexBufferBinding::unsetBinding | ( | unsigned short | index | ) |
Removes an existing binding.
void Ogre::VertexBufferBinding::unsetAllBindings | ( | void | ) |
Removes all the bindings.
const VertexBufferBindingMap& Ogre::VertexBufferBinding::getBindings | ( | void | ) | const |
Gets a read-only version of the buffer bindings.
const HardwareVertexBufferSharedPtr& Ogre::VertexBufferBinding::getBuffer | ( | unsigned short | index | ) | const |
Gets the buffer bound to the given source index.
bool Ogre::VertexBufferBinding::isBufferBound | ( | unsigned short | index | ) | const |
Gets whether a buffer is bound to the given source index.
|
inline |
|
inline |
Gets the highest index which has already been set, plus 1.
This is to assist in binding the vertex buffers such that there are not gaps in the list.
unsigned short Ogre::VertexBufferBinding::getLastBoundIndex | ( | void | ) | const |
Gets the last bound index.
bool Ogre::VertexBufferBinding::hasGaps | ( | void | ) | const |
Check whether any gaps in the bindings.
void Ogre::VertexBufferBinding::closeGaps | ( | BindingIndexMap & | bindingIndexMap | ) |
Remove any gaps in the bindings.
This is useful if you've removed vertex buffer from this vertex buffer bindings and want to remove any gaps in the bindings. Note, however, that if this bindings is already being used with a VertexDeclaration, you will need to alter that too. This method is mainly useful when reorganising buffers manually.
bindingIndexMap | To be retrieve the binding index map that used to translation old index to new index; will be cleared by this method before fill-in. |
|
inline |
Returns true if this binding has an element that contains instance data.