@urso/core 0.2.6 → 0.2.7

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 (146) 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 +31 -31
  5. package/package.json +52 -52
  6. package/src/js/app.js +76 -76
  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 +6 -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 +33 -33
  15. package/src/js/components/deviceRotate/_info.js +3 -3
  16. package/src/js/components/deviceRotate/controller.js +86 -86
  17. package/src/js/components/fullscreen/_info.js +6 -6
  18. package/src/js/components/fullscreen/android.js +104 -104
  19. package/src/js/components/fullscreen/controller.js +64 -64
  20. package/src/js/components/fullscreen/desktop.js +49 -49
  21. package/src/js/components/fullscreen/ios.js +111 -111
  22. package/src/js/components/loader/_info.js +4 -4
  23. package/src/js/components/loader/controller.js +66 -66
  24. package/src/js/components/loader/template.js +70 -70
  25. package/src/js/components/soundInitialPopup/_info.js +3 -3
  26. package/src/js/components/soundInitialPopup/controller.js +42 -42
  27. package/src/js/components/soundInitialPopup/template.js +109 -109
  28. package/src/js/components/stateDriven/_info.js +3 -3
  29. package/src/js/components/stateDriven/controller.js +96 -96
  30. package/src/js/config/load.js +5 -5
  31. package/src/js/config/main.js +9 -9
  32. package/src/js/extra/_info.js +23 -23
  33. package/src/js/extra/browserEvents.js +32 -32
  34. package/src/js/index.js +8 -8
  35. package/src/js/lib/_info.js +13 -13
  36. package/src/js/lib/cache.js +98 -98
  37. package/src/js/lib/composition.js +89 -89
  38. package/src/js/lib/device.js +1276 -1276
  39. package/src/js/lib/helper.js +524 -524
  40. package/src/js/lib/loader.js +121 -121
  41. package/src/js/lib/localData.js +15 -15
  42. package/src/js/lib/logger.js +22 -22
  43. package/src/js/lib/math.js +20 -20
  44. package/src/js/lib/objectPool.js +54 -54
  45. package/src/js/lib/time.js +18 -18
  46. package/src/js/lib/tween.js +147 -147
  47. package/src/js/modules/_info.js +11 -11
  48. package/src/js/modules/assets/_info.js +7 -7
  49. package/src/js/modules/assets/baseModel.js +18 -18
  50. package/src/js/modules/assets/config.js +35 -35
  51. package/src/js/modules/assets/controller.js +37 -37
  52. package/src/js/modules/assets/models/_info.js +12 -12
  53. package/src/js/modules/assets/models/atlas.js +8 -8
  54. package/src/js/modules/assets/models/audiosprite.js +27 -27
  55. package/src/js/modules/assets/models/bitmapFont.js +8 -8
  56. package/src/js/modules/assets/models/container.js +16 -16
  57. package/src/js/modules/assets/models/dragonBones.js +26 -26
  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 +330 -330
  64. package/src/js/modules/instances/_info.js +3 -3
  65. package/src/js/modules/instances/controller.js +218 -218
  66. package/src/js/modules/logic/_info.js +5 -5
  67. package/src/js/modules/logic/buttons.js +120 -120
  68. package/src/js/modules/logic/config/_info.js +3 -3
  69. package/src/js/modules/logic/config/buttons.js +63 -63
  70. package/src/js/modules/logic/config/sounds.js +23 -23
  71. package/src/js/modules/logic/controller.js +48 -48
  72. package/src/js/modules/logic/sounds.js +96 -96
  73. package/src/js/modules/objects/_info.js +11 -11
  74. package/src/js/modules/objects/baseModel.js +161 -161
  75. package/src/js/modules/objects/cache.js +99 -99
  76. package/src/js/modules/objects/controller.js +115 -115
  77. package/src/js/modules/objects/create.js +246 -246
  78. package/src/js/modules/objects/find.js +140 -140
  79. package/src/js/modules/objects/models/_info.js +25 -25
  80. package/src/js/modules/objects/models/atlasImage.js +50 -50
  81. package/src/js/modules/objects/models/bitmapText.js +23 -23
  82. package/src/js/modules/objects/models/button.js +184 -184
  83. package/src/js/modules/objects/models/buttonComposite.js +35 -35
  84. package/src/js/modules/objects/models/checkbox.js +95 -96
  85. package/src/js/modules/objects/models/collection.js +54 -54
  86. package/src/js/modules/objects/models/component.js +44 -44
  87. package/src/js/modules/objects/models/container.js +19 -19
  88. package/src/js/modules/objects/models/dragonBones.js +250 -250
  89. package/src/js/modules/objects/models/emitter.js +54 -54
  90. package/src/js/modules/objects/models/graphics.js +38 -38
  91. package/src/js/modules/objects/models/group.js +19 -19
  92. package/src/js/modules/objects/models/hitArea.js +104 -104
  93. package/src/js/modules/objects/models/image.js +34 -34
  94. package/src/js/modules/objects/models/imagesAnimation.js +113 -113
  95. package/src/js/modules/objects/models/mask.js +38 -38
  96. package/src/js/modules/objects/models/scrollbox.js +61 -61
  97. package/src/js/modules/objects/models/slider.js +199 -154
  98. package/src/js/modules/objects/models/spine.js +83 -83
  99. package/src/js/modules/objects/models/text.js +38 -38
  100. package/src/js/modules/objects/models/textInput.js +55 -55
  101. package/src/js/modules/objects/models/toggle.js +169 -169
  102. package/src/js/modules/objects/models/world.js +19 -19
  103. package/src/js/modules/objects/propertyAdapter.js +421 -421
  104. package/src/js/modules/objects/proxy.js +179 -179
  105. package/src/js/modules/objects/styles.js +116 -116
  106. package/src/js/modules/observer/_info.js +4 -4
  107. package/src/js/modules/observer/controller.js +99 -99
  108. package/src/js/modules/observer/events.js +32 -32
  109. package/src/js/modules/scenes/_info.js +8 -8
  110. package/src/js/modules/scenes/controller.js +34 -34
  111. package/src/js/modules/scenes/model.js +35 -35
  112. package/src/js/modules/scenes/pixiWrapper.js +194 -194
  113. package/src/js/modules/scenes/resolutions.js +161 -161
  114. package/src/js/modules/scenes/resolutionsConfig.js +73 -73
  115. package/src/js/modules/scenes/service.js +84 -84
  116. package/src/js/modules/soundManager/_info.js +3 -3
  117. package/src/js/modules/soundManager/controller.js +99 -99
  118. package/src/js/modules/soundManager/soundSprite.js +202 -202
  119. package/src/js/modules/statesManager/_info.js +12 -12
  120. package/src/js/modules/statesManager/action.js +55 -55
  121. package/src/js/modules/statesManager/actions/_info.js +3 -3
  122. package/src/js/modules/statesManager/all.js +23 -23
  123. package/src/js/modules/statesManager/configStates.js +71 -71
  124. package/src/js/modules/statesManager/controller.js +132 -132
  125. package/src/js/modules/statesManager/functionsStorage.js +82 -82
  126. package/src/js/modules/statesManager/helper.js +27 -27
  127. package/src/js/modules/statesManager/race.js +75 -75
  128. package/src/js/modules/statesManager/sequence.js +47 -47
  129. package/src/js/modules/template/_info.js +6 -6
  130. package/src/js/modules/template/controller.js +28 -28
  131. package/src/js/modules/template/model.js +11 -11
  132. package/src/js/modules/template/service.js +125 -125
  133. package/src/js/modules/template/types.js +46 -46
  134. package/src/js/modules/transport/_info.js +8 -8
  135. package/src/js/modules/transport/baseConnectionType.js +24 -24
  136. package/src/js/modules/transport/config.js +22 -22
  137. package/src/js/modules/transport/connectionTypes/_info.js +3 -3
  138. package/src/js/modules/transport/connectionTypes/websocket.js +74 -74
  139. package/src/js/modules/transport/connectionTypes/xhr.js +41 -41
  140. package/src/js/modules/transport/controller.js +48 -48
  141. package/src/js/modules/transport/decorator.js +16 -16
  142. package/src/js/modules/transport/service.js +138 -138
  143. package/src/js/templates/_info.js +4 -4
  144. package/src/js/templates/groups/_info.js +1 -1
  145. package/src/js/templates/scenes/_info.js +1 -1
  146. package/webpack.config.js +47 -47
