Coin Logo http://www.sim.no
http://www.coin3d.org

Public Types | Public Member Functions | Static Public Member Functions | Public Attributes | Protected Member Functions | Static Protected Member Functions | Friends
SoExtSelection Class Reference

The SoExtSelection class can be used for extended selection functionality.This class enables you to select geometry by specifying a lasso (a polygon) or a rectangle on screen. When objects are selected, you'll receive the same callbacks as for the SoSelection node. More...

#include <Inventor/nodes/SoExtSelection.h>

Inheritance diagram for SoExtSelection:
SoSelection SoSeparator SoGroup SoNode SoFieldContainer SoBase

List of all members.

Public Types

enum  LassoType { NOLASSO, LASSO, RECTANGLE }
enum  LassoPolicy { FULL_BBOX, PART_BBOX, FULL, PART }
enum  LassoMode { ALL_SHAPES, VISIBLE_SHAPES }
- Public Types inherited from SoSelection
enum  Policy { SINGLE, TOGGLE, SHIFT }
- Public Types inherited from SoSeparator
enum  CacheEnabled { OFF, ON, AUTO }

Public Member Functions

virtual SoType getTypeId (void) const
 SoExtSelection (void)
void useOverlay (SbBool overlay=1)
SbBool isUsingOverlay (void)
SoSeparatorgetOverlaySceneGraph (void)
void setOverlayLassoColorIndex (const int index)
int getOverlayLassoColorIndex (void)
void setLassoColor (const SbColor &color)
const SbColorgetLassoColor (void)
void setLassoWidth (const float width)
float getLassoWidth (void)
void setOverlayLassoPattern (const unsigned short pattern)
unsigned short getOverlayLassoPattern (void)
void animateOverlayLasso (const SbBool animate=1)
SbBool isOverlayLassoAnimated (void)
virtual void handleEvent (SoHandleEventAction *action)
virtual void GLRenderBelowPath (SoGLRenderAction *action)
void select (SoNode *root, int numcoords, SbVec2f *lasso, const SbViewportRegion &vp, SbBool shiftpolicy)
void select (SoNode *root, int numcoords, SbVec3f *lasso, const SbViewportRegion &vp, SbBool shiftkeypolicy)
const SbVec2sgetLassoCoordsDC (int &numCoords)
const SbVec3fgetLassoCoordsWC (int &numCoords)
const SoPathListgetSelectionPathList () const
void setLassoFilterCallback (SoLassoSelectionFilterCB *f, void *userdata=NULL, const SbBool callonlyifselectable=1)
void setTriangleFilterCallback (SoExtSelectionTriangleCB *func, void *userdata=NULL)
void setLineSegmentFilterCallback (SoExtSelectionLineSegmentCB *func, void *userdata=NULL)
void setPointFilterCallback (SoExtSelectionPointCB *func, void *userdata=NULL)
SbBool wasShiftDown (void) const
- Public Member Functions inherited from SoSelection
 SoSelection (void)
 SoSelection (const int nChildren)
void select (const SoPath *path)
void select (SoNode *node)
void deselect (const SoPath *path)
void deselect (const int which)
void deselect (SoNode *node)
void toggle (const SoPath *path)
void toggle (SoNode *node)
SbBool isSelected (const SoPath *path) const
SbBool isSelected (SoNode *node) const
void deselectAll (void)
int getNumSelected (void) const
const SoPathListgetList (void) const
SoPathgetPath (const int index) const
SoPathoperator[] (const int i) const
void addSelectionCallback (SoSelectionPathCB *f, void *userData=NULL)
void removeSelectionCallback (SoSelectionPathCB *f, void *userData=NULL)
void addDeselectionCallback (SoSelectionPathCB *f, void *userData=NULL)
void removeDeselectionCallback (SoSelectionPathCB *f, void *userData=NULL)
void addStartCallback (SoSelectionClassCB *f, void *userData=NULL)
void removeStartCallback (SoSelectionClassCB *f, void *userData=NULL)
void addFinishCallback (SoSelectionClassCB *f, void *userData=NULL)
void removeFinishCallback (SoSelectionClassCB *f, void *userData=NULL)
void setPickFilterCallback (SoSelectionPickCB *f, void *userData=NULL, const SbBool callOnlyIfSelectable=1)
void setPickMatching (const SbBool pickMatching)
SbBool isPickMatching (void) const
SbBool getPickMatching (void) const
void addChangeCallback (SoSelectionClassCB *f, void *userData=NULL)
void removeChangeCallback (SoSelectionClassCB *f, void *userData=NULL)
- Public Member Functions inherited from SoSeparator
 SoSeparator (void)
 SoSeparator (const int nchildren)
