VTK
|
Manages a TransformFeedback buffer. More...
#include <vtkTransformFeedback.h>
Classes | |
struct | VaryingMetaData |
Public Types | |
enum | VaryingRole { Vertex_ClipCoordinate_F, Color_RGBA_F, Normal_F, Next_Buffer } |
The role a captured varying fills. More... | |
typedef vtkObject | Superclass |
Public Member Functions | |
virtual vtkTypeBool | 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 |
void | PrintSelf (ostream &os, vtkIndent indent) override |
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... | |
vtkOpenGLBufferObject * | GetBuffer (int index) |
Get the transform buffer object. More... | |
int | GetBufferHandle (int index=0) |
Get the transform buffer object handle. More... | |
void | Allocate (int nbBuffers, size_t size, unsigned int hint) |
Generates and allocates the transform feedback buffers. More... | |
void | BindBuffer (bool allocateOneBuffer=true) |
Binds the feedback buffer, then call glBeginTransformFeedback with the specified PrimitiveMode. More... | |
void | ReadBuffer (int index=0) |
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 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 () |
vtkTypeBool | HasObserver (unsigned long event) |
vtkTypeBool | 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... | |
vtkTypeBool | HasObserver (unsigned long event, vtkCommand *) |
Allow people to add/remove/invoke observers (callbacks) to any VTK object. More... | |
vtkTypeBool | 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 vtkTypeBool | 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 () override | |
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=nullptr) |
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 40 of file vtkTransformFeedback.h.
Definition at line 44 of file vtkTransformFeedback.h.
The role a captured varying fills.
Useful for parsing later.
Enumerator | |
---|---|
Vertex_ClipCoordinate_F | |
Color_RGBA_F | |
Normal_F | |
Next_Buffer |
Definition at line 50 of file vtkTransformFeedback.h.
|
protected |
|
overrideprotected |
|
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 |
|
overridevirtual |
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 79 of file vtkTransformFeedback.h.
|
inlinestatic |
Returns the number of data elements each vertex requires for a given role.
Definition at line 217 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.
vtkOpenGLBufferObject* vtkTransformFeedback::GetBuffer | ( | int | index | ) |
Get the transform buffer object.
Only valid after calling BindBuffer.
Get the transform buffer object handle.
Only valid after 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.
|
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.
Generates and allocates the transform feedback buffers.
Must be called before BindBuffer. This releases old buffers. nbBuffers is the number of buffers to allocate. size if the size in byte to allocate per buffer. hint is the type of buffer (for example, GL_DYNAMIC_COPY)
void vtkTransformFeedback::BindBuffer | ( | bool | allocateOneBuffer = true | ) |
Binds the feedback buffer, then call glBeginTransformFeedback with the specified PrimitiveMode.
Must be called after BindVaryings and before any relevant glDraw commands. If allocateOneBuffer is true, allocates 1 buffer (used for retro compatibility).
void vtkTransformFeedback::ReadBuffer | ( | int | index = 0 | ) |
Calls glEndTransformFeedback(), flushes the OpenGL command stream, and reads the transform feedback buffer into BufferData.
Must be called after any relevant glDraw commands. If index is positive, data of specified buffer is copied to BufferData.
|
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[].