SYNOPSIS

#include <Inventor/elements/SoGLViewingMatrixElement.h>

Inherits SoViewingMatrixElement.

Public Member Functions

virtual void init (SoState *state)

FIXME: write doc. virtual void push (SoState *state)

virtual void pop (SoState *state, const SoElement *prevTopElement)

Static Public Member Functions

static SoType getClassTypeId (void)

static int getClassStackIndex (void)

static void * createInstance (void)

static void initClass (void)

static uint32_t getNodeId (SoState *const state)

static SbMatrix getResetMatrix (SoState *state)

Protected Member Functions

virtual ~SoGLViewingMatrixElement ()

virtual void setElt (const SbMatrix &matrix)

Additional Inherited Members

Detailed Description

The SoGLViewingMatrixElement class is used to store the current viewing matrix.

The viewing matrix contains the inverse camera coordinate system matrix. The camera coordinate system is built from the field values in the current SoCamera (currently either SoPerspectiveCamera or SoOrthographicCamera) and any transformations prior to the camera in the scene graph.

Constructor & Destructor Documentation

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

The destructor.

Member Function Documentation

void * SoGLViewingMatrixElement::createInstance (void)\fC [static]\fP

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

void SoGLViewingMatrixElement::push (\fBSoState\fP *state)\fC [virtual]\fP

This method is called every time a new element is required in one of the stacks. This happens when a writable element is requested, using SoState::getElement() or indirectly SoElement::getElement(), and the depth of the current element is less than the state depth.

Override this method if your element needs to copy data from the previous top of stack. The push() method is called on the new element, and the previous element can be found using SoElement::getNextInStack().

Reimplemented from SoElement.

void SoGLViewingMatrixElement::pop (\fBSoState\fP *state, const \fBSoElement\fP *prevTopElement)\fC [virtual]\fP

This method is callled when the state is popped, and the depth of the element is bigger than the current state depth. pop() is called on the new top of stack, and a pointer to the previous top of stack is passed in prevTopElement.

Override this method if you need to copy some state information from the previous top of stack.

Reimplemented from SoElement.

uint32_t SoGLViewingMatrixElement::getNodeId (\fBSoState\fP *conststate)\fC [static]\fP

Returns the node id of the current camera node. This is used by SoGLModelMatrixElement to detect a change in the viewing matrix inside an SoTransformSeparator node.

\fBSbMatrix\fP SoGLViewingMatrixElement::getResetMatrix (\fBSoState\fP *state)\fC [static]\fP

Returns the matrix that should be used by SoGLModelMatrixElement when the transformation should be reset during traversal (typically when encountering an SoResetTransform node). It is not sufficient to simply load the viewing matrix, since the transformations that were applied before the camera needs to be accounted for.

This function is an extension for Coin, and it is not available in the original SGI Open Inventor v2.1 API.

Since:

Coin 2.0

void SoGLViewingMatrixElement::setElt (const \fBSbMatrix\fP &matrix)\fC [protected]\fP, \fC [virtual]\fP

Sets the current viewing matrix.

Reimplemented from SoViewingMatrixElement.

Author

Generated automatically by Doxygen for Coin from the source code.