X3D Model Documentation: NetworkSensorConnectionPrototypes.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='NetworkSensorConnectionPrototypes.x3d'/>
  6            <meta name='descriptioncontent='Prototypes for NetworkSensor and Connection nodes'/>
  7            <meta name='creatorcontent='Don Brutzman, Chris Thorne, Don McGregor, Shun-Yun Hu'/>
  8            <meta name='createdcontent='14 March 2008'/>
  9            <meta name='modifiedcontent='20 October 2019'/>
 10            <meta name=' warning content=' under development '/>
 11            <meta name='referencecontent='NetworkSensorConnectionNodes.html'/>
 12            <meta name='referencecontent='http://www.xj3d.org/tutorials/general_sai.html'/>
 13            <meta name='referencecontent='https://www.web3d.org/x3d/specifications/ISO-IEC-CD-19775-2.2/Part02/X3D_SAI.html'/>
 14            <meta name='referencecontent='https://www.web3d.org/x3d/specifications/ISO-IEC-19777-2-X3DLanguageBindings-Java/Part2/X3D_Java.html'/>
 15            <meta name='subjectcontent='Prototypes for NetworkSensor and Connection nodes'/>
 16            <meta name='identifiercontent='https://www.web3d.org/x3d/content/examples/Basic/Networking/NetworkSensorConnectionPrototypes.x3d'/>
 17            <meta name='generatorcontent='X3D-Edit 3.3, https://savage.nps.edu/X3D-Edit'/>
 18            <meta name='licensecontent='../license.html'/>
 19       </head>
<!--

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

<!-- to top Index for DEF nodes: ConnectionScript, KeyboardDetector, MessageOutput, NetworkSensorScript, OurNetworkChannel, TextListener, TextSender

