@urso/core 0.5.9 → 0.5.12

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 (159) hide show
  1. package/.babelrc +11 -11
  2. package/LICENSE +20 -20
  3. package/README.md +220 -220
  4. package/build/js/index.js +1 -1
  5. package/build/js/index.js.LICENSE.txt +222 -38
  6. package/package.json +52 -52
  7. package/src/js/app.js +78 -78
  8. package/src/js/components/_info.js +10 -10
  9. package/src/js/components/base/_info.js +3 -3
  10. package/src/js/components/base/controller.js +78 -78
  11. package/src/js/components/debug/_info.js +7 -7
  12. package/src/js/components/debug/controller.js +38 -38
  13. package/src/js/components/debug/coords.js +23 -23
  14. package/src/js/components/debug/fps.js +34 -34
  15. package/src/js/components/debug/template.js +55 -55
  16. package/src/js/components/debug/timescale.js +60 -60
  17. package/src/js/components/deviceRotate/_info.js +3 -3
  18. package/src/js/components/deviceRotate/controller.js +86 -86
  19. package/src/js/components/fullscreen/_info.js +6 -6
  20. package/src/js/components/fullscreen/android.js +104 -104
  21. package/src/js/components/fullscreen/controller.js +76 -76
  22. package/src/js/components/fullscreen/desktop.js +49 -49
  23. package/src/js/components/fullscreen/ios.js +115 -115
  24. package/src/js/components/layersSwitcher/_info.js +4 -4
  25. package/src/js/components/layersSwitcher/config.js +26 -26
  26. package/src/js/components/layersSwitcher/controller.js +34 -34
  27. package/src/js/components/loader/_info.js +4 -4
  28. package/src/js/components/loader/controller.js +65 -65
  29. package/src/js/components/loader/template.js +70 -70
  30. package/src/js/components/soundInitialPopup/_info.js +3 -3
  31. package/src/js/components/soundInitialPopup/controller.js +42 -42
  32. package/src/js/components/soundInitialPopup/template.js +109 -109
  33. package/src/js/components/stateDriven/_info.js +3 -3
  34. package/src/js/components/stateDriven/controller.js +118 -118
  35. package/src/js/config/load.js +5 -5
  36. package/src/js/config/main.js +12 -12
  37. package/src/js/extra/_info.js +26 -26
  38. package/src/js/extra/browserEvents.js +51 -51
  39. package/src/js/extra/pixiPatch.js +148 -79
  40. package/src/js/extra/setTimeout.js +7 -7
  41. package/src/js/index.js +8 -8
  42. package/src/js/lib/_info.js +13 -13
  43. package/src/js/lib/cache.js +105 -105
  44. package/src/js/lib/composition.js +85 -85
  45. package/src/js/lib/device.js +1286 -1286
  46. package/src/js/lib/helper.js +539 -539
  47. package/src/js/lib/loader.js +136 -136
  48. package/src/js/lib/localData.js +15 -15
  49. package/src/js/lib/logger.js +69 -69
  50. package/src/js/lib/math.js +35 -35
  51. package/src/js/lib/objectPool.js +54 -54
  52. package/src/js/lib/time.js +18 -18
  53. package/src/js/lib/tween.js +147 -147
  54. package/src/js/modules/_info.js +12 -12
  55. package/src/js/modules/assets/_info.js +7 -7
  56. package/src/js/modules/assets/baseModel.js +18 -18
  57. package/src/js/modules/assets/config.js +37 -37
  58. package/src/js/modules/assets/controller.js +46 -46
  59. package/src/js/modules/assets/models/_info.js +11 -11
  60. package/src/js/modules/assets/models/atlas.js +8 -8
  61. package/src/js/modules/assets/models/audiosprite.js +27 -27
  62. package/src/js/modules/assets/models/bitmapFont.js +8 -8
  63. package/src/js/modules/assets/models/container.js +16 -16
  64. package/src/js/modules/assets/models/font.js +8 -8
  65. package/src/js/modules/assets/models/image.js +13 -13
  66. package/src/js/modules/assets/models/json.js +8 -8
  67. package/src/js/modules/assets/models/sound.js +14 -14
  68. package/src/js/modules/assets/models/spine.js +14 -14
  69. package/src/js/modules/assets/service.js +365 -365
  70. package/src/js/modules/i18n/_info.js +4 -4
  71. package/src/js/modules/i18n/config.js +17 -17
  72. package/src/js/modules/i18n/controller.js +79 -79
  73. package/src/js/modules/instances/_info.js +3 -3
  74. package/src/js/modules/instances/controller.js +261 -261
  75. package/src/js/modules/logic/_info.js +4 -4
  76. package/src/js/modules/logic/config/_info.js +2 -2
  77. package/src/js/modules/logic/config/sounds.js +23 -23
  78. package/src/js/modules/logic/controller.js +48 -48
  79. package/src/js/modules/logic/sounds.js +103 -103
  80. package/src/js/modules/objects/_info.js +13 -13
  81. package/src/js/modules/objects/baseModel.js +198 -197
  82. package/src/js/modules/objects/cache.js +99 -99
  83. package/src/js/modules/objects/controller.js +131 -131
  84. package/src/js/modules/objects/find.js +58 -58
  85. package/src/js/modules/objects/models/_info.js +27 -27
  86. package/src/js/modules/objects/models/atlasImage.js +50 -50
  87. package/src/js/modules/objects/models/bitmapText.js +37 -37
  88. package/src/js/modules/objects/models/button.js +189 -189
  89. package/src/js/modules/objects/models/buttonComposite.js +35 -35
  90. package/src/js/modules/objects/models/checkbox.js +96 -96
  91. package/src/js/modules/objects/models/collection.js +54 -54
  92. package/src/js/modules/objects/models/component.js +44 -44
  93. package/src/js/modules/objects/models/container.js +19 -19
  94. package/src/js/modules/objects/models/dragContainer.js +675 -675
  95. package/src/js/modules/objects/models/emitter.js +67 -67
  96. package/src/js/modules/objects/models/emitterFx.js +99 -99
  97. package/src/js/modules/objects/models/graphics.js +38 -38
  98. package/src/js/modules/objects/models/group.js +19 -19
  99. package/src/js/modules/objects/models/hitArea.js +104 -104
  100. package/src/js/modules/objects/models/image.js +34 -34
  101. package/src/js/modules/objects/models/imagesAnimation.js +113 -113
  102. package/src/js/modules/objects/models/mask.js +38 -38
  103. package/src/js/modules/objects/models/nineSlicePlane.js +30 -30
  104. package/src/js/modules/objects/models/scrollbox.js +64 -64
  105. package/src/js/modules/objects/models/slider.js +253 -253
  106. package/src/js/modules/objects/models/spine.js +276 -276
  107. package/src/js/modules/objects/models/text.js +59 -59
  108. package/src/js/modules/objects/models/textInput.js +66 -66
  109. package/src/js/modules/objects/models/toggle.js +180 -180
  110. package/src/js/modules/objects/models/world.js +19 -19
  111. package/src/js/modules/objects/propertyAdapter.js +587 -424
  112. package/src/js/modules/objects/proxy.js +294 -294
  113. package/src/js/modules/objects/selector.js +136 -136
  114. package/src/js/modules/objects/service.js +242 -242
  115. package/src/js/modules/objects/styles.js +210 -210
  116. package/src/js/modules/observer/_info.js +4 -4
  117. package/src/js/modules/observer/controller.js +99 -99
  118. package/src/js/modules/observer/events.js +51 -51
  119. package/src/js/modules/scenes/_info.js +8 -8
  120. package/src/js/modules/scenes/controller.js +103 -103
  121. package/src/js/modules/scenes/model.js +28 -28
  122. package/src/js/modules/scenes/pixiWrapper.js +237 -237
  123. package/src/js/modules/scenes/resolutions.js +173 -173
  124. package/src/js/modules/scenes/resolutionsConfig.js +73 -73
  125. package/src/js/modules/scenes/service.js +142 -142
  126. package/src/js/modules/soundManager/_info.js +3 -3
  127. package/src/js/modules/soundManager/controller.js +100 -100
  128. package/src/js/modules/soundManager/soundSprite.js +250 -250
  129. package/src/js/modules/statesManager/_info.js +12 -12
  130. package/src/js/modules/statesManager/action.js +60 -60
  131. package/src/js/modules/statesManager/actions/_info.js +3 -3
  132. package/src/js/modules/statesManager/all.js +23 -23
  133. package/src/js/modules/statesManager/configStates.js +71 -71
  134. package/src/js/modules/statesManager/controller.js +170 -170
  135. package/src/js/modules/statesManager/functionsStorage.js +82 -82
  136. package/src/js/modules/statesManager/helper.js +27 -27
  137. package/src/js/modules/statesManager/race.js +75 -75
  138. package/src/js/modules/statesManager/sequence.js +47 -47
  139. package/src/js/modules/template/_info.js +6 -6
  140. package/src/js/modules/template/controller.js +28 -28
  141. package/src/js/modules/template/model.js +11 -11
  142. package/src/js/modules/template/service.js +137 -137
  143. package/src/js/modules/template/types.js +46 -46
  144. package/src/js/modules/transport/_info.js +8 -8
  145. package/src/js/modules/transport/baseConnectionType.js +24 -24
  146. package/src/js/modules/transport/config.js +13 -13
  147. package/src/js/modules/transport/connectionTypes/_info.js +3 -3
  148. package/src/js/modules/transport/connectionTypes/websocket.js +74 -74
  149. package/src/js/modules/transport/connectionTypes/xhr.js +44 -44
  150. package/src/js/modules/transport/controller.js +48 -48
  151. package/src/js/modules/transport/decorator.js +17 -17
  152. package/src/js/modules/transport/service.js +153 -153
  153. package/src/js/templates/_info.js +4 -4
  154. package/src/js/templates/groups/_info.js +1 -1
  155. package/src/js/templates/scenes/_info.js +1 -1
  156. package/webpack.config.js +47 -47
  157. package/src/js/components/editor/_info.js +0 -4
  158. package/src/js/components/editor/api.js +0 -72
  159. package/src/js/components/editor/controller.js +0 -13
