@urso/core 0.7.92 → 0.7.93

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 (132) hide show
  1. package/.babelrc +11 -11
  2. package/LICENSE +20 -20
  3. package/README.md +227 -227
  4. package/build/js/index.js +1 -1
  5. package/build/js/index.js.LICENSE.txt +2 -2
  6. package/package.json +51 -50
  7. package/src/js/app.js +104 -104
  8. package/src/js/components/base/controller.js +78 -78
  9. package/src/js/components/debug/controller.js +38 -38
  10. package/src/js/components/debug/coords.js +23 -23
  11. package/src/js/components/debug/fps.js +36 -36
  12. package/src/js/components/debug/template.js +55 -55
  13. package/src/js/components/debug/timescale.js +60 -60
  14. package/src/js/components/deviceRotate/controller.js +95 -95
  15. package/src/js/components/editor/api.js +127 -127
  16. package/src/js/components/editor/controller.js +12 -12
  17. package/src/js/components/fullscreen/android.js +104 -104
  18. package/src/js/components/fullscreen/controller.js +76 -76
  19. package/src/js/components/fullscreen/desktop.js +49 -49
  20. package/src/js/components/fullscreen/ios.js +115 -115
  21. package/src/js/components/layersSwitcher/config.js +26 -26
  22. package/src/js/components/layersSwitcher/controller.js +36 -36
  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/controller.js +42 -42
  26. package/src/js/components/soundInitialPopup/template.js +109 -109
  27. package/src/js/components/stateDriven/controller.js +123 -123
  28. package/src/js/config/load.js +194 -194
  29. package/src/js/config/main.js +17 -17
  30. package/src/js/extra/browserEvents.js +57 -57
  31. package/src/js/extra/main.js +21 -19
  32. package/src/js/extra/pixiPatch.js +171 -171
  33. package/src/js/index.js +7 -7
  34. package/src/js/lib/cache.js +125 -125
  35. package/src/js/lib/composition.js +85 -85
  36. package/src/js/lib/device.js +1215 -1215
  37. package/src/js/lib/helper.js +678 -678
  38. package/src/js/lib/loader.js +211 -211
  39. package/src/js/lib/localData.js +28 -28
  40. package/src/js/lib/logger.js +69 -69
  41. package/src/js/lib/math.js +161 -161
  42. package/src/js/lib/objectPool.js +207 -207
  43. package/src/js/lib/time.js +18 -18
  44. package/src/js/lib/tween.js +152 -152
  45. package/src/js/modules/assets/baseModel.js +20 -20
  46. package/src/js/modules/assets/config.js +38 -38
  47. package/src/js/modules/assets/controller.js +65 -65
  48. package/src/js/modules/assets/models/atlas.js +18 -18
  49. package/src/js/modules/assets/models/audiosprite.js +28 -28
  50. package/src/js/modules/assets/models/bitmapFont.js +10 -10
  51. package/src/js/modules/assets/models/container.js +18 -18
  52. package/src/js/modules/assets/models/font.js +10 -10
  53. package/src/js/modules/assets/models/html.js +10 -10
  54. package/src/js/modules/assets/models/image.js +17 -17
  55. package/src/js/modules/assets/models/json.js +10 -10
  56. package/src/js/modules/assets/models/jsonAtlas.js +10 -10
  57. package/src/js/modules/assets/models/sound.js +16 -16
  58. package/src/js/modules/assets/models/spine.js +16 -16
  59. package/src/js/modules/assets/service.js +541 -541
  60. package/src/js/modules/i18n/config.js +17 -17
  61. package/src/js/modules/i18n/controller.js +71 -71
  62. package/src/js/modules/instances/controller.js +357 -357
  63. package/src/js/modules/logic/config/sounds.js +23 -23
  64. package/src/js/modules/logic/controller.js +52 -52
  65. package/src/js/modules/logic/main.js +8 -8
  66. package/src/js/modules/logic/sounds.js +103 -103
  67. package/src/js/modules/objects/baseModel.js +207 -207
  68. package/src/js/modules/objects/cache.js +99 -99
  69. package/src/js/modules/objects/config.js +9 -9
  70. package/src/js/modules/objects/controller.js +139 -139
  71. package/src/js/modules/objects/find.js +58 -58
  72. package/src/js/modules/objects/models/atlasImage.js +52 -52
  73. package/src/js/modules/objects/models/bitmapText.js +48 -48
  74. package/src/js/modules/objects/models/button.js +196 -196
  75. package/src/js/modules/objects/models/buttonComposite.js +37 -37
  76. package/src/js/modules/objects/models/checkbox.js +96 -96
  77. package/src/js/modules/objects/models/collection.js +54 -54
  78. package/src/js/modules/objects/models/component.js +48 -48
  79. package/src/js/modules/objects/models/container.js +21 -21
  80. package/src/js/modules/objects/models/dragContainer.js +664 -664
  81. package/src/js/modules/objects/models/emitter.js +69 -69
  82. package/src/js/modules/objects/models/emitterFx.js +114 -114
  83. package/src/js/modules/objects/models/graphics.js +40 -40
  84. package/src/js/modules/objects/models/group.js +21 -21
  85. package/src/js/modules/objects/models/hitArea.js +170 -119
  86. package/src/js/modules/objects/models/image.js +36 -36
  87. package/src/js/modules/objects/models/imagesAnimation.js +115 -115
  88. package/src/js/modules/objects/models/mask.js +40 -40
  89. package/src/js/modules/objects/models/nineSlicePlane.js +32 -32
  90. package/src/js/modules/objects/models/scrollbox.js +66 -66
  91. package/src/js/modules/objects/models/slider.js +352 -352
  92. package/src/js/modules/objects/models/spine.js +338 -338
  93. package/src/js/modules/objects/models/text.js +70 -70
  94. package/src/js/modules/objects/models/textInput.js +68 -68
  95. package/src/js/modules/objects/models/toggle.js +179 -179
  96. package/src/js/modules/objects/models/world.js +21 -21
  97. package/src/js/modules/objects/pool.js +68 -68
  98. package/src/js/modules/objects/propertyAdapter.js +588 -588
  99. package/src/js/modules/objects/proxy.js +298 -298
  100. package/src/js/modules/objects/selector.js +136 -136
  101. package/src/js/modules/objects/service.js +254 -254
  102. package/src/js/modules/objects/styles.js +210 -210
  103. package/src/js/modules/observer/controller.js +167 -167
  104. package/src/js/modules/observer/events.js +56 -56
  105. package/src/js/modules/scenes/controller.js +127 -127
  106. package/src/js/modules/scenes/model.js +28 -28
  107. package/src/js/modules/scenes/pixiWrapper.js +351 -351
  108. package/src/js/modules/scenes/resolutions.js +173 -173
  109. package/src/js/modules/scenes/resolutionsConfig.js +73 -73
  110. package/src/js/modules/scenes/service.js +146 -146
  111. package/src/js/modules/soundManager/controller.js +103 -103
  112. package/src/js/modules/soundManager/soundSprite.js +285 -285
  113. package/src/js/modules/statesManager/action.js +97 -97
  114. package/src/js/modules/statesManager/all.js +23 -23
  115. package/src/js/modules/statesManager/configStates.js +77 -77
  116. package/src/js/modules/statesManager/controller.js +218 -218
  117. package/src/js/modules/statesManager/functionsStorage.js +82 -82
  118. package/src/js/modules/statesManager/helper.js +27 -27
  119. package/src/js/modules/statesManager/race.js +91 -91
  120. package/src/js/modules/statesManager/sequence.js +48 -48
  121. package/src/js/modules/template/controller.js +28 -28
  122. package/src/js/modules/template/model.js +11 -11
  123. package/src/js/modules/template/service.js +137 -137
  124. package/src/js/modules/template/types.js +48 -48
  125. package/src/js/modules/transport/baseConnectionType.js +25 -25
  126. package/src/js/modules/transport/config.js +13 -13
  127. package/src/js/modules/transport/connectionTypes/websocket.js +76 -76
  128. package/src/js/modules/transport/connectionTypes/xhr.js +46 -46
  129. package/src/js/modules/transport/controller.js +48 -48
  130. package/src/js/modules/transport/decorator.js +17 -17
  131. package/src/js/modules/transport/service.js +150 -150
  132. 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;