@urso/core 0.5.12 → 0.6.0

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 +38 -222
  6. package/package.json +52 -52
  7. package/src/js/app.js +79 -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/editor/_info.js +4 -0
  20. package/src/js/components/editor/api.js +72 -0
  21. package/src/js/components/editor/controller.js +13 -0
  22. package/src/js/components/fullscreen/_info.js +6 -6
  23. package/src/js/components/fullscreen/android.js +104 -104
  24. package/src/js/components/fullscreen/controller.js +76 -76
  25. package/src/js/components/fullscreen/desktop.js +49 -49
  26. package/src/js/components/fullscreen/ios.js +115 -115
  27. package/src/js/components/layersSwitcher/_info.js +4 -4
  28. package/src/js/components/layersSwitcher/config.js +26 -26
  29. package/src/js/components/layersSwitcher/controller.js +34 -34
  30. package/src/js/components/loader/_info.js +4 -4
  31. package/src/js/components/loader/controller.js +65 -65
  32. package/src/js/components/loader/template.js +70 -70
  33. package/src/js/components/soundInitialPopup/_info.js +3 -3
  34. package/src/js/components/soundInitialPopup/controller.js +42 -42
  35. package/src/js/components/soundInitialPopup/template.js +109 -109
  36. package/src/js/components/stateDriven/_info.js +3 -3
  37. package/src/js/components/stateDriven/controller.js +118 -118
  38. package/src/js/config/load.js +5 -5
  39. package/src/js/config/main.js +12 -12
  40. package/src/js/extra/_info.js +26 -26
  41. package/src/js/extra/browserEvents.js +51 -51
  42. package/src/js/extra/pixiPatch.js +150 -148
  43. package/src/js/extra/setTimeout.js +7 -7
  44. package/src/js/index.js +8 -8
  45. package/src/js/lib/_info.js +13 -13
  46. package/src/js/lib/cache.js +105 -105
  47. package/src/js/lib/composition.js +85 -85
  48. package/src/js/lib/device.js +1286 -1286
  49. package/src/js/lib/helper.js +556 -539
  50. package/src/js/lib/loader.js +136 -136
  51. package/src/js/lib/localData.js +15 -15
  52. package/src/js/lib/logger.js +69 -69
  53. package/src/js/lib/math.js +35 -35
  54. package/src/js/lib/objectPool.js +203 -54
  55. package/src/js/lib/time.js +18 -18
  56. package/src/js/lib/tween.js +147 -147
  57. package/src/js/modules/_info.js +12 -12
  58. package/src/js/modules/assets/_info.js +7 -7
  59. package/src/js/modules/assets/baseModel.js +18 -18
  60. package/src/js/modules/assets/config.js +37 -37
  61. package/src/js/modules/assets/controller.js +46 -46
  62. package/src/js/modules/assets/models/_info.js +11 -11
  63. package/src/js/modules/assets/models/atlas.js +8 -8
  64. package/src/js/modules/assets/models/audiosprite.js +27 -27
  65. package/src/js/modules/assets/models/bitmapFont.js +8 -8
  66. package/src/js/modules/assets/models/container.js +16 -16
  67. package/src/js/modules/assets/models/font.js +8 -8
  68. package/src/js/modules/assets/models/image.js +15 -14
  69. package/src/js/modules/assets/models/json.js +8 -8
  70. package/src/js/modules/assets/models/sound.js +14 -14
  71. package/src/js/modules/assets/models/spine.js +14 -14
  72. package/src/js/modules/assets/service.js +366 -365
  73. package/src/js/modules/i18n/_info.js +4 -4
  74. package/src/js/modules/i18n/config.js +17 -17
  75. package/src/js/modules/i18n/controller.js +79 -79
  76. package/src/js/modules/instances/_info.js +3 -3
  77. package/src/js/modules/instances/controller.js +262 -261
  78. package/src/js/modules/logic/_info.js +4 -4
  79. package/src/js/modules/logic/config/_info.js +2 -2
  80. package/src/js/modules/logic/config/sounds.js +23 -23
  81. package/src/js/modules/logic/controller.js +48 -48
  82. package/src/js/modules/logic/sounds.js +103 -103
  83. package/src/js/modules/objects/_info.js +13 -13
  84. package/src/js/modules/objects/baseModel.js +198 -198
  85. package/src/js/modules/objects/cache.js +99 -99
  86. package/src/js/modules/objects/controller.js +131 -131
  87. package/src/js/modules/objects/find.js +58 -58
  88. package/src/js/modules/objects/models/_info.js +27 -27
  89. package/src/js/modules/objects/models/atlasImage.js +50 -50
  90. package/src/js/modules/objects/models/bitmapText.js +37 -37
  91. package/src/js/modules/objects/models/button.js +189 -189
  92. package/src/js/modules/objects/models/buttonComposite.js +35 -35
  93. package/src/js/modules/objects/models/checkbox.js +96 -96
  94. package/src/js/modules/objects/models/collection.js +54 -54
  95. package/src/js/modules/objects/models/component.js +46 -45
  96. package/src/js/modules/objects/models/container.js +19 -19
  97. package/src/js/modules/objects/models/dragContainer.js +675 -675
  98. package/src/js/modules/objects/models/emitter.js +67 -67
  99. package/src/js/modules/objects/models/emitterFx.js +99 -99
  100. package/src/js/modules/objects/models/graphics.js +38 -38
  101. package/src/js/modules/objects/models/group.js +19 -19
  102. package/src/js/modules/objects/models/hitArea.js +104 -104
  103. package/src/js/modules/objects/models/image.js +34 -34
  104. package/src/js/modules/objects/models/imagesAnimation.js +113 -113
  105. package/src/js/modules/objects/models/mask.js +38 -38
  106. package/src/js/modules/objects/models/nineSlicePlane.js +30 -30
  107. package/src/js/modules/objects/models/scrollbox.js +64 -64
  108. package/src/js/modules/objects/models/slider.js +253 -253
  109. package/src/js/modules/objects/models/spine.js +276 -276
  110. package/src/js/modules/objects/models/text.js +59 -59
  111. package/src/js/modules/objects/models/textInput.js +66 -66
  112. package/src/js/modules/objects/models/toggle.js +180 -180
  113. package/src/js/modules/objects/models/world.js +19 -19
  114. package/src/js/modules/objects/propertyAdapter.js +587 -587
  115. package/src/js/modules/objects/proxy.js +294 -294
  116. package/src/js/modules/objects/selector.js +136 -136
  117. package/src/js/modules/objects/service.js +242 -242
  118. package/src/js/modules/objects/styles.js +210 -210
  119. package/src/js/modules/observer/_info.js +4 -4
  120. package/src/js/modules/observer/controller.js +99 -99
  121. package/src/js/modules/observer/events.js +52 -51
  122. package/src/js/modules/scenes/_info.js +8 -8
  123. package/src/js/modules/scenes/controller.js +103 -103
  124. package/src/js/modules/scenes/model.js +28 -28
  125. package/src/js/modules/scenes/pixiWrapper.js +237 -237
  126. package/src/js/modules/scenes/resolutions.js +173 -173
  127. package/src/js/modules/scenes/resolutionsConfig.js +73 -73
  128. package/src/js/modules/scenes/service.js +142 -142
  129. package/src/js/modules/soundManager/_info.js +3 -3
  130. package/src/js/modules/soundManager/controller.js +100 -100
  131. package/src/js/modules/soundManager/soundSprite.js +251 -250
  132. package/src/js/modules/statesManager/_info.js +12 -12
  133. package/src/js/modules/statesManager/action.js +60 -60
  134. package/src/js/modules/statesManager/actions/_info.js +3 -3
  135. package/src/js/modules/statesManager/all.js +23 -23
  136. package/src/js/modules/statesManager/configStates.js +71 -71
  137. package/src/js/modules/statesManager/controller.js +170 -170
  138. package/src/js/modules/statesManager/functionsStorage.js +82 -82
  139. package/src/js/modules/statesManager/helper.js +27 -27
  140. package/src/js/modules/statesManager/race.js +75 -75
  141. package/src/js/modules/statesManager/sequence.js +47 -47
  142. package/src/js/modules/template/_info.js +6 -6
  143. package/src/js/modules/template/controller.js +28 -28
  144. package/src/js/modules/template/model.js +11 -11
  145. package/src/js/modules/template/service.js +137 -137
  146. package/src/js/modules/template/types.js +46 -46
  147. package/src/js/modules/transport/_info.js +8 -8
  148. package/src/js/modules/transport/baseConnectionType.js +24 -24
  149. package/src/js/modules/transport/config.js +13 -13
  150. package/src/js/modules/transport/connectionTypes/_info.js +3 -3
  151. package/src/js/modules/transport/connectionTypes/websocket.js +74 -74
  152. package/src/js/modules/transport/connectionTypes/xhr.js +44 -44
  153. package/src/js/modules/transport/controller.js +48 -48
  154. package/src/js/modules/transport/decorator.js +17 -17
  155. package/src/js/modules/transport/service.js +153 -153
  156. package/src/js/templates/_info.js +4 -4
  157. package/src/js/templates/groups/_info.js +1 -1
  158. package/src/js/templates/scenes/_info.js +1 -1
  159. package/webpack.config.js +47 -47
@@ -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;