Abstract base class for all indexed vertex-based shapes. More...
#include <Inventor/nodes/SoIndexedShape.h>
Public Member Functions | |
virtual SoType | getTypeId () const |
Static Public Member Functions | |
static SoType | getClassTypeId () |
Public Attributes | |
SoMFInt32 | coordIndex |
SoMFInt32 | materialIndex |
SoMFInt32 | normalIndex |
SoMFInt32 | tangentIndex |
SoMFInt32 | textureCoordIndex |
Abstract base class for all indexed vertex-based shapes.
This node is the abstract base class for all vertex-based shapes that are constructed from indices, including SoIndexedFaceSet, SoIndexedTriangleStripSet, and SoIndexedLineSet. SoIndexedShape defines fields that are used in all of its subclasses.
All subclasses of SoNonIndexedShape construct objects by using the coordinates specified by the vertexProperty field (from SoVertexShape), or the current inherited coordinates. The coordIndex field defined by this class contains the indices into the current coordinates of the vertices of the shape. These indices are also used for materials, normals, tangents or texture coordinates when the appropriate binding is PER_VERTEX_INDEXED.
Material, normal and tangent bindings are interpreted as follows for each subclass:
OVERALL | One material for the entire shape. |
PER_PART | Specific to the subclass. |
PER_PART_INDEXED | Same as PER_PART, using indices from the materialIndex, normalIndex or tangentIndex field. |
PER_FACE | Specific to the subclass. |
PER_FACE_INDEXED | Same as PER_FACE, using indices from the materialIndex, normalIndex or tangentIndex field. |
PER_VERTEX | One material per vertex. |
PER_VERTEX_INDEXED | One material per vertex, using indices from the materialIndex, normalIndex or tangentIndex field. |
When any _INDEXED binding is used for materials, normals or tangents, the materialIndex, normalIndex or tangentIndex field is used to determine the indices for the materials, normals or tangents. If this field contains a single value of -1 (the default), the coordinate indices from the coordIndex field are used as well for materials, normals or tangents. When the binding is PER_VERTEX_INDEXED, indices in these fields that correspond to negative indices in coordIndex are skipped; for other index bindings all the values in the fields are used, in order.
Explicit texture coordinates (as defined by SoTextureCoordinate2) may be bound to vertices of an indexed shape consecutively (if the texture coordinate binding is PER_VERTEX) or by using the indices in the textureCoordIndex field (if the binding is PER_VERTEX_INDEXED). As with all vertex-based shapes, if there is a current texture but no texture coordinates are specified, a default texture coordinate mapping is calculated using the bounding box of the shape.
Be sure that the indices contained in the coordIndex, materialIndex, normalIndex, tangentIndex, and textureCoordIndex fields are valid with respect to the current state, or errors will occur.
Limitations:
SoIndexedFaceSet, SoIndexedLineSet, SoIndexedTriangleStripSet, SoMaterialBinding, SoNonIndexedShape, SoNormalBinding, SoTangentBinding, SoShapeHints, SoTextureCoordinateBinding
static SoType SoIndexedShape::getClassTypeId | ( | ) | [static] |
Returns the type identifier for this class.
Reimplemented from SoVertexShape.
Reimplemented in SoGeoElevationGrid, SoIndexedFaceSet, SoIndexedLineSet, SoIndexedMarkerSet, SoIndexedPointSet, SoIndexedQuadMesh, SoIndexedTriangleFanSet, SoIndexedTriangleSet, SoIndexedTriangleStripSet, SoVolumeIndexedFaceSet, and SoVolumeIndexedTriangleStripSet.
virtual SoType SoIndexedShape::getTypeId | ( | ) | const [virtual] |
Returns the type identifier for this specific instance.
Reimplemented from SoVertexShape.
Reimplemented in SoGeoElevationGrid, SoIndexedFaceSet, SoIndexedLineSet, SoIndexedMarkerSet, SoIndexedPointSet, SoIndexedQuadMesh, SoIndexedTriangleFanSet, SoIndexedTriangleSet, SoIndexedTriangleStripSet, SoVolumeIndexedFaceSet, and SoVolumeIndexedTriangleStripSet.
The indices of the coordinates that the shape uses as its vertices.
The coordinates connect to form faces, lines, or other shapes. Each subclass defines special negative indices to use to indicate separation between faces, lines, and so on.
The indices of the materials that are used for the shape.
This field is used only when the material binding is one of the _INDEXED bindings. By default, the value of this field indicates that the coordinate indices should be used for materials as well.
The indices of the normals that are used for the shape.
This field is used only when the normal binding is one of the _INDEXED bindings. By default, the value of this field indicates that the coordinate indices should be used for normals as well.
The indices of the tangents that are used for the shape.
This field is used only when the tangent binding is one of the _INDEXED bindings. By default, the value of this field indicates that the coordinate indices should be used for tangents as well.
The indices of the texture coordinates that are used for the shape.
This field is used only when the texture coordinate binding is one of the _INDEXED bindings. By default, the value of this field indicates that the coordinate indices should be used for texture coordinates as well.