virtual void doAction (SoAction *action)
virtual void GLRender (SoGLRenderAction *action)
virtual void GLRenderInPath (SoGLRenderAction *action)
virtual void GLRenderOffPath (SoGLRenderAction *action)
virtual void callback (SoCallbackAction *action)
virtual void getBoundingBox (SoGetBoundingBoxAction *action)
virtual void getMatrix (SoGetMatrixAction *action)
virtual void rayPick (SoRayPickAction *action)
virtual void search (SoSearchAction *action)
virtual void getPrimitiveCount (SoGetPrimitiveCountAction *action)
virtual void audioRender (SoAudioRenderAction *action)
virtual void notify (SoNotList *nl)
virtual SbBool affectsState (void) const
- Public Member Functions inherited from SoGroup
 SoGroup (void)
 SoGroup (int nchildren)
virtual void addChild (SoNode *node)
virtual void insertChild (SoNode *child, int newchildindex)
virtual SoNodegetChild (int index) const
virtual int findChild (const SoNode *node) const
virtual int getNumChildren (void) const
virtual void removeChild (int childindex)
virtual void removeChild (SoNode *child)
virtual void removeAllChildren (void)
virtual void replaceChild (int index, SoNode *newchild)
virtual void replaceChild (SoNode *oldchild, SoNode *newchild)
virtual void pick (SoPickAction *action)
virtual void write (SoWriteAction *action)
virtual SoChildListgetChildren (void) const
- Public Member Functions inherited from SoNode
void setOverride (const SbBool state)
SbBool isOverride (void) const
void setNodeType (const NodeType type)
NodeType getNodeType (void) const
virtual SoNodecopy (SbBool copyconnections=0) const
virtual void grabEventsSetup (void)
virtual void grabEventsCleanup (void)
virtual void startNotify (void)
uint32_t getNodeId (void) const
virtual void writeInstance (SoOutput *out)
virtual SoNodeaddToCopyDict (void) const
virtual SoFieldContainercopyThroughConnection (void) const
- Public Member Functions inherited from SoFieldContainer
void setToDefaults (void)
SbBool hasDefaultValues (void) const
SbBool fieldsAreEqual (const SoFieldContainer *container) const
void copyFieldValues (const SoFieldContainer *container, SbBool copyconnections=0)
SbBool set (const char *const fielddata)
void get (SbString &fielddata)
virtual int getFields (SoFieldList &l) const
virtual int getAllFields (SoFieldList &l) const
virtual SoFieldgetField (const SbName &name) const
virtual SoFieldgetEventIn (const SbName &name) const
virtual SoFieldgetEventOut (const SbName &name) const
SbBool getFieldName (const SoField *const field, SbName &name) const
SbBool enableNotify (const SbBool flag)
SbBool isNotifyEnabled (void) const
SbBool set (const char *fielddata, SoInput *in)
void get (SbString &fielddata, SoOutput *out)
virtual SbBool validateNewFieldValue (SoField *field, void *newval)
virtual void addWriteReference (SoOutput *out, SbBool isfromfield=0)
SbBool getIsBuiltIn (void) const
void setUserData (void *userdata) const
void * getUserData (void) const
- Public Member Functions inherited from SoBase
void ref (void) const
void unref (void) const
void unrefNoDelete (void) const
int32_t getRefCount (void) const
void touch (void)
SbBool isOfType (SoType type) const
virtual SbName getName (void) const
virtual void setName (const SbName &newname)
void addAuditor (void *const auditor, const SoNotRec::Type type)
void removeAuditor (void *const auditor, const SoNotRec::Type type)
const SoAuditorListgetAuditors (void) const
SbBool shouldWrite (void)
void assertAlive (void) const

Static Public Member Functions

static SoType getClassTypeId (void)
static void initClass (void)

Public Attributes

SoSFEnum lassoType
SoSFEnum lassoPolicy
SoSFEnum lassoMode
- Public Attributes inherited from SoSelection
SoSFEnum policy
- Public Attributes inherited from SoSeparator
SoSFEnum renderCaching
SoSFEnum boundingBoxCaching
SoSFEnum renderCulling
SoSFEnum pickCulling

Protected Member Functions

