1 |
<?xml version="1.0" encoding="UTF-8"?>
|
2 |
<!DOCTYPE X3D PUBLIC "ISO//Web3D//DTD X3D 3.0//EN" "https://www.web3d.org/specifications/x3d-3.0.dtd">
|
3 | <X3D profile='Interactive' version='3.0' xmlns:xsd='http://www.w3.org/2001/XMLSchema-instance' xsd:noNamespaceSchemaLocation='https://www.web3d.org/specifications/x3d-3.0.xsd'> |
4 | <head> |
5 | <meta name='title' content='multisensor.x3d'/> |
6 | <meta name='MovingImage' content='multisensor-movie.mpg'/> |
7 | <meta name='reference' content='http://www.nist.gov/vrml.html'/> |
8 | <meta name='reference' content='http://www.itl.nist.gov/div897/ctg/vrml/vrml.html'/> |
9 | <meta name='creator' content='http://www.itl.nist.gov/div897/ctg/vrml/members.html'/> |
10 | <meta name='disclaimer' content='This file was provided by the National Institute of Standards and Technology, and is part of the X3D Conformance Test Suite, available at http://www.nist.gov/vrml.html The information contained within this file is provided for use in establishing conformance to the ISO VRML97 Specification. Conformance to this test does not imply recommendation or endorsement by the National Institute of Standards and Technology (NIST). This software can be redistributed and/or modified freely provided that any derivative works bear some notice that they are derived from it, and any modified versions bear some notice that they have been modified. '/> |
11 | <meta name='reference' content='Interactive Conformance Testing for VRML, Mary Brady and Lynn Rosenthal, NIST, created 8 September 2010 and updated 25 August 2016, https://www.nist.gov/itl/ssd/information-systems-group/interactive-conformance-testing-vrml'/> |
12 | <meta name='info' content='Correct definition and compliance of this conformance scene is maintained by the X3D Working Group, https://www.web3d.org/working-groups/x3d'/> |
13 | <meta name='creator' content='Michael Kass NIST'/> |
14 | <meta name='translator' content='Don Brutzman'/> |
15 | <meta name='translated' content='21 January 2001'/> |
16 | <meta name='modified' content='28 August 2023'/> |
17 | <meta name='description' content='Test if a CylinderSensor grabs all further motion events from pointing device when the sensor generates "isActive" true event for primitive geometry. The Box geometry has an associated CylinderSensor that routes its "rotation_changed" events to that geometrys Transform node. As a result, pressing the primary pointing device button while over the Box should rotate that geometry. In addition, a TouchSensor is assocated with the Box geometry and a PointLight, but is nested "higher" in the sensor hierarchy. Passing the primary pointing device over the Box should route and isActive event to a PointLight and illuminate the IndexedFaceSets. Dragging the pointing device over the Box geometry and holding the primary pointing device button down should generate an isActive = true event for the CylinderSensor and prevent the TouchSensor from activating (and the PointLight from coming ON), When the button is released, and the cursor is over the Box, the PointLight should turn on.'/> |
18 | <meta name='identifier' content='https://www.web3d.org/x3d/content/examples/ConformanceNist/Sensors/CylinderSensor/multisensor.x3d'/> |
19 | <meta name='generator' content='Vrml97ToX3dNist, http://ovrt.nist.gov/v2_x3d.html'/> |
20 | <meta name='generator' content='X3D-Edit 4.0, https://savage.nps.edu/X3D-Edit'/> |
21 | <meta name='license' content='../../license.html'/> |
22 | </head> |
23 | <Scene> |
24 | <WorldInfo title='multisensor.x3d'/> |
25 | <NavigationInfo type='"WALK" "FLY" "ANY"'/> |
26 | <Group> |
27 | <Viewpoint description='Front View' position='0 0 20'/> |
28 | <Viewpoint description='Rear View' orientation='0 1 0 3.14' position='0 0 -20'/> |
29 | <Viewpoint description='Top View' orientation='1 0 0 -1.57' position='0 20 0'/> |
30 | <Viewpoint description='Bottom View' orientation='1 0 0 1.57' position='0 -20 0'/> |
31 | <Viewpoint description='Right View' orientation='0 1 0 1.57' position='20 0 0'/> |
32 | <Viewpoint description='Left View' orientation='0 1 0 -1.57' position='-20 0 0'/> |
33 | </Group> |
34 | <Group> |
35 |
<!-- ROUTE information for LIGHT node:
[from TOUCH.isOver to on
]
-->
<PointLight DEF='LIGHT' location='0 0 2' on='false'/> |
36 | <Transform> |
37 | <Shape> |
38 | <Appearance> |
39 | <Material diffuseColor='0.5 0.5 0.5'/> |
40 | </Appearance> |
41 | <IndexedFaceSet coordIndex='0 1 2 3 -1'> |
42 | <Coordinate point='-10 -6 -8 10 -6 -8 10 6 -8 -10 6 -8'/> |
43 | </IndexedFaceSet> |
44 | </Shape> |
45 | <Shape> |
46 | <Appearance> |
47 | <Material diffuseColor='0.5 0.5 0.5'/> |
48 | </Appearance> |
49 | <IndexedFaceSet coordIndex='0 1 2 3 -1'> |
50 | <Coordinate point='-10 -6 -8 -10 -6 6 10 -6 6 10 -6 -8'/> |
51 | </IndexedFaceSet> |
52 | </Shape> |
53 | </Transform> |
54 | <Transform> |
55 |
<!-- ROUTE information for TOUCH node:
[from isOver to LIGHT.on
]
-->
<TouchSensor DEF='TOUCH' description='touch to activate'/> |
56 |
<!-- ROUTE information for MYBOX node:
[from BOXSENSOR.rotation_changed to set_rotation
]
-->
<Transform DEF='MYBOX'> |
57 |
<!-- ROUTE information for BOXSENSOR node:
[from rotation_changed to MYBOX.set_rotation
]
-->
<CylinderSensor DEF='BOXSENSOR' description='click and drag to rotate'/> |
58 | <Shape> |
59 | <Appearance> |
60 | <Material diffuseColor='1 1 0'/> |
61 | </Appearance> |
62 | <Box/> |
63 | </Shape> |
64 | </Transform> |
65 | </Transform> |
66 | </Group> |
67 | < ROUTE fromNode='BOXSENSOR' fromField='rotation_changed' toNode='MYBOX' toField='set_rotation'/> |
68 | < ROUTE fromNode='TOUCH' fromField='isOver' toNode='LIGHT' toField='on'/> |
69 | </Scene> |
70 | </X3D> |
Event Graph ROUTE Table entries with 2 ROUTE connections total, showing X3D event-model relationships for this scene.
Each row shows an event cascade that may occur during a single timestamp interval between frame renderings, as part of the X3D execution model.
TOUCH
TouchSensor isOver SFBool |
LIGHT
PointLight on SFBool |
BOXSENSOR
CylinderSensor rotation_changed SFRotation |
MYBOX
Transform set_rotation SFRotation |
<!--
Color legend: X3D terminology
<X3dNode
DEF='idName' field='value'/>
matches XML terminology
<XmlElement
DEF='idName' attribute='value'/>
(Light-blue background: event-based behavior node or statement)
(Grey background inside box: inserted documentation)
(Magenta background: X3D Extensibility)
-->
<!-- For additional help information about X3D scenes, please see X3D Tooltips, X3D Resources, and X3D Scene Authoring Hints. -->