Extensible 3D (X3D)
Part 1: Architecture and base components
22 Environmental sensor component
The name of this component is "EnvironmentalSensor". This name shall be used when referring to this component in the COMPONENT statement (see 7.2.5.4 Component statement).
This clause describes the Environmental Sensor component of this part of ISO/IEC 19775. Table 22.1 provides links to the major topics in this clause.
Environment sensors are nodes which emit events based on some event which occurs within the environment, usually an interaction between two elements within the world. Most environment sensors events occur because of an interaction between the viewer and the world. However, an environment sensor event may also occur because of an interaction between a non-manipulatable piece of hardware (e.g., a clock) and the world, or an event over the network.
The following node types are environmental sensors:
The ProximitySensor detects when the user navigates into a specified region in the world. The ProximitySensor itself is not visible. The TimeSensor is a clock that has no geometry or location associated with it; it is used to start and stop time-based nodes such as interpolators. The VisibilitySensor detects when a specific part of the world becomes visible to the user.
When environmental sensors are inserted into the transformation hierarchy and before the presentation is updated (i.e., read from file or created by a script), they shall generate events indicating any conditions which the sensor is intended to detect. The conditions for individual sensor types to generate these initial events are defined in the individual node specifications in 22.4 Node reference.
The Collision grouping node detects when the user collides with objects in the virtual world. Proximity, collision, and visibility sensors are each processed independently of whether others exist or overlap. See 23 Navigation component for more information.
X3DEnvironmentalSensorNode : X3DChildNode, X3DSensorNode { SFVec3f [in,out] center 0 0 0 (-∞,∞) SFBool [in,out] enabled TRUE SFNode [in,out] metadata NULL [X3DMetadataObject] SFVec3f [in,out] size 0 0 0 (-∞,∞) SFTime [out] enterTime SFTime [out] exitTime SFBool [out] isActive }
X3DEnvironmentalSensorNode is the base type for the environmental sensor nodes ProximitySensor and VisibilitySensor.
ProximitySensor : X3DEnvironmentalSensorNode { SFVec3f [in,out] center 0 0 0 (-∞,∞) SFBool [in,out] enabled TRUE SFNode [in,out] metadata NULL [X3DMetadataObject] SFVec3f [in,out] size 0 0 0 [0,∞) SFTime [out] enterTime SFTime [out] exitTime SFVec3f [out] centerOfRotation_changed SFBool [out] isActive SFRotation [out] orientation_changed SFVec3f [out] position_changed }
The ProximitySensor node generates events when the viewer enters,
exits, and moves within a region in space (defined by a box). A proximity
sensor is enabled or disabled by sending it an enabled event with a
value of TRUE
or FALSE
.
A disabled sensor does not send events.
A ProximitySensor node generates isActive TRUE
/FALSE
events as the viewer enters and exits the rectangular box defined by its center
and size fields. Browsers shall interpolate viewer positions and timestamp
the isActive events with the exact time the viewer first intersected
the proximity region. The center field defines the centre point of
the proximity region in object space. The size field specifies a vector
which defines the width (x), height (y), and depth (z) of the box bounding
the region. The components of the size field shall be greater than
or equal to zero. ProximitySensor nodes are affected by the hierarchical transformations
of their parents.
The enterTime event is generated whenever the isActive
TRUE event is generated (user enters the box),
and exitTime events are generated whenever an isActive FALSE
event is generated (user exits the box).
The centerOfRotation_changed field sends events whenever the user is contained within the proximity region and the center of rotation of the viewer for EXAMINE mode changes with respect to the ProximitySensor node's coordinate system . This may result when the bound Viewpoint nodes's center of rotation changes, when a new viewpoint is bound, when the user changes the center of rotation through the browser's user interface, or from changes to the ProximitySensor node's coordinate system. centerOfRotation_changed events are only generated when the currently bound NavigationInfo's type includes LOOKAT navigation. For more information, see Viewpoint and NavigationInfo.
The position_changed and orientation_changed fields send events whenever the user is contained within the proximity region and the position and orientation of the viewer changes with respect to the ProximitySensor node's coordinate system including enter and exit times. The viewer movement may be a result of a variety of circumstances resulting from browser navigation, ProximitySensor node's coordinate system changes, or bound Viewpoint node's position or orientation changes.
Each ProximitySensor node behaves independently of all other ProximitySensor nodes. Every enabled ProximitySensor node that is affected by the viewer's movement receives and sends events, possibly resulting in multiple ProximitySensor nodes receiving and sending events simultaneously. Unlike TouchSensor nodes, there is no notion of a ProximitySensor node lower in the scene graph "grabbing" events.
Instanced (DEF/USE) ProximitySensor nodes use the union of all the boxes to check for enter and exit. A multiply instanced ProximitySensor node will detect enter and exit for all instances of the box and send enter/exit events appropriately. For non-overlapping bounding boxes, position_changed and orientation_changed events are calculated relative to the coordinate system associated with the bounding box in which the proximity was detected. However, the results are undefined if the any of the boxes of a multiply instanced ProximitySensor node overlap.
A ProximitySensor node that surrounds the entire world has an
enterTime equal to the time that the world was entered and can be used
to start up animations or behaviours as soon as a world is loaded. A ProximitySensor
node with a box containing zero volume (i.e., any size field element
of 0.0) cannot generate events. This is equivalent to setting the enabled
field to FALSE
.
A ProximitySensor read from an X3D file shall generate isActive
TRUE
, position_changed, orientation_changed
and enterTime events if the sensor is enabled and the viewer is inside
the proximity region. A ProximitySensor inserted into the transformation hierarchy
shall generate isActive TRUE
, position_changed,
orientation_changed and enterTime events if the sensor is enabled
and the viewer is inside the proximity region. A ProximitySensor removed from
the transformation hierarchy shall generate isActive FALSE
,
position_changed, orientation_changed and exitTime events
if the sensor is enabled and the viewer is inside the proximity region.
VisibilitySensor : X3DEnvironmentalSensorNode { SFVec3f [in,out] center 0 0 0 (-∞,∞) SFBool [in,out] enabled TRUE SFNode [in,out] metadata NULL [X3DMetadataObject] SFVec3f [in,out] size 0 0 0 [0,∞) SFTime [out] enterTime SFTime [out] exitTime SFBool [out] isActive }
The VisibilitySensor node detects visibility changes of a rectangular box as the user navigates the world. VisibilitySensor is typically used to detect when the user can see a specific object or region in the scene in order to activate or deactivate some behaviour or animation. The purpose is often to attract the attention of the user or to improve performance.
The enabled field enables and disables the VisibilitySensor
node. If enabled is set to FALSE
, the
VisibilitySensor node does not send events. If enabled is TRUE
,
the VisibilitySensor node detects changes to the visibility status of the
box specified and sends events through the isActive field. A TRUE
event is output to isActive when any portion of the box impacts the
rendered view. A FALSE
event is sent when
the box has no effect on the view. Browsers shall guarantee that, if isActive
is FALSE
, the box has absolutely no effect
on the rendered view. Browsers may err liberally when isActive is TRUE
.
For example, the box may affect the rendering.
The fields center and size specify the object space location of the box centre and the extents of the box (i.e., width, height, and depth). The VisibilitySensor node's box is affected by hierarchical transformations of its parents. The components of the size field shall be greater than or equal to zero.
The enterTime event is generated whenever the isActive
TRUE
event is generated, and exitTime
events are generated whenever isActive FALSE
events are generated. A VisibilitySensor read from an X3D file shall generate
isActive TRUE
and enterTime
events if the sensor is enabled and the visibility box is visible. A VisibilitySensor
inserted into the transformation hierarchy shall generate isActive
TRUE
and enterTime events if the sensor
is enabled and the visibility box is visible. A VisibilitySensor removed from
the transformation hierarchy shall generate isActive FALSE
and exitTime events if the sensor is enabled and the visibility box
is visible.
Each VisibilitySensor node behaves independently of all other VisibilitySensor nodes. Every enabled VisibilitySensor node that is affected by the user's movement receives and sends events, possibly resulting in multiple VisibilitySensor nodes receiving and sending events simultaneously. Unlike TouchSensor nodes, there is no notion of a VisibilitySensor node lower in the scene graph "grabbing" events. Multiply instanced VisibilitySensor nodes (i.e., DEF/USE) use the union of all the boxes defined by their instances. An instanced VisibilitySensor node shall detect visibility changes for all instances of the box and send events appropriately.
The Environmental Sensor component provides two levels of support as specified in Table 22.2. Level 1 is intended to enable automatic animations by supporting a simplified ProximitySensor node. Level 2 provides full environment sensing support.
Table 22.2 — Environmental sensor component support levels
Level | Prerequisites | Nodes | Support |
---|---|---|---|
1 | Core 1 Time 1 Grouping 1 Navigation 1 |
||
X3DEnvironmentSensorNode (abstract) | n/a | ||
ProximitySensor | position_changed optionally supported. orientation_changed optionally supported. |
||
2 | Core 1 Time 1 Grouping 1 Navigation 1 |
||
All Level 1 Environmental Sensor nodes | All fields as supported in Level 1 | ||
ProximitySensor | All fields fully supported | ||
VisibilitySensor | All fields fully supported |