virtual const SoFieldDatagetFieldData (void) const
virtual ~SoExtSelection ()
- Protected Member Functions inherited from SoSelection
virtual ~SoSelection ()
void invokeSelectionPolicy (SoPath *path, SbBool shiftDown)
void performSingleSelection (SoPath *path)
void performToggleSelection (SoPath *path)
SoPathcopyFromThis (const SoPath *path) const
void addPath (SoPath *path)
void removePath (const int which)
int findPath (const SoPath *path) const
- Protected Member Functions inherited from SoSeparator
virtual ~SoSeparator ()
virtual SbBool cullTest (SoState *state)
virtual SbBool cullTest (SoGLRenderAction *action, int &cullresults)
virtual SbBool readInstance (SoInput *in, unsigned short flags)
- Protected Member Functions inherited from SoGroup
virtual ~SoGroup ()
virtual SbBool readChildren (SoInput *in)
virtual void copyContents (const SoFieldContainer *from, SbBool copyconnections)
- Protected Member Functions inherited from SoNode
 SoNode (void)
virtual ~SoNode ()
- Protected Member Functions inherited from SoFieldContainer
 SoFieldContainer (void)
 ~SoFieldContainer ()
- Protected Member Functions inherited from SoBase
 SoBase (void)
virtual ~SoBase ()
virtual void destroy (void)
SbBool hasMultipleWriteRefs (void) const
SbBool writeHeader (SoOutput *out, SbBool isgroup, SbBool isengine) const
void writeFooter (SoOutput *out) const
virtual const char * getFileFormatName (void) const

Static Protected Member Functions

static const SoFieldData ** getFieldDataPtr (void)

Friends

class SoExtSelectionP

Additional Inherited Members

- Protected Attributes inherited from SoSelection
SoPathList selectionList
SoCallbackListselCBList
SoCallbackListdeselCBList
SoCallbackListstartCBList
SoCallbackListfinishCBList
SoSelectionPickCB * pickCBFunc
void * pickCBData
SbBool callPickCBOnlyIfSelectable
SoCallbackListchangeCBList
SoPathmouseDownPickPath
SbBool pickMatching

Detailed Description

The SoExtSelection class can be used for extended selection functionality.

This class enables you to select geometry by specifying a lasso (a polygon) or a rectangle on screen. When objects are selected, you'll receive the same callbacks as for the SoSelection node.

The application programmer interface of this class is somewhat complex, due to it's non-trivial functionality. To see an extensive usage example of the SoExtSelection node, we advise you to go look at the "extselection" example application in the "nodes/" directory of Systems in Motion's SoGuiExamples CVS module. Further information and links for downloading and building this module should be available at www.coin3d.org.

This node class is an extension versus the original SGI Inventor v2.1 API. It is based on the API of TGS Inventor's SoExtSelection, and we aim to be fully compatible with this node to enable users to switch between using Coin and TGS Inventor. Please contact us if you find discrepancies between Coin's SoExtSelection and TGS's SoExtSelection node.

FILE FORMAT/DEFAULTS:

Since:
TGS Inventor 2.5
Coin 1.0

Member Enumeration Documentation

Enum for type of lasso selection.

Enumerator:
NOLASSO 

Makes this node behave like a normal SoSelection node.

LASSO 

Select objects using a lasso. Selections can be aborted by the end-user by hitting the END key on the keyboard.

RECTANGLE 

Select objects using a rectangle. Selections can be aborted by the end-user by hitting the END key on the keyboard.

Enum for specifying how objects are selected.

Enumerator:
FULL_BBOX 

The entire bounding box must be inside the lasso/rectangle.

PART_BBOX 

Some part of the bounding box must intersect the lasso/rectangle.

FULL 

All primitives must be completely inside the lasso/rectangle.

PART 

Some primitive must intersect the lasso/rectangle.

Enum for specifying selection mode.

Enumerator:
ALL_SHAPES 

All primitives inside the lasso/rectangle will be selected.

VISIBLE_SHAPES 

All visible primitives inside the lasso/rectangle will be selected.


Constructor & Destructor Documentation

SoExtSelection::SoExtSelection ( void  )
SoExtSelection::~SoExtSelection ( )
protectedvirtual

Destructor.


Member Function Documentation

SoType SoExtSelection::getClassTypeId ( void  )
static

This static method returns the SoType object associated with objects of this class.

Reimplemented from SoSelection.

SoType SoExtSelection::getTypeId ( void  ) const
virtual

Returns the type identification of an object derived from a class inheriting SoBase. This is used for run-time type checking and "downward" casting.

Usage example:

void foo(SoNode * node)
{
if (node->getTypeId() == SoFile::getClassTypeId()) {
SoFile * filenode = (SoFile *)node; // safe downward cast, knows the type
}
else if (node->getTypeId().isOfType(SoGroup::getClassTypeId())) {
SoGroup * group = (SoGroup *)node; // safe downward cast, knows the type
}
}

