Class SoIndexedTriangleStripSet
- java.lang.Object
-
- com.openinventor.inventor.Inventor
-
- com.openinventor.inventor.misc.SoBase
-
- com.openinventor.inventor.fields.SoFieldContainer
-
- com.openinventor.inventor.nodes.SoNode
-
- com.openinventor.inventor.nodes.SoShape
-
- com.openinventor.inventor.nodes.SoVertexShape
-
- com.openinventor.inventor.nodes.SoIndexedShape
-
- com.openinventor.inventor.nodes.SoIndexedTriangleStripSet
-
- All Implemented Interfaces:
SafeDisposable
- Direct Known Subclasses:
SoVolumeIndexedTriangleStripSet
public class SoIndexedTriangleStripSet extends SoIndexedShape
Indexed triangle strip set shape node. This shape node constructs triangle strips out of vertices located at the coordinates specified in thevertexProperty
field (fromSoVertexShape
), or the current inherited coordinates. For optimal performance, thevertexProperty
field is recommended.SoIndexedTriangleStripSet
uses the indices in thecoordIndex
field (fromSoIndexedShape
) to specify the vertices of the triangle strips. An index of SO_END_STRIP_INDEX (-1) indicates that the current strip has ended and the next one begins.The vertices of the faces are transformed by the current transformation matrix. The faces are drawn with the current light model and drawing style.
Treatment of the current material and normal binding is as follows: PER_PART specifies a material or normal per strip. PER_FACE binding specifies a material or normal for each triangle. PER_VERTEX specifies a material or normal for each vertex. The corresponding _INDEXED bindings are the same, but use the
materialIndex
ornormalIndex
indices (seeSoIndexedShape
). The default material binding is OVERALL. The default normal binding is PER_VERTEX_INDEXEDIf any normals (or materials) are specified, Open Inventor assumes you provide the correct number of them, as indicated by the binding. You will see unexpected results if you specify fewer normals (or materials) than the shape requires. If no normals are specified, they will be generated automatically.
To render triangles that are not in strips, see the
SoIndexedTriangleSet
node.Limitations:
- Due to limitations of the OpenGL VBO (vertex buffer object) rendering model, it is not possible to use VBO rendering (and performance may be lower) if either the normal binding or the material binding is set to either PER_PART(_INDEXED) or PER_FACE(_INDEXED).
File format/default:
IndexedTriangleStripSet {
vertexProperty NULL coordIndex -1 materialIndex -1 normalIndex -1 textureCoordIndex -1 Action behavior:
SoGLRenderAction
Draws a strip set based on the current coordinates, normals, materials, drawing style, and so on.SoRayPickAction
Picks on the strip set based on the current coordinates and transformation. Details about the intersection are returned in anSoFaceDetail
.SoGetBoundingBoxAction
Computes the bounding box that encloses all vertices of the strip set with the current transformation applied to them. Sets the center to the average of the coordinates of all vertices.SoCallbackAction
If any triangle callbacks are registered with the action, they will be invoked for each successive triangle forming the strips of the set.
-
-
Nested Class Summary
-
Nested classes/interfaces inherited from class com.openinventor.inventor.nodes.SoShape
SoShape.ShapeTypes
-
Nested classes/interfaces inherited from class com.openinventor.inventor.nodes.SoNode
SoNode.RenderModes
-
Nested classes/interfaces inherited from class com.openinventor.inventor.Inventor
Inventor.ConstructorCommand
-
-
Field Summary
Fields Modifier and Type Field Description static int
SO_END_STRIP_INDEX
Value of an index inSoIndexedShape.coordIndex
indicating that the current strip has ended and the next one begins.-
Fields inherited from class com.openinventor.inventor.nodes.SoIndexedShape
coordIndex, materialIndex, normalIndex, tangentIndex, textureCoordIndex
-
Fields inherited from class com.openinventor.inventor.nodes.SoVertexShape
vertexProperty
-
Fields inherited from class com.openinventor.inventor.nodes.SoShape
boundingBoxIgnoring
-
Fields inherited from class com.openinventor.inventor.Inventor
VERBOSE_LEVEL, ZeroHandle
-
-
Constructor Summary
Constructors Constructor Description SoIndexedTriangleStripSet()
Creates an indexed triangle strip set node with default settings.
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description int
getNumStrips()
Calls getNumStrips((com.openinventor.inventor.misc.SoState)null).int
getNumStrips(SoState state)
Returns number of strips.int
getNumTriangles()
Calls getNumTriangles((com.openinventor.inventor.misc.SoState)null).int
getNumTriangles(SoState state)
Returns number of triangles.-
Methods inherited from class com.openinventor.inventor.nodes.SoVertexShape
getNormalCache, getTangentCache
-
Methods inherited from class com.openinventor.inventor.nodes.SoShape
getShapeType, isPrimitiveRestartAvailable, isPrimitiveRestartAvailable
-
Methods inherited from class com.openinventor.inventor.nodes.SoNode
affectsState, callback, copy, copy, distribute, doAction, getAlternateRep, getBoundingBox, getByName, getMatrix, getPrimitiveCount, getRenderEngineMode, getRenderUnitID, GLRender, GLRenderBelowPath, GLRenderInPath, GLRenderOffPath, grabEventsCleanup, grabEventsSetup, handleEvent, isBoundingBoxIgnoring, isOverride, pick, rayPick, search, setOverride, touch, write
-
Methods inherited from class com.openinventor.inventor.fields.SoFieldContainer
copyFieldValues, copyFieldValues, enableNotify, fieldsAreEqual, get, getAllFields, getEventIn, getEventOut, getField, getFieldName, hasDefaultValues, isNotifyEnabled, set, setToDefaults
-
Methods inherited from class com.openinventor.inventor.misc.SoBase
dispose, getName, isDisposable, isSynchronizable, setName, setSynchronizable
-
Methods inherited from class com.openinventor.inventor.Inventor
getNativeResourceHandle
-
-
-
-
Field Detail
-
SO_END_STRIP_INDEX
public static final int SO_END_STRIP_INDEX
Value of an index inSoIndexedShape.coordIndex
indicating that the current strip has ended and the next one begins.- See Also:
- Constant Field Values
-
-
Method Detail
-
getNumStrips
public int getNumStrips()
Calls getNumStrips((com.openinventor.inventor.misc.SoState)null).
-
getNumTriangles
public int getNumTriangles()
Calls getNumTriangles((com.openinventor.inventor.misc.SoState)null).
-
getNumStrips
public int getNumStrips(SoState state)
Returns number of strips.
-
getNumTriangles
public int getNumTriangles(SoState state)
Returns number of triangles.
-
-