@urso/core 0.3.5 → 0.3.6

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (143) hide show
  1. package/.babelrc +11 -11
  2. package/README.md +10 -10
  3. package/build/js/index.js +1 -1
  4. package/build/js/index.js.LICENSE.txt +29 -29
  5. package/package.json +51 -51
  6. package/src/js/app.js +77 -77
  7. package/src/js/components/_info.js +8 -8
  8. package/src/js/components/base/_info.js +3 -3
  9. package/src/js/components/base/controller.js +78 -78
  10. package/src/js/components/debug/_info.js +7 -6
  11. package/src/js/components/debug/controller.js +38 -38
  12. package/src/js/components/debug/coords.js +23 -23
  13. package/src/js/components/debug/fps.js +34 -34
  14. package/src/js/components/debug/template.js +55 -33
  15. package/src/js/components/debug/timescale.js +60 -0
  16. package/src/js/components/deviceRotate/_info.js +3 -3
  17. package/src/js/components/deviceRotate/controller.js +86 -86
  18. package/src/js/components/fullscreen/_info.js +6 -6
  19. package/src/js/components/fullscreen/android.js +104 -104
  20. package/src/js/components/fullscreen/controller.js +64 -64
  21. package/src/js/components/fullscreen/desktop.js +49 -49
  22. package/src/js/components/fullscreen/ios.js +111 -111
  23. package/src/js/components/loader/_info.js +4 -4
  24. package/src/js/components/loader/controller.js +66 -66
  25. package/src/js/components/loader/template.js +70 -70
  26. package/src/js/components/soundInitialPopup/_info.js +3 -3
  27. package/src/js/components/soundInitialPopup/controller.js +42 -42
  28. package/src/js/components/soundInitialPopup/template.js +109 -109
  29. package/src/js/components/stateDriven/_info.js +3 -3
  30. package/src/js/components/stateDriven/controller.js +96 -96
  31. package/src/js/config/load.js +5 -5
  32. package/src/js/config/main.js +10 -10
  33. package/src/js/extra/_info.js +21 -21
  34. package/src/js/extra/browserEvents.js +32 -32
  35. package/src/js/index.js +8 -8
  36. package/src/js/lib/_info.js +13 -13
  37. package/src/js/lib/cache.js +98 -98
  38. package/src/js/lib/composition.js +89 -89
  39. package/src/js/lib/device.js +1276 -1276
  40. package/src/js/lib/helper.js +539 -539
  41. package/src/js/lib/loader.js +121 -121
  42. package/src/js/lib/localData.js +15 -15
  43. package/src/js/lib/logger.js +22 -22
  44. package/src/js/lib/math.js +35 -20
  45. package/src/js/lib/objectPool.js +54 -54
  46. package/src/js/lib/time.js +18 -18
  47. package/src/js/lib/tween.js +147 -147
  48. package/src/js/modules/_info.js +11 -11
  49. package/src/js/modules/assets/_info.js +7 -7
  50. package/src/js/modules/assets/baseModel.js +18 -18
  51. package/src/js/modules/assets/config.js +35 -35
  52. package/src/js/modules/assets/controller.js +39 -39
  53. package/src/js/modules/assets/models/_info.js +11 -11
  54. package/src/js/modules/assets/models/atlas.js +8 -8
  55. package/src/js/modules/assets/models/audiosprite.js +27 -27
  56. package/src/js/modules/assets/models/bitmapFont.js +8 -8
  57. package/src/js/modules/assets/models/container.js +16 -16
  58. package/src/js/modules/assets/models/font.js +8 -8
  59. package/src/js/modules/assets/models/image.js +14 -14
  60. package/src/js/modules/assets/models/json.js +8 -8
  61. package/src/js/modules/assets/models/sound.js +14 -14
  62. package/src/js/modules/assets/models/spine.js +8 -8
  63. package/src/js/modules/assets/service.js +327 -327
  64. package/src/js/modules/instances/_info.js +3 -3
  65. package/src/js/modules/instances/controller.js +219 -219
  66. package/src/js/modules/logic/_info.js +4 -4
  67. package/src/js/modules/logic/config/_info.js +2 -2
  68. package/src/js/modules/logic/config/sounds.js +23 -23
  69. package/src/js/modules/logic/controller.js +48 -48
  70. package/src/js/modules/logic/sounds.js +96 -96
  71. package/src/js/modules/objects/_info.js +11 -11
  72. package/src/js/modules/objects/baseModel.js +161 -161
  73. package/src/js/modules/objects/cache.js +99 -99
  74. package/src/js/modules/objects/controller.js +121 -121
  75. package/src/js/modules/objects/create.js +230 -230
  76. package/src/js/modules/objects/find.js +140 -140
  77. package/src/js/modules/objects/models/_info.js +24 -24
  78. package/src/js/modules/objects/models/atlasImage.js +50 -50
  79. package/src/js/modules/objects/models/bitmapText.js +23 -23
  80. package/src/js/modules/objects/models/button.js +184 -184
  81. package/src/js/modules/objects/models/buttonComposite.js +35 -35
  82. package/src/js/modules/objects/models/checkbox.js +96 -96
  83. package/src/js/modules/objects/models/collection.js +54 -54
  84. package/src/js/modules/objects/models/component.js +44 -44
  85. package/src/js/modules/objects/models/container.js +19 -19
  86. package/src/js/modules/objects/models/emitter.js +54 -54
  87. package/src/js/modules/objects/models/graphics.js +38 -38
  88. package/src/js/modules/objects/models/group.js +19 -19
  89. package/src/js/modules/objects/models/hitArea.js +104 -104
  90. package/src/js/modules/objects/models/image.js +34 -34
  91. package/src/js/modules/objects/models/imagesAnimation.js +113 -113
  92. package/src/js/modules/objects/models/mask.js +38 -38
  93. package/src/js/modules/objects/models/scrollbox.js +61 -61
  94. package/src/js/modules/objects/models/slider.js +199 -199
  95. package/src/js/modules/objects/models/spine.js +89 -82
  96. package/src/js/modules/objects/models/text.js +38 -38
  97. package/src/js/modules/objects/models/textInput.js +66 -66
  98. package/src/js/modules/objects/models/toggle.js +178 -178
  99. package/src/js/modules/objects/models/world.js +19 -19
  100. package/src/js/modules/objects/propertyAdapter.js +421 -421
  101. package/src/js/modules/objects/proxy.js +182 -179
  102. package/src/js/modules/objects/styles.js +116 -116
  103. package/src/js/modules/observer/_info.js +4 -4
  104. package/src/js/modules/observer/controller.js +99 -99
  105. package/src/js/modules/observer/events.js +36 -36
  106. package/src/js/modules/scenes/_info.js +8 -8
  107. package/src/js/modules/scenes/controller.js +42 -34
  108. package/src/js/modules/scenes/model.js +35 -35
  109. package/src/js/modules/scenes/pixiWrapper.js +194 -194
  110. package/src/js/modules/scenes/resolutions.js +168 -168
  111. package/src/js/modules/scenes/resolutionsConfig.js +73 -73
  112. package/src/js/modules/scenes/service.js +92 -84
  113. package/src/js/modules/soundManager/_info.js +3 -3
  114. package/src/js/modules/soundManager/controller.js +99 -99
  115. package/src/js/modules/soundManager/soundSprite.js +202 -202
  116. package/src/js/modules/statesManager/_info.js +12 -12
  117. package/src/js/modules/statesManager/action.js +60 -60
  118. package/src/js/modules/statesManager/actions/_info.js +3 -3
  119. package/src/js/modules/statesManager/all.js +23 -23
  120. package/src/js/modules/statesManager/configStates.js +71 -71
  121. package/src/js/modules/statesManager/controller.js +140 -140
  122. package/src/js/modules/statesManager/functionsStorage.js +82 -82
  123. package/src/js/modules/statesManager/helper.js +27 -27
  124. package/src/js/modules/statesManager/race.js +75 -75
  125. package/src/js/modules/statesManager/sequence.js +47 -47
  126. package/src/js/modules/template/_info.js +6 -6
  127. package/src/js/modules/template/controller.js +28 -28
  128. package/src/js/modules/template/model.js +11 -11
  129. package/src/js/modules/template/service.js +125 -125
  130. package/src/js/modules/template/types.js +44 -44
  131. package/src/js/modules/transport/_info.js +8 -8
  132. package/src/js/modules/transport/baseConnectionType.js +24 -24
  133. package/src/js/modules/transport/config.js +13 -13
  134. package/src/js/modules/transport/connectionTypes/_info.js +3 -3
  135. package/src/js/modules/transport/connectionTypes/websocket.js +74 -74
  136. package/src/js/modules/transport/connectionTypes/xhr.js +44 -44
  137. package/src/js/modules/transport/controller.js +48 -48
  138. package/src/js/modules/transport/decorator.js +17 -17
  139. package/src/js/modules/transport/service.js +153 -153
  140. package/src/js/templates/_info.js +4 -4
  141. package/src/js/templates/groups/_info.js +1 -1
  142. package/src/js/templates/scenes/_info.js +1 -1
  143. package/webpack.config.js +47 -47