For application programmers wanting to extend the library with new nodes, engines, nodekits, draggers or others: this method needs to be overridden in all subclasses. This is typically done as part of setting up the full type system for extension classes, which is usually accomplished by using the pre-defined macros available through for instance Inventor/nodes/SoSubNode.h (SO_NODE_INIT_CLASS and SO_NODE_CONSTRUCTOR for node classes), Inventor/engines/SoSubEngine.h (for engine classes) and so on.

For more information on writing Coin extensions, see the class documentation of the toplevel superclasses for the various class groups.

Reimplemented from SoSelection.

const SoFieldData ** SoExtSelection::getFieldDataPtr ( void  )
staticprotected

This API member is considered internal to the library, as it is not likely to be of interest to the application programmer.

Reimplemented from SoSelection.

const SoFieldData * SoExtSelection::getFieldData ( void  ) const
protectedvirtual

Returns a pointer to the class-wide field data storage object for this instance. If no fields are present, returns NULL.

Reimplemented from SoSelection.

void SoExtSelection::initClass ( void  )
static

Sets up initialization for data common to all instances of this class, like submitting necessary information to the Coin type system.

Reimplemented from SoSelection.

Referenced by SoInteraction::init().

void SoExtSelection::useOverlay ( SbBool  overlay = 1)

Specifies whether the overlay planes should be used to render the lasso.

This method has been obsoleted in Coin, as most graphics cards comes without support for overlay rendering. A better strategy is to just "overlay" the lasso graphics on top of the scene after everything else has been rendered – and this is the strategy we apply in Coin.

SbBool SoExtSelection::isUsingOverlay ( void  )

Returns whether overlay planes are used to draw the lasso.

See also:
useOverlay().
SoSeparator * SoExtSelection::getOverlaySceneGraph ( void  )

Returns the scene graph for overlay rendering. Will always return NULL in Coin, as this method has been obsoleted.

(It is probably used in TGS Inventor from the SoXt / SoWin libraries' So[Xt|Win]RenderArea class to fetch the overlay graph to draw, and as such should be treated as an internal method.)

void SoExtSelection::setOverlayLassoColorIndex ( const int  index)

Obsoleted in Coin, use SoExtSelection::setLassoColor() instead.

int SoExtSelection::getOverlayLassoColorIndex ( void  )

Obsoleted in Coin, use SoExtSelection::getLassoColor() instead.

See also:
setOverlayLassoColorIndex().
void SoExtSelection::setLassoColor ( const SbColor color)

Sets the lasso/rectangle line color. Default value is (1.0, 1.0, 1.0).

const SbColor & SoExtSelection::getLassoColor ( void  )

Returns the lasso color.

void SoExtSelection::setLassoWidth ( const float  width)

Sets the lasso line width. Default value is 1.0.

float SoExtSelection::getLassoWidth ( void  )

Returns the lasso line width.

void SoExtSelection::setOverlayLassoPattern ( const unsigned short  pattern)

Sets the lasso line pattern. Default value is 0xf0f0.

unsigned short SoExtSelection::getOverlayLassoPattern ( void  )

Returns the lasso line pattern.

void SoExtSelection::animateOverlayLasso ( const SbBool  animate = 1)

Sets whether the lasso should be animated by scrolling the line pattern.

SbBool SoExtSelection::isOverlayLassoAnimated ( void  )

Returns whether the lasso is set to animate or not.

void SoExtSelection::handleEvent ( SoHandleEventAction action)
virtual

Action method for SoHandleEventAction.

Inspects the event data from action, and processes it if it is something which this node should react to.

Nodes influencing relevant state variables for how event handling is done also overrides this method.

Reimplemented from SoSelection.

References SoHandleEventAction::getEvent(), SoSelection::handleEvent(), SoHandleEventAction::isHandled(), LASSO, lassoType, NOLASSO, RECTANGLE, SoBase::touch(), and SoEvent::wasShiftDown().

void SoExtSelection::GLRenderBelowPath ( SoGLRenderAction action)
virtual

SGI Open Inventor v2.1 obsoleted support for SoGLRenderAction::addMethod(). Instead, GLRender() might be called directly, and to optimize traversal, the SoSeparator node calls GLRenderBelowPath whenever the path code is BELOW_PATH or NO_PATH (path code is guaranteed not to change). To be compatible with SGI's Inventor (and thereby also TGS') we have chosen to follow their implementation in this respect.

SoSeparator::GLRenderBelowPath() do not traverse its children using SoChildList::traverse(), but calls GLRenderBelowPath() directly for all its children.

Reimplemented from SoSeparator.

