Scroll to navigation

SoHandleBoxDragger(3IV)() SoHandleBoxDragger(3IV)()

NAME

SoHandleBoxDragger — box you can scale, stretch and translate by dragging with the mouse

INHERITS FROM

SoBase > SoFieldContainer > SoNode > SoBaseKit > SoInteractionKit > SoDragger > SoHandleBoxDragger

SYNOPSIS

#include <Inventor/draggers/SoHandleBoxDragger.h>
 

Fields from class SoHandleBoxDragger:
 

SoSFVec3f scaleFactor
 

SoSFVec3f translation
 

Fields from class SoDragger:
 

SoSFBool isActive
 

Fields from class SoInteractionKit:
 

SoSFEnum renderCaching
 

SoSFEnum boundingBoxCaching
 

SoSFEnum renderCulling
 

SoSFEnum pickCulling
 

Parts from class SoBaseKit:
 

(SoNodeKitListPart) callbackList
 

Methods from class SoHandleBoxDragger:
 

SoHandleBoxDragger()
 

static const SoNodekitCatalog * getClassNodekitCatalog () const
 

static SoType getClassTypeId()
 

Methods from class SoDragger:
 

void addStartCallback(SoDraggerCB *f, void *userData = NULL)
 

void removeStartCallback(SoDraggerCB *f, void *userData = NULL)
 

void addMotionCallback(SoDraggerCB *f, void *userData = NULL)
 

void removeMotionCallback(SoDraggerCB *f, void *userData = NULL)
 

void addFinishCallback(SoDraggerCB *f, void *userData = NULL)
 

void removeFinishCallback(SoDraggerCB *f, void *userData = NULL)
 

void addValueChangedCallback(SoDraggerCB *f, void *userData = NULL)
 

void removeValueChangedCallback(SoDraggerCB *f, void *userData = NULL)
 

SbBool enableValueChangedCallbacks()
 

void setMinGesture(int pixels)
 

int getMinGesture() const
 

static void setMinScale(float newMinScale)
 

static float getMinScale()
 

Methods from class SoInteractionKit:
 

virtual SbBool setPartAsPath(const SbName &partName, SoPath *surrogatePath )
 

Methods from class SoBaseKit:
 

virtual const SoNodekitCatalog * getNodekitCatalog() const
 

virtual SoNode * getPart(const SbName &partName, SbBool makeIfNeeded)
 

SbString getPartString(const SoBase *part)
 

virtual SoNodeKitPath * createPathToPart(const SbName &partName, SbBool makeIfNeeded, const SoPath *pathToExtend = NULL)
 

virtual SbBool setPart(const SbName &partName, SoNode *newPart)
 

SbBool set(char *partName, char *parameters)
 

SbBool set(char *nameValuePairs)
 

static SbBool isSearchingChildren()
 

static void setSearchingChildren(SbBool newVal)
 

Methods from class SoNode:
 

void setOverride(SbBool state)
 

SbBool isOverride() const
 

SoNode * copy(SbBool copyConnections = FALSE) const
 

virtual SbBool affectsState() const
 

static SoNode * getByName(const SbName &name)
 

static int getByName(const SbName &name, SoNodeList &list)
 

Methods from class SoFieldContainer:
 

void setToDefaults()
 

SbBool hasDefaultValues() const
 

SbBool fieldsAreEqual(const SoFieldContainer *fc) const
 

void copyFieldValues(const SoFieldContainer *fc, SbBool copyConnections = FALSE)
 

void get(SbString &fieldDataString)
 

virtual int getFields(SoFieldList &resultList) const
 

virtual SoField * getField(const SbName &fieldName) const
 

SbBool getFieldName(const SoField *field, SbName &fieldName) const
 

SbBool isNotifyEnabled() const
 

SbBool enableNotify(SbBool flag)
 

Methods from class SoBase:
 

void ref()
 

void unref() const
 

void unrefNoDelete() const
 

void touch()
 

virtual SoType getTypeId() const
 

SbBool isOfType(SoType type) const
 

virtual void setName(const SbName &name)
 

virtual SbName getName() const
 

Macros from class SoBaseKit:
 
SO_GET_PART(kit, partName, partClass)
 
SO_CHECK_PART(kit, partName, partClass)
 

DESCRIPTION

SoHandleBoxDragger is a dragger shaped like a wireframe box with small corner cubes mounted on each corner. Click and drag any of these cubes to scale the box uniformly. Six other center cubes are centered on the sides of the box; white lines connect them to the center of the dragger. Drag one of the center cubes along its line to stretch the box in that direction. Dragging a face of the box translates the dragger within that plane.
 