@@ -1,168 +1,168 @@
1
- class ModulesScenesResolutions {
2
-
3
- constructor() {
4
- this.singleton = true;
5
- this._activeResolution = false; //object
6
- this._templateSize = { orientation: 0, width: 0, height: 0 };
7
- this._orientations = { landscape: 'landscape', portrait: 'portrait' }
8
- this._currentOrientation = null;
9
-
10
- this.refreshSceneSize = this.refreshSceneSize.bind(this);
11
- this.refreshSceneSize();
12
-
13
- //TODO optimization (performance)
14
- /*if (devicePixelRatio > 2)
15
- devicePixelRatio = 2;*/ // when we are calculating canvas size
16
- }
17
-
18
- _subscribeOnce() {
19
- this.addListener(Urso.events.EXTRA_BROWSEREVENTS_WINDOW_RESIZE, this.refreshSceneSize, true);
20
- this.addListener(Urso.events.MODULES_SCENES_NEW_SCENE_INIT, this.refreshSceneSize, true);
21
- }
22
-
23
- getTemplateSize() {
24
- return this._templateSize;
25
- }
26
-
27
- refreshSceneSize() {
28
- let windowSize = this._getWindowSize();
29
- let orientation = this._getOrientation(windowSize);
30
- let configResolution = this._getResolutionConfig(windowSize);
31
-
32
- let windowRatio = windowSize.width / windowSize.height;
33
- let optimalRatio = this._getOptimalRatio(configResolution, windowRatio, orientation);
34
-
35
- let currentResolution = Urso.helper.objectClone(configResolution);
36
- currentResolution.name = 'currentResolution';
37
- currentResolution.base = configResolution;
38
- currentResolution.width = (optimalRatio > windowRatio) ? Math.floor(windowSize.width) : Math.floor(Math.floor(windowSize.height) * optimalRatio);
39
- currentResolution.height = (optimalRatio > windowRatio) ? Math.floor(Math.floor(windowSize.width) / optimalRatio) : Math.floor(windowSize.height);
40
-
41
- this._templateSize = this._calculateTemplateSize(currentResolution);
42
- this._applyResolutionToPixi(currentResolution);
43
-
44
- console.log('[SCENE] New Orientation', orientation);
45
- console.log('[SCENE] New Resolution', currentResolution, 'windowSize:', windowSize);
46
- console.log('[SCENE] New Template Size', this._templateSize);
47
-
48
- //update InstancesModes
49
- Object.values(this._orientations).forEach((orientationValue) => Urso.removeInstancesMode(orientationValue + 'Orientation'));
50
- Urso.addInstancesMode(orientation + 'Orientation');
51
-
52
- //send new resolution event
53
- this.emit(Urso.events.MODULES_SCENES_NEW_RESOLUTION, { resolution: currentResolution, template: this._templateSize });
54
-
55
- if (this._currentOrientation !== this._templateSize.orientation) {
56
- this._currentOrientation = this._templateSize.orientation;
57
- this.emit(Urso.events.MODULES_SCENES_ORIENTATION_CHANGE, this._templateSize.orientation);
58
- }
59
-
60
- return true;
61
- };
62
-
63
- _getWindowSize() {
64
- const iOS = Urso.device.iOS;
65
- const { width, height } = document.body.getBoundingClientRect();
66
-
67
- let windowSize = {
68
- width: iOS ? window.innerWidth : width,
69
- height: iOS ? window.innerHeight : height
70
- };
71
-
72
- if (window.devicePixelRatio && window.devicePixelRatio !== 1) {
73
- windowSize.width *= window.devicePixelRatio;
74
- windowSize.height *= window.devicePixelRatio;
75
- }
76
-
77
- return windowSize;
78
- }
79
-
80
- _getOrientation(windowSize) {
81
- return windowSize.width > windowSize.height ? this._orientations.landscape : this._orientations.portrait; //todo move to constants
82
- }
83
-
84
- _getResolutionConfig(windowSize) {
85
- let orientation = this._getOrientation(windowSize);
86
- let mainDimension = windowSize.width > windowSize.height ? 'width' : 'height'; //todo move to constants
87
- let config = this.getInstance('ResolutionsConfig').get();
88
- let currentResolution = config[0];
89
-
90
- //select optimal resolution from config
91
- for (let resolution of config) {
92
- if (resolution.orientation !== orientation)
93
- continue;
94
-
95
- if (
96
- (currentResolution.orientation !== orientation) ||
97
- (
98
- currentResolution[mainDimension] < resolution[mainDimension] &&
99
- resolution[mainDimension] < windowSize[mainDimension]
100
- ) ||
101
- (
102
- windowSize[mainDimension] < currentResolution[mainDimension] &&
103
- resolution[mainDimension] < currentResolution[mainDimension]
104
- )
105
- )
106
- currentResolution = resolution;
107
- }
108
-
109
- return currentResolution;
110
- }
111
-
112
- _getOptimalRatio(configResolution, windowRatio, orientation) {
113
- let optimalRatio = configResolution.width / configResolution.height;
114
-
115
- if (configResolution.adaptive) {
116
- let display = !Urso.helper.mobileAndTabletCheck() ? 'desktop' : 'mobile'; //todo move to constants
117
- let adaptiveParams = this.getInstance('ResolutionsConfig').getAdaptive()[display];
118
-
119
- if (adaptiveParams.supported) {
120
- let limits = adaptiveParams.limits[orientation];
121
- optimalRatio = Urso.math.intMakeBetween(windowRatio, limits.min, limits.max);
122
- }
123
- }
124
-
125
- return optimalRatio;
126
- }
127
-
128
- _calculateTemplateSize(resolution) {
129
- this._templateSize.orientation = resolution.orientation;
130
- this._templateSize.width = resolution.base.width;
131
- this._templateSize.height = resolution.base.height;
132
-
133
- let dimensionsArray = ['width', 'height'];
134
-
135
- //adaptive corrections
136
- if (resolution.adaptive) {
137
- let dimensionsPassiveKey = (resolution.width / resolution.height > resolution.base.width / resolution.base.height) ? 0 : 1;
138
- let dimensionsMainKey = (dimensionsPassiveKey === 1) ? 0 : 1;
139
-
140
- this._templateSize[dimensionsArray[dimensionsPassiveKey]] =
141
- ~~(
142
- resolution[dimensionsArray[dimensionsPassiveKey]] *
143
- resolution.base[dimensionsArray[dimensionsMainKey]] / resolution[dimensionsArray[dimensionsMainKey]]
144
- );
145
- }
146
-
147
- return this._templateSize;
148
- }
149
-
150
- _applyResolutionToPixi(resolution) {
151
- let maxResolutionFactor = Math.min(this.getInstance('ResolutionsConfig').maxSize() / Math.max(resolution.width, resolution.height), 1);
152
- let dp = window.devicePixelRatio;
153
- let canvasSize = {
154
- width: ~~(resolution.width * maxResolutionFactor),
155
- height: ~~(resolution.height * maxResolutionFactor)
156
- };
157
-
158
- this.getInstance('PixiWrapper').resize(canvasSize.width, canvasSize.height);
159
- this.getInstance('PixiWrapper').setWorldScale(canvasSize.width / this._templateSize.width, canvasSize.height / this._templateSize.height);
160
- this.getInstance('PixiWrapper').setCanvasWidth(resolution.width / dp);
161
- this.getInstance('PixiWrapper').setCanvasHeight(resolution.height / dp);
162
-
163
- this._activeResolution = resolution;
164
- return true;
165
- };
166
- }
167
-
168
- module.exports = ModulesScenesResolutions;
1
+ class ModulesScenesResolutions {
2
+
3
+ constructor() {
4
+ this.singleton = true;
5
+ this._activeResolution = false; //object
6
+ this._templateSize = { orientation: 0, width: 0, height: 0 };
7
+ this._orientations = { landscape: 'landscape', portrait: 'portrait' }
8
+ this._currentOrientation = null;
9
+
10
+ this.refreshSceneSize = this.refreshSceneSize.bind(this);
11
+ this.refreshSceneSize();
12
+
13
+ //TODO optimization (performance)
14
+ /*if (devicePixelRatio > 2)
15
+ devicePixelRatio = 2;*/ // when we are calculating canvas size
16
+ }
17
+
18
+ _subscribeOnce() {
19
+ this.addListener(Urso.events.EXTRA_BROWSEREVENTS_WINDOW_RESIZE, this.refreshSceneSize, true);
20
+ this.addListener(Urso.events.MODULES_SCENES_NEW_SCENE_INIT, this.refreshSceneSize, true);
21
+ }
22
+
23
+ getTemplateSize() {
24
+ return this._templateSize;
25
+ }
26
+
27
+ refreshSceneSize() {
28
+ let windowSize = this._getWindowSize();
29
+ let orientation = this._getOrientation(windowSize);
30
+ let configResolution = this._getResolutionConfig(windowSize);
31
+
32
+ let windowRatio = windowSize.width / windowSize.height;
33
+ let optimalRatio = this._getOptimalRatio(configResolution, windowRatio, orientation);
34
+
35
+ let currentResolution = Urso.helper.objectClone(configResolution);
36
+ currentResolution.name = 'currentResolution';
37
+ currentResolution.base = configResolution;
38
+ currentResolution.width = (optimalRatio > windowRatio) ? Math.floor(windowSize.width) : Math.floor(Math.floor(windowSize.height) * optimalRatio);
39
+ currentResolution.height = (optimalRatio > windowRatio) ? Math.floor(Math.floor(windowSize.width) / optimalRatio) : Math.floor(windowSize.height);
40
+
41
+ this._templateSize = this._calculateTemplateSize(currentResolution);
42
+ this._applyResolutionToPixi(currentResolution);
43
+
44
+ console.log('[SCENE] New Orientation', orientation);
45
+ console.log('[SCENE] New Resolution', currentResolution, 'windowSize:', windowSize);
46
+ console.log('[SCENE] New Template Size', this._templateSize);
47
+
48
+ //update InstancesModes
49
+ Object.values(this._orientations).forEach((orientationValue) => Urso.removeInstancesMode(orientationValue + 'Orientation'));
50
+ Urso.addInstancesMode(orientation + 'Orientation');
51
+
52
+ //send new resolution event
53
+ this.emit(Urso.events.MODULES_SCENES_NEW_RESOLUTION, { resolution: currentResolution, template: this._templateSize });
54
+
55
+ if (this._currentOrientation !== this._templateSize.orientation) {
56
+ this._currentOrientation = this._templateSize.orientation;
57
+ this.emit(Urso.events.MODULES_SCENES_ORIENTATION_CHANGE, this._templateSize.orientation);
58
+ }
59
+
60
+ return true;
61
+ };
62
+
63
+ _getWindowSize() {
64
+ const iOS = Urso.device.iOS;
65
+ const { width, height } = document.body.getBoundingClientRect();
66
+
67
+ let windowSize = {
68
+ width: iOS ? window.innerWidth : width,
69
+ height: iOS ? window.innerHeight : height
70
+ };
71
+
72
+ if (window.devicePixelRatio && window.devicePixelRatio !== 1) {
73
+ windowSize.width *= window.devicePixelRatio;
74
+ windowSize.height *= window.devicePixelRatio;
75
+ }
76
+
77
+ return windowSize;
78
+ }
79
+
80
+ _getOrientation(windowSize) {
81
+ return windowSize.width > windowSize.height ? this._orientations.landscape : this._orientations.portrait; //todo move to constants
82
+ }
83
+
84
+ _getResolutionConfig(windowSize) {
85
+ let orientation = this._getOrientation(windowSize);
86
+ let mainDimension = windowSize.width > windowSize.height ? 'width' : 'height'; //todo move to constants
87
+ let config = this.getInstance('ResolutionsConfig').get();
88
+ let currentResolution = config[0];
89
+
90
+ //select optimal resolution from config
91
+ for (let resolution of config) {
92
+ if (resolution.orientation !== orientation)
93
+ continue;
94
+
95
+ if (
96
+ (currentResolution.orientation !== orientation) ||
97
+ (
98
+ currentResolution[mainDimension] < resolution[mainDimension] &&
99
+ resolution[mainDimension] < windowSize[mainDimension]
100
+ ) ||
101
+ (
102
+ windowSize[mainDimension] < currentResolution[mainDimension] &&
103
+ resolution[mainDimension] < currentResolution[mainDimension]
104
+ )
105
+ )
106
+ currentResolution = resolution;
107
+ }
108
+
109
+ return currentResolution;
110
+ }
111
+
112
+ _getOptimalRatio(configResolution, windowRatio, orientation) {
113
+ let optimalRatio = configResolution.width / configResolution.height;
114
+
115
+ if (configResolution.adaptive) {
116
+ let display = !Urso.helper.mobileAndTabletCheck() ? 'desktop' : 'mobile'; //todo move to constants
117
+ let adaptiveParams = this.getInstance('ResolutionsConfig').getAdaptive()[display];
118
+
119
+ if (adaptiveParams.supported) {
120
+ let limits = adaptiveParams.limits[orientation];
121
+ optimalRatio = Urso.math.intMakeBetween(windowRatio, limits.min, limits.max);
122
+ }
123
+ }
124
+
125
+ return optimalRatio;
126
+ }
127
+
128
+ _calculateTemplateSize(resolution) {
129
+ this._templateSize.orientation = resolution.orientation;
130
+ this._templateSize.width = resolution.base.width;
131
+ this._templateSize.height = resolution.base.height;
132
+
133
+ let dimensionsArray = ['width', 'height'];
134
+
135
+ //adaptive corrections
136
+ if (resolution.adaptive) {
137
+ let dimensionsPassiveKey = (resolution.width / resolution.height > resolution.base.width / resolution.base.height) ? 0 : 1;
138
+ let dimensionsMainKey = (dimensionsPassiveKey === 1) ? 0 : 1;
139
+
140
+ this._templateSize[dimensionsArray[dimensionsPassiveKey]] =
141
+ ~~(
142
+ resolution[dimensionsArray[dimensionsPassiveKey]] *
143
+ resolution.base[dimensionsArray[dimensionsMainKey]] / resolution[dimensionsArray[dimensionsMainKey]]
144
+ );
145
+ }
146
+
147
+ return this._templateSize;
148
+ }
149
+
150
+ _applyResolutionToPixi(resolution) {
151
+ let maxResolutionFactor = Math.min(this.getInstance('ResolutionsConfig').maxSize() / Math.max(resolution.width, resolution.height), 1);
152
+ let dp = window.devicePixelRatio;
153
+ let canvasSize = {
154
+ width: ~~(resolution.width * maxResolutionFactor),
155
+ height: ~~(resolution.height * maxResolutionFactor)
156
+ };
157
+
158
+ this.getInstance('PixiWrapper').resize(canvasSize.width, canvasSize.height);
159
+ this.getInstance('PixiWrapper').setWorldScale(canvasSize.width / this._templateSize.width, canvasSize.height / this._templateSize.height);
160
+ this.getInstance('PixiWrapper').setCanvasWidth(resolution.width / dp);
161
+ this.getInstance('PixiWrapper').setCanvasHeight(resolution.height / dp);
162
+
163
+ this._activeResolution = resolution;
164
+ return true;
165
+ };
166
+ }
167
+
168
+ module.exports = ModulesScenesResolutions;
@@ -1,73 +1,73 @@
1
- class ModulesScenesResolutionsConfig {
2
- constructor() {
3
- this.singleton = true;
4
-
5
- this._orientations = ['landscape', 'portrait'];
6
-
7
- this.contents = [
8
- {
9
- "name": 'default',
10
- "width": 1920,
11
- "height": 1080,
12
- "orientation": 'landscape',
13
- "adaptive": true
14
- }
15
- ];
16
-
17
- this.adaptiveConfig = {//works only if "adaptive": true for current resolution
18
- desktop: {
19
- supported: true,
20
- limits: {
21
- landscape: {
22
- min: 1, // width:height factor
23
- max: 2
24
- },
25
- portrait: {
26
- min: 0.5,
27
- max: 1
28
- }
29
- }
30
- },
31
- mobile: {
32
- supported: true,
33
- limits: {
34
- landscape: {
35
- min: 1, // width:height factor
36
- max: 2
37
- },
38
- portrait: {
39
- min: 0.5,
40
- max: 1
41
- }
42
- }
43
- }
44
- };
45
- }
46
-
47
- get() {
48
- return this.contents;
49
- };
50
-
51
-
52
- getAdaptive() {
53
- return this.adaptiveConfig;
54
- };
55
-
56
- maxSize() {
57
- return Math.max(this.maxWidth(), this.maxHeight());
58
- };
59
-
60
- maxWidth() {
61
- return this._maxDimension.call(this, 'width');
62
- };
63
-
64
- maxHeight() {
65
- return this._maxDimension.call(this, 'height');
66
- };
67
-
68
- _maxDimension(dim) {
69
- return this.contents.reduce((result, resolution) => resolution[dim] > result ? resolution[dim] : result, 0);
70
- };
71
- }
72
-
73
- module.exports = ModulesScenesResolutionsConfig;
1
+ class ModulesScenesResolutionsConfig {
2
+ constructor() {
3
+ this.singleton = true;
4
+
5
+ this._orientations = ['landscape', 'portrait'];
6
+
7
+ this.contents = [
8
+ {
9
+ "name": 'default',
10
+ "width": 1920,
11
+ "height": 1080,
12
+ "orientation": 'landscape',
13
+ "adaptive": true
14
+ }
15
+ ];
16
+
17
+ this.adaptiveConfig = {//works only if "adaptive": true for current resolution
18
+ desktop: {
19
+ supported: true,
20
+ limits: {
21
+ landscape: {
22
+ min: 1, // width:height factor
23
+ max: 2
24
+ },
25
+ portrait: {
26
+ min: 0.5,
27
+ max: 1
28
+ }
29
+ }
30
+ },
31
+ mobile: {
32
+ supported: true,
33
+ limits: {
34
+ landscape: {
35
+ min: 1, // width:height factor
36
+ max: 2
37
+ },
38
+ portrait: {
39
+ min: 0.5,
40
+ max: 1
41
+ }
42
+ }
43
+ }
44
+ };
45
+ }
46
+
47
+ get() {
48
+ return this.contents;
49
+ };
50
+
51
+
52
+ getAdaptive() {
53
+ return this.adaptiveConfig;
54
+ };
55
+
56
+ maxSize() {
57
+ return Math.max(this.maxWidth(), this.maxHeight());
58
+ };
59
+
60
+ maxWidth() {
61
+ return this._maxDimension.call(this, 'width');
62
+ };
63
+
64
+ maxHeight() {
65
+ return this._maxDimension.call(this, 'height');
66
+ };
67
+
68
+ _maxDimension(dim) {
69
+ return this.contents.reduce((result, resolution) => resolution[dim] > result ? resolution[dim] : result, 0);
70
+ };
71
+ }
72
+
73
+ module.exports = ModulesScenesResolutionsConfig;
@@ -1,84 +1,92 @@
1
- class ModulesScenesService {
2
- constructor() {
3
- this.singleton = true;
4
- this._displayInProgress = false;
5
- this._currentSceneName = false;
6
- this._currentSceneTemplate = false;
7
- this._sceneModel;
8
-
9
- this._pixiWrapper;
10
-
11
- this.init();
12
-
13
- this._assetsLoadedHandler = this._assetsLoadedHandler.bind(this);
14
- }
15
-
16
- init() {
17
- this._pixiWrapper = this.getInstance('PixiWrapper');
18
- this._pixiWrapper.init();
19
- }
20
-
21
- display(name) {
22
- if (this._displayInProgress) {
23
- console.warn("Scenes.display is busy ", this._currentSceneName);
24
- return false;
25
- }
26
-
27
- let template = Urso.template.scene(name);
28
-
29
- if (!template) {
30
- console.error('Scenes.display error: no template for scene', name);
31
- return false;
32
- }
33
-
34
- console.log('[SCENE] display:', name);
35
- this._displayInProgress = true;
36
- this.emit(Urso.events.MODULES_SCENES_DISPLAY_START, name);
37
-
38
- //destroy all components, if _sceneModel exists. Not exists only in first call
39
- if (this._sceneModel)
40
- this._sceneModel.destroy();
41
-
42
- this._currentSceneName = name;
43
- Urso.observer.clearAllLocal();
44
- Urso.observer.setPrefix(name);
45
-
46
- //parse template
47
- this._currentSceneTemplate = Urso.template.parse(template);
48
-
49
- console.log('[SCENE] current template:', this._currentSceneTemplate)
50
- this._sceneModel = this.getInstance('Model');
51
-
52
- //write model by template (functions) //todo set in model (this.getInstance('Model', params);)
53
- this._sceneModel.loadUpdate = (loadProgress) => { this._currentSceneTemplate.components.forEach(component => component.loadUpdate(loadProgress)); }
54
- this._sceneModel.create = () => { this._currentSceneTemplate.components.forEach(component => component.create()); }
55
- this._sceneModel.update = (deltaTime) => { this._currentSceneTemplate.components.forEach(component => component.update(deltaTime)); }
56
- this._sceneModel.destroy = () => { this._currentSceneTemplate.components.forEach(component => component.destroy()); }
57
-
58
- //start new scene by wrapper
59
- this.getInstance('PixiWrapper').setNewScene(this._sceneModel);
60
- this.emit(Urso.events.MODULES_SCENES_NEW_SCENE_INIT, name);
61
-
62
- Urso.assets.preload(this._currentSceneTemplate.assets, this._assetsLoadedHandler);
63
-
64
- }
65
-
66
- loadUpdate(loadProgress){
67
- if(!this._sceneModel)
68
- return;
69
- this._sceneModel.loadUpdate(loadProgress);
70
- this.emit(Urso.events.MODULES_ASSETS_LOAD_PROGRESS, loadProgress);
71
- }
72
-
73
- _assetsLoadedHandler() {
74
- Urso.objects.create(this._currentSceneTemplate.objects);
75
-
76
- //call all components create
77
- this._sceneModel.create();
78
-
79
- this.emit(Urso.events.MODULES_SCENES_DISPLAY_FINISHED);
80
- this._displayInProgress = false;
81
- }
82
- }
83
-
84
- module.exports = ModulesScenesService;
1
+ class ModulesScenesService {
2
+ constructor() {
3
+ this.singleton = true;
4
+
5
+ this._displayInProgress = false;
6
+ this._currentSceneName = false;
7
+ this._currentSceneTemplate = false;
8
+ this._sceneModel;
9
+
10
+ this.timeScale = 1;
11
+
12
+ this._pixiWrapper;
13
+
14
+ this.init();
15
+
16
+ this._assetsLoadedHandler = this._assetsLoadedHandler.bind(this);
17
+ }
18
+
19
+ init() {
20
+ this._pixiWrapper = this.getInstance('PixiWrapper');
21
+ this._pixiWrapper.init();
22
+ }
23
+
24
+ setTimeScale(value) {
25
+ this.timeScale = value;
26
+ gsap.globalTimeline.timeScale(this.timeScale);
27
+ }
28
+
29
+ display(name) {
30
+ if (this._displayInProgress) {
31
+ console.warn("Scenes.display is busy ", this._currentSceneName);
32
+ return false;
33
+ }
34
+
35
+ let template = Urso.template.scene(name);
36
+
37
+ if (!template) {
38
+ console.error('Scenes.display error: no template for scene', name);
39
+ return false;
40
+ }
41
+
42
+ console.log('[SCENE] display:', name);
43
+ this._displayInProgress = true;
44
+ this.emit(Urso.events.MODULES_SCENES_DISPLAY_START, name);
45
+
46
+ //destroy all components, if _sceneModel exists. Not exists only in first call
47
+ if (this._sceneModel)
48
+ this._sceneModel.destroy();
49
+
50
+ this._currentSceneName = name;
51
+ Urso.observer.clearAllLocal();
52
+ Urso.observer.setPrefix(name);
53
+
54
+ //parse template
55
+ this._currentSceneTemplate = Urso.template.parse(template);
56
+
57
+ console.log('[SCENE] current template:', this._currentSceneTemplate)
58
+ this._sceneModel = this.getInstance('Model');
59
+
60
+ //write model by template (functions) //todo set in model (this.getInstance('Model', params);)
61
+ this._sceneModel.loadUpdate = (loadProgress) => { this._currentSceneTemplate.components.forEach(component => component.loadUpdate(loadProgress)); }
62
+ this._sceneModel.create = () => { this._currentSceneTemplate.components.forEach(component => component.create()); }
63
+ this._sceneModel.update = (deltaTime) => { this._currentSceneTemplate.components.forEach(component => component.update(deltaTime)); }
64
+ this._sceneModel.destroy = () => { this._currentSceneTemplate.components.forEach(component => component.destroy()); }
65
+
66
+ //start new scene by wrapper
67
+ this.getInstance('PixiWrapper').setNewScene(this._sceneModel);
68
+ this.emit(Urso.events.MODULES_SCENES_NEW_SCENE_INIT, name);
69
+
70
+ Urso.assets.preload(this._currentSceneTemplate.assets, this._assetsLoadedHandler);
71
+
72
+ }
73
+
74
+ loadUpdate(loadProgress) {
75
+ if (!this._sceneModel)
76
+ return;
77
+ this._sceneModel.loadUpdate(loadProgress);
78
+ this.emit(Urso.events.MODULES_ASSETS_LOAD_PROGRESS, loadProgress);
79
+ }
80
+
81
+ _assetsLoadedHandler() {
82
+ Urso.objects.create(this._currentSceneTemplate.objects);
83
+
84
+ //call all components create
85
+ this._sceneModel.create();
86
+
87
+ this.emit(Urso.events.MODULES_SCENES_DISPLAY_FINISHED);
88
+ this._displayInProgress = false;
89
+ }
90
+ }
91
+
92
+ module.exports = ModulesScenesService;