Index for ProtoDeclare definitions: Connection, NetworkSensor
-->
 20       <Scene>
 21            <WorldInfo title='NetworkSensorConnectionPrototypes.x3d'/>
 22            <ProtoDeclare name='NetworkSensor'>
 23                 <ProtoInterface>
 24                      <field name='enabledtype='SFBoolvalue='trueaccessType='inputOutput'/>
 25                      <field name='metadatatype='SFNodeaccessType='inputOutput'
                     appinfo='X3DMetadataObject node type only'>
 26                           <!-- Metadata initialization node is NULL -->
 27                      </field>
 28                      <field name='isActivetype='SFBoolaccessType='outputOnly'/>
 29                      <field name='connectiontype='SFNodeaccessType='initializeOnly'
                     appinfo='Connection node only'>
 30                           <!-- Default Connection node goes here -->
 31                      </field>
 32                      <field name='httpRequesttype='SFStringaccessType='inputOnly'/>
 33                      <field name='httpResponsetype='MFStringaccessType='outputOnly'/>
 34                      <field name='channelIdtype='SFStringvalue='trueaccessType='initializeOnly'/>
 35                      <!-- TODO: how to handle user-defined fields? -->
 36                      <!-- perhaps corresponding MFString arrays for fieldName, fieldType, fieldAccessType, fieldInitialValues -->
 37                      <!-- for now we'll simply try to get a MFString field to work -->
 38                      <field name='textInputtype='SFStringaccessType='inputOnly'
                     appinfo='ROUTE StringSensor output here'/>
 39                      <field name='textOutputtype='MFStringaccessType='outputOnly'
                     appinfo='ROUTE this output to Text node string field'/>
 40                      <!-- TODO: can we get consistent type for textInput? -->
 41                 </ProtoInterface>
 42                 <ProtoBody>
 43                      <!-- First node determines node type of prototype -->
 44                      <Script DEF='NetworkSensorScript'   url=' "NetworkSensorScript.class" "https://www.web3d.org/x3d/content/examples/Networking/NetworkSensorScript.class" '>
 45                           <field name='enabledtype='SFBoolaccessType='inputOutput'/>
 46                           <field name='metadatatype='SFNodeaccessType='inputOutput'/>
 47                           <field name='isActivetype='SFBoolaccessType='outputOnly'/>
 48                           <field name='connectiontype='SFNodeaccessType='initializeOnly'
                          appinfo='Connection node only'/>
 49                           <field name='httpRequesttype='SFStringaccessType='inputOnly'/>
 50                           <field name='httpResponsetype='MFStringaccessType='outputOnly'/>
 51                           <field name='channelIdtype='SFStringaccessType='initializeOnly'/>
 52                           <IS>
 53                                <connect nodeField='enabledprotoField='enabled'/>
 54                                <connect nodeField='metadataprotoField='metadata'/>
 55                                <connect nodeField='isActiveprotoField='isActive'/>
 56                                <connect nodeField='connectionprotoField='connection'/>
 57                                <connect nodeField='httpRequestprotoField='httpRequest'/>
 58                                <connect nodeField='httpResponseprotoField='httpResponse'/>
 59                                <connect nodeField='channelIdprotoField='channelId'/>
 60                           </IS>
 61                      </Script>
 62                      <!-- Subsequent nodes do not render, but still must be a valid X3D subgraph -->
 63                 </ProtoBody>
 64            </ProtoDeclare>
 65            <ProtoDeclare name='Connection'>
 66                 <ProtoInterface>
 67                      <field name='enabledtype='SFBoolvalue='trueaccessType='inputOutput'/>
 68                      <field name='metadatatype='SFNodeaccessType='inputOutput'>
 69                           <!-- Metadata initialization node is NULL -->
 70                      </field>
 71                      <field name='isActivetype='SFBoolaccessType='outputOnly'/>
 72                      <field name='urltype='MFStringvalue='"x3dp://localhost:80"' accessType='inputOutput'/>
 73                      <!-- 1 for HTTP, 2 for HTTP 1.1, 3 for TCP/IP, 4 for UDP, 5 for multicast -->
 74                      <!-- spec TODO: change these code numbers to string enumerations instead -->
 75                      <field name='protocoltype='SFInt32value='0accessType='initializeOnly'/>
 76                      <field name='timeOuttype='SFTimevalue='0accessType='inputOutput'/>
 77                      <field name='securetype='SFBoolaccessType='inputOnly'/>
 78                 </ProtoInterface>
 79                 <ProtoBody>
 80                      <!-- First node determines node type of prototype -->
 81                      <Script DEF='ConnectionScript'   url=' "ConnectionScript.class" "https://www.web3d.org/x3d/content/examples/Networking/ConnectionScript.class" '>
 82                           <field name='enabledtype='SFBoolaccessType='inputOutput'/>
 83                           <field name='isActivetype='SFBoolaccessType='outputOnly'/>
 84                           <field name='urltype='MFStringaccessType='inputOutput'/>
 85                           <field name='protocoltype='SFInt32accessType='initializeOnly'/>
 86                           <field name='timeOuttype='SFTimeaccessType='inputOutput'/>
 87                           <field name='securetype='SFBoolaccessType='inputOnly'/>
 88                           <IS>
 89                                <connect nodeField='enabledprotoField='enabled'/>
 90                                <connect nodeField='isActiveprotoField='isActive'/>
 91                                <connect nodeField='urlprotoField='url'/>
 92                                <connect nodeField='protocolprotoField='protocol'/>
 93                                <connect nodeField='timeOutprotoField='timeOut'/>
 94                                <connect nodeField='secureprotoField='secure'/>
 95                           </IS>
 96                      </Script>
 97                      <!-- Subsequent nodes do not render, but still must be a valid X3D subgraph -->
 98                 </ProtoBody>
 99            </ProtoDeclare>
100            <!-- We'll put our initial example next. First the listener will output networked messages to a Text node -->
101            <Shape>
102 
               <!-- ROUTE information for MessageOutput node:  [from TextListener.textOutput to string ] -->
               <Text DEF='MessageOutputstring='"NetworkSensor messages will appear here"'>
