Class SoTextureUnit
- All Implemented Interfaces:
- SafeDisposable
SoTexture2, SoTexture2Transform, SoTextureCoordinate2, SoTextureCoordinateBinding, and SoTextureCoordinateFunction).
 If the graphics board supports multitexturing (OpenGL 1.5 or GL_ARB_multitexture extension), then multiple textures, each defined by a texture unit, can be applied to the same shape. The maximum number of texture units depends on the board and can be queried using getMaxTextureUnit.
 
Multitexturing is supported by the following shapes:
- SoCone
- SoCube
- SoCylinder
- SoFaceSet
- SoIndexedFaceSet
- SoIndexedQuadMesh
- SoIndexedTriangleStripSet
- SoQuadMesh
- SoSphere
- SoTriangleStripSet
Each texture unit is defined by the following texture properties:
- image of the texture (derived from SoTexture)
- texture coordinates (SoTextureCoordinate2,SoTextureCoordinate3,SoTextureCoordinateBinding, etc.)
- automatic texture coordinates generation (derived from SoTextureCoordinateFunction)
- stack of matrix transforms (SoTexture2Transform,SoTexture3Transform,SoMatrixTransform, etc.)
- mapping method: image mapping or bump mapping.
Limitations:
- Multitexturing is not supported for non convex shapes (SoShapeHints.UNKNOWN_FACE_TYPE).
- Automatic texture coordinate generation (SoTextureCoordinateFunction) is not possible for the bump mapping method.
- When not using shaders, only units 0 to 3 can be used.
- When using shaders, texture unit properties (listed above) can be defined for units 0 to 7. When shaders are used, it is also possible to use SoVertexShaderParameterto specify texture coordinates to be used by the shader(s).SoVertexShaderParameterparameter sets are limited to 32 on OpenGL3 hardware.
File format/default:
TextureUnit {
| unit | 0 | 
Action behavior:
SoGLRenderAction, SoCallbackAction
 
 Sets the current texture unit and the associated mapping method. Sets: SoTextureUnitElement
 
SoBumpMappingProperty, SoTexture2, SoTexture2Transform, SoTextureCoordinate2, SoTextureCoordinateBinding, SoTextureCoordinateFunction. 
 
- 
Nested Class SummaryNested classes/interfaces inherited from class com.openinventor.inventor.nodes.SoNodeSoNode.RenderModesNested classes/interfaces inherited from class com.openinventor.inventor.InventorInventor.ConstructorCommand
- 
Field SummaryFieldsFields inherited from class com.openinventor.inventor.InventorVERBOSE_LEVEL, ZeroHandle
- 
Constructor SummaryConstructors
- 
Method SummaryModifier and TypeMethodDescriptionstatic intCalls getMaxTextureUnit((com.openinventor.inventor.misc.SoState)null).static intgetMaxTextureUnit(SoState state) Returns the maximum number of texture units.Methods inherited from class com.openinventor.inventor.nodes.SoNodeaffectsState, 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, writeMethods inherited from class com.openinventor.inventor.fields.SoFieldContainercopyFieldValues, copyFieldValues, enableNotify, fieldsAreEqual, get, getAllFields, getEventIn, getEventOut, getField, getFieldName, hasDefaultValues, isNotifyEnabled, set, setToDefaultsMethods inherited from class com.openinventor.inventor.misc.SoBasedispose, getName, isDisposable, isSynchronizable, setName, setSynchronizableMethods inherited from class com.openinventor.inventor.InventorgetNativeResourceHandle
- 
Field Details- 
unitSpecifies the texture unit identifier. Can range from 0 to the largest texture unit, which isgetMaxTextureUnit()-1. Values greater than the largest texture unit are clamped at the largest texture unit.
 
- 
- 
Constructor Details- 
SoTextureUnitpublic SoTextureUnit()Constructor.
 
- 
- 
Method Details- 
getMaxTextureUnitpublic static int getMaxTextureUnit()Calls getMaxTextureUnit((com.openinventor.inventor.misc.SoState)null).
- 
getMaxTextureUnitReturns the maximum number of texture units. This is the max which can be used when a shader is on state. Without shaders, only the first 4 units (0..3) can be used.
 
-