@urso/core 0.4.45 → 0.4.49

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 +220 -220
  4. package/build/js/index.js +1 -1
  5. package/build/js/index.js.LICENSE.txt +32 -32
  6. package/package.json +51 -51
  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 +66 -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 +11 -10
  40. package/src/js/extra/_info.js +24 -24
  41. package/src/js/extra/browserEvents.js +38 -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 -131
  51. package/src/js/lib/localData.js +15 -15
  52. package/src/js/lib/logger.js +22 -22
  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 +11 -11
  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/create.js +237 -237
  88. package/src/js/modules/objects/find.js +140 -140
  89. package/src/js/modules/objects/models/_info.js +25 -25
  90. package/src/js/modules/objects/models/atlasImage.js +50 -50
  91. package/src/js/modules/objects/models/bitmapText.js +39 -39
  92. package/src/js/modules/objects/models/button.js +189 -189
  93. package/src/js/modules/objects/models/buttonComposite.js +35 -35
  94. package/src/js/modules/objects/models/checkbox.js +96 -96
  95. package/src/js/modules/objects/models/collection.js +54 -54
  96. package/src/js/modules/objects/models/component.js +44 -44
  97. package/src/js/modules/objects/models/container.js +19 -19
  98. package/src/js/modules/objects/models/emitter.js +67 -54
  99. package/src/js/modules/objects/models/graphics.js +38 -38
  100. package/src/js/modules/objects/models/group.js +19 -19
  101. package/src/js/modules/objects/models/hitArea.js +104 -104
  102. package/src/js/modules/objects/models/image.js +34 -34
  103. package/src/js/modules/objects/models/imagesAnimation.js +113 -113
  104. package/src/js/modules/objects/models/mask.js +38 -38
  105. package/src/js/modules/objects/models/nineSlicePlane.js +30 -30
  106. package/src/js/modules/objects/models/scrollbox.js +61 -61
  107. package/src/js/modules/objects/models/slider.js +253 -253
  108. package/src/js/modules/objects/models/spine.js +271 -271
  109. package/src/js/modules/objects/models/text.js +59 -59
  110. package/src/js/modules/objects/models/textInput.js +66 -66
  111. package/src/js/modules/objects/models/toggle.js +180 -180
  112. package/src/js/modules/objects/models/world.js +19 -19
  113. package/src/js/modules/objects/propertyAdapter.js +422 -422
  114. package/src/js/modules/objects/proxy.js +282 -282
  115. package/src/js/modules/objects/styles.js +120 -120
  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 +44 -44
  119. package/src/js/modules/scenes/_info.js +8 -8
  120. package/src/js/modules/scenes/controller.js +103 -103
  121. package/src/js/modules/scenes/model.js +28 -28
  122. package/src/js/modules/scenes/pixiWrapper.js +237 -237
  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 +139 -139
  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 +243 -243
  129. package/src/js/modules/statesManager/_info.js +12 -12
  130. package/src/js/modules/statesManager/action.js +60 -60
  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 +45 -45
  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,38 +1,38 @@
