@urso/core 0.5.8 → 0.5.9

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