103                      <FontStyle justify='"MIDDLE" "MIDDLE"'/>
104                 </Text>
105                 <Appearance>
106                      <Material ambientIntensity='0.25diffuseColor='0.374008 0 0.748016shininess='0.4specularColor='0.909091 0.909091 0.909091transparency='0.35'/>
107                 </Appearance>
108            </Shape>
109            <!-- Only need a single Connection definition for this example -->
110 
          <!-- ProtoInstance OurNetworkChannel is a DEF node that has 2 USE nodes: USE_1, USE_2 -->
          <ProtoInstance name='ConnectionDEF='OurNetworkChannel'>
111                 <fieldValue name='urlvalue='"x3dp://localhost:80"'/>
112                 <!-- protocol 1=http -->
113                 <fieldValue name='protocolvalue='1'/>
114                 <fieldValue name='timeOutvalue='10'/>
115                 <fieldValue name='securevalue='false'/>
116            </ProtoInstance>
117            <!-- Here is the listener that connects and sends strings to the Text node -->
118 
          <!-- ROUTE information for TextListener node:  [from textOutput to MessageOutput.string ] -->
          <ProtoInstance name='NetworkSensorDEF='TextListener'>
119                 <fieldValue name='connection'>
120                      <ProtoInstance USE='OurNetworkChannel'/>
121                 </fieldValue>
122                 <fieldValue name='channelIdvalue='78'/>
123            </ProtoInstance>
124            <!-- TODO: once a single string can successfully be sent, insert an intermediate Script to remember last 10 strings -->
125            < ROUTE  fromNode='TextListener' fromField='textOutput' toNode='MessageOutput' toField='string'/>
126            <!-- Now capture text from local keyboard, send to scenes listening to this network connection -->
127 
          <!-- ROUTE information for TextSender node:  [from KeyboardDetector.finalText to textInput ] -->
          <ProtoInstance name='NetworkSensorDEF='TextSender'>
128                 <fieldValue name='connection'>
129                      <ProtoInstance USE='OurNetworkChannel'/>
130                 </fieldValue>
131                 <fieldValue name='channelIdvalue='78'/>
132            </ProtoInstance>
133 
          <!-- ROUTE information for KeyboardDetector node:  [from finalText to TextSender.textInput ] -->
          <StringSensor DEF='KeyboardDetector'/>
134            < ROUTE  fromNode='KeyboardDetector' fromField='finalText' toNode='TextSender' toField='textInput'/>
135            <!-- done. we should now be able to type text and have it appear in the output for whoever's using the same scene. -->
136       </Scene>
137  </X3D>
<!--

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

<!-- to top Index for DEF nodes: ConnectionScript, KeyboardDetector, MessageOutput, NetworkSensorScript, OurNetworkChannel, TextListener, TextSender

Index for ProtoDeclare definitions: Connection, NetworkSensor
-->
X3D Tooltips element index: Appearance, connect, field, fieldValue, FontStyle, head, IS, Material, meta, ProtoBody, ProtoDeclare, ProtoInstance, ProtoInterface, ROUTE, Scene, Script, Shape, StringSensor, Text, WorldInfo, X3D, accessType and type, XML data types, field types

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.

KeyboardDetector
StringSensor
finalText
SFString

ROUTE
event to
(1)
TextSender
ProtoInstance
textInput
SFString

OurNetworkChannel
ProtoInstance
Connection
No ROUTE connection found for output events from this node.
This ProtoInstance contains SFNode/MFNode fieldValue declarations with
direct access to other nodes, and thus has potential to produce run-time animation. 

TextListener
ProtoInstance
textOutput
MFString

ROUTE
event to
(1)
MessageOutput
Text
string
MFString

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/Networking/NetworkSensorConnectionPrototypesIndex.html -->
<!-- Version control at
https://sourceforge.net/p/x3d/code/HEAD/tree/www.web3d.org/x3d/content/examples/Basic/Networking/NetworkSensorConnectionPrototypes.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)
    <ProtoInstance name='ProtoName'> <field name='fieldName'/> </ProtoInstance> -->

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