While you drag a face of the box, purple feedback arrows display the possible directions of motion. Press the <Shift> key to constrain the motion to one of the two major directions in the plane. The constraint direction is chosen based on the next user gesture. Press the <Control> key and the dragger will translate perpendicular to that plane. The translation field is modified as the face is dragged.
 
By default, dragging any of the small cubes scales about the center of the object. Pressing the <Control> key changes this: A corner cube will scale about its opposite corner. A center cube will scale about the center of its opposite face. Dragging one of the small cubes will usually result in changes to both the scaleFactor and translation fields. This is because any scale about a point other than the origin has a translation element.
 
As with all draggers, if you change the fields the dragger will move to match the new settings.
 
Remember: This is not an SoTransform!. If you want to move other objects with this dragger, you can either:
 
[a] Use an SoHandleBoxManip, which is subclassed from SoTransform. It creates one of these draggers and uses it as the interface to change its fields. (see the SoHandleBoxManip reference page).
 
[b] Use field-to-field connections to connect the fields of this dragger to those of any SoTransformation node.
 
You can change the parts in any instance of this dragger using setPart(). The default part geometries are defined as resources for this SoHandleBoxDragger class. They are detailed in the Dragger Resources section of the online reference page for this class. You can make your program use different default resources for the parts by copying the file /usr/share/data/draggerDefaults/handleBoxDragger.iv into your own directory, editing the file, and then setting the environment variable SO_DRAGGER_DIR to be a path to that directory.

FIELDS


SoSFVec3f scaleFactor
 

Scale of the dragger.
 


SoSFVec3f translation
 

Position of the dragger.
 

METHODS


SoHandleBoxDragger()
 

Constructor.
 


static const SoNodekitCatalog * getClassNodekitCatalog () const
 

Returns an SoNodekitCatalog for this class
 


static SoType getClassTypeId()
 

Returns type identifier for this class.
 

CATALOG PARTS

All parts
NULL by
Part Name Part Type Default Type Default
callbackList NodeKitListPart -- yes
surroundScale SurroundScale -- yes
translator1 Separator -- yes
translator1Active Separator -- yes
translator2 Separator -- yes
translator2Active Separator -- yes
translator3 Separator -- yes
translator3Active Separator -- yes
translator4 Separator -- yes
translator4Active Separator -- yes
translator5 Separator -- yes
translator5Active Separator -- yes
translator6 Separator -- yes
translator6Active Separator -- yes
extruder1 Separator -- yes
extruder1Active Separator -- yes
extruder2 Separator -- yes
extruder2Active Separator -- yes
extruder3 Separator -- yes
extruder3Active Separator -- yes
extruder4 Separator -- yes
extruder4Active Separator -- yes
extruder5 Separator -- yes
extruder5Active Separator -- yes
extruder6 Separator -- yes
extruder6Active Separator -- yes
uniform1 Separator -- yes
uniform1Active Separator -- yes
uniform2 Separator -- yes
uniform2Active Separator -- yes
uniform3 Separator -- yes
uniform3Active Separator -- yes
uniform4 Separator -- yes
uniform4Active Separator -- yes
uniform5 Separator -- yes
uniform5Active Separator -- yes
uniform6 Separator -- yes
uniform6Active Separator -- yes
uniform7 Separator -- yes
uniform7Active Separator -- yes
uniform8 Separator -- yes
uniform8Active Separator -- yes
arrow1 Separator -- yes
arrow2 Separator -- yes
arrow3 Separator -- yes
arrow4 Separator -- yes
arrow5 Separator -- yes
arrow6 Separator -- yes
Extra information for list parts from above table
Part Name Container Type Permissible Types
callbackList Separator Callback, EventCallback

DRAGGER RESOURCES

.in 0n+.5i Resource: handleBoxTranslator1
 
.in 0n+.5i Part: translator1
 

Appearance: White Line-Style Square
 

Description: Top face of handleBox. Picking this initiates scaling in x-z plane.
 
.in 0n+.5i Resource: handleBoxTranslator2
 
.in 0n+.5i Part: translator2
 

Appearance: White Line-Style Square
 

Description: Bottom face of handleBox. Picking this initiates scaling in x-z plane.
 
.in 0n+.5i Resource: handleBoxTranslator3
 
.in 0n+.5i Part: translator3
 

Appearance: White Line-Style Square
 

Description: Left face of handleBox. Picking this initiates scaling in y-z plane.
 
.in 0n+.5i Resource: handleBoxTranslator4
 
.in 0n+.5i Part: translator4
 

Appearance: White Line-Style Square
 

