@urso/core 0.4.45 → 0.4.46

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 (153) 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/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 +66 -66
  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 +10 -10
  37. package/src/js/extra/_info.js +24 -24
  38. package/src/js/extra/browserEvents.js +38 -38
  39. package/src/js/extra/pixiPatch.js +79 -79
  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 +539 -539
  47. package/src/js/lib/loader.js +131 -131
  48. package/src/js/lib/localData.js +15 -15
  49. package/src/js/lib/logger.js +22 -22
  50. package/src/js/lib/math.js +35 -35
  51. package/src/js/lib/objectPool.js +54 -54
  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 +18 -18
  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 +13 -13
  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 +365 -365
  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 +261 -261
  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 +11 -11
  81. package/src/js/modules/objects/baseModel.js +197 -197
  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/create.js +237 -237
  85. package/src/js/modules/objects/find.js +140 -140
  86. package/src/js/modules/objects/models/_info.js +25 -25
  87. package/src/js/modules/objects/models/atlasImage.js +50 -50
  88. package/src/js/modules/objects/models/bitmapText.js +39 -39
  89. package/src/js/modules/objects/models/button.js +189 -189
  90. package/src/js/modules/objects/models/buttonComposite.js +35 -35
  91. package/src/js/modules/objects/models/checkbox.js +96 -96
  92. package/src/js/modules/objects/models/collection.js +54 -54
  93. package/src/js/modules/objects/models/component.js +44 -44
  94. package/src/js/modules/objects/models/container.js +19 -19
  95. package/src/js/modules/objects/models/emitter.js +54 -54
  96. package/src/js/modules/objects/models/graphics.js +38 -38
  97. package/src/js/modules/objects/models/group.js +19 -19
  98. package/src/js/modules/objects/models/hitArea.js +104 -104
  99. package/src/js/modules/objects/models/image.js +34 -34
  100. package/src/js/modules/objects/models/imagesAnimation.js +113 -113
  101. package/src/js/modules/objects/models/mask.js +38 -38
  102. package/src/js/modules/objects/models/nineSlicePlane.js +30 -30
  103. package/src/js/modules/objects/models/scrollbox.js +61 -61
  104. package/src/js/modules/objects/models/slider.js +253 -253
  105. package/src/js/modules/objects/models/spine.js +271 -271
  106. package/src/js/modules/objects/models/text.js +59 -59
  107. package/src/js/modules/objects/models/textInput.js +66 -66
  108. package/src/js/modules/objects/models/toggle.js +180 -180
  109. package/src/js/modules/objects/models/world.js +19 -19
  110. package/src/js/modules/objects/propertyAdapter.js +422 -422
  111. package/src/js/modules/objects/proxy.js +282 -282
  112. package/src/js/modules/objects/styles.js +120 -120
  113. package/src/js/modules/observer/_info.js +4 -4
  114. package/src/js/modules/observer/controller.js +99 -99
  115. package/src/js/modules/observer/events.js +44 -44
  116. package/src/js/modules/scenes/_info.js +8 -8
  117. package/src/js/modules/scenes/controller.js +103 -103
  118. package/src/js/modules/scenes/model.js +28 -28
  119. package/src/js/modules/scenes/pixiWrapper.js +237 -237
  120. package/src/js/modules/scenes/resolutions.js +173 -173
  121. package/src/js/modules/scenes/resolutionsConfig.js +73 -73
  122. package/src/js/modules/scenes/service.js +139 -139
  123. package/src/js/modules/soundManager/_info.js +3 -3
  124. package/src/js/modules/soundManager/controller.js +100 -100
  125. package/src/js/modules/soundManager/soundSprite.js +243 -243
  126. package/src/js/modules/statesManager/_info.js +12 -12
  127. package/src/js/modules/statesManager/action.js +60 -60
  128. package/src/js/modules/statesManager/actions/_info.js +3 -3
  129. package/src/js/modules/statesManager/all.js +23 -23
  130. package/src/js/modules/statesManager/configStates.js +71 -71
  131. package/src/js/modules/statesManager/controller.js +170 -170
  132. package/src/js/modules/statesManager/functionsStorage.js +82 -82
  133. package/src/js/modules/statesManager/helper.js +27 -27
  134. package/src/js/modules/statesManager/race.js +75 -75
  135. package/src/js/modules/statesManager/sequence.js +47 -47
  136. package/src/js/modules/template/_info.js +6 -6
  137. package/src/js/modules/template/controller.js +28 -28
  138. package/src/js/modules/template/model.js +11 -11
  139. package/src/js/modules/template/service.js +137 -137
  140. package/src/js/modules/template/types.js +45 -45
  141. package/src/js/modules/transport/_info.js +8 -8
  142. package/src/js/modules/transport/baseConnectionType.js +24 -24
  143. package/src/js/modules/transport/config.js +13 -13
  144. package/src/js/modules/transport/connectionTypes/_info.js +3 -3
  145. package/src/js/modules/transport/connectionTypes/websocket.js +74 -74
  146. package/src/js/modules/transport/connectionTypes/xhr.js +44 -44
  147. package/src/js/modules/transport/controller.js +48 -48
  148. package/src/js/modules/transport/decorator.js +17 -17
  149. package/src/js/modules/transport/service.js +153 -153
  150. package/src/js/templates/_info.js +4 -4
  151. package/src/js/templates/groups/_info.js +1 -1
  152. package/src/js/templates/scenes/_info.js +1 -1
  153. 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
+ */