@urso/core 0.7.92 → 0.7.94-dev

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