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='ColorInterpolatorExample.x3d'/> |
6 | <meta name='description' content='Demonstrate basic design pattern for animating a node.'/> |
7 | <meta name='creator' content='Don Brutzman'/> |
8 | <meta name='created' content='17 April 2005'/> |
9 | <meta name='modified' content='20 October 2019'/> |
10 | <meta name='drawing' content='ColorInterpolatorExampleSceneGraphWithRoutes.png'/> |
11 | <meta name='Image' content='ColorInterpolatorExample4Colors.png'/> |
12 | <meta name='subject' content='Animation ColorInterpolator'/> |
13 | <meta name='identifier' content='https://www.web3d.org/x3d/content/examples/X3dForWebAuthors/Chapter07EventAnimationInterpolation/ColorInterpolatorExample.x3d'/> |
14 | <meta name='generator' content='X3D-Edit 3.3, https://savage.nps.edu/X3D-Edit'/> |
15 | <meta name='license' content='../license.html'/> |
16 | </head> |
17 | <Scene> |
18 | <WorldInfo title='ColorInterpolatorExample.x3d'/> |
19 | <Group> |
20 | <!-- Place triggering text above sphere of interest --> |
21 | <Transform translation='0 2 0'> |
22 | <Shape> |
23 | <Text string='"Touch text to" "start animation..."'> |
24 | <FontStyle justify='"MIDDLE" "MIDDLE"'/> |
25 | </Text> |
26 | <Appearance> |
27 | <Material/> |
28 | </Appearance> |
29 | </Shape> |
30 | <!-- Selectable Text design pattern has transparent Box and TouchSensor description as a tooltip --> |
31 | <Shape> |
32 | <Box size='6.2 2 .001'/> |
33 | <Appearance> |
34 | <Material transparency='1'/> |
35 | </Appearance> |
36 | </Shape> |
37 | <!-- This TouchSensor only reacts to user clicking on the sibling Shape and Text, because it is under a parent Transform grouping node --> |
38 |
<!-- ROUTE information for TextTriggerTouchSensor node:
[from touchTime to AnimationClock.startTime
]
-->
<TouchSensor DEF='TextTriggerTouchSensor' description='Touch text to start...'/> |
39 | </Transform> |
40 | <!-- Here is Sphere with accompanying Material that will get animated --> |
41 | <Transform translation='0 -1 0'> |
42 | <Shape> |
43 | <Sphere/> |
44 | <Appearance> |
45 | <!-- SphereMaterial diffuseColor gets overridden by interpolator output --> |
46 |
<!-- ROUTE information for SphereMaterial node:
[from ColorChanger.value_changed to diffuseColor
]
-->
<Material DEF='SphereMaterial' diffuseColor='0.5 0.5 0.5'/> |
47 | </Appearance> |
48 | </Shape> |
49 | </Transform> |
50 | <!-- TimeSensor is triggered to start by TouchSensor, then sends animating values to Interpolator --> |
51 |
<!-- ROUTE information for AnimationClock node:
[from TextTriggerTouchSensor.touchTime to startTime
]
[from fraction_changed to ColorChanger.set_fraction
]
-->
<TimeSensor DEF='AnimationClock' cycleInterval='6'/> |
52 | <!-- ROUTE 1: TouchSensor trigger to TimeSensor clock --> |
53 | < ROUTE fromNode='TextTriggerTouchSensor' fromField='touchTime' toNode='AnimationClock' toField='startTime'/> |
54 | <!-- Interpolator: ColorChanger interpolates evenly between red, green, blue and then back to red --> |
55 |
<!-- ROUTE information for ColorChanger node:
[from AnimationClock.fraction_changed to set_fraction
]
[from value_changed to SphereMaterial.diffuseColor
]
-->
<ColorInterpolator DEF='ColorChanger' key='0 0.3333 0.6666 1' keyValue='1 0 0 0 1 0 0 0 1 1 0 0'/> |
56 | <!-- ROUTE 2: the ColorChanger interpolator gets stimulated by AnimationClock TimeSensor fraction to compute a color value --> |
57 | < ROUTE fromNode='AnimationClock' fromField='fraction_changed' toNode='ColorChanger' toField='set_fraction'/> |
58 | <!-- ROUTE 3: Interpolator output is sent to target node of interest. Changed color value is routed to SphereMaterial color. --> |
59 | < ROUTE fromNode='ColorChanger' fromField='value_changed' toNode='SphereMaterial' toField='diffuseColor'/> |
60 | </Group> |
61 | </Scene> |
62 | </X3D> |
Event Graph ROUTE Table entries with 3 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.
TextTriggerTouchSensor
TouchSensor touchTime SFTime |
AnimationClock
TimeSensor startTime SFTime |
then
|
AnimationClock
TimeSensor fraction_changed SFFloat |
ColorChanger
ColorInterpolator set_fraction SFFloat |
then
|
ColorChanger
ColorInterpolator value_changed SFColor |
SphereMaterial
Material diffuseColor SFColor |
<!--
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. -->