SYNOPSIS

#include <Inventor/elements/SoLightElement.h>

Inherits SoAccumulatedElement.

Public Member Functions

virtual void init (SoState *state)

virtual void push (SoState *state)

Static Public Member Functions

static SoType getClassTypeId (void)

static int getClassStackIndex (void)

static void * createInstance (void)

static void initClass (void)

static void add (SoState *const state, SoLight *const light, const SbMatrix &matrix)

static const SoNodeList & getLights (SoState *const state)

static const SbMatrix & getMatrix (SoState *const state, const int index)

Protected Member Functions

SoLightElement (void)

virtual ~SoLightElement ()

Protected Attributes

SoNodeList lights

SbList< SbMatrix > * matrixlist

Additional Inherited Members

Detailed Description

The SoLightElement class manages the currently active light sources.

Constructor & Destructor Documentation

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

The constructor

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

The destructor.

Member Function Documentation

void * SoLightElement::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 SoLightElement::init (\fBSoState\fP *state)\fC [virtual]\fP

This function initializes the element type in the given SoState. It is called for the first element of each enabled element type in SoState objects.

Reimplemented from SoAccumulatedElement.

void SoLightElement::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 SoAccumulatedElement.

void SoLightElement::add (\fBSoState\fP *conststate, \fBSoLight\fP *constlight, const \fBSbMatrix\fP &matrix)\fC [static]\fP

Adds light to the list of active lights. matrix should transform the light from the world coordinate system to the view reference coordinate system.

const \fBSoNodeList\fP & SoLightElement::getLights (\fBSoState\fP *conststate)\fC [static]\fP

Returns the list of light nodes.

const \fBSbMatrix\fP & SoLightElement::getMatrix (\fBSoState\fP *conststate, const intindex)\fC [static]\fP

Get matrix which transforms light index from the world coordinate system to the view reference system.

Member Data Documentation

SoLightElement::lights\fC [protected]\fP

List of current light nodes.

SoLightElement::matrixlist\fC [protected]\fP

List of matrices to map from world coordinates to view reference coordinates. To avoid getting a hugs element (sizeof), this list is only allocated in the bottom element, and the pointer to this list is passed along to the other elements.

Author

Generated automatically by Doxygen for Coin from the source code.