SYNOPSIS

#include <Inventor/VRMLnodes/SoVRMLDragSensor.h>

Inherits SoVRMLSensor.

Inherited by SoVRMLCylinderSensor, SoVRMLPlaneSensor, and SoVRMLSphereSensor.

Public Member Functions

virtual SoType getTypeId (void) const

Returns the type identification of an object derived from a class inheriting SoBase. This is used for run-time type checking and 'downward' casting. virtual void handleEvent (SoHandleEventAction *action)

Static Public Member Functions

static SoType getClassTypeId (void)

static void initClass (void)

Public Attributes

SoSFVec3f trackPoint_changed

SoSFBool autoOffset

Protected Member Functions

virtual const SoFieldData * getFieldData (void) const

virtual SbBool dragStart (void)=0

virtual void drag (void)=0

virtual void dragFinish (void)=0

SoVRMLDragSensor (void)

virtual ~SoVRMLDragSensor ()

const SbVec3f & getLocalStartingPoint (void) const

const SbMatrix & getLocalToWorldMatrix (void) const

const SbMatrix & getWorldToLocalMatrix (void) const

const SbViewVolume & getViewVolume (void) const

const SbVec2f & getNormalizedLocaterPosition (void) const

Static Protected Member Functions

static const SoFieldData ** getFieldDataPtr (void)

Additional Inherited Members

Detailed Description

The SoVRMLDragSensor class is a superclass for VRML drag sensors.

This class collects the two fields that are common for some of the sensor nodes, plus some common functions for these. Since this is an abstract 'helper' class, it does not represent an actual node from the VRML97 specification, so don't use it as such.

For more information, a detailed discussion of drag sensors is available in section 4.6.7.4 of the VRML97 specification:

http://www.web3d.org/x3d/specifications/vrml/ISO-IEC-14772-VRML97/part1/concepts.html#4.6.7.4.

Constructor & Destructor Documentation

SoVRMLDragSensor::SoVRMLDragSensor (void)\fC [protected]\fP

Constructor.

SoVRMLDragSensor::~SoVRMLDragSensor ()\fC [protected]\fP, \fC [virtual]\fP

Destructor.

Member Function Documentation

\fBSoType\fP SoVRMLDragSensor::getTypeId (void) const\fC [virtual]\fP

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
  }
}

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 SoVRMLSensor.

Reimplemented in SoVRMLSphereSensor, SoVRMLCylinderSensor, and SoVRMLPlaneSensor.

const \fBSoFieldData\fP * SoVRMLDragSensor::getFieldData (void) const\fC [protected]\fP, \fC [virtual]\fP

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

Reimplemented from SoVRMLSensor.

Reimplemented in SoVRMLSphereSensor, SoVRMLCylinderSensor, and SoVRMLPlaneSensor.

void SoVRMLDragSensor::handleEvent (\fBSoHandleEventAction\fP *action)\fC [virtual]\fP

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 SoNode.

SbBool SoVRMLDragSensor::dragStart (void)\fC [protected]\fP, \fC [pure virtual]\fP

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

Called when dragger is selected (picked) by the user.

Implemented in SoVRMLCylinderSensor, SoVRMLPlaneSensor, and SoVRMLSphereSensor.

void SoVRMLDragSensor::drag (void)\fC [protected]\fP, \fC [pure virtual]\fP

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

Called when user drags the mouse after picking the dragger.

Implemented in SoVRMLCylinderSensor, SoVRMLPlaneSensor, and SoVRMLSphereSensor.

void SoVRMLDragSensor::dragFinish (void)\fC [protected]\fP, \fC [pure virtual]\fP

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

Called when mouse button is released after picking and interacting with the dragger.

Implemented in SoVRMLCylinderSensor, SoVRMLPlaneSensor, and SoVRMLSphereSensor.

const \fBSbVec3f\fP & SoVRMLDragSensor::getLocalStartingPoint (void) const\fC [protected]\fP

Returns the interaction starting point.

const \fBSbMatrix\fP & SoVRMLDragSensor::getLocalToWorldMatrix (void) const\fC [protected]\fP

Returns the matrix that transforms to the world coordinate system.

const \fBSbMatrix\fP & SoVRMLDragSensor::getWorldToLocalMatrix (void) const\fC [protected]\fP

Returns the matrix that transforms from the world coordinate system.

const \fBSbViewVolume\fP & SoVRMLDragSensor::getViewVolume (void) const\fC [protected]\fP

Returns the current view volume.

const \fBSbVec2f\fP & SoVRMLDragSensor::getNormalizedLocaterPosition (void) const\fC [protected]\fP

Returns the current normalized pointer position.

Member Data Documentation

\fBSoSFVec3f\fP SoVRMLDragSensor::trackPoint_changed

An event out that is generated when the trackpoint is changed.

\fBSoSFBool\fP SoVRMLDragSensor::autoOffset

When TRUE, the offset field is updated when a dragging sequence is finished. Default value is TRUE.

Author

Generated automatically by Doxygen for Coin from the source code.