Description: Right face of handleBox. Picking this initiates scaling in y-z plane.
 
.in 0n+.5i Resource: handleBoxTranslator5
 
.in 0n+.5i Part: translator5
 

Appearance: White Line-Style Square
 

Description: Front face of handleBox. Picking this initiates scaling in x-y plane.
 
.in 0n+.5i Resource: handleBoxTranslator6
 
.in 0n+.5i Part: translator6
 

Appearance: White Line-Style Square
 

Description: Back face of handleBox. Picking this initiates scaling in x-y plane.
 
.in 0n+.5i Resource: handleBoxTranslator1Active
 
.in 0n+.5i Part: translator1Active
 

Appearance: Yellow version of handleBoxTranslator1
 

Description: Replaces handleBoxTranslator1 during dragging.
 
.in 0n+.5i Resource: handleBoxTranslator2Active
 
.in 0n+.5i Part: translator2Active
 

Appearance: Yellow version of handleBoxTranslator2
 

Description: Replaces handleBoxTranslator2 during dragging.
 
.in 0n+.5i Resource: handleBoxTranslator3Active
 
.in 0n+.5i Part: translator3Active
 

Appearance: Yellow version of handleBoxTranslator3
 

Description: Replaces handleBoxTranslator3 during dragging.
 
.in 0n+.5i Resource: handleBoxTranslator4Active
 
.in 0n+.5i Part: translator4Active
 

Appearance: Yellow version of handleBoxTranslator4
 

Description: Replaces handleBoxTranslator4 during dragging.
 
.in 0n+.5i Resource: handleBoxTranslator5Active
 
.in 0n+.5i Part: translator5Active
 

Appearance: Yellow version of handleBoxTranslator5
 

Description: Replaces handleBoxTranslator5 during dragging.
 
.in 0n+.5i Resource: handleBoxTranslator6Active
 
.in 0n+.5i Part: translator6Active
 

Appearance: Yellow version of handleBoxTranslator6
 

Description: Replaces handleBoxTranslator6 during dragging.
 
.in 0n+.5i Resource: handleBoxExtruder1
 
.in 0n+.5i Part: extruder1
 

Appearance: Small white cube at (0,1.25,0) with line to origin
 

Description: Selecting this part initiates 1-D scaling along Y axis.
 
.in 0n+.5i Resource: handleBoxExtruder2
 
.in 0n+.5i Part: extruder2
 

Appearance: Small white cube at (0,-1.25,0) with line to origin
 

Description: Selecting this part initiates 1-D scaling along Y axis.
 
.in 0n+.5i Resource: handleBoxExtruder3
 
.in 0n+.5i Part: extruder3
 

Appearance: Small white cube at (-1.25,0,0) with line to origin
 

Description: Selecting this part initiates 1-D scaling along X axis.
 
.in 0n+.5i Resource: handleBoxExtruder4
 
.in 0n+.5i Part: extruder4
 

Appearance: Small white cube at (1.25,0,0) with line to origin
 

Description: Selecting this part initiates 1-D scaling along X axis.
 
.in 0n+.5i Resource: handleBoxExtruder5
 
.in 0n+.5i Part: extruder5
 

Appearance: Small white cube at (0,0,1.25) with line to origin
 

Description: Selecting this part initiates 1-D scaling along Z axis.
 
.in 0n+.5i Resource: handleBoxExtruder6
 
.in 0n+.5i Part: extruder6
 

Appearance: Small white cube at (0,0,-1.25) with line to origin
 

Description: Selecting this part initiates 1-D scaling along Z axis.
 
.in 0n+.5i Resource: handleBoxExtruder1Active
 
.in 0n+.5i Part: extruder1Active
 

Appearance: Yellow version of handleBoxExtruder1
 

Description: Replaces handleBoxExtruder1 during dragging.
 
.in 0n+.5i Resource: handleBoxExtruder2Active
 
.in 0n+.5i Part: extruder2Active
 

Appearance: Yellow version of handleBoxExtruder1
 

Description: Replaces handleBoxExtruder1 during dragging.
 
.in 0n+.5i Resource: handleBoxExtruder3Active
 
.in 0n+.5i Part: extruder3Active
 

Appearance: Yellow version of handleBoxExtruder3
 

Description: Replaces handleBoxExtruder3 during dragging.
 
.in 0n+.5i Resource: handleBoxExtruder4Active
 
.in 0n+.5i Part: extruder4Active
 

Appearance: Yellow version of handleBoxExtruder4
 

Description: Replaces handleBoxExtruder4 during dragging.
 
.in 0n+.5i Resource: handleBoxExtruder5Active
 
