OGRE  2.3
Object-Oriented Graphics Rendering Engine
Ogre::v1::RenderToVertexBuffer Class Referenceabstract

#include <OgreRenderToVertexBuffer.h>

+ Inheritance diagram for Ogre::v1::RenderToVertexBuffer:

Public Member Functions

 RenderToVertexBuffer ()
 C'tor. More...
 
virtual ~RenderToVertexBuffer ()
 D'tor. More...
 
unsigned int getMaxVertexCount () const
 Get the maximum number of vertices that the buffer will hold. More...
 
OperationType getOperationType () const
 What type of primitives does this object generate? More...
 
virtual void getRenderOperation (RenderOperation &op)=0
 Get the render operation for this buffer. More...
 
const MaterialPtrgetRenderToBufferMaterial ()
 Get the material which is used to render the geometry into the vertex buffer. More...
 
bool getResetsEveryUpdate () const
 Does this object reset its buffer each time it updates? More...
 
const RenderablegetSourceRenderable () const
 Get the source renderable of this object. More...
 
VertexDeclarationgetVertexDeclaration ()
 Get the vertex declaration that the pass will output. More...
 
virtual void reset ()
 Reset the vertex buffer to the initial state. More...
 
void setMaxVertexCount (unsigned int maxVertexCount)
 Set the maximum number of vertices that the buffer will hold. More...
 
void setOperationType (OperationType operationType)
 Set the type of primitives that this object generates. More...
 
void setRenderToBufferMaterialName (const String &materialName)
 Set the material name which is used to render the geometry into the vertex buffer. More...
 
void setResetsEveryUpdate (bool resetsEveryUpdate)
 Set whether this object resets its buffers each time it updates. More...
 
void setSourceRenderable (Renderable *source)
 Set the source renderable of this object. More...
 
virtual void update (SceneManager *sceneMgr)=0
 Update the contents of this vertex buffer by rendering. More...
 

Detailed Description

An object which renders geometry to a vertex.
Remarks
This is especially useful together with geometry shaders, as you can render procedural geometry which will get saved to a vertex buffer for reuse later, without regenerating it again. You can also create shaders that run on previous results of those shaders, creating stateful shaders.

Constructor & Destructor Documentation

◆ RenderToVertexBuffer()

Ogre::v1::RenderToVertexBuffer::RenderToVertexBuffer ( )

C'tor.

◆ ~RenderToVertexBuffer()

virtual Ogre::v1::RenderToVertexBuffer::~RenderToVertexBuffer ( )
virtual

D'tor.

Member Function Documentation

◆ getMaxVertexCount()

unsigned int Ogre::v1::RenderToVertexBuffer::getMaxVertexCount ( ) const
inline

Get the maximum number of vertices that the buffer will hold.

◆ getOperationType()

OperationType Ogre::v1::RenderToVertexBuffer::getOperationType ( ) const
inline

What type of primitives does this object generate?

◆ getRenderOperation()

virtual void Ogre::v1::RenderToVertexBuffer::getRenderOperation ( RenderOperation op)
pure virtual

◆ getRenderToBufferMaterial()

const MaterialPtr& Ogre::v1::RenderToVertexBuffer::getRenderToBufferMaterial ( )
inline

Get the material which is used to render the geometry into the vertex buffer.

◆ getResetsEveryUpdate()

bool Ogre::v1::RenderToVertexBuffer::getResetsEveryUpdate ( ) const
inline

Does this object reset its buffer each time it updates?

◆ getSourceRenderable()

const Renderable* Ogre::v1::RenderToVertexBuffer::getSourceRenderable ( ) const
inline

Get the source renderable of this object.

◆ getVertexDeclaration()

VertexDeclaration* Ogre::v1::RenderToVertexBuffer::getVertexDeclaration ( )

Get the vertex declaration that the pass will output.

Remarks
Use this object to set the elements of the buffer. Object will calculate buffers on its own. Only one source allowed!

◆ reset()

virtual void Ogre::v1::RenderToVertexBuffer::reset ( )
inlinevirtual

Reset the vertex buffer to the initial state.

In the next update, the source renderable will be used as input.

◆ setMaxVertexCount()

void Ogre::v1::RenderToVertexBuffer::setMaxVertexCount ( unsigned int  maxVertexCount)
inline

Set the maximum number of vertices that the buffer will hold.

◆ setOperationType()

void Ogre::v1::RenderToVertexBuffer::setOperationType ( OperationType  operationType)
inline

Set the type of primitives that this object generates.

◆ setRenderToBufferMaterialName()

void Ogre::v1::RenderToVertexBuffer::setRenderToBufferMaterialName ( const String materialName)

Set the material name which is used to render the geometry into the vertex buffer.

◆ setResetsEveryUpdate()

void Ogre::v1::RenderToVertexBuffer::setResetsEveryUpdate ( bool  resetsEveryUpdate)
inline

Set whether this object resets its buffers each time it updates.

◆ setSourceRenderable()

void Ogre::v1::RenderToVertexBuffer::setSourceRenderable ( Renderable source)
inline

Set the source renderable of this object.

During the first (and perhaps later) update of this object, this object's data will be used as input)

◆ update()

virtual void Ogre::v1::RenderToVertexBuffer::update ( SceneManager sceneMgr)
pure virtual

Update the contents of this vertex buffer by rendering.

Implemented in Ogre::v1::GLES2RenderToVertexBuffer, Ogre::v1::GL3PlusRenderToVertexBuffer, and Ogre::v1::D3D11RenderToVertexBuffer.


The documentation for this class was generated from the following file: