SYNOPSIS

#include <Inventor/fields/SoSFEnum.h>

Inherits SoSField.

Inherited by SoSFBitMask.

Public Member Functions

virtual SoType getTypeId (void) const

virtual void copyFrom (const SoField &field)

const SoSFEnum & operator= (const SoSFEnum &field)

virtual SbBool isSame (const SoField &field) const

int getValue (void) const

void setValue (int newvalue)

int operator= (int newvalue)

int operator== (const SoSFEnum &field) const

int operator!= (const SoSFEnum &field) const

void setValue (const SbName name)

void setEnums (const int num, const int *vals, const SbName *names)

int getNumEnums (void) const

int getEnum (const int idx, SbName &name) const

Static Public Member Functions

static void * createInstance (void)

static SoType getClassTypeId (void)

static void initClass (void)

Protected Member Functions

virtual SbBool findEnumValue (const SbName &name, int &val)

virtual SbBool findEnumName (int value, const SbName *&name) const

Protected Attributes

int value

int numEnums

int * enumValues

SbName * enumNames

SbBool legalValuesSet

Additional Inherited Members

Detailed Description

The SoSFEnum class is a container for an enum value.

This field is used where nodes, engines or other field containers needs to store one particular value out of an enumerated set.

A field of this type stores its value to file as the symbolic name, rather than the actual integer value.

SoSFEnum instances are initialized on an instance basis, usually in the constructor of the fieldcontainer with the macros SO_NODE_DEFINE_ENUM_VALUE(enumtype, symbolvalue) and SO_NODE_SET_SF_ENUM_TYPE(enumfield, enumtype) for nodes, or for engines; SO_ENGINE_DEFINE_ENUM_VALUE() and SO_ENGINE_SET_SF_ENUM_TYPE().

Example initialization from the constructor of the SoCone class:

SO_NODE_DEFINE_ENUM_VALUE(Part, SIDES);
SO_NODE_DEFINE_ENUM_VALUE(Part, BOTTOM);
SO_NODE_DEFINE_ENUM_VALUE(Part, ALL);
SO_NODE_SET_SF_ENUM_TYPE(parts, Part);

See also:

SoMFEnum, SoSFBitMask

Member Function Documentation

\fBSoType\fP SoSFEnum::getTypeId (void) const\fC [virtual]\fP

Returns the type identification instance which uniquely identifies the Coin field class the object belongs to.

See also:

getClassTypeId(), SoType

Implements SoField.

Reimplemented in SoSFBitMask.

void SoSFEnum::copyFrom (const \fBSoField\fP &f)\fC [virtual]\fP

Copy value(s) from f into this field. f must be of the same type as this field.

Implements SoField.

Reimplemented in SoSFBitMask.

SbBool SoSFEnum::isSame (const \fBSoField\fP &f) const\fC [virtual]\fP

Check for equal type and value(s).

Implements SoField.

Reimplemented in SoSFBitMask.

void SoSFEnum::setValue (const \fBSbName\fPname)

Set the value of this field by specifying an enumeration string value.

void SoSFEnum::setEnums (const intnum, const int *vals, const \fBSbName\fP *names)

Makes a set of num enumeration names map to integer values, given by vals.

int SoSFEnum::getNumEnums (void) const

Returns the number of enum names the SoSFEnum object understands.

Note that this API method is not part of the original SGI Inventor 2.1 API, and is an extension specific to Coin.

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

int SoSFEnum::getEnum (const intidx, \fBSbName\fP &name) const

Returns the value of the Nth enum this SoSFEnum object understands, and mutates name to contain the Nth enum's name.

Note that this API method is not part of the original SGI Inventor 2.1 API, and is an extension specific to Coin.

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

SbBool SoSFEnum::findEnumValue (const \fBSbName\fP &name, int &val)\fC [protected]\fP, \fC [virtual]\fP

Return in val the enumeration value which matches the given enumeration name.

Returns TRUE if name is a valid enumeration string, otherwise FALSE.

SbBool SoSFEnum::findEnumName (intvaluearg, const \fBSbName\fP *&name) const\fC [protected]\fP, \fC [virtual]\fP

Set the enumeration name which matches the given enumeration value.

Returns TRUE if value is a valid enumeration value, otherwise FALSE.

Member Data Documentation

int SoSFEnum::numEnums\fC [protected]\fP

Number of enumeration mappings.

int * SoSFEnum::enumValues\fC [protected]\fP

Array of enumeration values. Maps 1-to-1 with the enumNames.

\fBSbName\fP * SoSFEnum::enumNames\fC [protected]\fP

Array of enumeration names. Maps 1-to-1 with the enumValues.

SbBool SoSFEnum::legalValuesSet\fC [protected]\fP

Is TRUE if a set of enum name-to-value mappings has been set.

Author

Generated automatically by Doxygen for Coin from the source code.