| 
    MeVisLab Toolbox Reference
    
   | 
 
Draws an overlay image on the SoView2D. More...
#include <SoView2DOverlay.h>
  
Public Member Functions | |
| SoView2DOverlay () | |
| Constructor.   | |
| void | startDrawing (View2DSliceList *slicelist) override | 
| reimplemented from SoView2DExtension   | |
| void | endDrawing (View2DSliceList *slicelist) override | 
| reimplemented from SoView2DExtension   | |
| void | draw (View2DSliceList *dsl, View2DSlice *dslice, int slice) override | 
| reimplemented from SoView2DExtension   | |
| bool | evalEvent (SoView2D *view2d, View2DSliceList *slicelist, View2DEvent *ec, View2DEventPhase phase) override | 
| reimplemented from SoView2DExtension   | |
| void | GLRender (SoGLRenderAction *action) override | 
| reimplemented from SoNode, stores the LUT for later rendering   | |
  Public Member Functions inherited from SoView2DCallback | |
| SoView2DCallback () | |
| void | setEvalEventCB (SoView2DEvalEventCB *eval, void *usrData) | 
| set a callback for evalEvent, clears previous callback   | |
| void | setDrawCB (SoView2DDrawCB *draw, void *usrData) | 
| set a callback for draw, clears previous callback   | |
  Public Member Functions inherited from SoView2DExtension | |
| SoView2DExtension () | |
| Constructor.   | |
| void | init () | 
| setup internal state   | |
| virtual void | updateValues () | 
| Update fields to local variables, may be reimplemented if you want to update additional local vars.   | |
| virtual void | overwriteDrawingSettings (SoView2DDrawingSettings &) | 
| View2DEvent * | getEvent () | 
| get the current event (when inside of evalEvent)   | |
| float | getSelectDist () | 
| Set the distance tolerance on hit checking in pixels.   | |
| bool | isPointInsideDeviceRect (float pointX, float pointY, float centerX, float centerY, float hitRectangleSize=0.0) | 
| returns whether the given point is inside a rectangle around the given center.   | |
| void | drawMiniRect (float xp, float yp, float ext, float lineWidth=1.f) | 
| Draws a small rectangle with given half side length and a line width.   | |
| void | drawDashedMiniRect (float xp, float yp, float ext, float lineWidth) | 
| void | drawFilledMiniRect (float xp, float yp, float ext, float lineWidth=1.f) | 
| Draws a small filled rectangle with given half side length.   | |
| void | drawMiniTriangle (float xp, float yp, float ext, float lineWidth=1.f) | 
| Draws a small triangle with given center point, half height and line width.   | |
| void | drawFilledMiniTriangle (float xp, float yp, float ext, float lineWidth=1.f) | 
| Draws a small filled triangle with given center point and half height.   | |
| void | drawMiniCircle (float xp, float yp, float ext, float lineWidth=1.f) | 
| Draws a small circle with given center point and radius.   | |
| void | drawFilledMiniCircle (float xp, float yp, float ext, float lineWidth=1.f) | 
| Draws a small filled circle with given center point and radius.   | |
| void | drawFixedSizeMiniCircleAt (float xp, float yp) | 
| Draws a fixed size small circle at the given position.   | |
| void | drawVoxelBorder (View2DSlice *slice, float vx, float vy, float vz) | 
| surround the given voxel with a border   | |
| int | getX () | 
| get the x device position of current event, only returns valid result when called inside of evalEvent()   | |
| int | getY () | 
| get the y device position of current event, only returns valid result when called inside of evalEvent()   | |
| virtual bool | isDrawingOn () | 
| check if drawing is on   | |
| virtual bool | isEditingOn () | 
| check if editing is on   | |
| virtual bool | isFixZOn () | 
| check if z should stay fixed   | |
| virtual bool | isClipToSlice () | 
| check if the image is clipped to slice   | |
| virtual void | fieldChanged (SoSensor *sensor) | 
| handle if any field has changed   | |
| bool | isCreateNewMode () | 
| check if extension is in createNewMode   | |
| void | setCreateNewMode (bool flag) | 
| set this extension to create new objects   | |
| bool | isCreateNewModeRequest () | 
| check if extension has a request for createNewMode   | |
| void | setCreateNewModeRequest (bool flag) | 
| set that extension want to become createNewMode   | |
| virtual bool | isActive () | 
| returns if the extension is active (derive this method in child) (in createNewMode or with a selected object)(called by SoView2D)   | |
| virtual void | deleteSelectedObject () | 
| deletes the currently active object (derive this method in child) (called by SoView2D)   | |
| virtual void | getStatusString (SbString &status) | 
| get the current status of this extension   | |
| virtual bool | evaluateEvent (SoView2D *view2d, View2DEvent *ec) | 
| virtual bool | ignoreEvent (View2DEvent *ec) | 
| Return true if ec has been handled before and if ignoreHandledEvents is True.   | |
| bool | wantsMouseOverUpdates () const | 
| public access to _wantsMouseOverUpdateEvents   | |
| virtual void | consumeEvent (View2DEvent *ec, bool handled=TRUE) | 
| Set handled-flag of ec to true (= consumed) if handled is True and setEventHandled is True.   | |
| int | getSelectedModifierMask () | 
| Get compare and ignore mask for the currently selected button/modifier combination, usable with SoPointingAction.   | |
| int | getSelectedIgnoreMask () | 
| SoPointingAction::Trigger | getPointingActionTriggerFromFields () | 
| Get the trigger that matches the button/modifier field state.   | |
| virtual bool | implementsManagedInteractionAndClassicEventHandling () const | 
| return true if this node is a hybrid module providing managed interaction and classic event handling - in this case SoView2D::useManagedInteraction decides which one to use   | |
  Public Member Functions inherited from SoInteractionProviderNode | |