References SoGLRenderAction::addDelayedPath(), SoPath::copy(), SoFieldContainer::get(), SoAction::getCurPath(), SoAction::getState(), SbViewportRegion::getViewportOriginPixels(), SbViewportRegion::getViewportSizePixels(), SoSeparator::GLRenderBelowPath(), SoGLRenderAction::isRenderingDelayedPaths(), SoState::pop(), and SoState::push().

void SoExtSelection::select ( SoNode root,
int  numcoords,
SbVec2f lasso,
const SbViewportRegion vp,
SbBool  shiftpolicy 
)

Simulate lasso selection programmatically.

This function is currently just stubbed.

Since:
Coin 2.5
void SoExtSelection::select ( SoNode root,
int  numcoords,
SbVec3f lasso,
const SbViewportRegion vp,
SbBool  shiftpolicy 
)

Simulate lasso selection programmatically.

This function is currently just stubbed.

Since:
Coin 2.5
const SbVec2s * SoExtSelection::getLassoCoordsDC ( int &  numCoords)

Returns lasso coordinates in device coordinates.

This function is currently just stubbed.

Since:
Coin 2.5
const SbVec3f * SoExtSelection::getLassoCoordsWC ( int &  numCoords)

Returns lasso coordinates in world coordinates.

This function is currently just stubbed.

Since:
Coin 2.5
const SoPathList & SoExtSelection::getSelectionPathList ( void  ) const

Returns a pathlist containing selected objects.

This function is currently just stubbed.

Since:
Coin 2.5
void SoExtSelection::setLassoFilterCallback ( SoLassoSelectionFilterCB *  f,
void *  userdata = NULL,
const SbBool  callonlyifselectable = 1 
)

The lasso selection filter callback is called when a node is about to be selected, and enables the application programmer to return a new path to be used when selecting. The new returned path should not be ref'd. SoExtSelection will ref() and unref() it.

To cancel the selection, return NULL from the callback.

if callonlyifselectable is TRUE, the callback will only be invoked when the path to the new node pass through the SoExtSelection node.

This method is specific to Coin, and is not part of TGS OIV.

void SoExtSelection::setTriangleFilterCallback ( SoExtSelectionTriangleCB *  func,
void *  userdata = NULL 
)

Sets the callback that will be called for every triangle inside the lasso/rectangle when selecting.

The callback should return FALSE if it wants to continue being invoked. When the callback returns TRUE, the object/shape is selected, and no more callbacks will be invoked for the object.

See also:
setLineSegmentFilterCallback, setPointFilterCallback
void SoExtSelection::setLineSegmentFilterCallback ( SoExtSelectionLineSegmentCB *  func,
void *  userdata = NULL 
)

Sets the callback that will be called for every line segment inside the lasso/rectangle when selecting.

The callback should return FALSE if it wants to continue being invoked. When the callback returns TRUE, the object/shape is selected, and no more callbacks will be invoked for the object.

See also:
setTriangleFilterCallback, setPointFilterCallback
void SoExtSelection::setPointFilterCallback ( SoExtSelectionPointCB *  func,
void *  userdata = NULL 
)

Sets the callback that will be called for every point inside the lasso/rectangle when selecting.

The callback should return FALSE if it wants to continue being invoked. When the user returns TRUE, the object/shape is selected, and no more callbacks will be invoked for the object.

See also:
setLineSegmentFilterCallback, setTriangleFilterCallback
SbBool SoExtSelection::wasShiftDown ( void  ) const

Returns whether the SHIFT key was pressed during the latest user interaction. This is useful if you want to respect the shift policy while selecting primitives.

This method is specific to Coin, and is not part of TGS OIV.


Member Data Documentation

SoSFEnum SoExtSelection::lassoType

Field for lasso type. Default value is SoExtSelection::NOLASSO.

Selections with type SoExtSelection::RECTANGLE or SoExtSelection::LASSO can be aborted by the end-user by hitting the END key on the keyboard.

Referenced by handleEvent(), and SoExtSelection().

SoSFEnum SoExtSelection::lassoPolicy

Field for lasso policy. Default value is FULL_BBOX.

Referenced by SoExtSelection().

SoSFEnum SoExtSelection::lassoMode

Field for lasso mode. Default value is ALL_SHAPES.

Set this field to VISIBLE_SHAPES to make only the primitives visible from the current viewpoint be selected.

Referenced by SoExtSelection().


The documentation for this class was generated from the following files:

Copyright © 1998-2007 by Systems in Motion AS. All rights reserved.

Generated on Thu Jul 26 2012 for Coin by Doxygen. 1.8.1.1