Main Page | Modules | Class Hierarchy | Alphabetical List | Class List | File List | Class Members

SoNode Class Reference
[Nodes]

The SoNode class is the base class for nodes used in scene graphs. More...

#include <Inventor/nodes/SoNode.h>

Inheritance diagram for SoNode:

SoFieldContainer SoBase SoBaseColor SoBaseKit SoCallback SoCamera SoClipPlane SoColorIndex SoComplexity SoCoordinate3 SoCoordinate4 SoDrawStyle SoEnvironment SoEventCallback SoFile SoFont SoGroup SoInfo SoLabel SoLight SoLightModel SoMaterial SoMaterialBinding SoNodeKitListPart SoNormal SoNormalBinding SoPackedColor SoPickStyle SoPolygonOffset SoProfile SoProfileCoordinate2 SoProfileCoordinate3 SoShape SoShapeHints SoTexture2 SoTexture2Transform SoTextureCoordinate2 SoTextureCoordinateBinding SoTextureCoordinateFunction SoTransformation SoVertexProperty SoWWWInline List of all members.

Public Types

enum  NodeType { INVENTOR = 0, VRML1 = 1 }

Public Member Functions

void setOverride (const SbBool state)
SbBool isOverride (void) const
void setNodeType (const NodeType type)
NodeType getNodeType (void) const
virtual SoNodecopy (SbBool copyconnections=FALSE) const
virtual SbBool affectsState (void) const
virtual void doAction (SoAction *action)
virtual void GLRender (SoGLRenderAction *action)
virtual void GLRenderBelowPath (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 handleEvent (SoHandleEventAction *action)
virtual void pick (SoPickAction *action)
virtual void rayPick (SoRayPickAction *action)
virtual void search (SoSearchAction *action)
virtual void write (SoWriteAction *action)
virtual void getPrimitiveCount (SoGetPrimitiveCountAction *action)
virtual void grabEventsSetup (void)
virtual void grabEventsCleanup (void)
virtual void startNotify (void)
virtual void notify (SoNotList *l)
uint32_t getNodeId (void) const
virtual SoChildListgetChildren (void) const
virtual void writeInstance (SoOutput *out)
virtual SoNodeaddToCopyDict (void) const
virtual void copyContents (const SoFieldContainer *from, SbBool copyconnections)
virtual SoFieldContainercopyThroughConnection (void) const

Static Public Member Functions

SoType getClassTypeId (void)
SoNodegetByName (const SbName &name)
int getByName (const SbName &name, SoNodeList &l)
void initClass (void)
void initClasses (void)
uint32_t getNextNodeId (void)
int getActionMethodIndex (const SoType type)
void getBoundingBoxS (SoAction *action, SoNode *node)
void GLRenderS (SoAction *action, SoNode *node)
void callbackS (SoAction *action, SoNode *node)
void getMatrixS (SoAction *action, SoNode *node)
void handleEventS (SoAction *action, SoNode *node)
void pickS (SoAction *action, SoNode *node)
void rayPickS (SoAction *action, SoNode *node)
void searchS (SoAction *action, SoNode *node)
void writeS (SoAction *action, SoNode *node)
void getPrimitiveCountS (SoAction *action, SoNode *node)

Protected Member Functions

 SoNode (void)
virtual ~SoNode ()
virtual SbBool readInstance (SoInput *in, unsigned short flags)

Static Protected Member Functions

const SoFieldData ** getFieldDataPtr (void)
void setNextActionMethodIndex (int index)
int getNextActionMethodIndex (void)
void incNextActionMethodIndex (void)

Protected Attributes

uint32_t uniqueId

Static Protected Attributes

uint32_t nextUniqueId = 0
int nextActionMethodIndex = 0

Detailed Description

The SoNode class is the base class for nodes used in scene graphs.

Coin is a retained mode 3D visualization library (built on top of the immediate mode OpenGL library). "Retained mode" means that instead of passing commands to draw graphics primitives directly to the renderer, you build up data structures which are rendered by the library on demand.

The node classes are the main "primitive" for building these data structures. In Coin, you build tree hierarchies made up of different node types: group nodes (for the tree structure layout of the other nodes), appearance nodes (for setting up materials, textures, etc), shape nodes (for the actual geometry), and nodes for lighting and camera positioning.

One common issue with newcomers to the API is that you should not and can not use the C++ delete operator on nodes -- the destructor is protected. This is because node instances are using a common technique for memory resource handling called "reference counting". Nodes are deleted (actually, they delete themselves) when their unref() method is called and the reference count goes to zero.

Usually application programmers won't manually ref() and unref() nodes a lot, because you pass the nodes directly to SoGroup::addChild() or So*Viewer::setSceneGraph() or something similar. These functions will ref() the nodes they are passed, and unref() them when they are finished with them.

Make sure you do ref() nodes that you keep pointers to so they aren't accidentally deleted prematurely due to an unref() call from within the library itself. If you haven't manually called ref() on a top-level root node, it will then be deleted automatically. This code shows how to do it:

SoSeparator * root = new SoSeparator; // root's refcount starts out at zero root->addChild(foo_node); // foo_node refcount is increased by 1 root->addChild(bar_node); // bar_node refcount +1 // increase refcount before passing it to setScenegraph(), to avoid // premature destruction root->ref(); myviewer->setSceneGraph(root); // root's refcount +1, is now 2 // [misc visualization and processing] // myviewer will let go of it's reference to the root node, thereby // decreasing it's referencecount by 1 myviewer->setSceneGraph(NULL); // root's refcount goes from +1 to 0, and it will self-destruct controllably root->unref(); // avoid dangling pointer, in case "root" is attempted used again // (not really necessary, but good for smoking out bugs early) root = NULL;

For full information and tutorial-style introductions to all API issues, see the "Inventor Mentor: Programming Object-Oriented 3D Graphics with Open Inventor" (ISBN 0-201-62495-8). It has detailed explanations on all the basic principles involved.

See specifically the section "References and Deletion" in Chapter 3 to learn about the reference counting techniques.

Often when using the Coin library, one is interested in making extensions to it. Of particular interest is setting up extension nodes, which are then traversed, rendered and otherwise used by the rest of the library as any internal node.

The Coin header file Inventor/nodes/SoSubNode.h includes a set of convenience macros for quick and easy construction of extension nodes. Here's a complete snippet of code which shows how to set up a skeleton framework for an extension node class:

#include <Inventor/nodes/SoWWWInline.h> class MyWWWInline : public SoWWWInline { SO_NODE_HEADER(MyWWWInline); public: static void initClass(void); MyWWWInline(void); protected: virtual ~MyWWWInline(); }; SO_NODE_SOURCE(MyWWWInline); MyWWWInline::MyWWWInline(void) { SO_NODE_CONSTRUCTOR(MyWWWInline); } MyWWWInline::~MyWWWInline() { } void MyWWWInline::initClass(void) { SO_NODE_INIT_CLASS(MyWWWInline, SoWWWInline, "SoWWWInline"); } int main(int argc, char ** argv) { SoDB::init(); MyWWWInline::initClass(); // [...] return 0; }

You can then override for instance the GLRender() method to have your new class render OpenGL geometry different from it's superclass.

For extending the Coin library with your own classes, we strongly recommend that you make yourself acquainted with the excellent «The Inventor Toolmaker» book (ISBN 0-201-62493-1), which describes the tasks involved in detail. This book was written by the original SGI Inventor designers and explains many of the underlying design ideas, aswell as having lots of hands-on examples on how to extend the Coin toolkit in ways that are true to the fundamental design ideas. («The Inventor Toolmaker» is also available at SGI's online library, at no cost. See Download The Inventor Toolmaker.) Reading the sourcecode of the built-in classes in Coin should also provide very helpful.


Member Enumeration Documentation

enum SoNode::NodeType
 

Used to store node type.

Enumeration values:
INVENTOR  Specifies Inventor node type.
VRML1  Spcifies VRML V1.0 node type.


Constructor & Destructor Documentation

SoNode::SoNode void   )  [protected]
 

Default constructor, initializes node instance.

SoNode::~SoNode  )  [protected, virtual]
 

Destructor.


Member Function Documentation

void SoNode::setOverride const SbBool  state  ) 
 

Set the override flag.

If this flag is TRUE, the field values of this node will override the field values of other nodes of the same type during scene graph traversal.

A common applicaton for "override nodes" is to place them at the top of the tree as a convenient way to force e.g. a common drawstyle on the complete tree.

SbBool SoNode::isOverride void   )  const
 

Return status of override flag.

See also:
setOverride()

void SoNode::setNodeType const NodeType  type  ) 
 

Sets the node type for this node to type. Since some nodes should be handled differently in VRML1 vs. Inventor, this should be used to get correct behavior for those cases. The default node type is INVENTOR.

This method is an extension versus the Open Inventor API.

See also:
getNodeType()

SoNode::NodeType SoNode::getNodeType void   )  const
 

Returns the node type set for this node.

This method is an extension versus the Open Inventor API.

See also:
setNodeType()

SoNode * SoNode::copy SbBool  copyconnections = FALSE  )  const [virtual]
 

Make a duplicate of this node and return a pointer to the duplicate.

If this node is a group node, children are also copied and we return a pointer to the root of a full copy of the subgraph rooted here.

If copyconnections is TRUE, we also copy the connections to fields within this node (and ditto for any children and children's children etc).

Note that this function has been made virtual in Coin, which is not the case in the original Open Inventor API. We may change this method back into being non-virtual again for Coin version 2, as it was made virtual more or less by mistake. So please don't write application code that depends on SoNode::copy() being virtual.

The reason this method should not be virtual is because this is not the function the application programmer should override if she needs some special behavior during a copy operation (like copying the value of internal data not exposed as fields).

For that purpose, override the copyContents() method. Your overridden copyContents() method should then both copy internal data aswell as calling the parent superclass' copyContents() method for automatically handling of fields and other common data.

SbBool SoNode::affectsState void   )  const [virtual]
 

