Package org.web3d.x3d.sai.Geospatial
Interface GeoLOD
- All Superinterfaces:
X3DBoundedObject
,X3DChildNode
,X3DNode
- All Known Implementing Classes:
GeoLOD
Note that MFNode rootNode field can contain multiple nodes and has accessType inputOutput. Meanwhile MFNode children field is outputOnly, unlike other X3DGroupingNode exemplars.
Warning: this is an abstract interface that cannot be instantiated as a concrete object. Java programmers typically only need to use concrete objects provided by the
Package hint: This interface is defined by the X3D Java Language Binding Specification for the Scene Authoring Interface (SAI).
Warning: this is an abstract interface that cannot be instantiated as a concrete object. Java programmers typically only need to use concrete objects provided by the
org.web3d.x3d.jsail
classes.
GeoLOD node tooltip: [X3DChildNode,X3DBoundedObject,X3DVisibleObject] GeoLOD provides quadtree level-of-detail loading/unloading for multi-resolution terrains. GeoLOD can contain children and GeoOrigin nodes.
- Hint: children nodes expose the scene graph for the currently loaded set of nodes.
- Hint: rootNode specifies the geometry of the root tile.
- Warning: do not use rootUrl and rootNode simultaneously, since each specifies the root tile.
- Hint: X3D for Advanced Modeling (X3D4AM) slideset https://x3dgraphics.com/slidesets/X3dForAdvancedModeling/GeospatialComponentX3dEarth.pdf
- Warning: requires X3D profile='Full' or else include <component name='Geospatial' level='1'/>
- Warning: nested LOD (and/or GeoLOD) nodes with overlapping range intervals can lead to unexpected or undefined behavior.
Package hint: This interface is defined by the X3D Java Language Binding Specification for the Scene Authoring Interface (SAI).
- See Also:
-
Method Summary
Modifier and TypeMethodDescriptionvoid
addRootNode
(X3DNode[] newValue) Add array of child rootNode nodes to array of existing nodes (if any).float[]
Provide array of 3-tuple float results from initializeOnly SFVec3f field named bboxCenter.boolean
Provide boolean value from inputOutput SFBool field named bboxDisplay.float[]
Provide array of 3-tuple float results within allowed range of [0,infinity), or default value [-1 -1 -1], from initializeOnly SFVec3f field named bboxSize.double[]
Provide array of 3-tuple double results from initializeOnly SFVec3d field named center.String[]
Provide array of String results from initializeOnly MFString field named child1Url.String[]
Provide array of String results from initializeOnly MFString field named child2Url.String[]
Provide array of String results from initializeOnly MFString field named child3Url.String[]
Provide array of String results from initializeOnly MFString field named child4Url.X3DNode[]
Provide array of org.web3d.x3d.sai.Core.X3DNode results (using an array consisting of properly typed nodes or ProtoInstances) from outputOnly MFNode field children.Provide org.web3d.x3d.sai.Geospatial.GeoOrigin instance (using a properly typed node) (deprecated node, optional) from initializeOnly SFNode field geoOrigin.String[]
Provide array of String results from initializeOnly MFString field named geoSystem.int
getLevel()
Provide int value within allowed range of [0,1] from outputOnly SFInt32 field named level_changed.Provide org.web3d.x3d.sai.Core.X3DMetadataObject instance (using a properly typed node) from inputOutput SFNode field metadata.float
getRange()
Provide float value within allowed range of [0,infinity) from initializeOnly SFFloat field named range.X3DNode[]
Provide array of org.web3d.x3d.sai.Core.X3DNode results (using an array consisting of properly typed nodes or ProtoInstances) from initializeOnly MFNode field rootNode.String[]
Provide array of String results from initializeOnly MFString field named rootUrl.boolean
Provide boolean value from inputOutput SFBool field named visible.setBboxCenter
(float[] newValue) Accessor method to assign 3-tuple float array to initializeOnly SFVec3f field named bboxCenter.setBboxDisplay
(boolean newValue) Accessor method to assign boolean value to inputOutput SFBool field named bboxDisplay.setBboxSize
(float[] newValue) Accessor method to assign 3-tuple float array to initializeOnly SFVec3f field named bboxSize.setCenter
(double[] newValue) Accessor method to assign 3-tuple double array to initializeOnly SFVec3d field named center.setChild1Url
(String[] newValue) Accessor method to assign String array to initializeOnly MFString field named child1Url.setChild2Url
(String[] newValue) Accessor method to assign String array to initializeOnly MFString field named child2Url.setChild3Url
(String[] newValue) Accessor method to assign String array to initializeOnly MFString field named child3Url.setChild4Url
(String[] newValue) Accessor method to assign String array to initializeOnly MFString field named child4Url.setGeoOrigin
(GeoOrigin newValue) Accessor method to assign org.web3d.x3d.sai.Geospatial.GeoOrigin instance (using a properly typed node) to initializeOnly SFNode field geoOrigin.setGeoSystem
(String[] newValue) Accessor method to assign String array to initializeOnly MFString field named geoSystem.setMetadata
(X3DMetadataObject newValue) Accessor method to assign org.web3d.x3d.sai.Core.X3DMetadataObject instance (using a properly typed node) to inputOutput SFNode field metadata.setRange
(float newValue) Accessor method to assign float value to initializeOnly SFFloat field named range.void
setRootNode
(X3DNode newValue) Set single child rootNode node, replacing prior array of existing nodes (if any).setRootNode
(X3DNode[] newValue) Accessor method to assign org.web3d.x3d.sai.Core.X3DNode array (using an array consisting of properly typed nodes or ProtoInstances) to initializeOnly MFNode field rootNode.setRootUrl
(String[] newValue) Accessor method to assign String array to initializeOnly MFString field named rootUrl.setVisible
(boolean newValue) Accessor method to assign boolean value to inputOutput SFBool field named visible.
-
Method Details
-
getBboxCenter
float[] getBboxCenter()Provide array of 3-tuple float results from initializeOnly SFVec3f field named bboxCenter.
Tooltip: Bounding box center accompanies bboxSize and provides an optional hint for bounding box position offset from origin of local coordinate system.- Hint: precomputation and inclusion of bounding box information can speed up the initialization of large detailed models, with a corresponding cost of increased file size.
- Hint: X3D Architecture, 10.2.2 Bounding boxes https://www.web3d.org/specifications/X3Dv4/ISO-IEC19775-1v4-IS /Part01/components/grouping.html#BoundingBoxes
- Hint: X3D Architecture, 10.3.1 X3DBoundedObject https://www.web3d.org/specifications/X3Dv4/ISO-IEC19775-1v4-IS /Part01/components/grouping.html#X3DBoundedObject
- Specified by:
getBboxCenter
in interfaceX3DBoundedObject
- Returns:
- value of bboxCenter field
-
setBboxCenter
Accessor method to assign 3-tuple float array to initializeOnly SFVec3f field named bboxCenter.
Tooltip: Bounding box center accompanies bboxSize and provides an optional hint for bounding box position offset from origin of local coordinate system.- Hint: precomputation and inclusion of bounding box information can speed up the initialization of large detailed models, with a corresponding cost of increased file size.
- Hint: X3D Architecture, 10.2.2 Bounding boxes https://www.web3d.org/specifications/X3Dv4/ISO-IEC19775-1v4-IS /Part01/components/grouping.html#BoundingBoxes
- Hint: X3D Architecture, 10.3.1 X3DBoundedObject https://www.web3d.org/specifications/X3Dv4/ISO-IEC19775-1v4-IS /Part01/components/grouping.html#X3DBoundedObject
- Specified by:
setBboxCenter
in interfaceX3DBoundedObject
- Parameters:
newValue
- is new value for the bboxCenter field.- Returns:
GeoLOD
- namely this same object to allow sequential method pipelining (i.e. consecutive method invocations on the same object).
-
getBboxDisplay
boolean getBboxDisplay()Provide boolean value from inputOutput SFBool field named bboxDisplay.
Tooltip: Whether to display bounding box for associated geometry, aligned with world coordinates.- Hint: the bounding box is displayed regardless of whether contained content is visible.
- Specified by:
getBboxDisplay
in interfaceX3DBoundedObject
- Returns:
- value of bboxDisplay field
-
setBboxDisplay
Accessor method to assign boolean value to inputOutput SFBool field named bboxDisplay.
Tooltip: Whether to display bounding box for associated geometry, aligned with world coordinates.- Hint: the bounding box is displayed regardless of whether contained content is visible.
- Specified by:
setBboxDisplay
in interfaceX3DBoundedObject
- Parameters:
newValue
- is new value for the bboxDisplay field.- Returns:
GeoLOD
- namely this same object to allow sequential method pipelining (i.e. consecutive method invocations on the same object).
-
getBboxSize
float[] getBboxSize()Provide array of 3-tuple float results within allowed range of [0,infinity), or default value [-1 -1 -1], from initializeOnly SFVec3f field named bboxSize.
Tooltip: or [0,+infinity) Bounding box size is usually omitted, and can easily be calculated automatically by an X3D player at scene-loading time with minimal computational cost. Bounding box size can also be defined as an optional authoring hint that suggests an optimization or constraint.- Hint: can be useful for collision computations or inverse-kinematics (IK) engines.
- Hint: precomputation and inclusion of bounding box information can speed up the initialization of large detailed models, with a corresponding cost of increased file size.
- Hint: X3D Architecture, 10.2.2 Bounding boxes https://www.web3d.org/specifications/X3Dv4/ISO-IEC19775-1v4-IS /Part01/components/grouping.html#BoundingBoxes
- Hint: X3D Architecture, 10.3.1 X3DBoundedObject https://www.web3d.org/specifications/X3Dv4/ISO-IEC19775-1v4-IS /Part01/components/grouping.html#X3DBoundedObject
- Specified by:
getBboxSize
in interfaceX3DBoundedObject
- Returns:
- value of bboxSize field
-
setBboxSize
Accessor method to assign 3-tuple float array to initializeOnly SFVec3f field named bboxSize.
Tooltip: or [0,+infinity) Bounding box size is usually omitted, and can easily be calculated automatically by an X3D player at scene-loading time with minimal computational cost. Bounding box size can also be defined as an optional authoring hint that suggests an optimization or constraint.- Hint: can be useful for collision computations or inverse-kinematics (IK) engines.
- Hint: precomputation and inclusion of bounding box information can speed up the initialization of large detailed models, with a corresponding cost of increased file size.
- Hint: X3D Architecture, 10.2.2 Bounding boxes https://www.web3d.org/specifications/X3Dv4/ISO-IEC19775-1v4-IS /Part01/components/grouping.html#BoundingBoxes
- Hint: X3D Architecture, 10.3.1 X3DBoundedObject https://www.web3d.org/specifications/X3Dv4/ISO-IEC19775-1v4-IS /Part01/components/grouping.html#X3DBoundedObject
- Specified by:
setBboxSize
in interfaceX3DBoundedObject
- Parameters:
newValue
- is new value for the bboxSize field.- Returns:
GeoLOD
- namely this same object to allow sequential method pipelining (i.e. consecutive method invocations on the same object).
-
getCenter
double[] getCenter()Provide array of 3-tuple double results from initializeOnly SFVec3d field named center.
Tooltip: Viewer range from geographic-coordinates center triggers quadtree loading/unloading. *- Returns:
- value of center field
-
setCenter
Accessor method to assign 3-tuple double array to initializeOnly SFVec3d field named center.
Tooltip: Viewer range from geographic-coordinates center triggers quadtree loading/unloading. *- Parameters:
newValue
- is new value for the center field.- Returns:
GeoLOD
- namely this same object to allow sequential method pipelining (i.e. consecutive method invocations on the same object).
-
getChild1Url
String[] getChild1Url()Provide array of String results from initializeOnly MFString field named child1Url.
Tooltip: quadtree geometry loaded when viewer is within range. *- Returns:
- value of child1Url field
-
setChild1Url
Accessor method to assign String array to initializeOnly MFString field named child1Url.
Tooltip: quadtree geometry loaded when viewer is within range. *- Parameters:
newValue
- is new value for the child1Url field.- Returns:
GeoLOD
- namely this same object to allow sequential method pipelining (i.e. consecutive method invocations on the same object).
-
getChild2Url
String[] getChild2Url()Provide array of String results from initializeOnly MFString field named child2Url.
Tooltip: quadtree geometry loaded when viewer is within range. *- Returns:
- value of child2Url field
-
setChild2Url
Accessor method to assign String array to initializeOnly MFString field named child2Url.
Tooltip: quadtree geometry loaded when viewer is within range. *- Parameters:
newValue
- is new value for the child2Url field.- Returns:
GeoLOD
- namely this same object to allow sequential method pipelining (i.e. consecutive method invocations on the same object).
-
getChild3Url
String[] getChild3Url()Provide array of String results from initializeOnly MFString field named child3Url.
Tooltip: quadtree geometry loaded when viewer is within range. *- Returns:
- value of child3Url field
-
setChild3Url
Accessor method to assign String array to initializeOnly MFString field named child3Url.
Tooltip: quadtree geometry loaded when viewer is within range. *- Parameters:
newValue
- is new value for the child3Url field.- Returns:
GeoLOD
- namely this same object to allow sequential method pipelining (i.e. consecutive method invocations on the same object).
-
getChild4Url
String[] getChild4Url()Provide array of String results from initializeOnly MFString field named child4Url.
Tooltip: quadtree geometry loaded when viewer is within range. *- Returns:
- value of child4Url field
-
setChild4Url
Accessor method to assign String array to initializeOnly MFString field named child4Url.
Tooltip: quadtree geometry loaded when viewer is within range. *- Parameters:
newValue
- is new value for the child4Url field.- Returns:
GeoLOD
- namely this same object to allow sequential method pipelining (i.e. consecutive method invocations on the same object).
-
getChildren
X3DNode[] getChildren()Provide array of org.web3d.x3d.sai.Core.X3DNode results (using an array consisting of properly typed nodes or ProtoInstances) from outputOnly MFNode field children.
Tooltip: [X3DChildNode] The outputOnly children field exposes a portion of the scene graph for the currently loaded set of nodes. The value returned as an event is an MFNode containing the currently selected tile. This will either be the node specified by the rootNode field or the nodes specified by the child1Url, child2Url, child3Url, and child4Url fields. The GeoLOD node shall generate a new children output event each time the scene graph is changed (EXAMPLE whenever nodes are loaded or unloaded).- Warning: it is an error to define this transient outputOnly field in an X3D file, instead only use it a source for ROUTE events.
Warning: according to X3D Unified Object Model (X3DUOM), acceptable node types are limited to X3DChildNode.- Returns:
- value of children field
- See Also:
-
getGeoOrigin
GeoOrigin getGeoOrigin()Provide org.web3d.x3d.sai.Geospatial.GeoOrigin instance (using a properly typed node) (deprecated node, optional) from initializeOnly SFNode field geoOrigin.
Tooltip: [GeoOrigin] Single contained GeoOrigin node that can specify a local coordinate frame for extended precision.- Hint: X3D Architecture 25.2.5 Dealing with high-precision coordinates https://www.web3d.org/specifications/X3Dv4/ISO-IEC19775-1v4-IS /Part01/components/geospatial.html#high-precisioncoords
- Warning: XML validation requires placement as first child node following contained metadata nodes (if any).
- Returns:
- value of geoOrigin field
-
setGeoOrigin
Accessor method to assign org.web3d.x3d.sai.Geospatial.GeoOrigin instance (using a properly typed node) to initializeOnly SFNode field geoOrigin.
Tooltip: [GeoOrigin] Single contained GeoOrigin node that can specify a local coordinate frame for extended precision.- Hint: X3D Architecture 25.2.5 Dealing with high-precision coordinates https://www.web3d.org/specifications/X3Dv4/ISO-IEC19775-1v4-IS /Part01/components/geospatial.html#high-precisioncoords
- Warning: XML validation requires placement as first child node following contained metadata nodes (if any).
- Parameters:
newValue
- is new value for the geoOrigin field.- Returns:
GeoLOD
- namely this same object to allow sequential method pipelining (i.e. consecutive method invocations on the same object).
-
getGeoSystem
String[] getGeoSystem()Provide array of String results from initializeOnly MFString field named geoSystem.
Tooltip: Identifies spatial reference frame: Geodetic (GD), Geocentric (GC), Universal Transverse Mercator (UTM). Supported values: "GD" "UTM" or "GC" followed by additional quoted string parameters as appropriate for the type.- Hint: X3D Architecture 25.2.2 Spatial reference frames https://www.web3d.org/specifications/X3Dv4/ISO-IEC19775-1v4-IS /Part01/components/geospatial.html#Spatialreferenceframes
- Hint: X3D Architecture 25.2.4 Specifying geospatial coordinates https://www.web3d.org/specifications/X3Dv4/ISO-IEC19775-1v4-IS /Part01/components/geospatial.html#Specifyinggeospatialcoords
- Hint: UTM is Universal Transverse Mercator coordinate system https://en.wikipedia.org/wiki/Universal_Transverse_Mercator_coordinate_system
- Warning: deprecated values are GDC (replaced by GD) and GCC (replaced by GC).
- Returns:
- value of geoSystem field
-
setGeoSystem
Accessor method to assign String array to initializeOnly MFString field named geoSystem.
Tooltip: Identifies spatial reference frame: Geodetic (GD), Geocentric (GC), Universal Transverse Mercator (UTM). Supported values: "GD" "UTM" or "GC" followed by additional quoted string parameters as appropriate for the type.- Hint: X3D Architecture 25.2.2 Spatial reference frames https://www.web3d.org/specifications/X3Dv4/ISO-IEC19775-1v4-IS /Part01/components/geospatial.html#Spatialreferenceframes
- Hint: X3D Architecture 25.2.4 Specifying geospatial coordinates https://www.web3d.org/specifications/X3Dv4/ISO-IEC19775-1v4-IS /Part01/components/geospatial.html#Specifyinggeospatialcoords
- Hint: UTM is Universal Transverse Mercator coordinate system https://en.wikipedia.org/wiki/Universal_Transverse_Mercator_coordinate_system
- Warning: deprecated values are GDC (replaced by GD) and GCC (replaced by GC).
- Parameters:
newValue
- is new value for the geoSystem field.- Returns:
GeoLOD
- namely this same object to allow sequential method pipelining (i.e. consecutive method invocations on the same object).
-
getLevel
int getLevel()Provide int value within allowed range of [0,1] from outputOnly SFInt32 field named level_changed.
Tooltip: Output event that reports when the new children outputOnly event is generated, with value 0 or 1, where 0 indicates the rootNode field and 1 indicates the nodes specified by the child1Url, child2Url, child3Url, and child4Url fields.- Warning: it is an error to define this transient outputOnly field in an X3D file, instead only use it a source for ROUTE events.
- Returns:
- value of level_changed field
-
getMetadata
X3DMetadataObject getMetadata()Provide org.web3d.x3d.sai.Core.X3DMetadataObject instance (using a properly typed node) from inputOutput SFNode field metadata.
Tooltip: [X3DMetadataObject] Information about this node can be contained in a MetadataBoolean, MetadataDouble, MetadataFloat, MetadataInteger, MetadataString or MetadataSet node.- Hint: X3D Architecture 7.2.4 Metadata https://www.web3d.org/specifications/X3Dv4/ISO-IEC19775-1v4-IS /Part01/components/core.html#Metadata
- Specified by:
getMetadata
in interfaceX3DChildNode
- Specified by:
getMetadata
in interfaceX3DNode
- Returns:
- value of metadata field
- See Also:
-
setMetadata
Accessor method to assign org.web3d.x3d.sai.Core.X3DMetadataObject instance (using a properly typed node) to inputOutput SFNode field metadata.
Tooltip: [X3DMetadataObject] Information about this node can be contained in a MetadataBoolean, MetadataDouble, MetadataFloat, MetadataInteger, MetadataString or MetadataSet node.- Hint: X3D Architecture 7.2.4 Metadata https://www.web3d.org/specifications/X3Dv4/ISO-IEC19775-1v4-IS /Part01/components/core.html#Metadata
- Specified by:
setMetadata
in interfaceX3DChildNode
- Specified by:
setMetadata
in interfaceX3DNode
- Parameters:
newValue
- is new value for the metadata field.- Returns:
GeoLOD
- namely this same object to allow sequential method pipelining (i.e. consecutive method invocations on the same object).- See Also:
-
getRange
float getRange()Provide float value within allowed range of [0,infinity) from initializeOnly SFFloat field named range.
Tooltip: (0,+infinity) Viewer range from geographic-coordinates center triggers quadtree loading/unloading.- Hint: not setting range values indicates that level switching can be optimized automatically based on performance.
- Returns:
- value of range field
-
setRange
Accessor method to assign float value to initializeOnly SFFloat field named range.
Tooltip: (0,+infinity) Viewer range from geographic-coordinates center triggers quadtree loading/unloading.- Hint: not setting range values indicates that level switching can be optimized automatically based on performance.
- Parameters:
newValue
- is new value for the range field.- Returns:
GeoLOD
- namely this same object to allow sequential method pipelining (i.e. consecutive method invocations on the same object).
-
getRootNode
X3DNode[] getRootNode()Provide array of org.web3d.x3d.sai.Core.X3DNode results (using an array consisting of properly typed nodes or ProtoInstances) from initializeOnly MFNode field rootNode.
Tooltip: Geometry for the root tile.- Warning: either rootNode or rootUrl can specify root tile, but specifying both is an error.
Warning: according to X3D Unified Object Model (X3DUOM), acceptable node types are limited to X3DChildNode.- Returns:
- value of rootNode field
- See Also:
-
setRootNode
Accessor method to assign org.web3d.x3d.sai.Core.X3DNode array (using an array consisting of properly typed nodes or ProtoInstances) to initializeOnly MFNode field rootNode.
Tooltip: Geometry for the root tile.- Warning: either rootNode or rootUrl can specify root tile, but specifying both is an error.
Note: according to X3D Unified Object Model (X3DUOM), acceptable node types are limited to X3DChildNode.- Parameters:
newValue
- is new value for the rootNode field.- Returns:
GeoLOD
- namely this same object to allow sequential method pipelining (i.e. consecutive method invocations on the same object).
-
addRootNode
Add array of child rootNode nodes to array of existing nodes (if any).
Note: according to X3D Unified Object Model (X3DUOM), acceptable node types are limited to X3DChildNode.- Parameters:
newValue
- is new value array to be appended the rootNode field.
-
setRootNode
Set single child rootNode node, replacing prior array of existing nodes (if any).- Parameters:
newValue
- is new node for the rootNode field
-
getRootUrl
String[] getRootUrl()Provide array of String results from initializeOnly MFString field named rootUrl.
Tooltip: url for scene providing geometry for the root tile.- Warning: either rootNode or rootUrl can specify root tile, but specifying both is an error.
- Returns:
- value of rootUrl field
-
setRootUrl
Accessor method to assign String array to initializeOnly MFString field named rootUrl.
Tooltip: url for scene providing geometry for the root tile.- Warning: either rootNode or rootUrl can specify root tile, but specifying both is an error.
- Parameters:
newValue
- is new value for the rootUrl field.- Returns:
GeoLOD
- namely this same object to allow sequential method pipelining (i.e. consecutive method invocations on the same object).
-
getVisible
boolean getVisible()Provide boolean value from inputOutput SFBool field named visible.
Tooltip: Whether or not renderable content within this node is visually displayed.- Hint: the visible field has no effect on animation behaviors, event passing or other non-visual characteristics.
- Hint: content must be visible to be collidable and to be pickable.
- Specified by:
getVisible
in interfaceX3DBoundedObject
- Returns:
- value of visible field
-
setVisible
Accessor method to assign boolean value to inputOutput SFBool field named visible.
Tooltip: Whether or not renderable content within this node is visually displayed.- Hint: the visible field has no effect on animation behaviors, event passing or other non-visual characteristics.
- Hint: content must be visible to be collidable and to be pickable.
- Specified by:
setVisible
in interfaceX3DBoundedObject
- Parameters:
newValue
- is new value for the visible field.- Returns:
GeoLOD
- namely this same object to allow sequential method pipelining (i.e. consecutive method invocations on the same object).
-