Coin3D is Free Software, published under the BSD 3-clause license. |
https://bitbucket.org/Coin3D/ http://www.kongsberg.com/kogt/ |
The SoLazyElement class is used to handle material and shape properties. More...
#include <Inventor/elements/SoLazyElement.h>
Classes | |
struct | CoinState |
Public Member Functions | |
virtual void | init (SoState *state) |
virtual void | push (SoState *state) |
virtual SbBool | matches (const SoElement *) const |
virtual SoElement * | copyMatchInfo (void) const |
int32_t | getNumDiffuse (void) const |
int32_t | getNumTransparencies (void) const |
int32_t | getNumColorIndices (void) const |
SbBool | isPacked (void) const |
SbBool | isTransparent (void) const |
const uint32_t * | getPackedPointer (void) const |
const SbColor * | getDiffusePointer (void) const |
const int32_t * | getColorIndexPointer (void) const |
const float * | getTransparencyPointer (void) const |
Public Member Functions inherited from SoElement | |
const SoType | getTypeId (void) const |
int | getStackIndex (void) const |
virtual void | pop (SoState *state, const SoElement *prevTopElement) |
void | setDepth (const int depth) |
int | getDepth (void) const |
virtual void | print (FILE *file=stdout) const |
virtual | ~SoElement () |
Static Public Member Functions | |
static SoType | getClassTypeId (void) |
static int | getClassStackIndex (void) |
static void * | createInstance (void) |
static void | initClass () |
static void | setToDefault (SoState *state) |
static void | setDiffuse (SoState *state, SoNode *node, int32_t numcolors, const SbColor *colors, SoColorPacker *packer) |
static void | setTransparency (SoState *state, SoNode *node, int32_t numvalues, const float *transparency, SoColorPacker *packer) |
static void | setPacked (SoState *state, SoNode *node, int32_t numcolors, const uint32_t *colors, const SbBool packedtransparency=FALSE) |
static void | setColorIndices (SoState *state, SoNode *node, int32_t numindices, const int32_t *indices) |
static void | setAmbient (SoState *state, const SbColor *color) |
static void | setEmissive (SoState *state, const SbColor *color) |
static void | setSpecular (SoState *state, const SbColor *color) |
static void | setShininess (SoState *state, float value) |
static void | setColorMaterial (SoState *state, SbBool value) |
static void | enableBlending (SoState *state, int sfactor, int dfactor) |
static void | enableSeparateBlending (SoState *state, int sfactor, int dfactor, int alpha_sfactor, int alpha_dfactor) |
static void | disableBlending (SoState *state) |
static void | setLightModel (SoState *state, const int32_t model) |
static void | setVertexOrdering (SoState *state, VertexOrdering ordering) |
static void | setBackfaceCulling (SoState *state, SbBool onoff) |
static void | setTwosideLighting (SoState *state, SbBool onoff) |
static void | setShadeModel (SoState *state, SbBool flatshading) |
static void | setAlphaTest (SoState *state, int func, float value) |
static const SbColor & | getDiffuse (SoState *state, int index) |
static float | getTransparency (SoState *, int index) |
static const uint32_t * | getPackedColors (SoState *) |
static const int32_t * | getColorIndices (SoState *) |
static int32_t | getColorIndex (SoState *, int num) |
static const SbColor & | getAmbient (SoState *) |
static const SbColor & | getEmissive (SoState *) |
static const SbColor & | getSpecular (SoState *) |
static float | getShininess (SoState *) |
static SbBool | getColorMaterial (SoState *) |
static SbBool | getBlending (SoState *, int &sfactor, int &dfactor) |
static SbBool | getAlphaBlending (SoState *, int &sfactor, int &dfactor) |
static int32_t | getLightModel (SoState *) |
static int | getAlphaTest (SoState *state, float &value) |
static SbBool | getTwoSidedLighting (SoState *state) |
static SoLazyElement * | getInstance (SoState *state) |
static float | getDefaultAmbientIntensity (void) |
static SbColor | getDefaultDiffuse (void) |
static SbColor | getDefaultAmbient (void) |
static SbColor | getDefaultSpecular (void) |
static SbColor | getDefaultEmissive (void) |
static float | getDefaultShininess (void) |
static uint32_t | getDefaultPacked (void) |
static float | getDefaultTransparency (void) |
static int32_t | getDefaultLightModel (void) |
static int32_t | getDefaultColorIndex (void) |
static void | setMaterials (SoState *state, SoNode *node, uint32_t bitmask, SoColorPacker *cPacker, const SbColor *diffuse, const int numdiffuse, const float *transp, const int numtransp, const SbColor &ambient, const SbColor &emissive, const SbColor &specular, const float shininess, const SbBool istransparent) |
static SoLazyElement * | getWInstance (SoState *state) |
static void | setTransparencyType (SoState *state, int32_t type) |
Static Public Member Functions inherited from SoElement | |
static void | initClass (void) |
static SoType | getClassTypeId (void) |
static int | getClassStackIndex (void) |
static void | initElements (void) |
static int | getNumStackIndices (void) |
static SoType | getIdFromStackIndex (const int stackIndex) |
Protected Member Functions | |
virtual void | lazyDidSet (uint32_t mask) |
virtual void | lazyDidntSet (uint32_t mask) |
virtual void | setDiffuseElt (SoNode *, int32_t numcolors, const SbColor *colors, SoColorPacker *packer) |
virtual void | setPackedElt (SoNode *node, int32_t numcolors, const uint32_t *colors, const SbBool packedtransparency) |
virtual void | setColorIndexElt (SoNode *node, int32_t numindices, const int32_t *indices) |
virtual void | setTranspElt (SoNode *node, int32_t numtransp, const float *transp, SoColorPacker *packer) |
virtual void | setTranspTypeElt (int32_t type) |
virtual void | setAmbientElt (const SbColor *color) |
virtual void | setEmissiveElt (const SbColor *color) |
virtual void | setSpecularElt (const SbColor *color) |
virtual void | setShininessElt (float value) |
virtual void | setColorMaterialElt (SbBool value) |
virtual void | enableBlendingElt (int sfactor, int dfactor, int alpha_sfactor, int alpha_dfactor) |
virtual void | disableBlendingElt (void) |
virtual void | setLightModelElt (SoState *state, int32_t model) |
virtual void | setMaterialElt (SoNode *node, uint32_t bitmask, SoColorPacker *packer, const SbColor *diffuse, const int numdiffuse, const float *transp, const int numtransp, const SbColor &ambient, const SbColor &emissive, const SbColor &specular, const float shininess, const SbBool istransparent) |
virtual void | setVertexOrderingElt (VertexOrdering ordering) |
virtual void | setBackfaceCullingElt (SbBool onoff) |
virtual void | setTwosideLightingElt (SbBool onoff) |
virtual void | setShadeModelElt (SbBool flatshading) |
virtual void | setAlphaTestElt (int func, float value) |
Protected Member Functions inherited from SoElement | |
SoElement (void) | |
void | capture (SoState *const state) const |
virtual void | captureThis (SoState *state) const |
void | setTypeId (const SoType typeId) |
void | setStackIndex (const int index) |
SoElement * | getNextInStack (void) const |
SoElement * | getNextFree (void) const |
Protected Attributes | |
struct SoLazyElement::CoinState | coinstate |
Protected Attributes inherited from SoElement | |
SoType | typeId |
int | stackIndex |
int | depth |
Additional Inherited Members | |
Static Protected Member Functions inherited from SoElement | |
static SoElement * | getElement (SoState *const state, const int stackIndex) |
static const SoElement * | getConstElement (SoState *const state, const int stackIndex) |
static int | createStackIndex (const SoType id) |
Static Protected Attributes inherited from SoElement | |
static int | classStackIndex |
static SoTypeList * | stackToType |
The SoLazyElement class is used to handle material and shape properties.
So[GL]LazyElement is, as the name implies, an element that is lazy about sending things to OpenGL. The changes are not sent to OpenGL until SoGLLazyElement::send() is called. This means that you can change the state of certain attributes several times, but the state will only be sent to OpenGL once.
When creating a new shape node in Coin, it's a common operation to modify the OpenGL diffuse color. There are several ways you can send the color to OpenGL. If you're not going to use the color outside your node, you can just as well send it using plain OpenGL. You can also set the color in the element, and then force a send by using SoGLLazyElement::send(state, SoLazyElement::DIFFUSE_MASK).
However, when creating an extension shape node, it's always recommended to create an instance of SoMaterialBundle on the stack. If this instance is created after you update SoLazyElement with a new color, the new color will be sent to OpenGL when you call SoMaterialBundle::sendFirst(). This call will also update all other lazy OpenGL state, and it's actually required to either use SoMaterialBundle::sendFirst() or call SoGLLazyElement::send(state, SoLazyElement::ALL_MASK) when creating a shape node.
If you decide to send the color to OpenGL using glColor*(), you should notify SoGLLazyElement about this by calling SoGLLazyElement::reset(state, SoLazyElement::DIFFUSE_MASK). This will notify SoGLLazyElement that the current OpenGL diffuse color is unknown.
|
static |
This API member is considered internal to the library, as it is not likely to be of interest to the application programmer.
|
static |
This static method initializes static data for the SoDiffuseColorElement class.
|
virtual |
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 SoElement.
Reimplemented in SoGLLazyElement.
|
virtual |
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.
Reimplemented in SoGLLazyElement.
|
virtual |
Will always return TRUE in Coin.
Implements SoElement.
|
virtual |
Just returns NULL in Coin.
Implements SoElement.
|
static |
Internal function used for resetting the OpenGL state before FBO rendering.