| SoInteractionProviderNode () | |
| Default constructor.   | |
| ~SoInteractionProviderNode () override | |
| Destructor.   | |
| std::string | getID () const override | 
| Returns the ID string for identifying the provider and its actions.   | |
| void | objRef () override | 
| Memory management by reference counting; must be implemented in derived classes.   | |
| void | objUnref () override | 
  Public Member Functions inherited from SoInteractionOwner | |
| SoInteractionOwner () | |
| Default constructor.   | |
| ~SoInteractionOwner () override | |
| The destructor will destroy all interactions created with this object as owner.   | |
| std::list< SoInteraction * > | getInteractions (SoState *state) override | 
| Returns the list of all interactions of this provider.   | |
| void | pointerPosition (SoState *state, const SoPointerPosition &pos) override | 
| Same as below, with additional SoState argument. By default, simply calls the below version.   | |
| void | pointerLeftWindow (SoState *state) override | 
| Same as below, with additional SoState argument. By defaults, simply calls the below version.   | |
| void | addListener (SoInteractionOwnerListenerInterface *listener) | 
| Adds a listener object that is notified of changes in the interaction list.   | |
| void | removeListener (SoInteractionOwnerListenerInterface *listener) | 
| Removes a listener object that was notified of changes in the interaction list.   | |
  Public Member Functions inherited from SoInteractionProvider | |
| SoInteractionProvider () | |
| Default constructor.   | |
| virtual | ~SoInteractionProvider () | 
| template<class T > | |
| std::list< T * > | getInteractionsOfType (SoState *state) | 
| Returns list of interactions of a specific type.   | |
| virtual std::list< SoCommandAction * > | getCommandActions (SoState *state) | 
| virtual std::list< SoPointingAction * > | getPointingActions (SoState *state) | 
| virtual std::list< SoOffsetAction * > | getOffsetActions (SoState *state) | 
Static Public Member Functions | |
| static void | initClass () | 
| inventor runtime type system   | |
  Static Public Member Functions inherited from SoView2DCallback | |
| static void | initClass () | 
  Static Public Member Functions inherited from SoView2DExtension | |
| static void | initClass () | 
| Initializes this class.   | |
| static float | snapToPixelCenter (float coordinateComponent) | 
| Snaps the coordinate component to the pixel center.   | |
| static void | fieldChangedCB (void *data, SoSensor *sensor) | 
| inventor callbacks if any field has changed, calls fieldChanged   | |
| static bool | isImageParallel (SoSFMLImage *image, View2DSliceList *dsl) | 
Return true if image is parallel to the image of the slice list up to slice thickness.   | |
| static void | enableLineStippling (const SoSFEnum &lineStyleField) | 
| Set/reset stippling pattern.   | |
| static void | disableLineStippling (const SoSFEnum &lineStyleField) | 
| static void | getAxisOrientation (int axis, SbMatrix &matrix, char &negativeResult, char &positiveResult) | 
| Geometry helpers.   | |
| static float | pointToLineDistance (SbVec3f point, SbVec3f line1, SbVec3f line2) | 
| calculate 3D point to line distance   | |
| static float | pointToLineDistance (SbVec2f point, SbVec2f line1, SbVec2f line2) | 
| calculate 2D point to line distance   | |
| static Sign | edgeIntersectWithPlane (const SbVec3f &v1, const SbVec3f &v2, const SbPlane &plane, SbVec3f &intersect) | 
intersect given edge from v1 to v2 with given plane, returns sign and intersect point   | |
  Static Public Member Functions inherited from SoInteractionProviderNode | |
