X3D Model Documentation: CreateNodesECMAScript.x3d

  1  <?xml version="1.0" encoding="UTF-8"?>
  2  <!DOCTYPE X3D PUBLIC "ISO//Web3D//DTD X3D 3.1//EN" "https://www.web3d.org/specifications/x3d-3.1.dtd">
  3  <X3D profile='Immersive' version='3.1 xmlns:xsd='http://www.w3.org/2001/XMLSchema-instance' xsd:noNamespaceSchemaLocation='https://www.web3d.org/specifications/x3d-3.1.xsd'>
  4       <head>
  5            <meta name='titlecontent='CreateNodesECMAScript.x3d'/>
  6            <meta name='descriptioncontent='This example shows how to use createX3DFromString to create nodes'/>
  7            <meta name='creatorcontent='X3D Specification'/>
  8            <meta name='translatedcontent='23 February 2005'/>
  9            <meta name='modifiedcontent='20 October 2019'/>
 10            <meta name='subjectcontent='X3D ECMAScript Script Authoring Interface (SAI)'/>
 11            <meta name='identifiercontent='https://www.web3d.org/x3d/content/examples/Basic/ScriptConformance/CreateNodesECMAScript.x3d'/>
 12            <meta name='referencecontent='https://www.web3d.org/x3d/specifications/ISO-IEC-19777-1-X3DLanguageBindings-ECMAScript/Part1/examples.html#CreateNodes'/>
 13            <meta name='generatorcontent='Vrml97ToX3dNist, http://ovrt.nist.gov/v2_x3d.html'/>
 14            <meta name='generatorcontent='X3D-Edit 3.3, https://savage.nps.edu/X3D-Edit'/>
 15            <meta name='licensecontent='../license.html'/>
 16       </head>
<!--

<!--
Event Graph ROUTE Table shows event connections.
-->

<!-- to top Index for DEF nodes: HOLDER, SC
-->
 17       <Scene>
 18            <WorldInfo title='CreateNodesECMAScript.x3d'/>
 19 
          <!-- ROUTE information for HOLDER node:  [from SC.children to children ] -->
          <Transform DEF='HOLDERtranslation='-2.0 0.0 0.0'/>
 20 
          <!-- ROUTE information for SC node:  [from children to HOLDER.children ] -->
          <Script DEF='SC'>
 21                 <field name='childrentype='MFNodeaccessType='outputOnly'>
 22                      <!-- initialization nodes (if any) go here -->
 23                 </field>
  <![CDATA[
      
ecmascript:

function initialize() 
{
    // Create nodes directly in the parent scene
    shape = Browser.currentScene.createNode('Shape');
    box = Browser.currentScene.createNode('Box');
    shape.geometry = box;
    Browser.currentScene.RootNodes[0] = shape;

    // Create children using the createX3DFromString service
    vrmlCmd = 'PROFILE Interchange  Shape { geometry Sphere{} }'
    tmpScene = Browser.createX3DFromString(vrmlCmd);
    nodes = tmpScene.rootNodes;

    // Nodes must be removed before adding to another scene
    for(i=0; i < nodes.length; i++) {
        tmpScene.removeRootNode(nodes[i]);
    }

    children = nodes;
}

    
]]>
 25            </Script>
 26            < ROUTE  fromNode='SC' fromField='children' toNode='HOLDER' toField='children'/>
 27       </Scene>
 28  </X3D>
<!--

<!--
Event Graph ROUTE Table shows event connections.
-->

<!-- to top Index for DEF nodes: HOLDER, SC
-->
X3D Tooltips element index: field, head, meta, ROUTE, Scene, Script, Transform, WorldInfo, X3D, accessType and type, XML data types, field types

Event Graph ROUTE Table with 1 ROUTE connection 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.

SC
Script
children
MFNode

ROUTE
event to
(1)
HOLDER
Transform
children
MFNode
Additional guidance on X3D animation can be found in the 10-Step Animation Design Process and Event Tracing hint sheets. Have fun with X3D! 😀

-->
<!-- Online at
https://www.web3d.org/x3d/content/examples/Basic/ScriptConformance/CreateNodesECMAScriptIndex.html -->
<!-- Version control at
https://sourceforge.net/p/x3d/code/HEAD/tree/www.web3d.org/x3d/content/examples/Basic/ScriptConformance/CreateNodesECMAScript.x3d -->

<!-- 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)
-->

to top <!-- For additional help information about X3D scenes, please see X3D Tooltips, X3D Resources, and X3D Scene Authoring Hints. -->