#include <Inventor/nodes/SoExtSelection.h>
Inheritance diagram for SoExtSelection::
Public Types | |
enum | LassoType { NOLASSO, LASSO, RECTANGLE } |
enum | LassoPolicy { FULL_BBOX, PART_BBOX, FULL, PART } |
Public Methods | |
SoExtSelection (void) | |
void | useOverlay (SbBool overlay=TRUE) |
SbBool | isUsingOverlay (void) |
SoSeparator * | getOverlaySceneGraph (void) |
void | setOverlayLassoColorIndex (const int index) |
int | getOverlayLassoColorIndex (void) |
void | setLassoColor (const SbColor &color) |
const SbColor & | getLassoColor (void) |
void | setLassoWidth (const float width) |
float | getLassoWidth (void) |
void | setOverlayLassoPattern (const unsigned short pattern) |
unsigned short | getOverlayLassoPattern (void) |
void | animateOverlayLasso (const SbBool animate=TRUE) |
SbBool | isOverlayLassoAnimated (void) |
virtual void | handleEvent (SoHandleEventAction *action) |
virtual void | GLRenderBelowPath (SoGLRenderAction *action) |
void | setLassoFilterCallback (SoLassoSelectionFilterCB *f, void *userdata=NULL, const SbBool callonlyifselectable=TRUE) |
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 |
Static Public Methods | |
void | initClass (void) |
Public Attributes | |
SoSFEnum | lassoType |
SoSFEnum | lassoPolicy |
Protected Methods | |
virtual | ~SoExtSelection () |
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.
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 SoExtSelection and TGS SoExtSelection.
|
Enum for type of lasso selection.
|
|
Enum for specifying how objects are selected. |
|
Constructor. |
|
Destructor. |
|
Sets up initialization for data common to all instances of this class, like submitting necessary information to the Coin type system. Reimplemented from SoSelection. |
|
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. |
|
Returns whether overlay planes are used to draw the lasso.
|
|
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.) |
|
Obsoleted in Coin, use SoExtSelection::setLassoColor() instead. |
|
Obsoleted in Coin, use SoExtSelection::getLassoColor() instead.
|
|
Sets the lasso/rectangle line color. Default value is (1.0, 1.0, 1.0). |
|
Returns the lasso color. |
|
Sets the lasso line width. Default value is 1.0. |
|
Returns the lasso line width. |
|
Sets the lasso line pattern. Default value is 0xf0f0. |
|
Returns the lasso line pattern. |
|
Sets whether the lasso should be animated by scrolling the line pattern. |
|
Returns whether the lasso is set to animate or not. |
|
Overloaded to handle lasso selection. Reimplemented from SoSelection. |
|
Overloaded to render lasso. Reimplemented from SoSeparator. |
|
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. |
|
Sets the callback that will be called for every triangle inside the lasso/rectangle when selecting. The user should return FALSE if he/she wants to continue receiving callbacks. When the user returns TRUE, the object/shape is selected, and no more callbacks will be invoked for the object. |
|
Sets the callback that will be called for every line segment inside the lasso/rectangle when selecting. The user should return FALSE if he/she wants to continue receiving callbacks. When the user returns TRUE, the object/shape is selected, and no more callbacks will be invoked for the object. |
|
Sets the callback that will be called for every point inside the lasso/rectangle when selecting. The user should return FALSE if he/she wants to continue receiving callbacks. When the user returns TRUE, the object/shape is selected, and no more callbacks will be invoked for the object. |
|
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. |
|
Field for lasso type. Default value is NOLASSO. |
|
Field for lasso policy. Default value is FULL_BBOX. |