Returns TRUE if the node could have any effect on the state during traversal.

If it returns FALSE, no data in the traversal-state will change from the pre-traversal state to the post-traversal state. The SoSeparator node will for instance return FALSE, as it pushes and pops the state before and after traversal of its children. All SoShape nodes will also return FALSE, as just pushing out geometry data to the rendering engine won't affect the actual rendering state.

The default method returns TRUE, on a "better safe than sorry" philosophy.

Reimplemented in SoNodeKitListPart, SoSceneKit, SoArray, SoMultipleCopy, SoSeparator, SoShape, and SoSwitch.

void SoNode::doAction SoAction action  )  [virtual]
 

This function performs the typical operation of a node for any action.

Reimplemented in SoClipPlaneManip, SoDirectionalLightManip, SoPointLightManip, SoSpotLightManip, SoTransformManip, SoBaseKit, SoNodeKitListPart, SoAntiSquish, SoArray, SoBaseColor, SoCallback, SoCamera, SoClipPlane, SoComplexity, SoCoordinate3, SoCoordinate4, SoDrawStyle, SoFile, SoFont, SoFontStyle, SoGroup, SoLOD, SoLevelOfDetail, SoLightModel, SoMaterial, SoMaterialBinding, SoMatrixTransform, SoMultipleCopy, SoNormal, SoNormalBinding, SoPackedColor, SoPathSwitch, SoPickStyle, SoPolygonOffset, SoProfile, SoProfileCoordinate2, SoProfileCoordinate3, SoResetTransform, SoRotation, SoRotationXYZ, SoScale, SoSeparator, SoShapeHints, SoSurroundScale, SoSwitch, SoTexture2, SoTexture2Transform, SoTextureCoordinate2, SoTextureCoordinateBinding, SoTextureCoordinateDefault, SoTextureCoordinateEnvironment, SoTextureCoordinatePlane, SoTransform, SoTransformSeparator, SoTranslation, SoUnits, SoVertexProperty, and SoWWWInline.

void SoNode::GLRender SoGLRenderAction action  )  [virtual]
 

Action method for the SoGLRenderAction.

This is called during rendering traversals. Nodes influencing the rendering state in any way or who wants to throw geometry primitives at OpenGL overrides this method.

