SYNOPSIS

#include <Inventor/elements/SoGLMultiTextureImageElement.h>

Inherits SoMultiTextureImageElement.

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 void set (SoState *const state, SoNode *const node, const int unit, SoGLImage *image, const Model model, const SbColor &blendColor)

static void restore (SoState *state, const int unit)

static SoGLImage * get (SoState *state, const int unit, Model &model, SbColor &blendcolor)

static SbBool hasTransparency (SoState *state)

static void set (SoState *const state, SoNode *const node, SoGLImage *image, const Model model, const SbColor &blendColor)

static SoGLImage * get (SoState *state, Model &model, SbColor &blendcolor)

static int32_t getMaxGLTextureSize (void)

Protected Member Functions

virtual ~SoGLMultiTextureImageElement ()

virtual SbBool hasTransparency (const int unit=0) const

Additional Inherited Members

Detailed Description

The SoGLMultiTextureImageElement is used to control the current GL texture for texture units.

Constructor & Destructor Documentation

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

The destructor.

Member Function Documentation

void * SoGLMultiTextureImageElement::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 SoGLMultiTextureImageElement::initClass (void)\fC [static]\fP

This static method initializes static data in the SoGLMultiTextureImageElement class.

void SoGLMultiTextureImageElement::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 SoMultiTextureImageElement.

void SoGLMultiTextureImageElement::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.

void SoGLMultiTextureImageElement::set (\fBSoState\fP *conststate, \fBSoNode\fP *constnode, const intunit, \fBSoGLImage\fP *image, const Modelmodel, const \fBSbColor\fP &blendColor)\fC [static]\fP

Sets the current texture. Id didapply is TRUE, it is assumed that the texture image already is the current GL texture. Do not use this feature unless you know what you're doing.

SbBool SoGLMultiTextureImageElement::hasTransparency (\fBSoState\fP *state)\fC [static]\fP

Returns TRUE if any of the images have at least one transparent pixel.

Since:

Coin 3.1

SbBool SoGLMultiTextureImageElement::hasTransparency (const intunit = \fC0\fP) const\fC [protected]\fP, \fC [virtual]\fP

Called by containsTransparency(). Returns TRUE if image data has transparency. Default method does a very poor job of detecting this, since it returns TRUE when the number of components are 2 or

4.

Override whenever it is important to know this (SoGLTextureImageElement overrides it to avoid transparency handling where possible).

Reimplemented from SoMultiTextureImageElement.

int32_t SoGLMultiTextureImageElement::getMaxGLTextureSize (void)\fC [static]\fP

The size returned by this function will just be a very coarse estimate as it only uses the more or less obsoleted technique of calling glGetIntegerv(GL_MAX_TEXTURE_SIZE).

For a better estimate, use SoGLTextureImageElement::isTextureSizeLegal().

Note that this function needs an OpenGL context to be made current for it to work. Without that, you will most likely get a faulty return value or even a crash.

Author

Generated automatically by Doxygen for Coin from the source code.