@@ -1,161 +1,161 @@
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._currentOrientation = null;
8
-
9
- this.refreshSceneSize = this.refreshSceneSize.bind(this);
10
- this.refreshSceneSize();
11
-
12
- //TODO optimization (performance)
13
- /*if (devicePixelRatio > 2)
14
- devicePixelRatio = 2;*/ // when we are calculating canvas size
15
- }
16
-
17
- _subscribeOnce() {
18
- this.addListener(Urso.events.EXTRA_BROWSEREVENTS_WINDOW_RESIZE, this.refreshSceneSize, true);
19
- this.addListener(Urso.events.MODULES_SCENES_NEW_SCENE_INIT, this.refreshSceneSize, true);
20
- }
21
-
22
- getTemplateSize() {
23
- return this._templateSize;
24
- }
25
-
26
- refreshSceneSize() {
27
- let windowSize = this._getWindowSize();
28
- let orientation = this._getOrientation(windowSize);
29
- let configResolution = this._getResolutionConfig(windowSize);
30
-
31
- let windowRatio = windowSize.width / windowSize.height;
32
- let optimalRatio = this._getOptimalRatio(configResolution, windowRatio, orientation);
33
-
34
- let currentResolution = Urso.helper.objectClone(configResolution);
35
- currentResolution.name = 'currentResolution';
36
- currentResolution.base = configResolution;
37
- currentResolution.width = (optimalRatio > windowRatio) ? Math.floor(windowSize.width) : Math.floor(Math.floor(windowSize.height) * optimalRatio);
38
- currentResolution.height = (optimalRatio > windowRatio) ? Math.floor(Math.floor(windowSize.width) / optimalRatio) : Math.floor(windowSize.height);
39
-
40
- this._templateSize = this._calculateTemplateSize(currentResolution);
41
- this._applyResolutionToPixi(currentResolution);
42
-
43
- console.log('[SCENE] New Resolution', currentResolution, 'windowSize:', windowSize);
44
- console.log('[SCENE] New Template Size', this._templateSize);
45
-
46
- this.emit(Urso.events.MODULES_SCENES_NEW_RESOLUTION, { resolution: currentResolution, template: this._templateSize });
47
-
48
- if (this._currentOrientation !== this._templateSize.orientation) {
49
- this._currentOrientation = this._templateSize.orientation;
50
- this.emit(Urso.events.MODULES_SCENES_ORIENTATION_CHANGE, this._templateSize.orientation);
51
- }
52
-
53
- return true;
54
- };
55
-
56
- _getWindowSize() {
57
- const iOS = Urso.device.iOS;
58
- const { width, height } = document.body.getBoundingClientRect();
59
-
60
- let windowSize = {
61
- width: iOS ? window.innerWidth : width,
62
- height: iOS ? window.innerHeight : height
63
- };
64
-
65
- if (window.devicePixelRatio && window.devicePixelRatio !== 1) {
66
- windowSize.width *= window.devicePixelRatio;
67
- windowSize.height *= window.devicePixelRatio;
68
- }
69
-
70
- return windowSize;
71
- }
72
-
73
- _getOrientation(windowSize) {
74
- return windowSize.width > windowSize.height ? 'landscape' : 'portrait'; //todo move to constants
75
- }
76
-
77
- _getResolutionConfig(windowSize) {
78
- let orientation = this._getOrientation(windowSize);
79
- let mainDimension = windowSize.width > windowSize.height ? 'width' : 'height'; //todo move to constants
80
- let config = this.getInstance('ResolutionsConfig').get();
81
- let currentResolution = config[0];
82
-
83
- //select optimal resolution from config
84
- for (let resolution of config) {
85
- if (resolution.orientation !== orientation)
86
- continue;
87
-
88
- if (
89
- (currentResolution.orientation !== orientation) ||
90
- (
91
- currentResolution[mainDimension] < resolution[mainDimension] &&
92
- resolution[mainDimension] < windowSize[mainDimension]
93
- ) ||
94
- (
95
- windowSize[mainDimension] < currentResolution[mainDimension] &&
96
- resolution[mainDimension] < currentResolution[mainDimension]
97
- )
98
- )
99
- currentResolution = resolution;
100
- }
101
-
102
- return currentResolution;
103
- }
104
-
105
- _getOptimalRatio(configResolution, windowRatio, orientation) {
106
- let optimalRatio = configResolution.width / configResolution.height;
107
-
108
- if (configResolution.adaptive) {
109
- let display = !Urso.helper.mobileAndTabletCheck() ? 'desktop' : 'mobile'; //todo move to constants
110
- let adaptiveParams = this.getInstance('ResolutionsConfig').getAdaptive()[display];
111
-
112
- if (adaptiveParams.supported) {
113
- let limits = adaptiveParams.limits[orientation];
114
- optimalRatio = Urso.math.intMakeBetween(windowRatio, limits.min, limits.max);
115
- }
116
- }
117
-
118
- return optimalRatio;
119
- }
120
-
121
- _calculateTemplateSize(resolution) {
122
- this._templateSize.orientation = resolution.orientation;
123
- this._templateSize.width = resolution.base.width;
124
- this._templateSize.height = resolution.base.height;
125
-
126
- let dimensionsArray = ['width', 'height'];
127
-
128
- //adaptive corrections
129
- if (resolution.adaptive) {
130
- let dimensionsPassiveKey = (resolution.width / resolution.height > resolution.base.width / resolution.base.height) ? 0 : 1;
131
- let dimensionsMainKey = (dimensionsPassiveKey === 1) ? 0 : 1;
132
-
133
- this._templateSize[dimensionsArray[dimensionsPassiveKey]] =
134
- ~~(
135
- resolution[dimensionsArray[dimensionsPassiveKey]] *
136
- resolution.base[dimensionsArray[dimensionsMainKey]] / resolution[dimensionsArray[dimensionsMainKey]]
137
- );
138
- }
139
-
140
- return this._templateSize;
141
- }
142
-
143
- _applyResolutionToPixi(resolution) {
144
- let maxResolutionFactor = Math.min(this.getInstance('ResolutionsConfig').maxSize() / Math.max(resolution.width, resolution.height), 1);
145
- let dp = window.devicePixelRatio;
146
- let canvasSize = {
147
- width: ~~(resolution.width * maxResolutionFactor),
148
- height: ~~(resolution.height * maxResolutionFactor)
149
- };
150
-
151
- this.getInstance('PixiWrapper').resize(canvasSize.width, canvasSize.height);
152
- this.getInstance('PixiWrapper').setWorldScale(canvasSize.width / this._templateSize.width, canvasSize.height / this._templateSize.height);
153
- this.getInstance('PixiWrapper').setCanvasWidth(resolution.width / dp);
154
- this.getInstance('PixiWrapper').setCanvasHeight(resolution.height / dp);
155
-
156
- this._activeResolution = resolution;
157
- return true;
158
- };
159
- }
160
-
161
- 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._currentOrientation = null;
8
+
9
+ this.refreshSceneSize = this.refreshSceneSize.bind(this);
10
+ this.refreshSceneSize();
11
+
12
+ //TODO optimization (performance)
13
+ /*if (devicePixelRatio > 2)
14
+ devicePixelRatio = 2;*/ // when we are calculating canvas size
15
+ }
16
+
17
+ _subscribeOnce() {
18
+ this.addListener(Urso.events.EXTRA_BROWSEREVENTS_WINDOW_RESIZE, this.refreshSceneSize, true);
19
+ this.addListener(Urso.events.MODULES_SCENES_NEW_SCENE_INIT, this.refreshSceneSize, true);
20
+ }
21
+
22
+ getTemplateSize() {
23
+ return this._templateSize;
24
+ }
25
+
26
+ refreshSceneSize() {
27
+ let windowSize = this._getWindowSize();
28
+ let orientation = this._getOrientation(windowSize);
29
+ let configResolution = this._getResolutionConfig(windowSize);
30
+
31
+ let windowRatio = windowSize.width / windowSize.height;
32
+ let optimalRatio = this._getOptimalRatio(configResolution, windowRatio, orientation);
33
+
34
+ let currentResolution = Urso.helper.objectClone(configResolution);
35
+ currentResolution.name = 'currentResolution';
36
+ currentResolution.base = configResolution;
37
+ currentResolution.width = (optimalRatio > windowRatio) ? Math.floor(windowSize.width) : Math.floor(Math.floor(windowSize.height) * optimalRatio);
38
+ currentResolution.height = (optimalRatio > windowRatio) ? Math.floor(Math.floor(windowSize.width) / optimalRatio) : Math.floor(windowSize.height);
39
+
40
+ this._templateSize = this._calculateTemplateSize(currentResolution);
41
+ this._applyResolutionToPixi(currentResolution);
42
+
43
+ console.log('[SCENE] New Resolution', currentResolution, 'windowSize:', windowSize);
44
+ console.log('[SCENE] New Template Size', this._templateSize);
45
+
46
+ this.emit(Urso.events.MODULES_SCENES_NEW_RESOLUTION, { resolution: currentResolution, template: this._templateSize });
47
+
48
+ if (this._currentOrientation !== this._templateSize.orientation) {
49
+ this._currentOrientation = this._templateSize.orientation;
50
+ this.emit(Urso.events.MODULES_SCENES_ORIENTATION_CHANGE, this._templateSize.orientation);
51
+ }
52
+
53
+ return true;
54
+ };
55
+
56
+ _getWindowSize() {
57
+ const iOS = Urso.device.iOS;
58
+ const { width, height } = document.body.getBoundingClientRect();
59
+
60
+ let windowSize = {
61
+ width: iOS ? window.innerWidth : width,
62
+ height: iOS ? window.innerHeight : height
63
+ };
64
+
65
+ if (window.devicePixelRatio && window.devicePixelRatio !== 1) {
66
+ windowSize.width *= window.devicePixelRatio;
67
+ windowSize.height *= window.devicePixelRatio;
68
+ }
69
+
70
+ return windowSize;
71
+ }
72
+
73
+ _getOrientation(windowSize) {
74
+ return windowSize.width > windowSize.height ? 'landscape' : 'portrait'; //todo move to constants
75
+ }
76
+
77
+ _getResolutionConfig(windowSize) {
78
+ let orientation = this._getOrientation(windowSize);
79
+ let mainDimension = windowSize.width > windowSize.height ? 'width' : 'height'; //todo move to constants
80
+ let config = this.getInstance('ResolutionsConfig').get();
81
+ let currentResolution = config[0];
82
+
83
+ //select optimal resolution from config
84
+ for (let resolution of config) {
85
+ if (resolution.orientation !== orientation)
86
+ continue;
87
+
88
+ if (
89
+ (currentResolution.orientation !== orientation) ||
90
+ (
91
+ currentResolution[mainDimension] < resolution[mainDimension] &&
92
+ resolution[mainDimension] < windowSize[mainDimension]
93
+ ) ||
94
+ (
95
+ windowSize[mainDimension] < currentResolution[mainDimension] &&
96
+ resolution[mainDimension] < currentResolution[mainDimension]
97
+ )
98
+ )
99
+ currentResolution = resolution;
100
+ }
101
+
102
+ return currentResolution;
103
+ }
104
+
105
+ _getOptimalRatio(configResolution, windowRatio, orientation) {
106
+ let optimalRatio = configResolution.width / configResolution.height;
107
+
108
+ if (configResolution.adaptive) {
109
+ let display = !Urso.helper.mobileAndTabletCheck() ? 'desktop' : 'mobile'; //todo move to constants
110
+ let adaptiveParams = this.getInstance('ResolutionsConfig').getAdaptive()[display];
111
+
112
+ if (adaptiveParams.supported) {
113
+ let limits = adaptiveParams.limits[orientation];
114
+ optimalRatio = Urso.math.intMakeBetween(windowRatio, limits.min, limits.max);
115
+ }
116
+ }
117
+
118
+ return optimalRatio;
119
+ }
120
+
121
+ _calculateTemplateSize(resolution) {
122
+ this._templateSize.orientation = resolution.orientation;
123
+ this._templateSize.width = resolution.base.width;
124
+ this._templateSize.height = resolution.base.height;
125
+
126
+ let dimensionsArray = ['width', 'height'];
127
+
128
+ //adaptive corrections
129
+ if (resolution.adaptive) {
130
+ let dimensionsPassiveKey = (resolution.width / resolution.height > resolution.base.width / resolution.base.height) ? 0 : 1;
131
+ let dimensionsMainKey = (dimensionsPassiveKey === 1) ? 0 : 1;
132
+
133
+ this._templateSize[dimensionsArray[dimensionsPassiveKey]] =
134
+ ~~(
135
+ resolution[dimensionsArray[dimensionsPassiveKey]] *
136
+ resolution.base[dimensionsArray[dimensionsMainKey]] / resolution[dimensionsArray[dimensionsMainKey]]
137
+ );
138
+ }
139
+
140
+ return this._templateSize;
141
+ }
142
+
143
+ _applyResolutionToPixi(resolution) {
144
+ let maxResolutionFactor = Math.min(this.getInstance('ResolutionsConfig').maxSize() / Math.max(resolution.width, resolution.height), 1);
145
+ let dp = window.devicePixelRatio;
146
+ let canvasSize = {
147
+ width: ~~(resolution.width * maxResolutionFactor),
148
+ height: ~~(resolution.height * maxResolutionFactor)
149
+ };
150
+
151
+ this.getInstance('PixiWrapper').resize(canvasSize.width, canvasSize.height);
152
+ this.getInstance('PixiWrapper').setWorldScale(canvasSize.width / this._templateSize.width, canvasSize.height / this._templateSize.height);
153
+ this.getInstance('PixiWrapper').setCanvasWidth(resolution.width / dp);
154
+ this.getInstance('PixiWrapper').setCanvasHeight(resolution.height / dp);
155
+
156
+ this._activeResolution = resolution;
157
+ return true;
158
+ };
159
+ }
160
+
161
+ 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,84 @@
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
+ 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,4 +1,4 @@
1
- Urso.Core.Modules.SoundManager = {
2
- Controller: require('./controller.js'),
3
- SoundSprite: require('./soundSprite.js')
1
+ Urso.Core.Modules.SoundManager = {
2
+ Controller: require('./controller.js'),
3
+ SoundSprite: require('./soundSprite.js')
4
4
  };