BALL::VIEW::MeshBuffer Class Reference
[Renderer]

#include <BALL/VIEW/RENDERING/vertexBuffer.h>

List of all members.

Public Types

typedef GLuint Buffer [4]

Public Member Functions

 MeshBuffer ()
 MeshBuffer (const MeshBuffer &mesh_buffer)
virtual ~MeshBuffer ()
const MeshBufferoperator= (const MeshBuffer &buffer)
const MeshgetMesh ()
 Get the Mesh for this buffer object.
void setMesh (const Mesh &mesh)
 Set the Mesh which shall be drawn with this buffer object.
bool initialize ()
 Transfer all vertex, normal, index and color data of the mesh into the vertex buffer object.
bool draw ()
 Draw the mesh from the buffer.
void clear ()
 Unset the mesh pointer and clear the buffer.
void clearBuffer ()
 Free the reserved (and filled) vertex buffer.
bool isBusy () const
 Return true, if currently updateing or drawing.

Static Public Member Functions

static bool initGL ()
static void setGLRenderer (GLRenderer *renderer)

Protected Attributes

const Meshmesh_
Buffer buffer_
bool filled_
bool busy_
bool multiple_colors_
ColorRGBA color_
Size vertices_
Size triangles_

Static Protected Attributes

static GLRenderergl_renderer_

Detailed Description

Wrapper class to draw BALLView Mesh instances with OpenGL vertex buffer objects. Vertex Buffer Objects are an OpenGL extension available since OpenGL version 1.5.

See http://oss.sgi.com/projects/ogl-sample/registry/EXT/pixel_buffer_object.txt
Vertex Buffer Objects can drasticaly increase drawing speed for triangulated surfaces (up to 5 fold) compared with OpenGL display lists. To ensure a maximum of platform independence we use method pointers in the source file. These must be initialised by calling MeshBuffer::initGL() (See below).

Definition at line 40 of file vertexBuffer.h.


Member Typedef Documentation

typedef GLuint BALL::VIEW::MeshBuffer::Buffer[4]

Definition at line 46 of file vertexBuffer.h.


Constructor & Destructor Documentation

BALL::VIEW::MeshBuffer::MeshBuffer (  ) 
BALL::VIEW::MeshBuffer::MeshBuffer ( const MeshBuffer mesh_buffer  ) 
virtual BALL::VIEW::MeshBuffer::~MeshBuffer (  )  [virtual]

Member Function Documentation

void BALL::VIEW::MeshBuffer::clear (  ) 

Unset the mesh pointer and clear the buffer.

void BALL::VIEW::MeshBuffer::clearBuffer (  ) 

Free the reserved (and filled) vertex buffer.

bool BALL::VIEW::MeshBuffer::draw (  ) 

Draw the mesh from the buffer.

const Mesh* BALL::VIEW::MeshBuffer::getMesh (  )  [inline]

Get the Mesh for this buffer object.

Definition at line 66 of file vertexBuffer.h.

static bool BALL::VIEW::MeshBuffer::initGL (  )  [static]

Initialise the GL needed methods. Call this method one time after having a valid GL context (e.g. in GLRenderer::init).

bool BALL::VIEW::MeshBuffer::initialize (  ) 

Transfer all vertex, normal, index and color data of the mesh into the vertex buffer object.

bool BALL::VIEW::MeshBuffer::isBusy (  )  const [inline]

Return true, if currently updateing or drawing.

Definition at line 84 of file vertexBuffer.h.

const MeshBuffer& BALL::VIEW::MeshBuffer::operator= ( const MeshBuffer buffer  ) 
static void BALL::VIEW::MeshBuffer::setGLRenderer ( GLRenderer renderer  )  [inline, static]

Set the GLRender. This GLRender pointer is used to know if to draw the mesh transparent solid or transparent, as solid triangles or as points. Meshes can currently not drawn in wireframe mode with vertex buffer.

Definition at line 91 of file vertexBuffer.h.

void BALL::VIEW::MeshBuffer::setMesh ( const Mesh mesh  )  [inline]

Set the Mesh which shall be drawn with this buffer object.

Definition at line 69 of file vertexBuffer.h.


Member Data Documentation

Definition at line 96 of file vertexBuffer.h.

Definition at line 99 of file vertexBuffer.h.

Definition at line 101 of file vertexBuffer.h.

Definition at line 97 of file vertexBuffer.h.

Definition at line 98 of file vertexBuffer.h.

const Mesh* BALL::VIEW::MeshBuffer::mesh_ [protected]

Definition at line 95 of file vertexBuffer.h.

Definition at line 100 of file vertexBuffer.h.

Definition at line 103 of file vertexBuffer.h.

Definition at line 102 of file vertexBuffer.h.

Generated by  doxygen 1.6.3