| static void | initClass () | 
| Initializes this class.   | |
  Static Public Member Functions inherited from SoInteractionProvider | |
| static void | registerInteractionProviderNode (SoType type, GetProviderFunc func) | 
| Registers a function to obtain a SoInteractionProvider from a SoNode.   | |
| static SoInteractionProvider * | getInteractionProvider (SoNode *node) | 
| Returns a SoInteractionProvider from a SoNode if registered, else NULL.   | |
Public Attributes | |
| SoSFMLImage | image | 
| Fields.   | |
| SoSFBool | cacheTextures | 
| flag if textures should be cached   | |
| SoSFEnum | blendMode | 
| select the blend mode of the overlay   | |
| SoSFBool | inheritFilterMode | 
| inherit filter mode   | |
| SoSFEnum | filterMode | 
| filter mode for rendering   | |
| SoSFFloat | alphaFactor | 
| set the alpha factor for drawing   | |
| SoSFColor | baseColor | 
| set the base color which is multiplied with the overlay   | |
| SoSFBool | overwriteCurrentTimePoint | 
| Should the current time point be overwritten?   | |
| SoSFInt32 | timePoint | 
| select the timepoint of the input image to render   | |
| SoSFInt32 | maxTimePoint | 
| maximum timepoint value available (maximum of timePoint field)   | |
| SoSFEnum | lutPrecision | 
| defines the precision of the LUT   | |
| SoSFBool | useWorldCoords | 
| if this flag is on, the overlay can also render correct subimage overlays if the image is parallel to the image rendered on SoView2D   | |
| SoSFBool | applyLut | 
| if this flag is enabled, the overlay uses the lut that is present in the scene graph, default is true   | |
| SoSFBool | isCheckerTiling | 
| If enabled, draws a checkerboard tile each.   | |
| SoSFInt32 | checkerTileSize | 
| The size of the checkerboard tiles.   | |
| SoSFBool | areCheckerTilesInverted | 
| Invert the checkerboard with this flag.   | |
| SoSFString | overlayName | 
| Sets the name of the overlay for usage in a SoView2DShaderOverlay.   | |
  Public Attributes inherited from SoView2DExtension | |
| SoSFColor | color | 
| color that should be used for drawing   | |
| SoSFBool | drawingOn | 
| flag if the extension should draw, needs to be checked inside of the draw() method   | |
| SoSFBool | editingOn | 
| flag if the extension should edit objects on mouse events, needs to be checked inside of the evalEvent() method   | |
| SoSFBool | maskValid | 
| flag if the event mask is valid.   | |
| SoSFFloat | selectionTolerance | 
| the selection tolerance in pixels   | |
| SoSFBool | wantsAllEvents | 
| flag if ALL events should be passed to evalEvent(), if disabled, events are only passed to evalEvent when the mouse mask gets valid   | |
| SoSFBool | wantsKeyEvents | 
| flag if keyboard events should be passed to evalEvent()   | |
| SoSFBool | wantsMouseWheelEvents | 
| flag if MouseWheel events should be passed to evalEvent()   | |
| SoSFBool | setEventHandled | 
| Set event handled if it is indeed handled by this extension.   | |
| SoSFBool | ignoreHandledEvents | 
| Ignore events, that have been handled by previous extensions.   | |
| SoSFEnum | button1 | 
| mouse mask for button1   | |
| SoSFEnum | button2 | 
| mouse mask for button2   | |
| SoSFEnum | button3 | 
| mouse mask for button3   | |
| SoSFEnum | shift | 
| shift modifier for mouse mask   | |
| SoSFEnum | control | 
| shift control for mouse mask   | |
| SoSFEnum | alt | 
| shift alt for mouse mask   | |
| SoSFBool | needsValidVoxel | 
| sets if a valid voxel must be hit to get evalEvent() calls   | |
| SoSFBool | renderOnSlab | 
| defines if the extension should be rendered on all slab slices   | |
| SoSFBool | createNewMode | 
| flag if extension is in createNewMode   | |
| SoSFTrigger | createNewModeRequest | 
| SoSFBool | clipToSlice | 
| Flag to clip drawing to slice.   | |
| SoSFEnum | cursorShape | 
| Set cursor shape if the mouse mask fits and mouseEvents are effectively sent to evalEvent for editing.   | |
| SoSFBool | fixZOn | 
| DEPRECATED flag that indicates that the extension should fix the z value, only used in SoView2DRectangle.   | |
  Public Attributes inherited from SoInteractionProviderNode | |
