Class TextBox
- java.lang.Object
- 
- All Implemented Interfaces:
- SafeDisposable
 - Direct Known Subclasses:
- DicomInfo
 
 public class TextBox extends SoAnnotation (Preview Feature) Shape node to display a text box in window coordinates.Preview Feature means this class is fully supported and can be used in Open Inventor applications. Being tagged as a Preview Feature just means that the implementation is still subject to API changes and adjustments based on feedback from early adopters. Please be also aware that source compatibility might be broken regardless of the Open Inventor compatibility changes policy due to our commitment to bring needed changes to be sure the specifications of this Preview Feature match the expectations of our customers. This node displays a text box at a fixed location in the viewer window. The positionis specified in normalized device coordinates -1 to 1. HorizontalalignmentHand verticalalignmentVcan be specified. For example position -0.98, -0.98, 0 with TOP/LEFT alignment (the default) puts a text box in the upper left corner of the window. The text box automatically expands or shrinks when lines of text are added to or deleted from the box. Positioning a text box in the lower left corner creates a sort of 'console' output overlaying the scene. Note that the alignment options control the positioning of the text box. The text can be left, center or right justified inside the box using thealignmentHfield.In order to have convenient default values for the font properties, by default the font properties are not inherited from the scene graph. By default the text is rendered using an SoText2 node with font name 'Arial:Bold', font size 15 and line spacing 1.1. The application can modify the fontNameandfontSizefields or modify text properties directly using the getFontNode() and getTextNode() methods.Lighting and picking are disabled. A bordercan be drawn around the box. Text will be rendered on top of whatever is rendered in the main scene graph. The application can modify the text strings directly, but this class also provides some convenience methods that are very useful. For example, the addLine() method appends a new string to the end of the list.The bounding box of this node is ignored, i.e. it does not contribute to an SoGetBoundingBoxAction traversal and it does not affect a "viewAll" call on the camera or viewer. File format/default: TextBox { position 0 0 0 alignmentH LEFT alignmentV TOP textAlignH LEFT fontName Arial:Bold fontSize 15 border FALSE borderColor 1 1 1 
- 
- 
Nested Class SummaryNested Classes Modifier and Type Class Description static classTextBox.AlignmentHHorizontal alignment values.static classTextBox.AlignmentVVertical alignment values.- 
Nested classes/interfaces inherited from class com.openinventor.inventor.nodes.SoSeparatorSoSeparator.Cachings, SoSeparator.FastEditings, SoSeparator.RenderUnitIds
 - 
Nested classes/interfaces inherited from class com.openinventor.inventor.nodes.SoNodeSoNode.RenderModes
 - 
Nested classes/interfaces inherited from class com.openinventor.inventor.InventorInventor.ConstructorCommand
 
- 
 - 
Field SummaryFields Modifier and Type Field Description SoSFEnum<TextBox.AlignmentH>alignmentHHorizontal alignment of the text box (default is LEFT).SoSFEnum<TextBox.AlignmentV>alignmentVVertical alignment of the text box (default is TOP).SoSFBoolborderEnable drawing a border around the text box (default is false).SoSFColorborderColorBorder color (default is 1,1,1).SoSFStringfontNameSpecify the font name (default is "Arial:Bold").SoSFFloatfontSizeSpecify the font size in pixels (default is 15).SoSFVec3fpositionPosition of the text box in normalized screen coordinates (-1 to 1).SoSFEnum<TextBox.AlignmentH>textAlignHHorizontal alignment of the text inside the box (default is LEFT).- 
Fields inherited from class com.openinventor.inventor.nodes.SoSeparatorboundingBoxCaching, fastEditing, pickCulling, renderCaching, renderCulling, renderUnitId
 - 
Fields inherited from class com.openinventor.inventor.nodes.SoGroupboundingBoxIgnoring
 - 
Fields inherited from class com.openinventor.inventor.InventorVERBOSE_LEVEL, ZeroHandle
 
- 
 - 
Constructor SummaryConstructors Constructor Description TextBox()Constructor
 - 
Method SummaryAll Methods Instance Methods Concrete Methods Modifier and Type Method Description voidaddLine(java.lang.String text)Add a line of text at the bottom of the box.intgetNumLines()Get number of lines of text currently in the boxSoNode.RenderModesgetRenderEngineMode()Returns the supported Render engine mode.voidsetLine(java.lang.String text, int line)Set the contents of the specified line of text (convenience method).- 
Methods inherited from class com.openinventor.inventor.nodes.SoGroupaddChild, findChild, getChild, getNumChildren, insertChild, removeAllChildren, removeChild, removeChild, replaceChild, replaceChild
 - 
Methods inherited from class com.openinventor.inventor.nodes.SoNodeaffectsState, callback, copy, copy, distribute, doAction, getAlternateRep, getBoundingBox, getByName, getMatrix, getPrimitiveCount, getRenderUnitID, GLRender, GLRenderBelowPath, GLRenderInPath, GLRenderOffPath, grabEventsCleanup, grabEventsSetup, handleEvent, isBoundingBoxIgnoring, isOverride, pick, rayPick, search, setOverride, touch, write
 - 
Methods inherited from class com.openinventor.inventor.fields.SoFieldContainercopyFieldValues, copyFieldValues, enableNotify, fieldsAreEqual, get, getAllFields, getEventIn, getEventOut, getField, getFieldName, hasDefaultValues, isNotifyEnabled, set, setToDefaults
 - 
Methods inherited from class com.openinventor.inventor.misc.SoBasedispose, getName, isDisposable, isSynchronizable, setName, setSynchronizable
 - 
Methods inherited from class com.openinventor.inventor.InventorgetNativeResourceHandle
 
- 
 
- 
- 
- 
Field Detail- 
positionpublic SoSFVec3f position Position of the text box in normalized screen coordinates (-1 to 1). Default is 0,0,0.
 - 
alignmentHpublic SoSFEnum<TextBox.AlignmentH> alignmentH Horizontal alignment of the text box (default is LEFT).
 - 
alignmentVpublic SoSFEnum<TextBox.AlignmentV> alignmentV Vertical alignment of the text box (default is TOP).
 - 
textAlignHpublic SoSFEnum<TextBox.AlignmentH> textAlignH Horizontal alignment of the text inside the box (default is LEFT).
 - 
fontNamepublic SoSFString fontName Specify the font name (default is "Arial:Bold"). See SoFont.name for details
 - 
fontSizepublic SoSFFloat fontSize Specify the font size in pixels (default is 15).
 - 
borderpublic SoSFBool border Enable drawing a border around the text box (default is false).
 - 
borderColorpublic SoSFColor borderColor Border color (default is 1,1,1).
 
- 
 - 
Method Detail- 
setLinepublic void setLine(java.lang.String text, int line)Set the contents of the specified line of text (convenience method).
 - 
addLinepublic void addLine(java.lang.String text) Add a line of text at the bottom of the box.
 - 
getNumLinespublic int getNumLines() Get number of lines of text currently in the box
 - 
getRenderEngineModepublic SoNode.RenderModes getRenderEngineMode() Description copied from class:SoNodeReturns the supported Render engine mode.For custom node, this method returns by default SoNode.RenderModes.OIV_UNKNOWN_RENDERING_MODE, override this method to specify the Render engine mode supported by your custom node.- Overrides:
- getRenderEngineModein class- SoNode
- Returns:
- the supported Render engine mode for this node.
 
 
- 
 
-