.in 0n+.5i Part: extruder5Active
 

Appearance: Yellow version of handleBoxExtruder5
 

Description: Replaces handleBoxExtruder5 during dragging.
 
.in 0n+.5i Resource: handleBoxExtruder6Active
 
.in 0n+.5i Part: extruder6Active
 

Appearance: Yellow version of handleBoxExtruder6
 

Description: Replaces handleBoxExtruder6 during dragging.
 
.in 0n+.5i Resource: handleBoxUniform1
 
.in 0n+.5i Part: uniform1
 

Appearance: Small white cube in (+x+y+z) corner of handleBox
 

Description: Picking this initiates uniform scaling.
 
.in 0n+.5i Resource: handleBoxUniform2
 
.in 0n+.5i Part: uniform2
 

Appearance: Small white cube in (+x+y-z) corner of handleBox
 

Description: Picking this initiates uniform scaling.
 
.in 0n+.5i Resource: handleBoxUniform3
 
.in 0n+.5i Part: uniform3
 

Appearance: Small white cube in (+x-y+z) corner of handleBox
 

Description: Picking this initiates uniform scaling.
 
.in 0n+.5i Resource: handleBoxUniform4
 
.in 0n+.5i Part: uniform4
 

Appearance: Small white cube in (+x-y-z) corner of handleBox
 

Description: Picking this initiates uniform scaling.
 
.in 0n+.5i Resource: handleBoxUniform5
 
.in 0n+.5i Part: uniform5
 

Appearance: Small white cube in (-x+y+z) corner of handleBox
 

Description: Picking this initiates uniform scaling.
 
.in 0n+.5i Resource: handleBoxUniform6
 
.in 0n+.5i Part: uniform6
 

Appearance: Small white cube in (-x+y-z) corner of handleBox
 

Description: Picking this initiates uniform scaling.
 
.in 0n+.5i Resource: handleBoxUniform7
 
.in 0n+.5i Part: uniform7
 

Appearance: Small white cube in (-x-y+z) corner of handleBox
 

Description: Picking this initiates uniform scaling.
 
.in 0n+.5i Resource: handleBoxUniform8
 
.in 0n+.5i Part: uniform8
 

Appearance: Small white cube in (-x-y-z) corner of handleBox
 

Description: Picking this initiates uniform scaling.
 
.in 0n+.5i Resource: handleBoxUniform1Active
 
.in 0n+.5i Part: uniform1Active
 

Appearance: Yellow version of handleBoxUniform1Active
 

Description: Replaces handleBoxUniform1Active during dragging.
 
.in 0n+.5i Resource: handleBoxUniform2Active
 
.in 0n+.5i Part: uniform2Active
 

Appearance: Yellow version of handleBoxUniform1Active
 

Description: Replaces handleBoxUniform1Active during dragging.
 
.in 0n+.5i Resource: handleBoxUniform3Active
 
.in 0n+.5i Part: uniform3Active
 

Appearance: Yellow version of handleBoxUniform1Active
 

Description: Replaces handleBoxUniform1Active during dragging.
 
.in 0n+.5i Resource: handleBoxUniform4Active
 
.in 0n+.5i Part: uniform4Active
 

Appearance: Yellow version of handleBoxUniform1Active
 

Description: Replaces handleBoxUniform1Active during dragging.
 
.in 0n+.5i Resource: handleBoxUniform5Active
 
.in 0n+.5i Part: uniform5Active
 

Appearance: Yellow version of handleBoxUniform1Active
 

Description: Replaces handleBoxUniform1Active during dragging.
 
.in 0n+.5i Resource: handleBoxUniform6Active
 
.in 0n+.5i Part: uniform6Active
 

Appearance: Yellow version of handleBoxUniform1Active
 

Description: Replaces handleBoxUniform1Active during dragging.
 
.in 0n+.5i Resource: handleBoxUniform7Active
 
.in 0n+.5i Part: uniform7Active
 

Appearance: Yellow version of handleBoxUniform1Active
 

Description: Replaces handleBoxUniform1Active during dragging.
 
.in 0n+.5i Resource: handleBoxUniform8Active
 
.in 0n+.5i Part: uniform8Active
 

Appearance: Yellow version of handleBoxUniform1Active
 

Description: Replaces handleBoxUniform1Active during dragging.
 
.in 0n+.5i Resource: handleBoxArrow1
 
.in 0n+.5i Part: arrow1
 

Appearance: Purple Arrow, pointing up
 

Description: Displayed when translating if Y direction is permitted.
 
.in 0n+.5i Resource: handleBoxArrow2
 