Reimplemented in SoDragger, SoTabPlaneDragger, SoClipPlaneManip, SoDirectionalLightManip, SoPointLightManip, SoSpotLightManip, SoTransformManip, SoBaseKit, SoNodeKitListPart, SoAnnotation, SoAntiSquish, SoArray, SoAsciiText, SoBaseColor, SoCallback, SoCamera, SoClipPlane, SoColorIndex, SoComplexity, SoCone, SoCoordinate3, SoCoordinate4, SoCube, SoCylinder, SoDirectionalLight, SoDrawStyle, SoEnvironment, SoFaceSet, SoFile, SoFont, SoFontStyle, SoGroup, SoImage, SoIndexedFaceSet, SoIndexedLineSet, SoIndexedNurbsCurve, SoIndexedNurbsSurface, SoIndexedTriangleStripSet, SoLOD, SoLevelOfDetail, SoLightModel, SoLineSet, SoMarkerSet, SoMaterial, SoMaterialBinding, SoMatrixTransform, SoMultipleCopy, SoNormal, SoNormalBinding, SoNurbsCurve, SoNurbsSurface, SoPackedColor, SoPathSwitch, SoPointLight, SoPointSet, SoPolygonOffset, SoProfile, SoProfileCoordinate2, SoProfileCoordinate3, SoQuadMesh, SoResetTransform, SoRotation, SoRotationXYZ, SoScale, SoSeparator, SoShape, SoShapeHints, SoSphere, SoSpotLight, SoSurroundScale, SoSwitch, SoText2, SoText3, SoTexture2, SoTexture2Transform, SoTextureCoordinate2, SoTextureCoordinateBinding, SoTextureCoordinateDefault, SoTextureCoordinateEnvironment, SoTextureCoordinatePlane, SoTransform, SoTransformSeparator, SoTranslation, SoTriangleStripSet, SoUnits, SoVertexProperty, and SoWWWInline.

void SoNode::GLRenderBelowPath SoGLRenderAction action  )  [virtual]
 

Implements the SoAction::BELOW_PATH traversal method for the rendering action.

Reimplemented in SoAnnotation, SoExtSelection, SoLOD, SoLocateHighlight, and SoSeparator.

void SoNode::GLRenderInPath SoGLRenderAction action  )  [virtual]
 

Implements the SoAction::IN_PATH traversal method for the rendering action.

Reimplemented in SoAnnotation, SoLOD, SoLocateHighlight, and SoSeparator.

void SoNode::GLRenderOffPath SoGLRenderAction action  )  [virtual]
 

Implements the SoAction::OFF_PATH traversal method for the rendering action.

Reimplemented in SoAnnotation, SoLOD, and SoSeparator.

void SoNode::callback SoCallbackAction action  )  [virtual]
 

Action method for SoCallbackAction.

Simply updates the state according to how the node behaves for the render action, so the application programmer can use the SoCallbackAction for extracting information about the scene graph.

Reimplemented in SoDragger, SoClipPlaneManip, SoDirectionalLightManip, SoPointLightManip, SoSpotLightManip, SoTransformManip, SoBaseKit, SoNodeKitListPart, SoAntiSquish, SoArray, SoBaseColor, SoCallback, SoCamera, SoClipPlane, SoComplexity, SoCoordinate3, SoCoordinate4, SoDrawStyle, SoEnvironment, SoFile, SoFont, SoFontStyle, SoGroup, SoLOD, SoLevelOfDetail, SoLight, SoLightModel, SoMaterial, SoMaterialBinding, SoMatrixTransform, SoMultipleCopy, SoNormal, SoNormalBinding, SoPackedColor, SoPickStyle, SoPolygonOffset, SoProfile, SoProfileCoordinate2, SoProfileCoordinate3, SoResetTransform, SoRotation, SoRotationXYZ, SoScale, SoSeparator, SoShape, SoShapeHints, SoSurroundScale, SoSwitch, SoTexture2, SoTexture2Transform, SoTextureCoordinate2, SoTextureCoordinateBinding, SoTextureCoordinateDefault, SoTextureCoordinateEnvironment, SoTextureCoordinatePlane, SoTransform, SoTransformSeparator, SoTranslation, SoUnits, SoVertexProperty, and SoWWWInline.

void SoNode::getBoundingBox SoGetBoundingBoxAction action  )  [virtual]
 

Action method for the SoGetBoundingBoxAction.

Calculates bounding box and center coordinates for node and modifies the values of the action to encompass the bounding box for this node and to shift the center point for the scene more towards the one for this node.

Nodes influencing how geometry nodes calculates their bounding box also overrides this method to change the relevant state variables.

Reimplemented in SoCenterballDragger, SoDragger, SoClipPlaneManip, SoDirectionalLightManip, SoPointLightManip, SoSpotLightManip, SoTransformManip, SoBaseKit, SoNodeKitListPart, SoAntiSquish, SoArray, SoBlinker, SoCallback, SoCamera, SoComplexity, SoCoordinate3, SoCoordinate4, SoFile, SoFont, SoFontStyle, SoGroup, SoIndexedLineSet, SoIndexedNurbsCurve, SoLOD, SoLineSet, SoMatrixTransform, SoMultipleCopy, SoNurbsCurve, SoPathSwitch, SoPointSet, SoProfile, SoProfileCoordinate2, SoResetTransform, SoRotation, SoRotationXYZ, SoScale, SoSeparator, SoShape, SoShapeHints, SoSurroundScale, SoSwitch, SoTransform, SoTransformSeparator, SoTranslation, SoUnits, SoVertexProperty, and SoWWWInline.

