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='unison.x3d'/> |
6 | <meta name='MovingImage' content='unison-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 SphereSensor works in "unison" with a "sibling" TouchSensor associated with the same Box geometry. The Box geometry has an associated SphereSensor that routes its "rotation_changed" events to that geometrys Transform node. In addition, a TouchSensor is also a child of the same Transform node. As a result, passing the primary pointing device over the Box should turn on a PointLight. Pressing the primary pointing device button while over the Box and "dragging" should rotate that geometry, while the PointLight remains on. When the cursor is released, the Box should stop rotating. When the pointing device is no longer over the Box, the PointLight should turn off.'/> |
18 | <meta name='identifier' content='https://www.web3d.org/x3d/content/examples/ConformanceNist/Sensors/SphereSensor/unison.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='unison.x3d'/> |
25 | <NavigationInfo type='"WALK" "FLY" "ANY"'/> |
26 | <Viewpoint description='Front View'/> |
27 | <Viewpoint description='Rear View' orientation='0 1 0 3.14' position='0 0 -10'/> |
28 | <Viewpoint description='Top View' orientation='1 0 0 -1.57' position='0 10 0'/> |
29 | <Viewpoint description='Bottom View' orientation='1 0 0 1.57' position='0 -10 0'/> |
30 | <Viewpoint description='Right View' orientation='0 1 0 1.57' position='10 0 0'/> |
31 | <Viewpoint description='Left View' orientation='0 1 0 -1.57' position='-10 0 0'/> |
32 | <Group> |
33 |
<!-- ROUTE information for LIGHT node:
[from TOUCH.isOver to on
]
-->
<PointLight DEF='LIGHT' location='0 0 2' on='false'/> |
34 | <Transform> |
35 | <Shape> |
36 | <Appearance> |
37 | <Material diffuseColor='0.5 0.5 0.5'/> |
38 | </Appearance> |
39 | <IndexedFaceSet coordIndex='0 1 2 3 -1'> |
40 | <Coordinate point='-10 -6 -8 10 -6 -8 10 6 -8 -10 6 -8'/> |
41 | </IndexedFaceSet> |
42 | </Shape> |
43 | <Shape> |
44 | <Appearance> |
45 | <Material diffuseColor='0.5 0.5 0.5'/> |
46 | </Appearance> |
47 | <IndexedFaceSet coordIndex='0 1 2 3 -1'> |
48 | <Coordinate point='-10 -6 -8 -10 -6 6 10 -6 6 10 -6 -8'/> |
49 | </IndexedFaceSet> |
50 | </Shape> |
51 | </Transform> |
52 | <Transform> |
53 |
<!-- ROUTE information for TOUCH node:
[from isOver to LIGHT.on
]
-->
<TouchSensor DEF='TOUCH' description='touch to activate'/> |
54 |
<!-- ROUTE information for BOXSENSOR node:
[from rotation_changed to MYBOX.set_rotation
]
-->
<SphereSensor DEF='BOXSENSOR' description='click and drag to rotate'/> |
55 |
<!-- ROUTE information for MYBOX node:
[from BOXSENSOR.rotation_changed to set_rotation
]
-->
<Transform DEF='MYBOX'> |
56 | <Shape> |
57 | <Appearance> |
58 | <Material diffuseColor='1 1 0'/> |
59 | </Appearance> |
60 | <Box/> |
61 | </Shape> |
62 | </Transform> |
63 | </Transform> |
64 | </Group> |
65 | < ROUTE fromNode='BOXSENSOR' fromField='rotation_changed' toNode='MYBOX' toField='set_rotation'/> |
66 | < ROUTE fromNode='TOUCH' fromField='isOver' toNode='LIGHT' toField='on'/> |
67 | </Scene> |
68 | </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
SphereSensor 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. -->