VTK
|
Manages a TransformFeedback buffer. More...
#include <vtkTransformFeedback.h>
Classes | |
struct | VaryingMetaData |
Public Types | |
enum | VaryingRole { Vertex_ClipCoordinate_F, Color_RGBA_F } |
The role a captured varying fills. More... | |
typedef vtkObject | Superclass |
Public Member Functions | |
virtual int | IsA (const char *type) |
Return 1 if this class is the same type of (or a subclass of) the named class. More... | |
vtkTransformFeedback * | NewInstance () const |
virtual void | PrintSelf (ostream &os, vtkIndent indent) |
Methods invoked by print to print information about the object including superclasses. More... | |
void | ClearVaryings () |
Clear the list of varying attributes to capture. More... | |
void | AddVarying (VaryingRole role, const std::string &var) |
Capture the varying 'var' with the indicated role. More... | |
const std::vector< VaryingMetaData > & | GetVaryings () const |
Get the list of captured varyings,. More... | |
size_t | GetBytesPerVertex () const |
Returns the number of bytes per vertexs, accounting for all roles. More... | |
size_t | GetBufferSize () const |
The size (in bytes) of the capture buffer. More... | |
void | BindVaryings (vtkShaderProgram *prog) |
GL_SEPARATE_ATTRIBS is not supported yet. More... | |
void | BindBuffer () |
Generates, binds, and allocates the feedback buffer, then call glBeginTransformFeedback with the specified PrimitiveMode. More... | |
void | ReadBuffer () |
Calls glEndTransformFeedback(), flushes the OpenGL command stream, and reads the transform feedback buffer into BufferData. More... | |
void | ReleaseGraphicsResources () |
Release any graphics resources used by this object. More... | |
void | ReleaseBufferData (bool freeBuffer=true) |
Release the memory used by the buffer data. More... | |
virtual void | SetNumberOfVertices (size_t) |
The number of vertices expected to be captured. More... | |
void | SetNumberOfVertices (int drawMode, size_t inputVerts) |
The number of vertices expected to be captured. More... | |
virtual size_t | GetNumberOfVertices () |
The number of vertices expected to be captured. More... | |
virtual int | GetBufferHandle () |
Get the handle to the transform buffer object. More... | |
virtual void | SetPrimitiveMode (int) |
The type of primitive to capture. More... | |
virtual int | GetPrimitiveMode () |
The type of primitive to capture. More... | |
virtual void * | GetBufferData () |
Get the transform buffer data as a void pointer. More... | |
Public Member Functions inherited from vtkObject | |
vtkBaseTypeMacro (vtkObject, vtkObjectBase) | |
virtual void | DebugOn () |
Turn debugging output on. More... | |
virtual void | DebugOff () |
Turn debugging output off. More... | |
bool | GetDebug () |
Get the value of the debug flag. More... | |
void | SetDebug (bool debugFlag) |
Set the value of the debug flag. More... | |
virtual void | Modified () |
Update the modification time for this object. More... | |
virtual vtkMTimeType | GetMTime () |
Return this object's modified time. More... | |
void | RemoveObserver (unsigned long tag) |
void | RemoveObservers (unsigned long event) |
void | RemoveObservers (const char *event) |
void | RemoveAllObservers () |
int | HasObserver (unsigned long event) |
int | HasObserver (const char *event) |
int | InvokeEvent (unsigned long event) |
int | InvokeEvent (const char *event) |
unsigned long | AddObserver (unsigned long event, vtkCommand *, float priority=0.0f) |
Allow people to add/remove/invoke observers (callbacks) to any VTK object. More... | |
unsigned long | AddObserver (const char *event, vtkCommand *, float priority=0.0f) |
Allow people to add/remove/invoke observers (callbacks) to any VTK object. More... | |
vtkCommand * | GetCommand (unsigned long tag) |
Allow people to add/remove/invoke observers (callbacks) to any VTK object. More... | |
void | RemoveObserver (vtkCommand *) |
Allow people to add/remove/invoke observers (callbacks) to any VTK object. More... | |
void | RemoveObservers (unsigned long event, vtkCommand *) |
Allow people to add/remove/invoke observers (callbacks) to any VTK object. More... | |
void | RemoveObservers (const char *event, vtkCommand *) |
Allow people to add/remove/invoke observers (callbacks) to any VTK object. More... | |
int | HasObserver (unsigned long event, vtkCommand *) |
Allow people to add/remove/invoke observers (callbacks) to any VTK object. More... | |
int | HasObserver (const char *event, vtkCommand *) |
Allow people to add/remove/invoke observers (callbacks) to any VTK object. More... | |
template<class U , class T > | |
unsigned long | AddObserver (unsigned long event, U observer, void(T::*callback)(), float priority=0.0f) |
Overloads to AddObserver that allow developers to add class member functions as callbacks for events. More... | |
template<class U , class T > | |
unsigned long | AddObserver (unsigned long event, U observer, void(T::*callback)(vtkObject *, unsigned long, void *), float priority=0.0f) |
Overloads to AddObserver that allow developers to add class member functions as callbacks for events. More... | |
template<class U , class T > | |
unsigned long | AddObserver (unsigned long event, U observer, bool(T::*callback)(vtkObject *, unsigned long, void *), float priority=0.0f) |
Allow user to set the AbortFlagOn() with the return value of the callback method. More... | |
int | InvokeEvent (unsigned long event, void *callData) |
This method invokes an event and return whether the event was aborted or not. More... | |
int | InvokeEvent (const char *event, void *callData) |
This method invokes an event and return whether the event was aborted or not. More... | |
Public Member Functions inherited from vtkObjectBase | |
const char * | GetClassName () const |
Return the class name as a string. More... | |
virtual void | Delete () |
Delete a VTK object. More... | |
virtual void | FastDelete () |
Delete a reference to this object. More... | |
void | InitializeObjectBase () |
void | Print (ostream &os) |
Print an object to an ostream. More... | |
virtual void | Register (vtkObjectBase *o) |
Increase the reference count (mark as used by another object). More... | |
virtual void | UnRegister (vtkObjectBase *o) |
Decrease the reference count (release by another object). More... | |
int | GetReferenceCount () |
Return the current reference count of this object. More... | |
void | SetReferenceCount (int) |
Sets the reference count. More... | |
void | PrintRevisions (ostream &) |
Legacy. More... | |
virtual void | PrintHeader (ostream &os, vtkIndent indent) |
Methods invoked by print to print information about the object including superclasses. More... | |
virtual void | PrintTrailer (ostream &os, vtkIndent indent) |
Methods invoked by print to print information about the object including superclasses. More... | |
Static Public Member Functions | |
static vtkTransformFeedback * | New () |
static int | IsTypeOf (const char *type) |
static vtkTransformFeedback * | SafeDownCast (vtkObjectBase *o) |
static size_t | GetBytesPerVertex (VaryingRole role) |
Returns the number of data elements each vertex requires for a given role. More... | |
Static Public Member Functions inherited from vtkObject | |
static vtkObject * | New () |
Create an object with Debug turned off, modified time initialized to zero, and reference counting on. More... | |
static void | BreakOnError () |
This method is called when vtkErrorMacro executes. More... | |
static void | SetGlobalWarningDisplay (int val) |
This is a global flag that controls whether any debug, warning or error messages are displayed. More... | |
static void | GlobalWarningDisplayOn () |
This is a global flag that controls whether any debug, warning or error messages are displayed. More... | |
static void | GlobalWarningDisplayOff () |
This is a global flag that controls whether any debug, warning or error messages are displayed. More... | |
static int | GetGlobalWarningDisplay () |
This is a global flag that controls whether any debug, warning or error messages are displayed. More... | |
Static Public Member Functions inherited from vtkObjectBase | |
static vtkTypeBool | IsTypeOf (const char *name) |
Return 1 if this class type is the same type of (or a subclass of) the named class. More... | |
static vtkObjectBase * | New () |
Create an object with Debug turned off, modified time initialized to zero, and reference counting on. More... | |
Protected Member Functions | |
virtual vtkObjectBase * | NewInstanceInternal () const |
vtkTransformFeedback () | |
~vtkTransformFeedback () | |
Protected Member Functions inherited from vtkObject | |
vtkObject () | |
~vtkObject () override | |
void | RegisterInternal (vtkObjectBase *, vtkTypeBool check) override |
void | UnRegisterInternal (vtkObjectBase *, vtkTypeBool check) override |
void | InternalGrabFocus (vtkCommand *mouseEvents, vtkCommand *keypressEvents=NULL) |
These methods allow a command to exclusively grab all events. More... | |
void | InternalReleaseFocus () |
These methods allow a command to exclusively grab all events. More... | |
Protected Member Functions inherited from vtkObjectBase | |
vtkObjectBase () | |
virtual | ~vtkObjectBase () |
virtual void | CollectRevisions (ostream &) |
virtual void | ReportReferences (vtkGarbageCollector *) |
vtkObjectBase (const vtkObjectBase &) | |
void | operator= (const vtkObjectBase &) |
Additional Inherited Members | |
Protected Attributes inherited from vtkObject | |
bool | Debug |
vtkTimeStamp | MTime |
vtkSubjectHelper * | SubjectHelper |
Protected Attributes inherited from vtkObjectBase | |
vtkAtomicInt32 | ReferenceCount |
vtkWeakPointerBase ** | WeakPointers |
Manages a TransformFeedback buffer.
OpenGL's TransformFeedback allows varying attributes from a vertex/geometry shader to be captured into a buffer for later processing. This is used in VTK to capture vertex information during GL2PS export when using the OpenGL2 backend as a replacement for the deprecated OpenGL feedback buffer.
Definition at line 39 of file vtkTransformFeedback.h.
Definition at line 43 of file vtkTransformFeedback.h.
The role a captured varying fills.
Useful for parsing later.
Enumerator | |
---|---|
Vertex_ClipCoordinate_F | |
Color_RGBA_F |
Definition at line 49 of file vtkTransformFeedback.h.
|
protected |
|
protected |
|
static |
|
static |
|
virtual |
Return 1 if this class is the same type of (or a subclass of) the named class.
Returns 0 otherwise. This method works in combination with vtkTypeMacro found in vtkSetGet.h.
Reimplemented from vtkObjectBase.
|
static |
|
protectedvirtual |
vtkTransformFeedback* vtkTransformFeedback::NewInstance | ( | ) | const |
|
virtual |
void vtkTransformFeedback::ClearVaryings | ( | ) |
Clear the list of varying attributes to capture.
void vtkTransformFeedback::AddVarying | ( | VaryingRole | role, |
const std::string & | var | ||
) |
Capture the varying 'var' with the indicated role.
|
inline |
Get the list of captured varyings,.
Definition at line 76 of file vtkTransformFeedback.h.
|
inlinestatic |
Returns the number of data elements each vertex requires for a given role.
Definition at line 201 of file vtkTransformFeedback.h.
size_t vtkTransformFeedback::GetBytesPerVertex | ( | ) | const |
Returns the number of bytes per vertexs, accounting for all roles.
|
virtual |
The number of vertices expected to be captured.
If the drawMode setter is used, PrimitiveMode will also be set appropriately. For the single argument version set function, set the exact number of vertices expected to be emitted, accounting for primitive expansion (e.g. triangle strips -> triangle strips). The two argument setter is for convenience. Given the number of vertices used as input to a draw command and the draw mode, it will calculate the total number of vertices.
void vtkTransformFeedback::SetNumberOfVertices | ( | int | drawMode, |
size_t | inputVerts | ||
) |
The number of vertices expected to be captured.
If the drawMode setter is used, PrimitiveMode will also be set appropriately. For the single argument version set function, set the exact number of vertices expected to be emitted, accounting for primitive expansion (e.g. triangle strips -> triangle strips). The two argument setter is for convenience. Given the number of vertices used as input to a draw command and the draw mode, it will calculate the total number of vertices.
|
virtual |
The number of vertices expected to be captured.
If the drawMode setter is used, PrimitiveMode will also be set appropriately. For the single argument version set function, set the exact number of vertices expected to be emitted, accounting for primitive expansion (e.g. triangle strips -> triangle strips). The two argument setter is for convenience. Given the number of vertices used as input to a draw command and the draw mode, it will calculate the total number of vertices.
size_t vtkTransformFeedback::GetBufferSize | ( | ) | const |
The size (in bytes) of the capture buffer.
Available after adding all Varyings and setting NumberOfVertices.
void vtkTransformFeedback::BindVaryings | ( | vtkShaderProgram * | prog | ) |
GL_SEPARATE_ATTRIBS is not supported yet.
The bufferMode argument to glTransformFeedbackVaryings. Must be GL_INTERLEAVED_ATTRIBS or GL_SEPARATE_ATTRIBS. Default is interleaved. Must be set prior to calling BindVaryings. vtkSetMacro(BufferMode, int) vtkGetMacro(BufferMode, int) Call glTransformFeedbackVaryings(). Must be called after the shaders are attached to prog, but before the program is linked.
|
virtual |
Get the handle to the transform buffer object.
Only valid after calling BindBuffer and before ReadBuffer.
|
virtual |
The type of primitive to capture.
Must be one of GL_POINTS, GL_LINES, or GL_TRIANGLES. Default is GL_POINTS. Must be set prior to calling BindBuffer.
|
virtual |
The type of primitive to capture.
Must be one of GL_POINTS, GL_LINES, or GL_TRIANGLES. Default is GL_POINTS. Must be set prior to calling BindBuffer.
void vtkTransformFeedback::BindBuffer | ( | ) |
Generates, binds, and allocates the feedback buffer, then call glBeginTransformFeedback with the specified PrimitiveMode.
Must be called after BindVaryings and before any relevant glDraw commands.
void vtkTransformFeedback::ReadBuffer | ( | ) |
Calls glEndTransformFeedback(), flushes the OpenGL command stream, and reads the transform feedback buffer into BufferData.
Must be called after any relevant glDraw commands.
|
virtual |
Get the transform buffer data as a void pointer.
Only valid after calling ReadBuffer.
void vtkTransformFeedback::ReleaseGraphicsResources | ( | ) |
Release any graphics resources used by this object.
void vtkTransformFeedback::ReleaseBufferData | ( | bool | freeBuffer = true | ) |
Release the memory used by the buffer data.
If freeBuffer == true (default), the data is deleted. If false, the caller is responsible for deleting the BufferData with delete[].