void SoNode::getMatrix SoGetMatrixAction action  )  [virtual]
 

Action method for SoGetMatrixAction.

Updates action by accumulating with the transformation matrix of this node (if any).

Reimplemented in SoCenterballDragger, SoDragger, SoClipPlaneManip, SoDirectionalLightManip, SoPointLightManip, SoSpotLightManip, SoTransformManip, SoBaseKit, SoNodeKitListPart, SoAntiSquish, SoArray, SoCallback, SoFile, SoGroup, SoMatrixTransform, SoMultipleCopy, SoPathSwitch, SoResetTransform, SoRotation, SoRotationXYZ, SoScale, SoSeparator, SoSurroundScale, SoSwitch, SoTexture2Transform, SoTransform, SoTransformSeparator, SoTranslation, SoUnits, and SoWWWInline.

void SoNode::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 in SoDragger, SoClipPlaneManip, SoDirectionalLightManip, SoPointLightManip, SoSpotLightManip, SoTransformManip, SoBaseKit, SoNodeKitListPart, SoArray, SoCallback, SoCamera, SoEventCallback, SoExtSelection, SoFile, SoGroup, SoLocateHighlight, SoMultipleCopy, SoPathSwitch, SoSelection, SoSeparator, SoSwitch, SoWWWAnchor, and SoWWWInline.

void SoNode::pick SoPickAction action  )  [virtual]
 

Action method for SoPickAction.

Does common processing for SoPickAction action instances.

Reimplemented in SoClipPlaneManip, SoDirectionalLightManip, SoPointLightManip, SoSpotLightManip, SoTransformManip, SoNodeKitListPart, SoAntiSquish, SoArray, SoBaseColor, SoCallback, SoClipPlane, SoComplexity, SoCoordinate3, SoCoordinate4, SoFile, SoFont, SoFontStyle, SoGroup, SoMaterialBinding, SoMatrixTransform, SoMultipleCopy, SoNormal, SoNormalBinding, SoPathSwitch, SoPickStyle, SoProfile, SoProfileCoordinate2, SoProfileCoordinate3, SoResetTransform, SoRotation, SoRotationXYZ, SoScale, SoShapeHints, SoSurroundScale, SoSwitch, SoTexture2Transform, SoTextureCoordinate2, SoTextureCoordinateBinding, SoTextureCoordinateDefault, SoTextureCoordinateEnvironment, SoTextureCoordinatePlane, SoTransform, SoTransformSeparator, SoTranslation, SoUnits, SoVertexProperty, and SoWWWInline.

void SoNode::rayPick SoRayPickAction action  )  [virtual]
 

Action method for SoRayPickAction.

Checks the ray specification of the action and tests for intersection with the data of the node.

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

Reimplemented in SoDragger, SoBaseKit, SoCamera, SoCone, SoCube, SoCylinder, SoImage, SoIndexedNurbsCurve, SoIndexedNurbsSurface, SoLOD, SoLevelOfDetail, SoNurbsCurve, SoNurbsSurface, SoSeparator, SoShape, SoSphere, and SoText2.

void SoNode::search SoSearchAction action  )  [virtual]
 

Action method for SoSearchAction.

Compares the search criteria from the action to see if this node is a match. Searching is done by matching up all criteria set up in the SoSearchAction -- if any of the requested criteria is a miss, the search is not deemed successful for the node.

See also:
SoSearchAction

Reimplemented in SoDragger, SoClipPlaneManip, SoDirectionalLightManip, SoPointLightManip, SoSpotLightManip, SoTransformManip, SoBaseKit, SoNodeKitListPart, SoArray, SoCallback, SoGroup, SoMultipleCopy, SoPathSwitch, SoSeparator, SoSwitch, and SoWWWInline.

void SoNode::write SoWriteAction action  )  [virtual]
 

Action method for SoWriteAction.

Writes out a node object, and any connected nodes, engines etc, if necessary.