| SoSFString | instanceName | 
| Defines interface field to store the instance name.   | |
| SoSFString | interactionProviderID | 
| This field overrides the instanceName as providerID if specified.   | |
Protected Member Functions | |
| ~SoView2DOverlay () override | |
| Destructor.   | |
| virtual int | getTimePoint (View2DSliceList *slicelist, int slice) | 
| Returns the current timepoint which is either the actual shown timepoint or the timepoint overwritten by the field overwriteTimePoint; The slice parameter is not used in the standard implementation but can be necessary in derived classes.   | |
  Protected Member Functions inherited from SoView2DExtension | |
| virtual void | editingOnChanged (SoField *) | 
| called when editingOn field is touched:   | |
| virtual void | buttonMaskChanged (SoField *) | 
| called when one of the button/modifier fields is touched:   | |
| virtual void | createNewModeRequestTriggered (SoField *) | 
| called when createNewModeRequest field ist touched:   | |
| ~SoView2DExtension () override | |
| destructor   | |
| void | GLRender (SoGLRenderAction *action) override | 
| Inventor actions.   | |
| void | callback (SoCallbackAction *action) override | 
| void | handleEvent (SoHandleEventAction *action) override | 
| void | getMatrix (SoGetMatrixAction *action) override | 
| void | getBoundingBox (SoGetBoundingBoxAction *action) override | 
| void | pick (SoPickAction *action) override | 
| void | doAction (SoAction *action) override | 
  Protected Member Functions inherited from SoInteractionOwner | |
| virtual void | pointerPosition (const SoPointerPosition &) | 
| Override this if you always need to be informed of the current mouse cursor position.   | |
| virtual void | pointerLeftWindow () | 
| This is called when the mouse cursor leaves the window.   | |
| bool | hasInteractions () const | 
| Returns whether there are any actions defined by this owner.   | |
| template<class T > | |
| bool | hasInteractionsOfType () const | 
| Same as above, but asking for a specific type of interaction.   | |
| void | addPointingAction (SoPointingAction *) | 
| void | addCommandAction (SoCommandAction *) | 
| void | addOffsetAction (SoOffsetAction *) | 
Protected Attributes | |
| View2DLut * | _lutData | 
| the lut data that is rendered   | |
| ml::LUTFunction * | _lutFunction | 
| the lut from the scene, stored by GLRender   | |
| bool | _reloadData | 
| flag if data needs to be reloaded   | |
| int | _id | 
| id for texture caching   | |
| int | _oldTimePoint | 
| previous timepoint   | |
| bool | _oldUseWorldCoords | 
| previous world coord flag   | |
| unsigned int | _imageSerial | 
| serial number of last input image   | |
| SoView2DShaderOverlayInfo | _overlayInfo | 
| for usage by shaders   | |
  Protected Attributes inherited from SoView2DExtension | |
| SoNodeSensor * | _nodeSensor | 
| node sensor that is used to notice field changes   | |
| float | _rgbColor [4] | 
| Color of the object, update on each field change by _nodeSensor.   | |
| bool | _wantsMouseOverUpdateEvents | 
| set this flag to receive mouse over events while the extension is active   | |
Additional Inherited Members | |
  Public Types inherited from SoView2DExtension | |
| enum | Sign { ZERO , NEGATIVE , POSITIVE } | 
| defines the sign of a number, with zero as an extra value  More... | |
  Public Types inherited from SoInteractionProvider | |
| typedef SoInteractionProvider *(* | GetProviderFunc) (SoNode *) | 
Draws an overlay image on the SoView2D.
SoView2DOverlay is derived from SoView2DCallback to allow others to register with the callback
Definition at line 39 of file SoView2DOverlay.h.
| SoView2DOverlay::SoView2DOverlay | ( | ) | 
Constructor.
      
  | 
  overrideprotected | 
Destructor.
      
  | 
  overridevirtual | 