@@ -1,173 +1,173 @@
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.preResize = this.preResize.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_PRE_RESIZE, this.preResize, true);
20
- this.addListener(Urso.events.EXTRA_BROWSEREVENTS_WINDOW_RESIZE, this.refreshSceneSize, true);
21
- this.addListener(Urso.events.MODULES_SCENES_NEW_SCENE_INIT, this.refreshSceneSize, true);
22
- }
23
-
24
- getTemplateSize() {
25
- return this._templateSize;
26
- }
27
-
28
- preResize() {
29
- if (Urso.helper.mobileAndTabletCheck())
30
- this.getInstance('PixiWrapper').hideCanvas();
31
- }
32
-
33
- refreshSceneSize() {
34
- let windowSize = this._getWindowSize();
35
- let orientation = this._getOrientation(windowSize);
36
- let configResolution = this._getResolutionConfig(windowSize);
37
-
38
- let windowRatio = windowSize.width / windowSize.height;
39
- let optimalRatio = this._getOptimalRatio(configResolution, windowRatio, orientation);
40
-
41
- let currentResolution = Urso.helper.objectClone(configResolution);
42
- currentResolution.name = 'currentResolution';
43
- currentResolution.base = configResolution;
44
- currentResolution.width = (optimalRatio > windowRatio) ? Math.floor(windowSize.width) : Math.floor(Math.floor(windowSize.height) * optimalRatio);
45
- currentResolution.height = (optimalRatio > windowRatio) ? Math.floor(Math.floor(windowSize.width) / optimalRatio) : Math.floor(windowSize.height);
46
-
47
- this._templateSize = this._calculateTemplateSize(currentResolution);
48
- this._applyResolutionToPixi(currentResolution);
49
-
50
- console.log('[SCENE] New Orientation', orientation);
51
- console.log('[SCENE] New Resolution', currentResolution, 'windowSize:', windowSize);
52
- console.log('[SCENE] New Template Size', this._templateSize);
53
-
54
- if (this._currentOrientation !== this._templateSize.orientation) {
55
- this._currentOrientation = this._templateSize.orientation;
56
-
57
- //update InstancesModes
58
- Object.values(Urso.device.ScreenOrientation).forEach((orientationValue) => Urso.removeInstancesMode(orientationValue + 'Orientation', true));
59
- Urso.addInstancesMode(this._templateSize.orientation + 'Orientation');
60
-
61
- this.emit(Urso.events.MODULES_SCENES_ORIENTATION_CHANGE, this._templateSize.orientation);
62
- }
63
-
64
- //send new resolution event
65
- this.emit(Urso.events.MODULES_SCENES_NEW_RESOLUTION, { resolution: currentResolution, template: this._templateSize });
66
-
67
- return true;
68
- };
69
-
70
- _getWindowSize() {
71
- let windowSize = {
72
- width: window.innerWidth,
73
- height: window.innerHeight
74
- };
75
-
76
- if (window.devicePixelRatio && window.devicePixelRatio !== 1) {
77
- windowSize.width *= window.devicePixelRatio;
78
- windowSize.height *= window.devicePixelRatio;
79
- }
80
-
81
- return windowSize;
82
- }
83
-
84
- _getOrientation(windowSize) {
85
- return windowSize.width > windowSize.height ? Urso.device.ScreenOrientation.LANDSCAPE : Urso.device.ScreenOrientation.PORTRAIT;
86
- }
87
-
88
- _getResolutionConfig(windowSize) {
89
- let orientation = this._getOrientation(windowSize);
90
- let mainDimension = windowSize.width > windowSize.height ? 'width' : 'height'; //todo move to constants
91
- let config = this.getInstance('ResolutionsConfig').get();
92
- let currentResolution = config[0];
93
-
94
- //select optimal resolution from config
95
- for (let resolution of config) {
96
- if (resolution.orientation !== orientation)
97
- continue;
98
-
99
- if (
100
- (currentResolution.orientation !== orientation) ||
101
- (
102
- currentResolution[mainDimension] < resolution[mainDimension] &&
103
- resolution[mainDimension] < windowSize[mainDimension]
104
- ) ||
105
- (
106
- windowSize[mainDimension] < currentResolution[mainDimension] &&
107
- resolution[mainDimension] < currentResolution[mainDimension]
108
- )
109
- )
110
- currentResolution = resolution;
111
- }
112
-
113
- return currentResolution;
114
- }
115
-
116
- _getOptimalRatio(configResolution, windowRatio, orientation) {
117
- let optimalRatio = configResolution.width / configResolution.height;
118
-
119
- if (configResolution.adaptive) {
120
- let display = !Urso.helper.mobileAndTabletCheck() ? 'desktop' : 'mobile'; //todo move to constants
121
- let adaptiveParams = this.getInstance('ResolutionsConfig').getAdaptive()[display];
122
-
123
- if (adaptiveParams.supported) {
124
- let limits = adaptiveParams.limits[orientation];
125
- optimalRatio = Urso.math.intMakeBetween(windowRatio, limits.min, limits.max);
126
- }
127
- }
128
-
129
- return optimalRatio;
130
- }
131
-
132
- _calculateTemplateSize(resolution) {
133
- this._templateSize.orientation = resolution.orientation;
134
- this._templateSize.width = resolution.base.width;
135
- this._templateSize.height = resolution.base.height;
136
-
137
- let dimensionsArray = ['width', 'height'];
138
-
139
- //adaptive corrections
140
- if (resolution.adaptive) {
141
- let dimensionsPassiveKey = (resolution.width / resolution.height > resolution.base.width / resolution.base.height) ? 0 : 1;
142
- let dimensionsMainKey = (dimensionsPassiveKey === 1) ? 0 : 1;
143
-
144
- this._templateSize[dimensionsArray[dimensionsPassiveKey]] =
145
- ~~(
146
- resolution[dimensionsArray[dimensionsPassiveKey]] *
147
- resolution.base[dimensionsArray[dimensionsMainKey]] / resolution[dimensionsArray[dimensionsMainKey]]
148
- );
149
- }
150
-
151
- return this._templateSize;
152
- }
153
-
154
- _applyResolutionToPixi(resolution) {
155
- let maxResolutionFactor = Math.min(this.getInstance('ResolutionsConfig').maxSize() / Math.max(resolution.width, resolution.height), 1);
156
- let dp = window.devicePixelRatio;
157
- let canvasSize = {
158
- width: ~~(resolution.width * maxResolutionFactor),
159
- height: ~~(resolution.height * maxResolutionFactor)
160
- };
161
-
162
- this.getInstance('PixiWrapper').showCanvas();
163
- this.getInstance('PixiWrapper').resize(canvasSize.width, canvasSize.height);
164
- this.getInstance('PixiWrapper').setWorldScale(canvasSize.width / this._templateSize.width, canvasSize.height / this._templateSize.height);
165
- this.getInstance('PixiWrapper').setCanvasWidth(resolution.width / dp);
166
- this.getInstance('PixiWrapper').setCanvasHeight(resolution.height / dp);
167
-
168
- this._activeResolution = resolution;
169
- return true;
170
- };
171
- }
172
-
173
- 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.preResize = this.preResize.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_PRE_RESIZE, this.preResize, true);
20
+ this.addListener(Urso.events.EXTRA_BROWSEREVENTS_WINDOW_RESIZE, this.refreshSceneSize, true);
21
+ this.addListener(Urso.events.MODULES_SCENES_NEW_SCENE_INIT, this.refreshSceneSize, true);
22
+ }
23
+
24
+ getTemplateSize() {
25
+ return this._templateSize;
26
+ }
27
+
28
+ preResize() {
29
+ if (Urso.helper.mobileAndTabletCheck())
30
+ this.getInstance('PixiWrapper').hideCanvas();
31
+ }
32
+
33
+ refreshSceneSize() {
34
+ let windowSize = this._getWindowSize();
35
+ let orientation = this._getOrientation(windowSize);
36
+ let configResolution = this._getResolutionConfig(windowSize);
37
+
38
+ let windowRatio = windowSize.width / windowSize.height;
39
+ let optimalRatio = this._getOptimalRatio(configResolution, windowRatio, orientation);
40
+
41
+ let currentResolution = Urso.helper.objectClone(configResolution);
42
+ currentResolution.name = 'currentResolution';
43
+ currentResolution.base = configResolution;
44
+ currentResolution.width = (optimalRatio > windowRatio) ? Math.floor(windowSize.width) : Math.floor(Math.floor(windowSize.height) * optimalRatio);
45
+ currentResolution.height = (optimalRatio > windowRatio) ? Math.floor(Math.floor(windowSize.width) / optimalRatio) : Math.floor(windowSize.height);
46
+
47
+ this._templateSize = this._calculateTemplateSize(currentResolution);
48
+ this._applyResolutionToPixi(currentResolution);
49
+
50
+ console.log('[SCENE] New Orientation', orientation);
51
+ console.log('[SCENE] New Resolution', currentResolution, 'windowSize:', windowSize);
52
+ console.log('[SCENE] New Template Size', this._templateSize);
53
+
54
+ if (this._currentOrientation !== this._templateSize.orientation) {
55
+ this._currentOrientation = this._templateSize.orientation;
56
+
57
+ //update InstancesModes
58
+ Object.values(Urso.device.ScreenOrientation).forEach((orientationValue) => Urso.removeInstancesMode(orientationValue + 'Orientation', true));
59
+ Urso.addInstancesMode(this._templateSize.orientation + 'Orientation');
60
+
61
+ this.emit(Urso.events.MODULES_SCENES_ORIENTATION_CHANGE, this._templateSize.orientation);
62
+ }
63
+
64
+ //send new resolution event
65
+ this.emit(Urso.events.MODULES_SCENES_NEW_RESOLUTION, { resolution: currentResolution, template: this._templateSize });
66
+
67
+ return true;
68
+ };
69
+
70
+ _getWindowSize() {
71
+ let windowSize = {
72
+ width: window.innerWidth,
73
+ height: window.innerHeight
74
+ };
75
+
76
+ if (window.devicePixelRatio && window.devicePixelRatio !== 1) {
77
+ windowSize.width *= window.devicePixelRatio;
78
+ windowSize.height *= window.devicePixelRatio;
79
+ }
80
+
81
+ return windowSize;
82
+ }
83
+
84
+ _getOrientation(windowSize) {
85
+ return windowSize.width > windowSize.height ? Urso.device.ScreenOrientation.LANDSCAPE : Urso.device.ScreenOrientation.PORTRAIT;
86
+ }
87
+
88
+ _getResolutionConfig(windowSize) {
89
+ let orientation = this._getOrientation(windowSize);
90
+ let mainDimension = windowSize.width > windowSize.height ? 'width' : 'height'; //todo move to constants
91
+ let config = this.getInstance('ResolutionsConfig').get();
92
+ let currentResolution = config[0];
93
+
94
+ //select optimal resolution from config
95
+ for (let resolution of config) {
96
+ if (resolution.orientation !== orientation)
97
+ continue;
98
+
99
+ if (
100
+ (currentResolution.orientation !== orientation) ||
101
+ (
102
+ currentResolution[mainDimension] < resolution[mainDimension] &&
103
+ resolution[mainDimension] < windowSize[mainDimension]
104
+ ) ||
105
+ (
106
+ windowSize[mainDimension] < currentResolution[mainDimension] &&
107
+ resolution[mainDimension] < currentResolution[mainDimension]
108
+ )
109
+ )
110
+ currentResolution = resolution;
111
+ }
112
+
113
+ return currentResolution;
114
+ }
115
+
116
+ _getOptimalRatio(configResolution, windowRatio, orientation) {
117
+ let optimalRatio = configResolution.width / configResolution.height;
118
+
119
+ if (configResolution.adaptive) {
120
+ let display = !Urso.helper.mobileAndTabletCheck() ? 'desktop' : 'mobile'; //todo move to constants
121
+ let adaptiveParams = this.getInstance('ResolutionsConfig').getAdaptive()[display];
122
+
123
+ if (adaptiveParams.supported) {
124
+ let limits = adaptiveParams.limits[orientation];
125
+ optimalRatio = Urso.math.intMakeBetween(windowRatio, limits.min, limits.max);
126
+ }
127
+ }
128
+
129
+ return optimalRatio;
130
+ }
131
+
132
+ _calculateTemplateSize(resolution) {
133
+ this._templateSize.orientation = resolution.orientation;
134
+ this._templateSize.width = resolution.base.width;
135
+ this._templateSize.height = resolution.base.height;
136
+
137
+ let dimensionsArray = ['width', 'height'];
138
+
139
+ //adaptive corrections
140
+ if (resolution.adaptive) {
141
+ let dimensionsPassiveKey = (resolution.width / resolution.height > resolution.base.width / resolution.base.height) ? 0 : 1;
142
+ let dimensionsMainKey = (dimensionsPassiveKey === 1) ? 0 : 1;
143
+
144
+ this._templateSize[dimensionsArray[dimensionsPassiveKey]] =
145
+ ~~(
146
+ resolution[dimensionsArray[dimensionsPassiveKey]] *
147
+ resolution.base[dimensionsArray[dimensionsMainKey]] / resolution[dimensionsArray[dimensionsMainKey]]
148
+ );
149
+ }
150
+
151
+ return this._templateSize;
152
+ }
153
+
154
+ _applyResolutionToPixi(resolution) {
155
+ let maxResolutionFactor = Math.min(this.getInstance('ResolutionsConfig').maxSize() / Math.max(resolution.width, resolution.height), 1);
156
+ let dp = window.devicePixelRatio;
157
+ let canvasSize = {
158
+ width: ~~(resolution.width * maxResolutionFactor),
159
+ height: ~~(resolution.height * maxResolutionFactor)
160
+ };
161
+
162
+ this.getInstance('PixiWrapper').showCanvas();
163
+ this.getInstance('PixiWrapper').resize(canvasSize.width, canvasSize.height);
164
+ this.getInstance('PixiWrapper').setWorldScale(canvasSize.width / this._templateSize.width, canvasSize.height / this._templateSize.height);
165
+ this.getInstance('PixiWrapper').setCanvasWidth(resolution.width / dp);
166
+ this.getInstance('PixiWrapper').setCanvasHeight(resolution.height / dp);
167
+
168
+ this._activeResolution = resolution;
169
+ return true;
170
+ };
171
+ }
172
+
173
+ module.exports = ModulesScenesResolutions;
@@ -1,73 +1,73 @@
1
- class ModulesScenesResolutionsConfig {
2
- constructor() {
3
- this.singleton = true;
4
-
5
- this._orientations = [Urso.device.ScreenOrientation.LANDSCAPE, Urso.device.ScreenOrientation.PORTRAIT]; //you can use only one orientation for config contents
6
-
7
- this.contents = [
8
- {
9
- "name": 'default',
10
- "width": 1920,
11
- "height": 1080,
12
- "orientation": Urso.device.ScreenOrientation.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 = [Urso.device.ScreenOrientation.LANDSCAPE, Urso.device.ScreenOrientation.PORTRAIT]; //you can use only one orientation for config contents
6
+
7
+ this.contents = [
8
+ {
9
+ "name": 'default',
10
+ "width": 1920,
11
+ "height": 1080,
12
+ "orientation": Urso.device.ScreenOrientation.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;