Reimplemented in SoDragger, SoBaseKit, SoBlinker, SoCallback, SoGroup, SoPendulum, SoShuttle, SoSwitch, and SoVertexShape.

void SoNode::getPrimitiveCount SoGetPrimitiveCountAction action  )  [virtual]
 

Action method for the SoGetPrimitiveCountAction.

Calculates the number of triangle, line segment and point primitives for the node and adds these to the counters of the action.

Nodes influencing how geometry nodes calculates their primitive count also overrides this method to change the relevant state variables.

Reimplemented in SoDragger, SoBaseKit, SoNodeKitListPart, SoArray, SoAsciiText, SoCallback, SoCamera, SoComplexity, SoCone, SoCoordinate3, SoCoordinate4, SoCube, SoCylinder, SoFaceSet, SoFile, SoFont, SoFontStyle, SoGroup, SoImage, SoIndexedFaceSet, SoIndexedLineSet, SoIndexedNurbsCurve, SoIndexedNurbsSurface, SoIndexedTriangleStripSet, SoLOD, SoLineSet, SoMarkerSet, SoMaterialBinding, SoMatrixTransform, SoMultipleCopy, SoNormal, SoNormalBinding, SoNurbsCurve, SoNurbsSurface, SoPathSwitch, SoPointSet, SoProfile, SoProfileCoordinate2, SoProfileCoordinate3, SoQuadMesh, SoResetTransform, SoRotation, SoRotationXYZ, SoScale, SoSeparator, SoShape, SoSphere, SoSwitch, SoText2, SoText3, SoTransform, SoTransformSeparator, SoTranslation, SoTriangleStripSet, SoUnits, SoVertexProperty, and SoWWWInline.

void SoNode::grabEventsSetup void   )  [virtual]
 

Called from SoHandleEventAction::setGrabber() to notify a node when it becomes the node where all events are sent.

Reimplemented in SoDragger.

void SoNode::grabEventsCleanup void   )  [virtual]
 

Called from SoHandleEventAction to notify a node when it looses status as the node where events are sent.

Reimplemented in SoDragger.

void SoNode::startNotify void   )  [virtual]
 

This is the method which starts the notification sequence after changes.

At the end of a notification sequence, all "immediate" sensors (i.e. sensors set up with a zero priority) are triggered.

Reimplemented from SoBase.

void SoNode::notify SoNotList l  )  [virtual]
 

Notifies all auditors for this instance when changes are made.

Reimplemented from SoFieldContainer.

Reimplemented in SoAsciiText, SoBlinker, SoImage, SoMaterial, SoPackedColor, SoSeparator, SoText3, SoTexture2, SoVertexProperty, and SoVertexShape.

uint32_t SoNode::getNodeId void   )  const
 

This returns the node's current unique identification number. It is unlikely that application programmers will ever need use this method fom client application code, unless working with extensions to the core library (and probably not even then).

The id number is only valid for as long as the node is kept unchanged -- upon any kind of change the internal id will be updated (in the notify() method), and the old id number forgotten.

The technique described above plays an important role in the way internal scenegraph caches are set up and invalidated.

See also:
SoNode::getNextNodeId()

SoChildList * SoNode::getChildren void   )  const [virtual]
 

Returns list of children for this node.

Reimplemented in SoClipPlaneManip, SoDirectionalLightManip, SoPointLightManip, SoSpotLightManip, SoTransformManip, SoBaseKit, SoNodeKitListPart, SoFile, SoGroup, and SoWWWInline.

void SoNode::writeInstance SoOutput out  )  [virtual]
 

This method is called from write() if the actual writing pass of the write action is taking place. It dumps the node to the given out output stream.

Reimplemented from SoFieldContainer.

SoNode * SoNode::addToCopyDict void   )  const [virtual]
 

Add a copy of this node and (recursively) all children to the copy dictionary of SoFieldContainer if this has not already been done.

Used internally during copy operations.

Reimplemented in SoBaseKit.

void SoNode::copyContents const SoFieldContainer from,
SbBool  copyconnections
[virtual]
 

Makes a deep copy of all data of from into this instance, except external scenegraph references if copyconnections is FALSE.

This is the method that should be overridden by subclasses which needs to account for internal data that are not handled automatically.

Make sure that when you override the copyContents() method in your extension class that you also make it call upwards to it's parent superclass in the inheritance hierarchy, as copyContents() in for instance SoNode and SoFieldContainer does important work. It should go something like this:

void MyCoinExtensionNode::copyContents(const SoFieldContainer * from, SbBool copyconnections) { // let parent superclasses do their thing (copy fields, copy // instance name, etc etc) SoNode::copyContents(from, copyconnections); // [..then copy internal data..] }

Reimplemented from SoFieldContainer.

Reimplemented in SoRotateCylindricalDragger, SoRotateSphericalDragger, SoClipPlaneManip, SoDirectionalLightManip, SoPointLightManip, SoSpotLightManip, SoTransformManip, SoBaseKit, SoInteractionKit, SoNodeKitListPart, SoCallback, SoFile, SoGroup, and SoWWWInline.

SoFieldContainer * SoNode::copyThroughConnection void   )  const [virtual]
 

Return copy of this instance.

Note: default implementation just returns this pointer, SoNode and SoEngine overrides this method to return the pointer to the actual copy.

Reimplemented from SoFieldContainer.

SoType SoNode::getClassTypeId void   )  [static]
 

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

Reimplemented from SoFieldContainer.

SoNode * SoNode::getByName const SbName name  )  [static]
 

Returns the last node that was registered under name.

int SoNode::getByName const SbName name,
SoNodeList l
[static]
 

Finds all nodes with name and appends them to the l nodelist. Returns the number of nodes with the specified name.

void SoNode::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 SoFieldContainer.

Reimplemented in SoCenterballDragger, SoDirectionalLightDragger, SoDragPointDragger, SoDragger, SoHandleBoxDragger, SoJackDragger, SoPointLightDragger, SoRotateCylindricalDragger, SoRotateDiscDragger, SoRotateSphericalDragger, SoScale1Dragger, SoScale2Dragger, SoScale2UniformDragger, SoScaleUniformDragger, SoSpotLightDragger, SoTabBoxDragger, SoTabPlaneDragger, SoTrackballDragger, SoTransformBoxDragger, SoTransformerDragger, SoTranslate1Dragger, SoTranslate2Dragger, SoCenterballManip, SoClipPlaneManip, SoDirectionalLightManip, SoHandleBoxManip, SoJackManip, SoPointLightManip, SoSpotLightManip, SoTabBoxManip, SoTrackballManip, SoTransformBoxManip, SoTransformManip, SoTransformerManip, SoAppearanceKit, SoBaseKit, SoCameraKit, SoInteractionKit, SoLightKit, SoNodeKitListPart, SoSceneKit, SoSeparatorKit, SoShapeKit, SoWrapperKit, SoAnnotation, SoAntiSquish, SoArray, SoAsciiText, SoBaseColor, SoBlinker, SoCallback, SoCamera, SoClipPlane, SoColorIndex, SoComplexity, SoCone, SoCoordinate3, SoCoordinate4, SoCube, SoCylinder, SoDirectionalLight, SoDrawStyle, SoEnvironment, SoEventCallback, SoExtSelection, SoFaceSet, SoFile, SoFont, SoFontStyle, SoGroup, SoImage, SoIndexedFaceSet, SoIndexedLineSet, SoIndexedNurbsCurve, SoIndexedNurbsSurface, SoIndexedShape, SoIndexedTriangleStripSet, SoInfo, SoLOD, SoLabel, SoLevelOfDetail, SoLight, SoLightModel, SoLineSet, SoLinearProfile, SoLocateHighlight, SoMarkerSet, SoMaterial, SoMaterialBinding, SoMatrixTransform, SoMultipleCopy, SoNonIndexedShape, SoNormal, SoNormalBinding, SoNurbsCurve, SoNurbsProfile, SoNurbsSurface, SoOrthographicCamera, SoPackedColor, SoPathSwitch, SoPendulum, SoPerspectiveCamera, SoPickStyle, SoPointLight, SoPointSet, SoPolygonOffset, SoProfile, SoProfileCoordinate2, SoProfileCoordinate3, SoQuadMesh, SoResetTransform, SoRotation, SoRotationXYZ, SoRotor, SoScale, SoSelection, SoSeparator, SoShape, SoShapeHints, SoShuttle, SoSphere, SoSpotLight, SoSurroundScale, SoSwitch, SoText2, SoText3, SoTexture2, SoTexture2Transform, SoTextureCoordinate2, SoTextureCoordinateBinding, SoTextureCoordinateDefault, SoTextureCoordinateEnvironment, SoTextureCoordinateFunction, SoTextureCoordinatePlane, SoTransform, SoTransformSeparator, SoTransformation, SoTranslation, SoTriangleStripSet, SoUnits, SoVertexProperty, SoVertexShape, SoWWWAnchor, and SoWWWInline.

