@@ -29,77 +29,59 @@ function getElementColor(element) {
29
29
) ;
30
30
}
31
31
32
- var svgIcons = [
33
- {
34
- id : "animation_pathReset" ,
32
+ var svgIconsById = {
33
+ animation_pathReset : {
35
34
tagName : "path" ,
36
35
transform : "translate(16,16) scale(0.85) translate(-16,-16)" ,
37
36
d :
38
37
"M24.316,5.318,9.833,13.682,9.833,5.5,5.5,5.5,5.5,25.5,9.833,25.5,9.833,17.318,24.316,25.682z" ,
39
38
} ,
40
- {
41
- id : "animation_pathPause" ,
39
+ animation_pathPause : {
42
40
tagName : "path" ,
43
41
transform : "translate(16,16) scale(0.85) translate(-16,-16)" ,
44
42
d : "M13,5.5,7.5,5.5,7.5,25.5,13,25.5zM24.5,5.5,19,5.5,19,25.5,24.5,25.5z" ,
45
43
} ,
46
- {
47
- id : "animation_pathPlay" ,
44
+ animation_pathPlay : {
48
45
tagName : "path" ,
49
46
transform : "translate(16,16) scale(0.85) translate(-16,-16)" ,
50
47
d : "M6.684,25.682L24.316,15.5L6.684,5.318V25.682z" ,
51
48
} ,
52
- {
53
- id : "animation_pathPlayReverse" ,
49
+ animation_pathPlayReverse : {
54
50
tagName : "path" ,
55
51
transform : "translate(16,16) scale(-0.85,0.85) translate(-16,-16)" ,
56
52
d : "M6.684,25.682L24.316,15.5L6.684,5.318V25.682z" ,
57
53
} ,
58
- {
59
- id : "animation_pathLoop" ,
54
+ animation_pathLoop : {
60
55
tagName : "path" ,
61
56
transform : "translate(16,16) scale(0.85) translate(-16,-16)" ,
62
57
d :
63
58
"M24.249,15.499c-0.009,4.832-3.918,8.741-8.75,8.75c-2.515,0-4.768-1.064-6.365-2.763l2.068-1.442l-7.901-3.703l0.744,8.694l2.193-1.529c2.244,2.594,5.562,4.242,9.26,4.242c6.767,0,12.249-5.482,12.249-12.249H24.249zM15.499,6.75c2.516,0,4.769,1.065,6.367,2.764l-2.068,1.443l7.901,3.701l-0.746-8.693l-2.192,1.529c-2.245-2.594-5.562-4.245-9.262-4.245C8.734,3.25,3.25,8.734,3.249,15.499H6.75C6.758,10.668,10.668,6.758,15.499,6.75z" ,
64
59
} ,
65
- {
66
- id : "animation_pathClock" ,
60
+ animation_pathClock : {
67
61
tagName : "path" ,
68
62
transform : "translate(16,16) scale(0.85) translate(-16,-15.5)" ,
69
63
d :
70
64
"M15.5,2.374C8.251,2.375,2.376,8.251,2.374,15.5C2.376,22.748,8.251,28.623,15.5,28.627c7.249-0.004,13.124-5.879,13.125-13.127C28.624,8.251,22.749,2.375,15.5,2.374zM15.5,25.623C9.909,25.615,5.385,21.09,5.375,15.5C5.385,9.909,9.909,5.384,15.5,5.374c5.59,0.01,10.115,4.535,10.124,10.125C25.615,21.09,21.091,25.615,15.5,25.623zM8.625,15.5c-0.001-0.552-0.448-0.999-1.001-1c-0.553,0-1,0.448-1,1c0,0.553,0.449,1,1,1C8.176,16.5,8.624,16.053,8.625,15.5zM8.179,18.572c-0.478,0.277-0.642,0.889-0.365,1.367c0.275,0.479,0.889,0.641,1.365,0.365c0.479-0.275,0.643-0.887,0.367-1.367C9.27,18.461,8.658,18.297,8.179,18.572zM9.18,10.696c-0.479-0.276-1.09-0.112-1.366,0.366s-0.111,1.09,0.365,1.366c0.479,0.276,1.09,0.113,1.367-0.366C9.821,11.584,9.657,10.973,9.18,10.696zM22.822,12.428c0.478-0.275,0.643-0.888,0.366-1.366c-0.275-0.478-0.89-0.642-1.366-0.366c-0.479,0.278-0.642,0.89-0.366,1.367C21.732,12.54,22.344,12.705,22.822,12.428zM12.062,21.455c-0.478-0.275-1.089-0.111-1.366,0.367c-0.275,0.479-0.111,1.09,0.366,1.365c0.478,0.277,1.091,0.111,1.365-0.365C12.704,22.344,12.54,21.732,12.062,21.455zM12.062,9.545c0.479-0.276,0.642-0.888,0.366-1.366c-0.276-0.478-0.888-0.642-1.366-0.366s-0.642,0.888-0.366,1.366C10.973,9.658,11.584,9.822,12.062,9.545zM22.823,18.572c-0.48-0.275-1.092-0.111-1.367,0.365c-0.275,0.479-0.112,1.092,0.367,1.367c0.477,0.275,1.089,0.113,1.365-0.365C23.464,19.461,23.3,18.848,22.823,18.572zM19.938,7.813c-0.477-0.276-1.091-0.111-1.365,0.366c-0.275,0.48-0.111,1.091,0.366,1.367s1.089,0.112,1.366-0.366C20.581,8.702,20.418,8.089,19.938,7.813zM23.378,14.5c-0.554,0.002-1.001,0.45-1.001,1c0.001,0.552,0.448,1,1.001,1c0.551,0,1-0.447,1-1C24.378,14.949,23.929,14.5,23.378,14.5zM15.501,6.624c-0.552,0-1,0.448-1,1l-0.466,7.343l-3.004,1.96c-0.478,0.277-0.642,0.889-0.365,1.365c0.275,0.479,0.889,0.643,1.365,0.367l3.305-1.676C15.39,16.99,15.444,17,15.501,17c0.828,0,1.5-0.671,1.5-1.5l-0.5-7.876C16.501,7.072,16.053,6.624,15.501,6.624zM15.501,22.377c-0.552,0-1,0.447-1,1s0.448,1,1,1s1-0.447,1-1S16.053,22.377,15.501,22.377zM18.939,21.455c-0.479,0.277-0.643,0.889-0.366,1.367c0.275,0.477,0.888,0.643,1.366,0.365c0.478-0.275,0.642-0.889,0.366-1.365C20.028,21.344,19.417,21.18,18.939,21.455z" ,
71
65
} ,
72
- {
73
- id : "animation_pathWingButton" ,
66
+ animation_pathWingButton : {
74
67
tagName : "path" ,
75
68
d :
76
69
"m 4.5,0.5 c -2.216,0 -4,1.784 -4,4 l 0,24 c 0,2.216 1.784,4 4,4 l 13.71875,0 C 22.478584,27.272785 27.273681,22.511272 32.5,18.25 l 0,-13.75 c 0,-2.216 -1.784,-4 -4,-4 l -24,0 z" ,
77
70
} ,
78
- {
79
- id : "animation_pathPointer" ,
71
+ animation_pathPointer : {
80
72
tagName : "path" ,
81
73
d : "M-15,-65,-15,-55,15,-55,15,-65,0,-95z" ,
82
74
} ,
83
- {
84
- id : "animation_pathSwooshFX" ,
75
+ animation_pathSwooshFX : {
85
76
tagName : "path" ,
86
77
d :
87
78
"m 85,0 c 0,16.617 -4.813944,35.356 -13.131081,48.4508 h 6.099803 c 8.317138,-13.0948 13.13322,-28.5955 13.13322,-45.2124 0,-46.94483 -38.402714,-85.00262 -85.7743869,-85.00262 -1.0218522,0 -2.0373001,0.0241 -3.0506131,0.0589 45.958443,1.59437 82.723058,35.77285 82.723058,81.70532 z" ,
88
79
} ,
89
- ] ;
90
-
91
- function getSVGIconInfo ( id ) {
92
- for ( var i = 0 ; i < svgIcons . length ; i ++ ) {
93
- if ( "#" + svgIcons [ i ] . id === id ) {
94
- return svgIcons [ i ] ;
95
- }
96
- }
97
- }
80
+ } ;
98
81
99
82
//Dynamically builds an SVG element from a JSON object.
100
83
function svgFromObject ( obj ) {
101
84
var ele = document . createElementNS ( svgNS , obj . tagName ) ;
102
-
103
85
for ( var field in obj ) {
104
86
if ( obj . hasOwnProperty ( field ) && field !== "tagName" ) {
105
87
if ( field === "children" ) {
@@ -117,7 +99,6 @@ function svgFromObject(obj) {
117
99
}
118
100
}
119
101
}
120
-
121
102
return ele ;
122
103
}
123
104
@@ -155,7 +136,7 @@ function makeColorString(background, gradient) {
155
136
}
156
137
157
138
function rectButton ( x , y , path ) {
158
- var svgInfo = getSVGIconInfo ( path ) ;
139
+ var iconInfo = svgIconsById [ path ] ;
159
140
160
141
var button = {
161
142
tagName : "g" ,
@@ -180,10 +161,10 @@ function rectButton(x, y, path) {
180
161
} ,
181
162
{
182
163
class : "cesium-animation-buttonPath" ,
183
- id : svgInfo . id ,
184
- tagName : svgInfo . tagName ,
185
- transform : svgInfo . transform ,
186
- d : svgInfo . d ,
164
+ id : path ,
165
+ tagName : iconInfo . tagName ,
166
+ transform : iconInfo . transform ,
167
+ d : iconInfo . d ,
187
168
} ,
188
169
{
189
170
tagName : "title" ,
@@ -195,8 +176,8 @@ function rectButton(x, y, path) {
195
176
}
196
177
197
178
function wingButton ( x , y , path ) {
198
- var buttonSVGInfo = getSVGIconInfo ( path ) ;
199
- var wingInfo = getSVGIconInfo ( "# animation_pathWingButton") ;
179
+ var buttonIconInfo = svgIconsById [ path ] ;
180
+ var wingIconInfo = svgIconsById [ " animation_pathWingButton"] ;
200
181
201
182
var button = {
202
183
tagName : "g" ,
@@ -205,22 +186,22 @@ function wingButton(x, y, path) {
205
186
children : [
206
187
{
207
188
class : "cesium-animation-buttonGlow" ,
208
- id : wingInfo . id ,
209
- tagName : wingInfo . tagName ,
210
- d : wingInfo . d ,
189
+ id : "animation_pathWingButton" ,
190
+ tagName : wingIconInfo . tagName ,
191
+ d : wingIconInfo . d ,
211
192
} ,
212
193
{
213
194
class : "cesium-animation-buttonMain" ,
214
- id : wingInfo . id ,
215
- tagName : wingInfo . tagName ,
216
- d : wingInfo . d ,
195
+ id : "animation_pathWingButton" ,
196
+ tagName : wingIconInfo . tagName ,
197
+ d : wingIconInfo . d ,
217
198
} ,
218
199
{
219
200
class : "cesium-animation-buttonPath" ,
220
- id : buttonSVGInfo . id ,
221
- tagName : buttonSVGInfo . tagName ,
222
- transform : buttonSVGInfo . transform ,
223
- d : buttonSVGInfo . d ,
201
+ id : path ,
202
+ tagName : buttonIconInfo . tagName ,
203
+ transform : buttonIconInfo . transform ,
204
+ d : buttonIconInfo . d ,
224
205
} ,
225
206
{
226
207
tagName : "title" ,
@@ -516,19 +497,19 @@ function Animation(container, viewModel) {
516
497
this . _topG = topG ;
517
498
518
499
this . _realtimeSVG = new SvgButton (
519
- wingButton ( 3 , 4 , "# animation_pathClock" ) ,
500
+ wingButton ( 3 , 4 , "animation_pathClock" ) ,
520
501
viewModel . playRealtimeViewModel
521
502
) ;
522
503
this . _playReverseSVG = new SvgButton (
523
- rectButton ( 44 , 99 , "# animation_pathPlayReverse" ) ,
504
+ rectButton ( 44 , 99 , "animation_pathPlayReverse" ) ,
524
505
viewModel . playReverseViewModel
525
506
) ;
526
507
this . _playForwardSVG = new SvgButton (
527
- rectButton ( 124 , 99 , "# animation_pathPlay" ) ,
508
+ rectButton ( 124 , 99 , "animation_pathPlay" ) ,
528
509
viewModel . playForwardViewModel
529
510
) ;
530
511
this . _pauseSVG = new SvgButton (
531
- rectButton ( 84 , 99 , "# animation_pathPause" ) ,
512
+ rectButton ( 84 , 99 , "animation_pathPause" ) ,
532
513
viewModel . pauseViewModel
533
514
) ;
534
515
@@ -547,24 +528,24 @@ function Animation(container, viewModel) {
547
528
} ) ;
548
529
this . _shuttleRingBackPanel = shuttleRingBackPanel ;
549
530
550
- var swooshSVGInfo = getSVGIconInfo ( "# animation_pathSwooshFX") ;
551
- var shuttleRingPointer = getSVGIconInfo ( "# animation_pathPointer") ;
531
+ var swooshIconInfo = svgIconsById [ " animation_pathSwooshFX"] ;
532
+ var shuttleRingPointerIconInfo = svgIconsById [ " animation_pathPointer"] ;
552
533
553
534
var shuttleRingSwooshG = svgFromObject ( {
554
535
tagName : "g" ,
555
536
class : "cesium-animation-shuttleRingSwoosh" ,
556
537
children : [
557
538
{
558
- tagName : swooshSVGInfo . tagName ,
539
+ tagName : swooshIconInfo . tagName ,
559
540
transform : "translate(100,97) scale(-1,1)" ,
560
- id : swooshSVGInfo . id ,
561
- d : swooshSVGInfo . d ,
541
+ id : "animation_pathSwooshFX" ,
542
+ d : swooshIconInfo . d ,
562
543
} ,
563
544
{
564
- tagName : swooshSVGInfo . tagName ,
545
+ tagName : swooshIconInfo . tagName ,
565
546
transform : "translate(100,97)" ,
566
- id : swooshSVGInfo . id ,
567
- d : swooshSVGInfo . d ,
547
+ id : "animation_pathSwooshFX" ,
548
+ d : swooshIconInfo . d ,
568
549
} ,
569
550
{
570
551
tagName : "line" ,
@@ -579,9 +560,9 @@ function Animation(container, viewModel) {
579
560
580
561
this . _shuttleRingPointer = svgFromObject ( {
581
562
class : "cesium-animation-shuttleRingPointer" ,
582
- tagName : shuttleRingPointer . tagName ,
583
- id : shuttleRingPointer . id ,
584
- d : shuttleRingPointer . d ,
563
+ id : "animation_pathPointer" ,
564
+ tagName : shuttleRingPointerIconInfo . tagName ,
565
+ d : shuttleRingPointerIconInfo . d ,
585
566
} ) ;
586
567
587
568
var knobG = svgFromObject ( {
0 commit comments