1 |
<?xml version="1.0" encoding="UTF-8"?>
|
2 |
<!DOCTYPE X3D PUBLIC "ISO//Web3D//DTD X3D 3.3//EN" "https://www.web3d.org/specifications/x3d-3.3.dtd">
|
3 | <X3D profile='Immersive' version='3.3' xmlns:xsd='http://www.w3.org/2001/XMLSchema-instance' xsd:noNamespaceSchemaLocation='https://www.web3d.org/specifications/x3d-3.3.xsd'> |
4 | <head> |
5 | <meta name='title' content='ECMAScriptSaiAddDynamicRoutes.x3d'/> |
6 | <meta name='description' content='Java Scene Authoring Interface (JSAI) scene and source code example that show adding dynamic ROUTEs to a scene.'/> |
7 | <meta name='creator' content='X3D Working Group'/> |
8 | <meta name='created' content='23 February 2005'/> |
9 | <meta name='modified' content='28 October 2019'/> |
10 | <meta name='reference' content='https://www.web3d.org/files/specifications/19777-1/V3.3/Part1/X3D_ECMAScript.html'/> |
11 | <meta name='specificationSection' content='X3D language bindings, ISO/IEC 19777-1, Part 1: ECMAScript, B.5 Add dynamic routes'/> |
12 | <meta name='specificationUrl' content='https://www.web3d.org/files/specifications/19777-1/V3.3/Part1/examples.html#AddDynamicRoutes'/> |
13 | <meta name='generator' content='X3D-Edit 3.3, https://savage.nps.edu/X3D-Edit'/> |
14 | <meta name='identifier' content='https://www.web3d.org/x3d/content/examples/Basic/X3dSpecifications/ECMAScriptSaiAddDynamicRoutes.x3d'/> |
15 | <meta name='license' content='../license.html'/> |
16 | </head> |
17 | <Scene> |
18 | <WorldInfo title='ECMAScriptSaiAddDynamicRoutes.x3d'/> |
19 | <Script DEF='SC' url=' "ECMAScriptSaiAddDynamicRoutes.js" "https://www.web3d.org/x3d/content/examples/Basic/X3dSpecifications/ECMAScriptSaiAddDynamicRoutes.js" '> |
20 | <field name='touchTime' type='SFTime' accessType='inputOnly'/> |
21 | <field name='Script' type='SFNode' accessType='initializeOnly'/> |
<![CDATA[
ecmascript: function touchTime(value) { // Create nodes directly in the parent scene var scene = Browser.currentScene; var shape = scene.createNode('Shape'); var box = scene.createNode('Box'); var touchSensor = scene.createNode('TouchSensor'); shape.geometry = box; // Create a Group to hold the nodes var group = scene.createNode('Group'); // Add the shape and sensor to the group group.children = new MFNode(shape, touchSensor); // Add the nodes to the scene scene.RootNodes[0] = group; // Add a route from the touchSensor to this script scene.addRoute(touchSensor, 'touchTime', Script, 'touchTime'); }
]]>
|
|
23 | </Script> |
24 | </Scene> |
25 | </X3D> |
Event Graph ROUTE Table with 0 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.
<!--
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. -->