1
- class ExtraBrowserEvents {
2
- constructor() {
3
- this.singleton = true;
4
-
5
- this.RESIZE_DELAY = 250; //delay for resize event (browser will refresh his own params)
6
-
7
- this.resizeHandler = this.resizeHandler.bind(this);
8
- this.visibilitychangeHandler = this.visibilitychangeHandler.bind(this);
9
-
10
- this._resizeTimeoutId;
11
-
12
- this.init();
13
- }
14
-
15
- init() {
16
- document.addEventListener("visibilitychange", this.visibilitychangeHandler);
17
-
18
- window.addEventListener('resize', this.resizeHandler);
19
- window.addEventListener('orientationchange', this.resizeHandler);
20
- document.addEventListener('fullscreenchange', this.resizeHandler);
21
- document.addEventListener('webkitfullscreenchange', this.resizeHandler);
22
- document.addEventListener('mozfullscreenchange', this.resizeHandler);
23
- }
24
-
25
- visibilitychangeHandler() {
26
- this.emit(Urso.events.EXTRA_BROWSEREVENTS_WINDOW_VISIBILITYCHANGE, document.visibilityState);
27
- }
28
-
29
- resizeHandler() {
30
- if (this._resizeTimeoutId)
31
- Urso.clearTimeout(this._resizeTimeoutId)
32
-
33
- this.emit(Urso.events.EXTRA_BROWSEREVENTS_WINDOW_PRE_RESIZE);
34
- this._resizeTimeoutId = Urso.setTimeout(() => this.emit(Urso.events.EXTRA_BROWSEREVENTS_WINDOW_RESIZE), this.RESIZE_DELAY);
35
- }
36
- }
37
-
38
- module.exports = ExtraBrowserEvents;
1
+ class ExtraBrowserEvents {
2
+ constructor() {
3
+ this.singleton = true;
4
+
5
+ this.RESIZE_DELAY = 250; //delay for resize event (browser will refresh his own params)
6
+
7
+ this.resizeHandler = this.resizeHandler.bind(this);
8
+ this.visibilitychangeHandler = this.visibilitychangeHandler.bind(this);
9
+
10
+ this._resizeTimeoutId;
11
+
12
+ this.init();
13
+ }
14
+
15
+ init() {
16
+ document.addEventListener("visibilitychange", this.visibilitychangeHandler);
17
+
18
+ window.addEventListener('resize', this.resizeHandler);
19
+ window.addEventListener('orientationchange', this.resizeHandler);
20
+ document.addEventListener('fullscreenchange', this.resizeHandler);
21
+ document.addEventListener('webkitfullscreenchange', this.resizeHandler);
22
+ document.addEventListener('mozfullscreenchange', this.resizeHandler);
23
+ }
24
+
25
+ visibilitychangeHandler() {
26
+ this.emit(Urso.events.EXTRA_BROWSEREVENTS_WINDOW_VISIBILITYCHANGE, document.visibilityState);
27
+ }
28
+
29
+ resizeHandler() {
30
+ if (this._resizeTimeoutId)
31
+ Urso.clearTimeout(this._resizeTimeoutId)
32
+
33
+ this.emit(Urso.events.EXTRA_BROWSEREVENTS_WINDOW_PRE_RESIZE);
34
+ this._resizeTimeoutId = Urso.setTimeout(() => this.emit(Urso.events.EXTRA_BROWSEREVENTS_WINDOW_RESIZE), this.RESIZE_DELAY);
35
+ }
36
+ }
37
+
38
+ module.exports = ExtraBrowserEvents;
@@ -1,79 +1,79 @@
1
- /**
2
- * ModulesObjectsModelsText fillCustomColors patch
3
- */
4
-
5
-
6
- /**
7
- * Render the text with letter-spacing.
8
- *
9
- * @param text - The text to draw
10
- * @param x - Horizontal position to draw the text
11
- * @param y - Vertical position to draw the text
12
- * @param isStroke - Is this drawing for the outside stroke of the
13
- * text? If not, it's for the inside fill
14
- */
15
- PIXI.Text.prototype.drawLetterSpacing = function (text, x, y, isStroke) {
16
- if (isStroke === void 0) { isStroke = false; }
17
- var style = this._style;
18
- // letterSpacing of 0 means normal
19
- var letterSpacing = style.letterSpacing;
20
- // Checking that we can use moddern canvas2D api
21
- // https://developer.chrome.com/origintrials/#/view_trial/3585991203293757441
22
- // note: this is unstable API, Chrome less 94 use a `textLetterSpacing`, newest use a letterSpacing
23
- // eslint-disable-next-line max-len
24
- var supportLetterSpacing = 'letterSpacing' in CanvasRenderingContext2D.prototype
25
- || 'textLetterSpacing' in CanvasRenderingContext2D.prototype;
26
-
27
- if ((letterSpacing === 0 || supportLetterSpacing) && (!this.fillCustomColors || this.fillCustomColors.length === 0)) { //colors patch in if state
28
- if (supportLetterSpacing) {
29
- this.context.letterSpacing = letterSpacing;
30
- this.context.textLetterSpacing = letterSpacing;
31
- }
32
- if (isStroke) {
33
- this.context.strokeText(text, x, y);
34
- }
35
- else {
36
- this.context.fillText(text, x, y);
37
- }
38
- return;
39
- }
40
- var currentPosition = x;
41
-
42
- var textIndexOffset = this.text.indexOf(text); //colors patch block
43
- var allTextLength = this.text.length;
44
- var customColors = new Array(allTextLength);
45
- if (this.fillCustomColors) {
46
- for (var k in this.fillCustomColors) {
47
- var colorsParams = this.fillCustomColors[k];
48
- //customColors[colorsParams.position] = colorsParams.color;
49
- customColors.fill(colorsParams.color, colorsParams.position, allTextLength);
50
- }
51
- }
52
-
53
- // Using Array.from correctly splits characters whilst keeping emoji together.
54
- // This is not supported on IE as it requires ES6, so regular text splitting occurs.
55
- // This also doesn't account for emoji that are multiple emoji put together to make something else.
56
- // Handling all of this would require a big library itself.
57
- // https://medium.com/@giltayar/iterating-over-emoji-characters-the-es6-way-f06e4589516
58
- // https://github.com/orling/grapheme-splitter
59
- var stringArray = Array.from ? Array.from(text) : text.split('');
60
- var previousWidth = this.context.measureText(text).width;
61
- var currentWidth = 0;
62
- for (var i = 0; i < stringArray.length; ++i) {
63
- var currentChar = stringArray[i];
64
-
65
- if (isStroke) {
66
- this.context.strokeText(currentChar, currentPosition, y);
67
- }
68
- else {
69
- if (customColors[textIndexOffset + i]) { //colors patch block
70
- this.context.fillStyle = customColors[textIndexOffset + i];
71
- }
72
-
73
- this.context.fillText(currentChar, currentPosition, y);
74
- }
75
- currentWidth = this.context.measureText(text.substring(i + 1)).width;
76
- currentPosition += previousWidth - currentWidth + letterSpacing;
77
- previousWidth = currentWidth;
78
- }
79
- };
1
+ /**
2
+ * ModulesObjectsModelsText fillCustomColors patch
3
+ */
4
+
5
+
6
+ /**
7
+ * Render the text with letter-spacing.
8
+ *
9
+ * @param text - The text to draw
10
+ * @param x - Horizontal position to draw the text
11
+ * @param y - Vertical position to draw the text
12
+ * @param isStroke - Is this drawing for the outside stroke of the
13
+ * text? If not, it's for the inside fill
14
+ */
15
+ PIXI.Text.prototype.drawLetterSpacing = function (text, x, y, isStroke) {
16
+ if (isStroke === void 0) { isStroke = false; }
17
+ var style = this._style;
18
+ // letterSpacing of 0 means normal
19
+ var letterSpacing = style.letterSpacing;
20
+ // Checking that we can use moddern canvas2D api
21
+ // https://developer.chrome.com/origintrials/#/view_trial/3585991203293757441
22
+ // note: this is unstable API, Chrome less 94 use a `textLetterSpacing`, newest use a letterSpacing
23
+ // eslint-disable-next-line max-len
24
+ var supportLetterSpacing = 'letterSpacing' in CanvasRenderingContext2D.prototype
25
+ || 'textLetterSpacing' in CanvasRenderingContext2D.prototype;
26
+
27
+ if ((letterSpacing === 0 || supportLetterSpacing) && (!this.fillCustomColors || this.fillCustomColors.length === 0)) { //colors patch in if state
28
+ if (supportLetterSpacing) {
29
+ this.context.letterSpacing = letterSpacing;
30
+ this.context.textLetterSpacing = letterSpacing;
31
+ }
32
+ if (isStroke) {
33
+ this.context.strokeText(text, x, y);
34
+ }
35
+ else {
36
+ this.context.fillText(text, x, y);
37
+ }
38
+ return;
39
+ }
40
+ var currentPosition = x;
41
+
42
+ var textIndexOffset = this.text.indexOf(text); //colors patch block
43
+ var allTextLength = this.text.length;
44
+ var customColors = new Array(allTextLength);
45
+ if (this.fillCustomColors) {
46
+ for (var k in this.fillCustomColors) {
47
+ var colorsParams = this.fillCustomColors[k];
48
+ //customColors[colorsParams.position] = colorsParams.color;
49
+ customColors.fill(colorsParams.color, colorsParams.position, allTextLength);
50
+ }
51
+ }
52
+
53
+ // Using Array.from correctly splits characters whilst keeping emoji together.
54
+ // This is not supported on IE as it requires ES6, so regular text splitting occurs.
55
+ // This also doesn't account for emoji that are multiple emoji put together to make something else.
56
+ // Handling all of this would require a big library itself.
57
+ // https://medium.com/@giltayar/iterating-over-emoji-characters-the-es6-way-f06e4589516
58
+ // https://github.com/orling/grapheme-splitter
59
+ var stringArray = Array.from ? Array.from(text) : text.split('');
60
+ var previousWidth = this.context.measureText(text).width;
61
+ var currentWidth = 0;
62
+ for (var i = 0; i < stringArray.length; ++i) {
63
+ var currentChar = stringArray[i];
64
+
65
+ if (isStroke) {
66
+ this.context.strokeText(currentChar, currentPosition, y);
67
+ }
68
+ else {
69
+ if (customColors[textIndexOffset + i]) { //colors patch block
70
+ this.context.fillStyle = customColors[textIndexOffset + i];
71
+ }
72
+
73
+ this.context.fillText(currentChar, currentPosition, y);
74
+ }
75
+ currentWidth = this.context.measureText(text.substring(i + 1)).width;
76
+ currentPosition += previousWidth - currentWidth + letterSpacing;
77
+ previousWidth = currentWidth;
78
+ }
79
+ };
@@ -1,7 +1,7 @@
1
- Urso.setTimeout = (callback, delay) => {
2
- return gsap.delayedCall(delay / 1000, callback);
3
- }
4
-
5
- Urso.clearTimeout = (tween) => {
6
- tween.kill();
7
- }
1
+ Urso.setTimeout = (callback, delay) => {
2
+ return gsap.delayedCall(delay / 1000, callback);
3
+ }
4
+
5
+ Urso.clearTimeout = (tween) => {
6
+ tween.kill();
7
+ }
package/src/js/index.js CHANGED
@@ -1,8 +1,8 @@
1
- window.Urso = { Core: {} };
2
-
3
- require('./config/load.js');
4
- Urso.config = require('./config/main.js');
5
- Urso.Core.App = require('./app.js');
6
-
7
- //function to run game with engine
8
- Urso.runGame = (new Urso.Core.App()).setup;
1
+ window.Urso = { Core: {} };
2
+
3
+ require('./config/load.js');
4
+ Urso.config = require('./config/main.js');
5
+ Urso.Core.App = require('./app.js');
6
+
7
+ //function to run game with engine
8
+ Urso.runGame = (new Urso.Core.App()).setup;
@@ -1,13 +1,13 @@
1
- Urso.Core.Lib = {
2
- Cache: require('./cache.js'),
3
- Composition: require('./composition.js'),
4
- Device: require('./device.js'),
5
- Helper: require('./helper.js'),
6
- Loader: require('./loader.js'),
7
- LocalData: require('./localData.js'),
8
- Logger: require('./logger.js'),
9
- Math: require('./math.js'),
10
- ObjectPool: require('./objectPool.js'),
11
- Time: require('./time.js'),
12
- Tween: require('./tween.js')
13
- };
1
+ Urso.Core.Lib = {
2
+ Cache: require('./cache.js'),
3
+ Composition: require('./composition.js'),
4
+ Device: require('./device.js'),
5
+ Helper: require('./helper.js'),
6
+ Loader: require('./loader.js'),
7
+ LocalData: require('./localData.js'),
8
+ Logger: require('./logger.js'),
9
+ Math: require('./math.js'),
10
+ ObjectPool: require('./objectPool.js'),
11
+ Time: require('./time.js'),
12
+ Tween: require('./tween.js')
13
+ };
@@ -1,105 +1,105 @@
1
- class LibCache {
2
- constructor() {
3
- this.assetsList = {
4
- image: {},
5
- atlas: {},
6
- json: {},
7
- binary: {},
8
- spine: {},
9
- bitmapFont: {},
10
- sound: {},
11
- texture: {},
12
- file: {}
13
- };
14
-
15
- this.globalAtlas = new PIXI.spine.TextureAtlas();
16
- };
17
-
18
- addFile(key, someData) {
19
- this.assetsList.file[key] = someData;
20
- };
21
-
22
- addAtlas(key, someData) {
23
- this.assetsList.atlas[key] = someData;
24
- };
25
-
26
- addBinary(key, someData) {
27
- this.assetsList.binary[key] = someData;
28
- };
29
-
30
- addBitmapFont(key, someData) {
31
- this.assetsList.bitmapFont[key] = someData;
32
- };
33
-
34
- addContainer(key, someData) {
35
- this.assetsList.container[key] = someData;
36
- };
37
-
38
- addImage(key, someData) {
39
- this.assetsList.image[key] = someData;
40
- };
41
-
42
- addJson(key, someData) {
43
- this.assetsList.json[key] = someData;
44
- };
45
-
46
- addSound(key, someData) {
47
- this.assetsList.sound[key] = someData;
48
- };
49
-
50
- addTexture(key, someData) {
51
- this.assetsList.texture[key] = someData;
52
- this.globalAtlas.addTexture(key, someData);
53
- };
54
-
55
- addSpine(key, someData) {
56
- this.assetsList.spine[key] = someData;
57
- };
58
-
59
- getFile(key) {
60
- return this.assetsList.file[key];
61
- };
62
-
63
- getAtlas(key) {
64
- return this.assetsList.atlas[key];
65
- };
66
-
67
- getBinary(key) {
68
- return this.assetsList.binary[key];
69
- };
70
-
71
- getBitmapFont(key) {
72
- return this.assetsList.bitmapFont[key];
73
- };
74
-
75
- getContainer(key) {
76
- return this.assetsList.container[key];
77
- };
78
-
79
- getImage(key) {
80
- return this.assetsList.image[key];
81
- };
82
-
83
- getJson(key) {
84
- return this.assetsList.json[key];
85
- };
86
-
87
- getSound(key) {
88
- return this.assetsList.sound[key];
89
- };
90
-
91
- getSpine(key) {
92
- return this.assetsList.spine[key];
93
- };
94
-
95
- getTexture(key) {
96
- return this.assetsList.texture[key];
97
- };
98
-
99
- getGlobalAtlas() {
100
- return this.globalAtlas;
101
- }
102
-
103
- };
104
-
105
- module.exports = LibCache;
1
+ class LibCache {
2
+ constructor() {
3
+ this.assetsList = {
4
+ image: {},
5
+ atlas: {},
6
+ json: {},
7
+ binary: {},
8
+ spine: {},
9
+ bitmapFont: {},
10
+ sound: {},
11
+ texture: {},
12
+ file: {}
13
+ };
14
+
15
+ this.globalAtlas = new PIXI.spine.TextureAtlas();
16
+ };
17
+
18
+ addFile(key, someData) {
19
+ this.assetsList.file[key] = someData;
20
+ };
21
+
22
+ addAtlas(key, someData) {
23
+ this.assetsList.atlas[key] = someData;
24
+ };
25
+
26
+ addBinary(key, someData) {
27
+ this.assetsList.binary[key] = someData;
28
+ };
29
+
30
+ addBitmapFont(key, someData) {
31
+ this.assetsList.bitmapFont[key] = someData;
32
+ };
33
+
34
+ addContainer(key, someData) {
35
+ this.assetsList.container[key] = someData;
36
+ };
37
+
38
+ addImage(key, someData) {
39
+ this.assetsList.image[key] = someData;
40
+ };
41
+
42
+ addJson(key, someData) {
43
+ this.assetsList.json[key] = someData;
44
+ };
45
+
46
+ addSound(key, someData) {
47
+ this.assetsList.sound[key] = someData;
48
+ };
49
+
50
+ addTexture(key, someData) {
51
+ this.assetsList.texture[key] = someData;
52
+ this.globalAtlas.addTexture(key, someData);
53
+ };
54
+
55
+ addSpine(key, someData) {
56
+ this.assetsList.spine[key] = someData;
57
+ };
58
+
59
+ getFile(key) {
60
+ return this.assetsList.file[key];
61
+ };
62
+
63
+ getAtlas(key) {
64
+ return this.assetsList.atlas[key];
65
+ };
66
+
67
+ getBinary(key) {
68
+ return this.assetsList.binary[key];
69
+ };
70
+
71
+ getBitmapFont(key) {
72
+ return this.assetsList.bitmapFont[key];
73
+ };
74
+
75
+ getContainer(key) {
76
+ return this.assetsList.container[key];
77
+ };
78
+
79
+ getImage(key) {
80
+ return this.assetsList.image[key];
81
+ };
82
+
83
+ getJson(key) {
84
+ return this.assetsList.json[key];
85
+ };
86
+
87
+ getSound(key) {
88
+ return this.assetsList.sound[key];
89
+ };
90
+
91
+ getSpine(key) {
92
+ return this.assetsList.spine[key];
93
+ };
94
+
95
+ getTexture(key) {
96
+ return this.assetsList.texture[key];
97
+ };
98
+
99
+ getGlobalAtlas() {
100
+ return this.globalAtlas;
101
+ }
102
+
103
+ };
104
+
105
+ module.exports = LibCache;
@@ -1,85 +1,85 @@
1
- // Class for creating multi inheritance.
2
- class LibComposition {
3
- // Inherit method to create base classes.
4
- static inherit(..._bases) {
5
- class classes {
6
-
7
- // The base classes
8
- get base() { return _bases; }
9
-
10
- constructor(..._args) {
11
- let index = 0;
12
-
13
- for (let b of this.base) {
14
- let obj = new b(_args[index++]);
15
- LibComposition.copy(this, obj);
16
- }
17
- }
18
-
19
- }
20
-
21
- // Copy over properties and methods
22
- for (let base of _bases) {
23
- LibComposition.copy(classes, base);
24
- LibComposition.copy(classes.prototype, base.prototype, true);
25
- }
26
-
27
- return classes;
28
- }
29
-
30
- // Copies the properties from one class to another
31
- static copy(_target, _source, protoFlag) {
32
- for (let key of Reflect.ownKeys(_source)) {
33
- if (key !== "constructor" && key !== "prototype" && key !== "name") {
34
- let desc = Object.getOwnPropertyDescriptor(_source, key);
35
- Object.defineProperty(_target, key, desc);
36
- }
37
- }
38
-
39
- if (protoFlag && Object.getPrototypeOf(_source) !== Object.prototype) {
40
- LibComposition.copy(_target, Object.getPrototypeOf(_source));
41
- }
42
- }
43
- }
44
-
45
- module.exports = LibComposition;
46
-
47
-
48
- /**
49
- *
50
- example:
51
-
52
-
53
- class ages
54
- {
55
- constructor(_age) { this.age = _age; }
56
- set age(_a) { this._age = _a; }
57
- get age() { return this._age; }
58
- increase() { this.age++; }
59
- }
60
-
61
- class genders
62
- {
63
- constructor(_gender) { this.gender = _gender; }
64
- set gender(_g) { this._gender = _g; }
65
- get gender() { return this._gender; }
66
- male() { this._gender = 'M'; }
67
- female() { this._gender = 'F'; }
68
- }
69
-
70
- class person extends Urso.Game.Lib.Composition.inherit(ages, genders)
71
- {
72
- constructor(...args)
73
- {
74
- super(18, 'M');
75
- this.name = args[0];
76
- }
77
-
78
- set name(_n) { this._name = _n; }
79
- get name() { return this._name; }
80
- }
81
-
82
- let p = new person('Adam');
83
- console.log(p.name, p.age, p.gender);
84
-
85
- */
1
+ // Class for creating multi inheritance.
2
+ class LibComposition {
3
+ // Inherit method to create base classes.
4
+ static inherit(..._bases) {
5
+ class classes {
6
+
7
+ // The base classes
8
+ get base() { return _bases; }
9
+
10
+ constructor(..._args) {
11
+ let index = 0;
12
+
13
+ for (let b of this.base) {
14
+ let obj = new b(_args[index++]);
15
+ LibComposition.copy(this, obj);
16
+ }
17
+ }
18
+
19
+ }
20
+
21
+ // Copy over properties and methods
22
+ for (let base of _bases) {
23
+ LibComposition.copy(classes, base);
24
+ LibComposition.copy(classes.prototype, base.prototype, true);
25
+ }
26
+
27
+ return classes;
28
+ }
29
+
30
+ // Copies the properties from one class to another
31
+ static copy(_target, _source, protoFlag) {
32
+ for (let key of Reflect.ownKeys(_source)) {
33
+ if (key !== "constructor" && key !== "prototype" && key !== "name") {
34
+ let desc = Object.getOwnPropertyDescriptor(_source, key);
35
+ Object.defineProperty(_target, key, desc);
36
+ }
37
+ }
38
+
39
+ if (protoFlag && Object.getPrototypeOf(_source) !== Object.prototype) {
40
+ LibComposition.copy(_target, Object.getPrototypeOf(_source));
41
+ }
42
+ }
43
+ }
44
+
45
+ module.exports = LibComposition;
46
+
47
+
48
+ /**
49
+ *
50
+ example:
51
+
52
+
53
+ class ages
54
+ {
55
+ constructor(_age) { this.age = _age; }
56
+ set age(_a) { this._age = _a; }
57
+ get age() { return this._age; }
58
+ increase() { this.age++; }
59
+ }
60
+
61
+ class genders
62
+ {
63
+ constructor(_gender) { this.gender = _gender; }
64
+ set gender(_g) { this._gender = _g; }
65
+ get gender() { return this._gender; }
66
+ male() { this._gender = 'M'; }
67
+ female() { this._gender = 'F'; }
68
+ }
69
+
70
+ class person extends Urso.Game.Lib.Composition.inherit(ages, genders)
71
+ {
72
+ constructor(...args)
73
+ {
74
+ super(18, 'M');
75
+ this.name = args[0];
76
+ }
77
+
78
+ set name(_n) { this._name = _n; }
79
+ get name() { return this._name; }
80
+ }
81
+
82
+ let p = new person('Adam');
83
+ console.log(p.name, p.age, p.gender);
84
+
85
+ */