@urso/core 0.6.15 → 0.6.16

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 (156) 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 +38 -222
  6. package/package.json +52 -52
  7. package/src/js/app.js +79 -79
  8. package/src/js/components/_info.js +11 -11
  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 +36 -36
  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 +16 -16
  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 +150 -150
  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 +556 -556
  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 +203 -203
  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 +20 -20
  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 +15 -15
  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 +366 -366
  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 +357 -357
  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 +200 -200
  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 +46 -46
  93. package/src/js/modules/objects/models/container.js +19 -19
  94. package/src/js/modules/objects/models/dragContainer.js +667 -667
  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 +296 -287
  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 +588 -587
  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 +52 -52
  119. package/src/js/modules/scenes/_info.js +8 -8
  120. package/src/js/modules/scenes/controller.js +119 -119
  121. package/src/js/modules/scenes/model.js +28 -28
  122. package/src/js/modules/scenes/pixiWrapper.js +336 -336
  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 +251 -251
  129. package/src/js/modules/statesManager/_info.js +12 -12
  130. package/src/js/modules/statesManager/action.js +68 -68
  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
@@ -1,366 +1,366 @@
1
- class ModulesAssetsService {
2
-
3
- constructor() {
4
- this.singleton = true;
5
-
6
- this.assets = {};
7
-
8
- this._currentQuality = 'auto';
9
- this._addedAssetsCache = [];
10
- this.lazyLoadProcessStarted = false;
11
- };
12
-
13
- getQuality() {
14
- return this._currentQuality;
15
- }
16
-
17
- updateQuality() {
18
- this._currentQuality = this._detectQuality();
19
- Urso.addInstancesMode(this._currentQuality + 'Quality');
20
- }
21
-
22
- sortAssets(assets) {
23
- this.assets[this.getInstance('Config').loadingGroups.initial] = [];
24
-
25
- if (Array.isArray(assets))
26
- for (let asset of assets)
27
- this._addAsset(asset);
28
- else
29
- this._addAsset(assets);
30
- }
31
-
32
- startLoad(callback) {
33
- this.loadGroup(
34
- this.getInstance('Config').loadingGroups.initial,
35
- (() => { callback(); this._startLazyLoad(); }).bind(this)
36
- )
37
- }
38
-
39
- loadUpdate(param) {
40
- Urso.scenes.loadUpdate(Math.floor(param.progress));
41
- }
42
-
43
- loadGroup(group, callback = () => { }) {
44
- if (!this.assets[group])
45
- return Urso.logger.error('ModulesAssetsService group error, no assets:' + group + ' Check ModulesAssetsConfig please');
46
-
47
- //we need load and parse atlases at first (!)
48
- this._loadGroupAtlases(group, () => { this._loadGroupRestAssets(group, callback) });
49
- }
50
-
51
- _loadGroupAtlases(group, callback) {
52
- const atlases = this.assets[group].filter(assetModel => assetModel.type === Urso.types.assets.ATLAS);
53
-
54
- if (!atlases.length)
55
- return callback();
56
-
57
- let loader = Urso.getInstance('Lib.Loader');
58
-
59
- for (let assetModel of atlases)
60
- this._addAssetToLoader(assetModel, loader);
61
-
62
- loader.start(() => { this._processLoadedAtlases(group); callback(); });
63
- }
64
-
65
- _loadGroupRestAssets(group, callback) {
66
- let loader = Urso.getInstance('Lib.Loader');
67
- loader.setOnLoadUpdate(this.loadUpdate.bind(this));
68
- const noAtlasSpines = [];
69
-
70
- for (let assetModel of this.assets[group])
71
- if (assetModel.type !== Urso.types.assets.ATLAS)
72
- if (!Urso.cache.getFile(assetModel.path)) {
73
- //filter noAtlas Spine files
74
- if (assetModel.type === Urso.types.assets.SPINE && assetModel.noAtlas) {
75
- noAtlasSpines.push(assetModel);
76
- } else
77
- this._addAssetToLoader(assetModel, loader);
78
- }
79
-
80
- loader.start(
81
- () => {
82
- this._processLoadedAssets(group);
83
- this._loadNoAtlasSpines(noAtlasSpines, () => {
84
- this.emit(Urso.events.MODULES_ASSETS_GROUP_LOADED, group);
85
- callback();
86
- });
87
- }
88
- );
89
- }
90
-
91
- _loadNoAtlasSpines(noAtlasSpines, callback) {
92
- if (!noAtlasSpines.length)
93
- return callback();
94
-
95
- let loader = Urso.getInstance('Lib.Loader');
96
-
97
- for (let assetModel of noAtlasSpines)
98
- this._addAssetToLoader(assetModel, loader);
99
-
100
- loader.start(callback);
101
- }
102
-
103
- _processLoadedAtlases(group) {
104
- const atlases = this.assets[group].filter(assetModel => assetModel.type === Urso.types.assets.ATLAS);
105
-
106
- for (let assetModel of atlases) {
107
- const assetKey = assetModel.key;
108
- let imageData = Urso.cache.getAtlas(assetKey);
109
- const folderPath = imageData.url.split('/').slice(0, -1).join('/');
110
-
111
- for (let i = 0; i < imageData.spritesheet._frames.length; i++) {
112
- let frame = imageData.spritesheet._frames[i];
113
- let texture = imageData.textures[i];
114
- let newFilename = frame.filename;
115
-
116
- if (!frame.filename.includes('/'))
117
- newFilename = folderPath + '/' + frame.filename;
118
-
119
- Urso.cache.addFile(newFilename, texture);
120
- }
121
- }
122
- }
123
-
124
- _processLoadedAssets(group) {
125
- for (let assetModel of this.assets[group]) {
126
- if (assetModel.type === Urso.types.assets.IMAGE)
127
- this._processLoadedImage(assetModel);
128
-
129
- if (assetModel.type === Urso.types.assets.BITMAPFONT)
130
- this._processLoadedBitmapFont(assetModel);
131
-
132
- if (assetModel.type === Urso.types.assets.FONT)
133
- this._processLoadedFont(assetModel);
134
- }
135
-
136
- delete this.assets[group];
137
- }
138
-
139
- _processLoadedFont(source) {
140
- const data = Urso.cache.getFile(source.key);
141
- const font = new FontFace(source.key, data.data);
142
- font.load().then(() => {
143
- document.fonts.add(font);
144
- });
145
- }
146
-
147
- _processLoadedBitmapFont(assetModel) {
148
- this._updateFontKey(assetModel.key)
149
- }
150
-
151
- _updateFontKey(fontName) {
152
- const fontData = Urso.cache.getBitmapFont(fontName);
153
-
154
- if (PIXI.BitmapFont.available[fontName] || !fontData)
155
- return;
156
-
157
- const savedFont = PIXI.BitmapFont.available[fontData.bitmapFont.font];
158
-
159
- if (savedFont) {
160
- PIXI.BitmapFont.available[fontName] = savedFont;
161
- delete PIXI.BitmapFont.available[fontData.bitmapFont.font];
162
- }
163
- }
164
-
165
- getCurrentResolution() {
166
- const { qualityFactors, defaultQualityFactor } = this.getInstance('Config');
167
- return qualityFactors[this._currentQuality] || defaultQualityFactor || 1;
168
- }
169
-
170
- _processLoadedImage(assetModel) {
171
- const resolution = this.getCurrentResolution();
172
-
173
- const assetKey = assetModel.key;
174
- //textures cache
175
- let imageData = Urso.cache.getImage(assetKey);
176
-
177
- if (!imageData) {
178
- //from atlas ?!
179
- let texture = Urso.cache.getFile(assetModel.path);
180
-
181
- if (!texture)
182
- return Urso.logger.error('ModulesAssetsService process Loaded Image error: no image ', assetModel);
183
-
184
- Urso.cache.addTexture(assetKey, texture); //TODO change resolution of base texture
185
- } else {
186
- //regular image
187
- const baseTexture = new PIXI.BaseTexture(imageData.data, { resolution });
188
- const texture = new PIXI.Texture(baseTexture);
189
- Urso.cache.addTexture(assetKey, texture);
190
- }
191
-
192
- if (assetModel.preloadGPU) {
193
- let tempOblect = Urso.objects.create({
194
- type: Urso.types.objects.IMAGE,
195
- assetKey: assetKey,
196
- x: -10000, y: -10000
197
- }, false, true);
198
-
199
- setTimeout(() => { tempOblect.destroy() }, 1)
200
- }
201
- }
202
-
203
- _addAsset(asset, loadingGroup) {
204
- //cache for all assets. We do not need to load same assets twice or more
205
- if (asset.type !== Urso.types.assets.CONTAINER) {
206
- let addedAssetKey = `${asset.type}_${asset.key}`;
207
-
208
- if (this._addedAssetsCache.includes(addedAssetKey))
209
- return;
210
-
211
- this._addedAssetsCache.push(addedAssetKey);
212
- }
213
-
214
- let model;
215
-
216
- switch (asset.type) {
217
- case Urso.types.assets.IMAGE:
218
- model = this.getInstance('Models.Image', asset)
219
- break;
220
- case Urso.types.assets.CONTAINER:
221
- model = this.getInstance('Models.Container', asset)
222
- break;
223
- case Urso.types.assets.ATLAS:
224
- model = this.getInstance('Models.Atlas', asset)
225
- break;
226
- case Urso.types.assets.AUDIOSPRITE:
227
- model = this.getInstance('Models.Audiosprite', asset)
228
- break;
229
- case Urso.types.assets.JSON:
230
- model = this.getInstance('Models.Json', asset)
231
- break;
232
- case Urso.types.assets.SPINE:
233
- model = this.getInstance('Models.Spine', asset)
234
- break;
235
- case Urso.types.assets.BITMAPFONT:
236
- model = this.getInstance('Models.BitmapFont', asset)
237
- break;
238
- case Urso.types.assets.FONT:
239
- model = this.getInstance('Models.Font', asset)
240
- break;
241
- case Urso.types.assets.SOUND:
242
- model = this.getInstance('Models.Sound', asset)
243
- break;
244
- default:
245
- Urso.logger.error('ModulesAssetsService asset type error', asset);
246
- break;
247
- };
248
-
249
- //set loadingGroup
250
- model.loadingGroup = loadingGroup || model.loadingGroup || this.getInstance('Config').loadingGroups.initial;
251
-
252
- //check if container
253
- if (model.contents) {
254
- for (let content of model.contents) {
255
- this._addAsset(content, model.loadingGroup);
256
- }
257
-
258
- return;
259
- }
260
-
261
- //add single asset to loading group
262
- if (!this.assets[model.loadingGroup])
263
- this.assets[model.loadingGroup] = [];
264
-
265
- this.assets[model.loadingGroup].push(model);
266
- }
267
-
268
- _startLazyLoad() {
269
- if (this.lazyLoadProcessStarted)
270
- return;
271
-
272
- this.lazyLoadProcessStarted = true;
273
- this._continueLazyLoad();
274
- }
275
-
276
- _continueLazyLoad(step) {
277
- if (!step)
278
- step = 0;
279
-
280
- const lazyLoadGroups = this.getInstance('Config').lazyLoadGroups;
281
-
282
- if (step >= lazyLoadGroups.length) {
283
- this.emit(Urso.events.MODULES_ASSETS_LAZYLOAD_FINISHED);
284
- return;
285
- }
286
-
287
- let groupName = lazyLoadGroups[step];
288
-
289
- if (!groupName)
290
- Urso.logger.error('ModulesAssetsService lazy loading groupName error');
291
-
292
- this.loadGroup(groupName, () => { this._continueLazyLoad(step + 1); })
293
- }
294
-
295
- _qualityReducer(qualityFactors, widthFactor) {
296
- return [(acc, val) => {
297
- if (acc === null) {
298
- return val;
299
- }
300
-
301
- const currentQuality = qualityFactors[acc];
302
- const qualityFactor = qualityFactors[val];
303
-
304
- const nextQuality = (currentQuality > qualityFactor && qualityFactor >= widthFactor)
305
- || (qualityFactor >= widthFactor && widthFactor > currentQuality)
306
- || (widthFactor >= qualityFactor && qualityFactor > currentQuality);
307
-
308
- return nextQuality ? val : acc;
309
-
310
- }, null]
311
- }
312
-
313
- _detectQuality() {
314
- const { qualityFactors } = this.getInstance('Config');
315
- const userQuality = Urso.helper.parseGetParams()['quality'];
316
-
317
- if (userQuality && qualityFactors[userQuality]) {
318
- return userQuality;
319
- }
320
-
321
- return this._calculateQuality(qualityFactors);
322
- }
323
-
324
- _calculateQuality(qualityFactors) {
325
- const { android, iOS, iPad, macOS } = Urso.device;
326
- const isMobile = android || iOS || iPad;
327
-
328
- if (macOS && !isMobile) {
329
- return 'high';
330
- }
331
-
332
- if (macOS && iPad) {
333
- return 'medium';
334
- }
335
-
336
- const resCfg = Urso.getInstance('Modules.Scenes.ResolutionsConfig').contents[0];
337
-
338
- const { devicePixelRatio } = window;
339
- let { width, height } = screen;
340
-
341
- if (isMobile) {
342
- width = (width > height) ? width : height;
343
- }
344
-
345
- if (iOS) {
346
- width *= devicePixelRatio;
347
- }
348
-
349
- const widthFactor = width / resCfg.width;
350
-
351
- return Object
352
- .keys(qualityFactors)
353
- .reduce(...this._qualityReducer(qualityFactors, widthFactor));
354
- }
355
-
356
- _addAssetToLoader(assetModel, loader) {
357
- if (assetModel.path)
358
- loader.addAsset(assetModel);
359
- else if (assetModel.contents) {
360
- //do nothing, its a container
361
- } else
362
- Urso.logger.error('ModulesAssetsService model error', assetModel);
363
- };
364
- }
365
-
366
- module.exports = ModulesAssetsService;
1
+ class ModulesAssetsService {
2
+
3
+ constructor() {
4
+ this.singleton = true;
5
+
6
+ this.assets = {};
7
+
8
+ this._currentQuality = 'auto';
9
+ this._addedAssetsCache = [];
10
+ this.lazyLoadProcessStarted = false;
11
+ };
12
+
13
+ getQuality() {
14
+ return this._currentQuality;
15
+ }
16
+
17
+ updateQuality() {
18
+ this._currentQuality = this._detectQuality();
19
+ Urso.addInstancesMode(this._currentQuality + 'Quality');
20
+ }
21
+
22
+ sortAssets(assets) {
23
+ this.assets[this.getInstance('Config').loadingGroups.initial] = [];
24
+
25
+ if (Array.isArray(assets))
26
+ for (let asset of assets)
27
+ this._addAsset(asset);
28
+ else
29
+ this._addAsset(assets);
30
+ }
31
+
32
+ startLoad(callback) {
33
+ this.loadGroup(
34
+ this.getInstance('Config').loadingGroups.initial,
35
+ (() => { callback(); this._startLazyLoad(); }).bind(this)
36
+ )
37
+ }
38
+
39
+ loadUpdate(param) {
40
+ Urso.scenes.loadUpdate(Math.floor(param.progress));
41
+ }
42
+
43
+ loadGroup(group, callback = () => { }) {
44
+ if (!this.assets[group])
45
+ return Urso.logger.error('ModulesAssetsService group error, no assets:' + group + ' Check ModulesAssetsConfig please');
46
+
47
+ //we need load and parse atlases at first (!)
48
+ this._loadGroupAtlases(group, () => { this._loadGroupRestAssets(group, callback) });
49
+ }
50
+
51
+ _loadGroupAtlases(group, callback) {
52
+ const atlases = this.assets[group].filter(assetModel => assetModel.type === Urso.types.assets.ATLAS);
53
+
54
+ if (!atlases.length)
55
+ return callback();
56
+
57
+ let loader = Urso.getInstance('Lib.Loader');
58
+
59
+ for (let assetModel of atlases)
60
+ this._addAssetToLoader(assetModel, loader);
61
+
62
+ loader.start(() => { this._processLoadedAtlases(group); callback(); });
63
+ }
64
+
65
+ _loadGroupRestAssets(group, callback) {
66
+ let loader = Urso.getInstance('Lib.Loader');
67
+ loader.setOnLoadUpdate(this.loadUpdate.bind(this));
68
+ const noAtlasSpines = [];
69
+
70
+ for (let assetModel of this.assets[group])
71
+ if (assetModel.type !== Urso.types.assets.ATLAS)
72
+ if (!Urso.cache.getFile(assetModel.path)) {
73
+ //filter noAtlas Spine files
74
+ if (assetModel.type === Urso.types.assets.SPINE && assetModel.noAtlas) {
75
+ noAtlasSpines.push(assetModel);
76
+ } else
77
+ this._addAssetToLoader(assetModel, loader);
78
+ }
79
+
80
+ loader.start(
81
+ () => {
82
+ this._processLoadedAssets(group);
83
+ this._loadNoAtlasSpines(noAtlasSpines, () => {
84
+ this.emit(Urso.events.MODULES_ASSETS_GROUP_LOADED, group);
85
+ callback();
86
+ });
87
+ }
88
+ );
89
+ }
90
+
91
+ _loadNoAtlasSpines(noAtlasSpines, callback) {
92
+ if (!noAtlasSpines.length)
93
+ return callback();
94
+
95
+ let loader = Urso.getInstance('Lib.Loader');
96
+
97
+ for (let assetModel of noAtlasSpines)
98
+ this._addAssetToLoader(assetModel, loader);
99
+
100
+ loader.start(callback);
101
+ }
102
+
103
+ _processLoadedAtlases(group) {
104
+ const atlases = this.assets[group].filter(assetModel => assetModel.type === Urso.types.assets.ATLAS);
105
+
106
+ for (let assetModel of atlases) {
107
+ const assetKey = assetModel.key;
108
+ let imageData = Urso.cache.getAtlas(assetKey);
109
+ const folderPath = imageData.url.split('/').slice(0, -1).join('/');
110
+
111
+ for (let i = 0; i < imageData.spritesheet._frames.length; i++) {
112
+ let frame = imageData.spritesheet._frames[i];
113
+ let texture = imageData.textures[i];
114
+ let newFilename = frame.filename;
115
+
116
+ if (!frame.filename.includes('/'))
117
+ newFilename = folderPath + '/' + frame.filename;
118
+
119
+ Urso.cache.addFile(newFilename, texture);
120
+ }
121
+ }
122
+ }
123
+
124
+ _processLoadedAssets(group) {
125
+ for (let assetModel of this.assets[group]) {
126
+ if (assetModel.type === Urso.types.assets.IMAGE)
127
+ this._processLoadedImage(assetModel);
128
+
129
+ if (assetModel.type === Urso.types.assets.BITMAPFONT)
130
+ this._processLoadedBitmapFont(assetModel);
131
+
132
+ if (assetModel.type === Urso.types.assets.FONT)
133
+ this._processLoadedFont(assetModel);
134
+ }
135
+
136
+ delete this.assets[group];
137
+ }
138
+
139
+ _processLoadedFont(source) {
140
+ const data = Urso.cache.getFile(source.key);
141
+ const font = new FontFace(source.key, data.data);
142
+ font.load().then(() => {
143
+ document.fonts.add(font);
144
+ });
145
+ }
146
+
147
+ _processLoadedBitmapFont(assetModel) {
148
+ this._updateFontKey(assetModel.key)
149
+ }
150
+
151
+ _updateFontKey(fontName) {
152
+ const fontData = Urso.cache.getBitmapFont(fontName);
153
+
154
+ if (PIXI.BitmapFont.available[fontName] || !fontData)
155
+ return;
156
+
157
+ const savedFont = PIXI.BitmapFont.available[fontData.bitmapFont.font];
158
+
159
+ if (savedFont) {
160
+ PIXI.BitmapFont.available[fontName] = savedFont;
161
+ delete PIXI.BitmapFont.available[fontData.bitmapFont.font];
162
+ }
163
+ }
164
+
165
+ getCurrentResolution() {
166
+ const { qualityFactors, defaultQualityFactor } = this.getInstance('Config');
167
+ return qualityFactors[this._currentQuality] || defaultQualityFactor || 1;
168
+ }
169
+
170
+ _processLoadedImage(assetModel) {
171
+ const resolution = this.getCurrentResolution();
172
+
173
+ const assetKey = assetModel.key;
174
+ //textures cache
175
+ let imageData = Urso.cache.getImage(assetKey);
176
+
177
+ if (!imageData) {
178
+ //from atlas ?!
179
+ let texture = Urso.cache.getFile(assetModel.path);
180
+
181
+ if (!texture)
182
+ return Urso.logger.error('ModulesAssetsService process Loaded Image error: no image ', assetModel);
183
+
184
+ Urso.cache.addTexture(assetKey, texture); //TODO change resolution of base texture
185
+ } else {
186
+ //regular image
187
+ const baseTexture = new PIXI.BaseTexture(imageData.data, { resolution });
188
+ const texture = new PIXI.Texture(baseTexture);
189
+ Urso.cache.addTexture(assetKey, texture);
190
+ }
191
+
192
+ if (assetModel.preloadGPU) {
193
+ let tempOblect = Urso.objects.create({
194
+ type: Urso.types.objects.IMAGE,
195
+ assetKey: assetKey,
196
+ x: -10000, y: -10000
197
+ }, false, true);
198
+
199
+ setTimeout(() => { tempOblect.destroy() }, 1)
200
+ }
201
+ }
202
+
203
+ _addAsset(asset, loadingGroup) {
204
+ //cache for all assets. We do not need to load same assets twice or more
205
+ if (asset.type !== Urso.types.assets.CONTAINER) {
206
+ let addedAssetKey = `${asset.type}_${asset.key}`;
207
+
208
+ if (this._addedAssetsCache.includes(addedAssetKey))
209
+ return;
210
+
211
+ this._addedAssetsCache.push(addedAssetKey);
212
+ }
213
+
214
+ let model;
215
+
216
+ switch (asset.type) {
217
+ case Urso.types.assets.IMAGE:
218
+ model = this.getInstance('Models.Image', asset)
219
+ break;
220
+ case Urso.types.assets.CONTAINER:
221
+ model = this.getInstance('Models.Container', asset)
222
+ break;
223
+ case Urso.types.assets.ATLAS:
224
+ model = this.getInstance('Models.Atlas', asset)
225
+ break;
226
+ case Urso.types.assets.AUDIOSPRITE:
227
+ model = this.getInstance('Models.Audiosprite', asset)
228
+ break;
229
+ case Urso.types.assets.JSON:
230
+ model = this.getInstance('Models.Json', asset)
231
+ break;
232
+ case Urso.types.assets.SPINE:
233
+ model = this.getInstance('Models.Spine', asset)
234
+ break;
235
+ case Urso.types.assets.BITMAPFONT:
236
+ model = this.getInstance('Models.BitmapFont', asset)
237
+ break;
238
+ case Urso.types.assets.FONT:
239
+ model = this.getInstance('Models.Font', asset)
240
+ break;
241
+ case Urso.types.assets.SOUND:
242
+ model = this.getInstance('Models.Sound', asset)
243
+ break;
244
+ default:
245
+ Urso.logger.error('ModulesAssetsService asset type error', asset);
246
+ break;
247
+ };
248
+
249
+ //set loadingGroup
250
+ model.loadingGroup = loadingGroup || model.loadingGroup || this.getInstance('Config').loadingGroups.initial;
251
+
252
+ //check if container
253
+ if (model.contents) {
254
+ for (let content of model.contents) {
255
+ this._addAsset(content, model.loadingGroup);
256
+ }
257
+
258
+ return;
259
+ }
260
+
261
+ //add single asset to loading group
262
+ if (!this.assets[model.loadingGroup])
263
+ this.assets[model.loadingGroup] = [];
264
+
265
+ this.assets[model.loadingGroup].push(model);
266
+ }
267
+
268
+ _startLazyLoad() {
269
+ if (this.lazyLoadProcessStarted)
270
+ return;
271
+
272
+ this.lazyLoadProcessStarted = true;
273
+ this._continueLazyLoad();
274
+ }
275
+
276
+ _continueLazyLoad(step) {
277
+ if (!step)
278
+ step = 0;
279
+
280
+ const lazyLoadGroups = this.getInstance('Config').lazyLoadGroups;
281
+
282
+ if (step >= lazyLoadGroups.length) {
283
+ this.emit(Urso.events.MODULES_ASSETS_LAZYLOAD_FINISHED);
284
+ return;
285
+ }
286
+
287
+ let groupName = lazyLoadGroups[step];
288
+
289
+ if (!groupName)
290
+ Urso.logger.error('ModulesAssetsService lazy loading groupName error');
291
+
292
+ this.loadGroup(groupName, () => { this._continueLazyLoad(step + 1); })
293
+ }
294
+
295
+ _qualityReducer(qualityFactors, widthFactor) {
296
+ return [(acc, val) => {
297
+ if (acc === null) {
298
+ return val;
299
+ }
300
+
301
+ const currentQuality = qualityFactors[acc];
302
+ const qualityFactor = qualityFactors[val];
303
+
304
+ const nextQuality = (currentQuality > qualityFactor && qualityFactor >= widthFactor)
305
+ || (qualityFactor >= widthFactor && widthFactor > currentQuality)
306
+ || (widthFactor >= qualityFactor && qualityFactor > currentQuality);
307
+
308
+ return nextQuality ? val : acc;
309
+
310
+ }, null]
311
+ }
312
+
313
+ _detectQuality() {
314
+ const { qualityFactors } = this.getInstance('Config');
315
+ const userQuality = Urso.helper.parseGetParams()['quality'];
316
+
317
+ if (userQuality && qualityFactors[userQuality]) {
318
+ return userQuality;
319
+ }
320
+
321
+ return this._calculateQuality(qualityFactors);
322
+ }
323
+
324
+ _calculateQuality(qualityFactors) {
325
+ const { android, iOS, iPad, macOS } = Urso.device;
326
+ const isMobile = android || iOS || iPad;
327
+
328
+ if (macOS && !isMobile) {
329
+ return 'high';
330
+ }
331
+
332
+ if (macOS && iPad) {
333
+ return 'medium';
334
+ }
335
+
336
+ const resCfg = Urso.getInstance('Modules.Scenes.ResolutionsConfig').contents[0];
337
+
338
+ const { devicePixelRatio } = window;
339
+ let { width, height } = screen;
340
+
341
+ if (isMobile) {
342
+ width = (width > height) ? width : height;
343
+ }
344
+
345
+ if (iOS) {
346
+ width *= devicePixelRatio;
347
+ }
348
+
349
+ const widthFactor = width / resCfg.width;
350
+
351
+ return Object
352
+ .keys(qualityFactors)
353
+ .reduce(...this._qualityReducer(qualityFactors, widthFactor));
354
+ }
355
+
356
+ _addAssetToLoader(assetModel, loader) {
357
+ if (assetModel.path)
358
+ loader.addAsset(assetModel);
359
+ else if (assetModel.contents) {
360
+ //do nothing, its a container
361
+ } else
362
+ Urso.logger.error('ModulesAssetsService model error', assetModel);
363
+ };
364
+ }
365
+
366
+ module.exports = ModulesAssetsService;