reimplemented from SoView2DExtension
Reimplemented from SoView2DCallback.
      
  | 
  overridevirtual | 
reimplemented from SoView2DExtension
Reimplemented from SoView2DExtension.
      
  | 
  overridevirtual | 
reimplemented from SoView2DExtension
Reimplemented from SoView2DCallback.
      
  | 
  protectedvirtual | 
Returns the current timepoint which is either the actual shown timepoint or the timepoint overwritten by the field overwriteTimePoint; The slice parameter is not used in the standard implementation but can be necessary in derived classes.
      
  | 
  override | 
reimplemented from SoNode, stores the LUT for later rendering
      
  | 
  static | 
inventor runtime type system
      
  | 
  overridevirtual | 
reimplemented from SoView2DExtension
Reimplemented from SoView2DExtension.
      
  | 
  protected | 
id for texture caching
Definition at line 122 of file SoView2DOverlay.h.
      
  | 
  protected | 
serial number of last input image
Definition at line 128 of file SoView2DOverlay.h.
      
  | 
  protected | 
the lut data that is rendered
Definition at line 114 of file SoView2DOverlay.h.
      
  | 
  protected | 
the lut from the scene, stored by GLRender
Definition at line 117 of file SoView2DOverlay.h.
      
  | 
  protected | 
previous timepoint
Definition at line 124 of file SoView2DOverlay.h.
      
  | 
  protected | 
previous world coord flag
Definition at line 126 of file SoView2DOverlay.h.
      
  | 
  protected | 
for usage by shaders
Definition at line 131 of file SoView2DOverlay.h.
      
  | 
  protected | 
flag if data needs to be reloaded
Definition at line 120 of file SoView2DOverlay.h.
| SoSFFloat SoView2DOverlay::alphaFactor | 
set the alpha factor for drawing
Definition at line 57 of file SoView2DOverlay.h.
| SoSFBool SoView2DOverlay::applyLut | 
if this flag is enabled, the overlay uses the lut that is present in the scene graph, default is true
Definition at line 74 of file SoView2DOverlay.h.
| SoSFBool SoView2DOverlay::areCheckerTilesInverted | 
Invert the checkerboard with this flag.
Definition at line 83 of file SoView2DOverlay.h.
| SoSFColor SoView2DOverlay::baseColor | 
set the base color which is multiplied with the overlay
Definition at line 59 of file SoView2DOverlay.h.
| SoSFEnum SoView2DOverlay::blendMode | 
select the blend mode of the overlay
Definition at line 51 of file SoView2DOverlay.h.
| SoSFBool SoView2DOverlay::cacheTextures | 
flag if textures should be cached
Definition at line 49 of file SoView2DOverlay.h.
| SoSFInt32 SoView2DOverlay::checkerTileSize | 
The size of the checkerboard tiles.
Definition at line 80 of file SoView2DOverlay.h.
| SoSFEnum SoView2DOverlay::filterMode | 
filter mode for rendering
Definition at line 55 of file SoView2DOverlay.h.
| SoSFMLImage SoView2DOverlay::image | 
| SoSFBool SoView2DOverlay::inheritFilterMode | 
inherit filter mode
Definition at line 53 of file SoView2DOverlay.h.
| SoSFBool SoView2DOverlay::isCheckerTiling | 
If enabled, draws a checkerboard tile each.
Definition at line 77 of file SoView2DOverlay.h.
| SoSFEnum SoView2DOverlay::lutPrecision | 
defines the precision of the LUT
Definition at line 67 of file SoView2DOverlay.h.
| SoSFInt32 SoView2DOverlay::maxTimePoint | 
maximum timepoint value available (maximum of timePoint field)
Definition at line 65 of file SoView2DOverlay.h.
| SoSFString SoView2DOverlay::overlayName | 
Sets the name of the overlay for usage in a SoView2DShaderOverlay.
Definition at line 86 of file SoView2DOverlay.h.
| SoSFBool SoView2DOverlay::overwriteCurrentTimePoint | 
Should the current time point be overwritten?
Definition at line 61 of file SoView2DOverlay.h.
| SoSFInt32 SoView2DOverlay::timePoint | 
select the timepoint of the input image to render
Definition at line 63 of file SoView2DOverlay.h.
| SoSFBool SoView2DOverlay::useWorldCoords | 
if this flag is on, the overlay can also render correct subimage overlays if the image is parallel to the image rendered on SoView2D
Definition at line 71 of file SoView2DOverlay.h.