VTK
9.1.0
|
Class for drawing 3D primitives to a graphical context. More...
#include <vtkContext3D.h>
Public Types | |
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... | |
vtkContext3D * | NewInstance () const |
void | PrintSelf (ostream &os, vtkIndent indent) override |
Methods invoked by print to print information about the object including superclasses. More... | |
bool | Begin (vtkContextDevice3D *device) |
Begin painting on a vtkContextDevice3D, no painting can occur before this call has been made. More... | |
vtkContextDevice3D * | GetDevice () |
Get access to the underlying 3D context. More... | |
bool | End () |
Ends painting on the device, you would not usually need to call this as it should be called by the destructor. More... | |
void | DrawLine (const vtkVector3f &start, const vtkVector3f &end) |
Draw a line between the specified points. More... | |
void | DrawPoly (const float *points, int n) |
Draw a poly line between the specified points. More... | |
void | DrawPoint (const vtkVector3f &point) |
Draw a point at the point in 3D space. More... | |
void | DrawPoints (const float *points, int n) |
Draw a sequence of points at the specified locations. More... | |
void | DrawPoints (const float *points, int n, unsigned char *colors, int nc_comps) |
Draw a sequence of points at the specified locations. More... | |
void | DrawTriangleMesh (const float *mesh, int n, const unsigned char *colors, int nc) |
Draw triangles to generate the specified mesh. More... | |
void | ApplyPen (vtkPen *pen) |
Apply the supplied pen which controls the outlines of shapes, as well as lines, points and related primitives. More... | |
void | ApplyBrush (vtkBrush *brush) |
Apply the supplied brush which controls the outlines of shapes, as well as lines, points and related primitives. More... | |
void | SetTransform (vtkTransform *transform) |
Set the transform for the context, the underlying device will use the matrix of the transform. More... | |
vtkTransform * | GetTransform () |
Compute the current transform applied to the context. More... | |
void | AppendTransform (vtkTransform *transform) |
Append the transform for the context, the underlying device will use the matrix of the transform. More... | |
void | PushMatrix () |
Push/pop the transformation matrix for the painter (sets the underlying matrix for the device when available). More... | |
void | PopMatrix () |
Push/pop the transformation matrix for the painter (sets the underlying matrix for the device when available). More... | |
void | EnableClippingPlane (int i, double *planeEquation) |
Enable/Disable the specified clipping plane. More... | |
void | DisableClippingPlane (int i) |
Enable/Disable the specified clipping plane. More... | |
![]() | |
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 | PrintSelf (ostream &os, vtkIndent indent) override |
Methods invoked by print to print information about the object including superclasses. 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... | |
![]() | |
const char * | GetClassName () const |
Return the class name as a string. More... | |
virtual vtkTypeBool | IsA (const char *name) |
Return 1 if this class is the same type of (or a subclass of) the named class. More... | |
virtual vtkIdType | GetNumberOfGenerationsFromBase (const char *name) |
Given the name of a base class of this class type, return the distance of inheritance between this class type and the named class (how many generations of inheritance are there between this class and the named class). 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... | |
bool | GetIsInMemkind () const |
A local state flag that remembers whether this object lives in the normal or extended memory space. 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 vtkTypeBool | IsTypeOf (const char *type) |
static vtkContext3D * | SafeDownCast (vtkObjectBase *o) |
static vtkContext3D * | New () |
Creates a 3D context object. More... | |
![]() | |
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 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 vtkIdType | GetNumberOfGenerationsFromBaseType (const char *name) |
Given a the name of a base class of this class type, return the distance of inheritance between this class type and the named class (how many generations of inheritance are there between this class and the named class). More... | |
static vtkObjectBase * | New () |
Create an object with Debug turned off, modified time initialized to zero, and reference counting on. More... | |
static void | SetMemkindDirectory (const char *directoryname) |
The name of a directory, ideally mounted -o dax, to memory map an extended memory space within. More... | |
static bool | GetUsingMemkind () |
A global state flag that controls whether vtkObjects are constructed in the usual way (the default) or within the extended memory space. More... | |
Protected Member Functions | |
virtual vtkObjectBase * | NewInstanceInternal () const |
vtkContext3D () | |
~vtkContext3D () override | |
![]() | |
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... | |
![]() | |
vtkObjectBase () | |
virtual | ~vtkObjectBase () |
virtual void | RegisterInternal (vtkObjectBase *, vtkTypeBool check) |
virtual void | UnRegisterInternal (vtkObjectBase *, vtkTypeBool check) |
virtual void | ReportReferences (vtkGarbageCollector *) |
vtkObjectBase (const vtkObjectBase &) | |
void | operator= (const vtkObjectBase &) |
Protected Attributes | |
vtkSmartPointer< vtkContextDevice3D > | Device |
vtkSmartPointer< vtkTransform > | Transform |
![]() | |
bool | Debug |
vtkTimeStamp | MTime |
vtkSubjectHelper * | SubjectHelper |
![]() | |
std::atomic< int32_t > | ReferenceCount |
vtkWeakPointerBase ** | WeakPointers |
Additional Inherited Members | |
![]() | |
static vtkMallocingFunction | GetCurrentMallocFunction () |
static vtkReallocingFunction | GetCurrentReallocFunction () |
static vtkFreeingFunction | GetCurrentFreeFunction () |
static vtkFreeingFunction | GetAlternateFreeFunction () |
Class for drawing 3D primitives to a graphical context.
This defines the interface for drawing onto a 3D context. The context must be set up with a vtkContextDevice3D derived class that provides the functions to facilitate the low level calls to the context. Currently only an OpenGL based device is provided.
Definition at line 59 of file vtkContext3D.h.
typedef vtkObject vtkContext3D::Superclass |
Definition at line 62 of file vtkContext3D.h.
|
protected |
|
overrideprotected |
|
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 |
vtkContext3D * vtkContext3D::NewInstance | ( | ) | const |
|
overridevirtual |
|
static |
Creates a 3D context object.
bool vtkContext3D::Begin | ( | vtkContextDevice3D * | device | ) |
Begin painting on a vtkContextDevice3D, no painting can occur before this call has been made.
Only one painter is allowed at a time on any given paint device. Returns true if successful, otherwise false.
vtkContextDevice3D * vtkContext3D::GetDevice | ( | ) |
Get access to the underlying 3D context.
bool vtkContext3D::End | ( | ) |
Ends painting on the device, you would not usually need to call this as it should be called by the destructor.
Returns true if the painter is no longer active, otherwise false.
void vtkContext3D::DrawLine | ( | const vtkVector3f & | start, |
const vtkVector3f & | end | ||
) |
Draw a line between the specified points.
void vtkContext3D::DrawPoly | ( | const float * | points, |
int | n | ||
) |
Draw a poly line between the specified points.
void vtkContext3D::DrawPoint | ( | const vtkVector3f & | point | ) |
Draw a point at the point in 3D space.
void vtkContext3D::DrawPoints | ( | const float * | points, |
int | n | ||
) |
Draw a sequence of points at the specified locations.
void vtkContext3D::DrawPoints | ( | const float * | points, |
int | n, | ||
unsigned char * | colors, | ||
int | nc_comps | ||
) |
Draw a sequence of points at the specified locations.
The points will be colored by the colors array, which must have nc_comps components (defining a single color).
void vtkContext3D::DrawTriangleMesh | ( | const float * | mesh, |
int | n, | ||
const unsigned char * | colors, | ||
int | nc | ||
) |
Draw triangles to generate the specified mesh.
void vtkContext3D::ApplyPen | ( | vtkPen * | pen | ) |
Apply the supplied pen which controls the outlines of shapes, as well as lines, points and related primitives.
This makes a deep copy of the vtkPen object in the vtkContext2D, it does not hold a pointer to the supplied object.
void vtkContext3D::ApplyBrush | ( | vtkBrush * | brush | ) |
Apply the supplied brush which controls the outlines of shapes, as well as lines, points and related primitives.
This makes a deep copy of the vtkBrush object in the vtkContext2D, it does not hold a pointer to the supplied object.
void vtkContext3D::SetTransform | ( | vtkTransform * | transform | ) |
Set the transform for the context, the underlying device will use the matrix of the transform.
Note, this is set immediately, later changes to the matrix will have no effect until it is set again.
vtkTransform * vtkContext3D::GetTransform | ( | ) |
Compute the current transform applied to the context.
void vtkContext3D::AppendTransform | ( | vtkTransform * | transform | ) |
Append the transform for the context, the underlying device will use the matrix of the transform.
Note, this is set immediately, later changes to the matrix will have no effect until it is set again. The matrix of the transform will multiply the current context transform.
void vtkContext3D::PushMatrix | ( | ) |
Push/pop the transformation matrix for the painter (sets the underlying matrix for the device when available).
void vtkContext3D::PopMatrix | ( | ) |
Push/pop the transformation matrix for the painter (sets the underlying matrix for the device when available).
void vtkContext3D::EnableClippingPlane | ( | int | i, |
double * | planeEquation | ||
) |
Enable/Disable the specified clipping plane.
i is the index of the clipping plane being enabled or disabled (0 - 5). planeEquation points to the four coefficients of the equation for the clipping plane: Ax + By + Cz + D = 0. This is the equation format expected by glClipPlane.
void vtkContext3D::DisableClippingPlane | ( | int | i | ) |
Enable/Disable the specified clipping plane.
i is the index of the clipping plane being enabled or disabled (0 - 5). planeEquation points to the four coefficients of the equation for the clipping plane: Ax + By + Cz + D = 0. This is the equation format expected by glClipPlane.
|
protected |
Definition at line 180 of file vtkContext3D.h.
|
protected |
Definition at line 181 of file vtkContext3D.h.