X3D Model Documentation: CoordinateInterpolator2dExample.x3d

  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            <component level='3name='Interpolation'/>
  6            <meta name='titlecontent='CoordinateInterpolator2dExample.x3d'/>
  7            <meta name='descriptioncontent='Example to interpolate using CoordinateInterpolator2D - select and hold geometry for a user-controlled animation loop.'/>
  8            <meta name='creatorcontent='Don Brutzman, Jeff Weekley, Jane Wu'/>
  9            <meta name='createdcontent='9 October 2001'/>
 10            <meta name='modifiedcontent='31 August 2023'/>
 11            <meta name='subjectcontent='CoordinateInterpolator2D'/>
 12            <meta name='Imagecontent='CoordinateInterpolator2dExamplePhoneTouchScreenImage.png'/>
 13            <meta name='referencecontent='[x3d-public] TimeSensor Control https://web3d.org/pipermail/x3d-public_web3d.org/2023-August/019468.html'/>
 14            <meta name='identifiercontent='https://www.web3d.org/x3d/content/examples/X3dForWebAuthors/Chapter07EventAnimationInterpolation/CoordinateInterpolator2dExample.x3d'/>
 15            <meta name='referencecontent='https://www.web3d.org/x3d/content/examples/Basic/development/CoordinateInterpolator2dExample.x3d'/>
 16            <meta name='generatorcontent='X3D-Edit 3.3, https://savage.nps.edu/X3D-Edit'/>
 17            <meta name='licensecontent='../license.html'/>
 18       </head>
<!--

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

<!-- to top Index for DEF nodes: AnimatedCrossSectionExtrusion, Clock, InterpolateCrossSection, Toucher

Index for Viewpoint node: Viewpoint_1
-->
 19       <Scene>
 20            <WorldInfo title='CoordinateInterpolator2dExample.x3d'/>
 21            <Viewpoint description='Click to activate animationorientation='1 0 0 -0.4position='0 4 10'/>
 22 
          <!-- ROUTE information for Clock node:  [from Toucher.isActive to enabled ] [from Toucher.touchTime to startTime ] [from fraction_changed to InterpolateCrossSection.set_fraction ] -->
          <TimeSensor DEF='ClockcycleInterval='5enabled='falseloop='true'/>
 23 
          <!-- ROUTE information for InterpolateCrossSection node:  [from Clock.fraction_changed to set_fraction ] [from value_changed to AnimatedCrossSectionExtrusion.set_crossSection ] -->
          <CoordinateInterpolator2D DEF='InterpolateCrossSectionkey='0 0.45 0.9 1keyValue='1 1 1 -1 -1 -1 -1 1 1 1 2 2 2 -2 -1 -1 -1 1 2 2 1 1 1 -1 -1 -1 -1 1 1 1 1 1 1 -1 -1 -1 -1 1 1 1'/>
 24            < ROUTE  fromNode='Clock' fromField='fraction_changed' toNode='InterpolateCrossSection' toField='set_fraction'/>
 25            <Transform translation='1.15 1 0'>
 26                 <!-- &amp; is the XML escape character code for ampersand character -->
 27 
               <!-- ROUTE information for Toucher node:  [from isActive to Clock.enabled ] [from touchTime to Clock.startTime ] -->
               <TouchSensor DEF='Toucherdescription='select & hold shape to animate Extrusion'/>
 28                 < ROUTE  fromNode='Toucher' fromField='isActive' toNode='Clock' toField='enabled'/>
 29                 <!-- also reset clock to restart -->
 30                 < ROUTE  fromNode='Toucher' fromField='touchTime' toNode='Clock' toField='startTime'/>
 31                 <Shape>
 32                      <Appearance>
 33                           <Material diffuseColor='0.2 0.8 0.4emissiveColor='0.05 0.2 0.1'/>
 34                      </Appearance>
 35 
                    <!-- ROUTE information for AnimatedCrossSectionExtrusion node:  [from InterpolateCrossSection.value_changed to set_crossSection ] -->
                    <Extrusion DEF='AnimatedCrossSectionExtrusionspine='-4 0 -2 -1 0 -2 2 0 1 2 0 4'/>
 36                      <!-- default Extrusion crossSection='1 1 1 -1 -1 -1 -1 1 1 1' is a square -->
 37                 </Shape>
 38                 < ROUTE  fromNode='InterpolateCrossSection' fromField='value_changed' toNode='AnimatedCrossSectionExtrusion' toField='set_crossSection'/>
 39            </Transform>
 40            <Transform translation='-1.5 -1 2'>
 41                 <Billboard axisOfRotation='0 0 0'>
 42                      <Shape>
 43                           <Text string='"select & hold shape" "to animate Extrusion"'>
 44                                <FontStyle family='"SANS"justify='"MIDDLE" "MIDDLE"size='0.8'/>
 45                           </Text>
 46                           <Appearance>
 47                                <Material diffuseColor='0.8 0.4 0.2'/>
 48                           </Appearance>
 49                      </Shape>
 50                 </Billboard>
 51            </Transform>
 52       </Scene>
 53  </X3D>
<!--

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

<!-- to top Index for DEF nodes: AnimatedCrossSectionExtrusion, Clock, InterpolateCrossSection, Toucher

Index for Viewpoint node: Viewpoint_1
-->
X3D Tooltips element index: Appearance, Billboard, component, CoordinateInterpolator2D, Extrusion, FontStyle, head, Material, meta, ROUTE, Scene, Shape, Text, TimeSensor, TouchSensor, Transform, Viewpoint, WorldInfo, X3D, accessType and type, XML data types, field types

Event Graph ROUTE Table entries with 4 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.

Toucher
TouchSensor
isActive
SFBool

ROUTE
event to
(1)
Clock
TimeSensor
enabled
SFBool
then
 
 
 
Clock
TimeSensor
fraction_changed
SFFloat

ROUTE
event to
(2)
InterpolateCrossSection
CoordinateInterpolator2D
set_fraction
SFFloat
then
 
 
 
InterpolateCrossSection
CoordinateInterpolator2D
value_changed
MFVec2f

ROUTE
event to
(3)
AnimatedCrossSectionExtrusion
Extrusion
set_crossSection
MFVec2f
Toucher
TouchSensor
touchTime
SFTime

ROUTE
event to
(1)
Clock
TimeSensor
startTime
SFTime
then
 
 
 
Clock
TimeSensor
fraction_changed
SFFloat

ROUTE
event to
(2)
InterpolateCrossSection
CoordinateInterpolator2D
set_fraction
SFFloat
then
 
 
 
InterpolateCrossSection
CoordinateInterpolator2D
value_changed
MFVec2f

ROUTE
event to
(3)
AnimatedCrossSectionExtrusion
Extrusion
set_crossSection
MFVec2f

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/X3dForWebAuthors/Chapter07EventAnimationInterpolation/CoordinateInterpolator2dExampleIndex.html -->
<!-- Version control at
https://sourceforge.net/p/x3d/code/HEAD/tree/www.web3d.org/x3d/content/examples/X3dForWebAuthors/Chapter07EventAnimationInterpolation/CoordinateInterpolator2dExample.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. -->