void SoNode::initClasses void   )  [static]
 

Initialize all the node classes of Coin.

Reimplemented in SoDragger.

uint32_t SoNode::getNextNodeId void   )  [static]
 

Return the next unique identification number to be assigned upon node construction or change. It is unlikely that application programmers will ever need use this method fom client application code, unless working with extensions to the core library (and probably not even then).

See also:
SoNode::getNodeId

int SoNode::getActionMethodIndex const SoType  type  )  [static]
 

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

void SoNode::getBoundingBoxS SoAction action,
SoNode node
[static]
 

This is a static "helper" method registered with the action, and used for calling the SoNode::getBoundingBox() virtual method which does the real work.

void SoNode::GLRenderS SoAction action,
SoNode node
[static]
 

This is a static "helper" method registered with the action, and used for calling the SoNode::GLRender() virtual method which does the real work.

void SoNode::callbackS SoAction action,
SoNode node
[static]
 

This is a static "helper" method registered with the action, and used for calling the SoNode::callback() virtual method which does the real work.

void SoNode::getMatrixS SoAction action,
SoNode node
[static]
 

This is a static "helper" method registered with the action, and used for calling the SoNode::getMatrix() virtual method which does the real work.

void SoNode::handleEventS SoAction action,
SoNode node
[static]
 

This is a static "helper" method registered with the action, and used for calling the SoNode::handleEvent() virtual method which does the real work.

void SoNode::pickS SoAction action,
SoNode node
[static]
 

This is a static "helper" method registered with the action, and used for calling the SoNode::pick() virtual method which does the real work.

void SoNode::rayPickS SoAction action,
SoNode node
[static]
 

This is a static "helper" method registered with the action, and used for calling the SoNode::rayPick() virtual method which does the real work.

void SoNode::searchS SoAction action,
SoNode node
[static]
 

This is a static "helper" method registered with the action, and used for calling the SoNode::search() virtual method which does the real work.

void SoNode::writeS SoAction action,
SoNode node
[static]
 

This is a static "helper" method registered with the action, and used for calling the SoNode::write() virtual method which does the real work.

void SoNode::getPrimitiveCountS SoAction action,
SoNode node
[static]
 

This is a static "helper" method registered with the action, and used for calling the SoNode::getPrimitiveCount() virtual method which does the real work.

SbBool SoNode::readInstance SoInput in,
unsigned short  flags
[protected, virtual]
 

This method is mainly intended for internal use during file import operations.

It reads a definition of an instance from the input stream in. The input stream state points to the start of a serialized / persistant representation of an instance of this class type.

TRUE or FALSE is returned, depending on if the instantiation and configuration of the new object of this class type went ok or not. The import process should be robust and handle corrupted input streams by returning FALSE.

flags is used internally during binary import when reading user extension nodes, group nodes or engines.

Reimplemented from SoFieldContainer.

Reimplemented in SoBaseKit, SoInteractionKit, SoNodeKitListPart, SoFile, SoGroup, SoImage, SoNormalBinding, SoSeparator, SoTexture2, SoTextureCoordinateBinding, and SoWWWInline.

const SoFieldData ** SoNode::getFieldDataPtr void   )  [static, protected]
 

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

void SoNode::setNextActionMethodIndex int  index  )  [static, protected]
 

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

Only in TGS Inventor on Win32 -- to avoid needing to export the nextActionMethodIndex member, see SoNode.h for more info.

int SoNode::getNextActionMethodIndex void   )  [static, protected]
 

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

Only in TGS Inventor on Win32 -- to avoid needing to export the nextActionMethodIndex member, see SoNode.h for more info.

void SoNode::incNextActionMethodIndex void   )  [static, protected]
 

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

Only in TGS Inventor on Win32 -- to avoid needing to export the nextActionMethodIndex member, see SoNode.h for more info.


Member Data Documentation

uint32_t SoNode::uniqueId [protected]
 

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

uint32_t SoNode::nextUniqueId = 0 [static, protected]
 

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

int SoNode::nextActionMethodIndex = 0 [static, protected]
 

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


The documentation for this class was generated from the following files:
Generated on Tue Jul 27 23:53:06 2004 for Coin by doxygen 1.3.7