.in 0n+.5i Part: arrow2
 

Appearance: Purple Arrow, pointing down
 

Description: Displayed when translating if Y direction is permitted.
 
.in 0n+.5i Resource: handleBoxArrow3
 
.in 0n+.5i Part: arrow3
 

Appearance: Purple Arrow, pointing left
 

Description: Displayed when translating if X direction is permitted.
 
.in 0n+.5i Resource: handleBoxArrow4
 
.in 0n+.5i Part: arrow4
 

Appearance: Purple Arrow, pointing right
 

Description: Displayed when translating if X direction is permitted.
 
.in 0n+.5i Resource: handleBoxArrow5
 
.in 0n+.5i Part: arrow5
 

Appearance: Purple Arrow, pointing forward
 

Description: Displayed when translating if Z direction is permitted.
 
.in 0n+.5i Resource: handleBoxArrow6
 
.in 0n+.5i Part: arrow6
 

Appearance: Purple Arrow, pointing backward
 

Description: Displayed when translating if Z direction is permitted.
 

FILE FORMAT/DEFAULTS

HandleBoxDragger {

renderCaching AUTO boundingBoxCaching AUTO renderCulling AUTO pickCulling AUTO isActive FALSE translation 0 0 0 scaleFactor 1 1 1 callbackList NULL surroundScale NULL translator1 <handleBoxTranslator1 resource> translator1Active <handleBoxTranslator1Active resource> translator2 <handleBoxTranslator2 resource> translator2Active <handleBoxTranslator2Active resource> translator3 <handleBoxTranslator3 resource> translator3Active <handleBoxTranslator3Active resource> translator4 <handleBoxTranslator4 resource> translator4Active <handleBoxTranslator4Active resource> translator5 <handleBoxTranslator5 resource> translator5Active <handleBoxTranslator5Active resource> translator6 <handleBoxTranslator6 resource> translator6Active <handleBoxTranslator6Active resource> extruder1 <handleBoxExtruder1 resource> extruder1Active <handleBoxExtruder1Active resource> extruder2 <handleBoxExtruder2 resource> extruder2Active <handleBoxExtruder2Active resource> extruder3 <handleBoxExtruder3 resource> extruder3Active <handleBoxExtruder3Active resource> extruder4 <handleBoxExtruder4 resource> extruder4Active <handleBoxExtruder4Active resource> extruder5 <handleBoxExtruder5 resource> extruder5Active <handleBoxExtruder5Active resource> extruder6 <handleBoxExtruder6 resource> extruder6Active <handleBoxExtruder6Active resource> uniform1 <handleBoxUniform1 resource> uniform1Active <handleBoxUniform1Active resource> uniform2 <handleBoxUniform2 resource> uniform2Active <handleBoxUniform2Active resource> uniform3 <handleBoxUniform3 resource> uniform3Active <handleBoxUniform3Active resource> uniform4 <handleBoxUniform4 resource> uniform4Active <handleBoxUniform4Active resource> uniform5 <handleBoxUniform5 resource> uniform5Active <handleBoxUniform5Active resource> uniform6 <handleBoxUniform6 resource> uniform6Active <handleBoxUniform6Active resource> uniform7 <handleBoxUniform7 resource> uniform7Active <handleBoxUniform7Active resource> uniform8 <handleBoxUniform8 resource> uniform8Active <handleBoxUniform8Active resource> arrow1 <handleBoxArrow1 resource> arrow2 <handleBoxArrow2 resource> arrow3 <handleBoxArrow3 resource> arrow4 <handleBoxArrow4 resource> arrow5 <handleBoxArrow5 resource> arrow6 <handleBoxArrow6 resource>
}

NOTE

Unlike most multi-function draggers, SoHandleBoxDragger is not a compound dragger made up of other draggers that perform its smaller tasks. This is not because it was inappropriate, but because was written before implementation of the methods that synchronize multiple child draggers. The younger SoTransformBoxDragger has similarities to the handle box dragger, but the transform box dragger is a compound dragger.

SEE ALSO

SoInteractionKit, SoDragger, SoCenterballDragger, SoDirectionalLightDragger, SoDragPointDragger, SoJackDragger, SoPointLightDragger, SoRotateCylindricalDragger, SoRotateDiscDragger, SoRotateSphericalDragger, SoScale1Dragger, SoScale2Dragger, SoScale2UniformDragger, SoScaleUniformDragger, SoSpotLightDragger, SoTabBoxDragger, SoTabPlaneDragger, SoTrackballDragger, SoTransformBoxDragger, SoTransformerDragger, SoTranslate1Dragger, SoTranslate2Dragger