@urso/core 0.5.3 → 0.5.6

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 (158) 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 +222 -38
  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/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 +12 -12
  37. package/src/js/extra/_info.js +26 -26
  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 +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 +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 +12 -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/find.js +58 -140
  85. package/src/js/modules/objects/models/_info.js +26 -26
  86. package/src/js/modules/objects/models/atlasImage.js +50 -50
  87. package/src/js/modules/objects/models/bitmapText.js +39 -39
  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 +44 -44
  93. package/src/js/modules/objects/models/container.js +19 -19
  94. package/src/js/modules/objects/models/emitter.js +67 -67
  95. package/src/js/modules/objects/models/emitterFx.js +99 -99
  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 +64 -61
  104. package/src/js/modules/objects/models/slider.js +253 -253
  105. package/src/js/modules/objects/models/spine.js +276 -276
  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 +423 -423
  111. package/src/js/modules/objects/proxy.js +282 -282
  112. package/src/js/modules/objects/selector.js +136 -0
  113. package/src/js/modules/objects/service.js +240 -240
  114. package/src/js/modules/objects/styles.js +210 -120
  115. package/src/js/modules/observer/_info.js +4 -4
  116. package/src/js/modules/observer/controller.js +99 -99
  117. package/src/js/modules/observer/events.js +45 -45
  118. package/src/js/modules/scenes/_info.js +8 -8
  119. package/src/js/modules/scenes/controller.js +103 -103
  120. package/src/js/modules/scenes/model.js +28 -28
  121. package/src/js/modules/scenes/pixiWrapper.js +237 -237
  122. package/src/js/modules/scenes/resolutions.js +173 -173
  123. package/src/js/modules/scenes/resolutionsConfig.js +73 -73
  124. package/src/js/modules/scenes/service.js +142 -142
  125. package/src/js/modules/soundManager/_info.js +3 -3
  126. package/src/js/modules/soundManager/controller.js +100 -100
  127. package/src/js/modules/soundManager/soundSprite.js +256 -243
  128. package/src/js/modules/statesManager/_info.js +12 -12
  129. package/src/js/modules/statesManager/action.js +60 -60
  130. package/src/js/modules/statesManager/actions/_info.js +3 -3
  131. package/src/js/modules/statesManager/all.js +23 -23
  132. package/src/js/modules/statesManager/configStates.js +71 -71
  133. package/src/js/modules/statesManager/controller.js +170 -170
  134. package/src/js/modules/statesManager/functionsStorage.js +82 -82
  135. package/src/js/modules/statesManager/helper.js +27 -27
  136. package/src/js/modules/statesManager/race.js +75 -75
  137. package/src/js/modules/statesManager/sequence.js +47 -47
  138. package/src/js/modules/template/_info.js +6 -6
  139. package/src/js/modules/template/controller.js +28 -28
  140. package/src/js/modules/template/model.js +11 -11
  141. package/src/js/modules/template/service.js +137 -137
  142. package/src/js/modules/template/types.js +46 -46
  143. package/src/js/modules/transport/_info.js +8 -8
  144. package/src/js/modules/transport/baseConnectionType.js +24 -24
  145. package/src/js/modules/transport/config.js +13 -13
  146. package/src/js/modules/transport/connectionTypes/_info.js +3 -3
  147. package/src/js/modules/transport/connectionTypes/websocket.js +74 -74
  148. package/src/js/modules/transport/connectionTypes/xhr.js +44 -44
  149. package/src/js/modules/transport/controller.js +48 -48
  150. package/src/js/modules/transport/decorator.js +17 -17
  151. package/src/js/modules/transport/service.js +153 -153
  152. package/src/js/templates/_info.js +4 -4
  153. package/src/js/templates/groups/_info.js +1 -1
  154. package/src/js/templates/scenes/_info.js +1 -1
  155. package/webpack.config.js +47 -47
  156. package/src/js/components/editor/_info.js +0 -4
  157. package/src/js/components/editor/api.js +0 -72
  158. package/src/js/components/editor/controller.js +0 -13
@@ -1,99 +1,99 @@
1
- class ModulesObjectsModelsEmitterFx extends Urso.Core.Modules.Objects.BaseModel {
2
- constructor(params) {
3
- super(params);
4
-
5
- this.type = Urso.types.objects.EMITTERFX;
6
-
7
- this.emitter = null;
8
- this.update = this.update.bind(this);
9
-
10
- this._addBaseObject();
11
- this._createBundle();
12
- }
13
-
14
- /**
15
- *
16
- * @param {Object} params
17
- *
18
- * - Params have to contain 'cfg' which is a key of JSON config made via
19
- * https://editor.revoltfx.electronauts.net editor.
20
- * - In a case config doesn't have textures described in it, you can use spritesheetFilter which should be a
21
- * string, described common part of texures asset keys. That string will be used as filter to get textures from cache.
22
- * If textures should be animated, texture's asset key have to be of the next format:
23
- * mc_commonPart_01 - where 'mc' stands for 'movieclips' allows us use animation, commonPart - described all textures in a spriteSheet,
24
- * and _01 - number of frame.
25
- */
26
- setupParams(params) {
27
- super.setupParams(params);
28
-
29
- this.autostart = Urso.helper.recursiveGet('autostart', params, false);
30
- this.cfg = Urso.helper.recursiveGet('cfg', params, false);
31
- this.spritesheetFilter = Urso.helper.recursiveGet('spritesheetFilter', params, false);
32
- }
33
-
34
- update(deltaTime) {
35
- if (this._emitter) {
36
- this._bundle.update(deltaTime * PIXI.settings.TARGET_FPMS);
37
- }
38
- }
39
-
40
- /**
41
- * @param {String} emitterName
42
- * Inits emitter by it's name. If no name given - inits first emitter from config.
43
- */
44
- play(emitterName) {
45
- this._isActive = true;
46
-
47
- emitterName = emitterName || this._defaultEmitterName;
48
-
49
- this._emitter = this._bundle.getParticleEmitter(emitterName);
50
- this._emitter.init(this._baseObject, true, 1);
51
- }
52
-
53
- /**
54
- *
55
- * Stops emitter. If new emitter wasn't inited before particles disappears - clears this._emitter to stop bundle update.
56
- */
57
- stop() {
58
- if(!this._emitter)
59
- return;
60
-
61
- this._emitter.stop();
62
- this._emitter.on.completed.add(() => {
63
- if(!this._isActive)
64
- this._emitter = null;
65
- });
66
-
67
- this._isActive = false;
68
- }
69
-
70
- _addBaseObject() {
71
- this._baseObject = new PIXI.Container();
72
- };
73
-
74
- _createBundle() {
75
- this._bundle = new PIXI.particlesFx.FX();
76
- let fx_settings_data = Urso.cache.getJson(this.cfg).data;
77
-
78
- if(this.spritesheetFilter)
79
- fx_settings_data.spritesheetFilter = this.spritesheetFilter;
80
-
81
- this._defaultEmitterName = fx_settings_data.emitters[0].name;
82
-
83
- this._bundle.initBundle(fx_settings_data);
84
- this.autostart && this.play();
85
- }
86
-
87
- _subscribeOnce() {
88
- this.addListener(Urso.events.MODULES_SCENES_UPDATE, this.update);
89
- }
90
-
91
- _customDestroy() {
92
- this.removeListener(Urso.events.MODULES_SCENES_UPDATE, this.update);
93
- this._emitter.stop(false);
94
- this._bundle = null;
95
- this._emitter = null;
96
- }
97
- }
98
-
99
- module.exports = ModulesObjectsModelsEmitterFx;
1
+ class ModulesObjectsModelsEmitterFx extends Urso.Core.Modules.Objects.BaseModel {
2
+ constructor(params) {
3
+ super(params);
4
+
5
+ this.type = Urso.types.objects.EMITTERFX;
6
+
7
+ this.emitter = null;
8
+ this.update = this.update.bind(this);
9
+
10
+ this._addBaseObject();
11
+ this._createBundle();
12
+ }
13
+
14
+ /**
15
+ *
16
+ * @param {Object} params
17
+ *
18
+ * - Params have to contain 'cfg' which is a key of JSON config made via
19
+ * https://editor.revoltfx.electronauts.net editor.
20
+ * - In a case config doesn't have textures described in it, you can use spritesheetFilter which should be a
21
+ * string, described common part of texures asset keys. That string will be used as filter to get textures from cache.
22
+ * If textures should be animated, texture's asset key have to be of the next format:
23
+ * mc_commonPart_01 - where 'mc' stands for 'movieclips' allows us use animation, commonPart - described all textures in a spriteSheet,
24
+ * and _01 - number of frame.
25
+ */
26
+ setupParams(params) {
27
+ super.setupParams(params);
28
+
29
+ this.autostart = Urso.helper.recursiveGet('autostart', params, false);
30
+ this.cfg = Urso.helper.recursiveGet('cfg', params, false);
31
+ this.spritesheetFilter = Urso.helper.recursiveGet('spritesheetFilter', params, false);
32
+ }
33
+
34
+ update(deltaTime) {
35
+ if (this._emitter) {
36
+ this._bundle.update(deltaTime * PIXI.settings.TARGET_FPMS);
37
+ }
38
+ }
39
+
40
+ /**
41
+ * @param {String} emitterName
42
+ * Inits emitter by it's name. If no name given - inits first emitter from config.
43
+ */
44
+ play(emitterName) {
45
+ this._isActive = true;
46
+
47
+ emitterName = emitterName || this._defaultEmitterName;
48
+
49
+ this._emitter = this._bundle.getParticleEmitter(emitterName);
50
+ this._emitter.init(this._baseObject, true, 1);
51
+ }
52
+
53
+ /**
54
+ *
55
+ * Stops emitter. If new emitter wasn't inited before particles disappears - clears this._emitter to stop bundle update.
56
+ */
57
+ stop() {
58
+ if(!this._emitter)
59
+ return;
60
+
61
+ this._emitter.stop();
62
+ this._emitter.on.completed.add(() => {
63
+ if(!this._isActive)
64
+ this._emitter = null;
65
+ });
66
+
67
+ this._isActive = false;
68
+ }
69
+
70
+ _addBaseObject() {
71
+ this._baseObject = new PIXI.Container();
72
+ };
73
+
74
+ _createBundle() {
75
+ this._bundle = new PIXI.particlesFx.FX();
76
+ let fx_settings_data = Urso.cache.getJson(this.cfg).data;
77
+
78
+ if(this.spritesheetFilter)
79
+ fx_settings_data.spritesheetFilter = this.spritesheetFilter;
80
+
81
+ this._defaultEmitterName = fx_settings_data.emitters[0].name;
82
+
83
+ this._bundle.initBundle(fx_settings_data);
84
+ this.autostart && this.play();
85
+ }
86
+
87
+ _subscribeOnce() {
88
+ this.addListener(Urso.events.MODULES_SCENES_UPDATE, this.update);
89
+ }
90
+
91
+ _customDestroy() {
92
+ this.removeListener(Urso.events.MODULES_SCENES_UPDATE, this.update);
93
+ this._emitter.stop(false);
94
+ this._bundle = null;
95
+ this._emitter = null;
96
+ }
97
+ }
98
+
99
+ module.exports = ModulesObjectsModelsEmitterFx;
@@ -1,38 +1,38 @@
1
- class ModulesObjectsModelsGraphics extends Urso.Core.Modules.Objects.BaseModel {
2
- constructor(params) {
3
- super(params);
4
-
5
- this.type = Urso.types.objects.GRAPHICS;
6
- this._addBaseObject();
7
- this._drawPoligon();
8
- }
9
-
10
- setupParams(params) {
11
- super.setupParams(params);
12
-
13
- this.polygon = Urso.helper.recursiveGet('figure.polygon', params, []);
14
- this.rectangle = Urso.helper.recursiveGet('figure.rectangle', params, []);
15
- this.fillColor = Urso.helper.recursiveGet('figure.fillColor', params, 0x000000);
16
- }
17
-
18
- _drawPoligon() {
19
- if (!this.polygon.length && !this.rectangle.length)
20
- return;
21
-
22
- this._baseObject.beginFill(this.fillColor);
23
-
24
- if (this.polygon.length) {
25
- this._baseObject.drawPolygon(this.polygon);
26
- } else if (this.rectangle.length) {
27
- this._baseObject.drawRect(...this.rectangle)
28
- }
29
-
30
- this._baseObject.endFill();
31
- };
32
-
33
- _addBaseObject() {
34
- this._baseObject = new PIXI.Graphics();
35
- };
36
- }
37
-
38
- module.exports = ModulesObjectsModelsGraphics;
1
+ class ModulesObjectsModelsGraphics extends Urso.Core.Modules.Objects.BaseModel {
2
+ constructor(params) {
3
+ super(params);
4
+
5
+ this.type = Urso.types.objects.GRAPHICS;
6
+ this._addBaseObject();
7
+ this._drawPoligon();
8
+ }
9
+
10
+ setupParams(params) {
11
+ super.setupParams(params);
12
+
13
+ this.polygon = Urso.helper.recursiveGet('figure.polygon', params, []);
14
+ this.rectangle = Urso.helper.recursiveGet('figure.rectangle', params, []);
15
+ this.fillColor = Urso.helper.recursiveGet('figure.fillColor', params, 0x000000);
16
+ }
17
+
18
+ _drawPoligon() {
19
+ if (!this.polygon.length && !this.rectangle.length)
20
+ return;
21
+
22
+ this._baseObject.beginFill(this.fillColor);
23
+
24
+ if (this.polygon.length) {
25
+ this._baseObject.drawPolygon(this.polygon);
26
+ } else if (this.rectangle.length) {
27
+ this._baseObject.drawRect(...this.rectangle)
28
+ }
29
+
30
+ this._baseObject.endFill();
31
+ };
32
+
33
+ _addBaseObject() {
34
+ this._baseObject = new PIXI.Graphics();
35
+ };
36
+ }
37
+
38
+ module.exports = ModulesObjectsModelsGraphics;
@@ -1,20 +1,20 @@
1
- class ModulesObjectsModelsGroup extends Urso.Core.Modules.Objects.BaseModel {
2
- constructor(params) {
3
- super(params);
4
-
5
- this.type = Urso.types.objects.GROUP;
6
- this._addBaseObject();
7
- }
8
-
9
- setupParams(params) {
10
- super.setupParams(params);
11
-
12
- this.groupName = Urso.helper.recursiveGet('groupName', params, false);
13
- }
14
-
15
- _addBaseObject() {
16
- this._baseObject = new PIXI.Container();
17
- };
18
- }
19
-
1
+ class ModulesObjectsModelsGroup extends Urso.Core.Modules.Objects.BaseModel {
2
+ constructor(params) {
3
+ super(params);
4
+
5
+ this.type = Urso.types.objects.GROUP;
6
+ this._addBaseObject();
7
+ }
8
+
9
+ setupParams(params) {
10
+ super.setupParams(params);
11
+
12
+ this.groupName = Urso.helper.recursiveGet('groupName', params, false);
13
+ }
14
+
15
+ _addBaseObject() {
16
+ this._baseObject = new PIXI.Container();
17
+ };
18
+ }
19
+
20
20
  module.exports = ModulesObjectsModelsGroup;
@@ -1,104 +1,104 @@
1
- class ModulesObjectsModelsHitArea extends Urso.Core.Modules.Objects.BaseModel {
2
- constructor(params) {
3
- super(params);
4
- this._isDisabled = false;
5
-
6
- this.type = Urso.types.objects.HITAREA;
7
-
8
- this._addBaseObject();
9
-
10
- this.enable = this.enable.bind(this);
11
- this.disable = this.disable.bind(this);
12
- }
13
-
14
- setupParams(params) {
15
- super.setupParams(params);
16
-
17
- //must have x,y, width, height
18
- this.action = Urso.helper.recursiveGet(
19
- 'action', params, (position) => { this.emit(Urso.events.MODULES_OBJECTS_HIT_AREA_PRESS, { position, name: this.name, class: this.class }) }
20
- );
21
- this.onOverCallback = Urso.helper.recursiveGet('onOverCallback', params, false);
22
- this.onOutCallback = Urso.helper.recursiveGet('onOutCallback', params, false);
23
- this.onTouchMoveCallback = Urso.helper.recursiveGet('onTouchMoveCallback', params, false);
24
- }
25
-
26
- enable() {
27
- if (!this._isDisabled)
28
- return false;
29
-
30
- this._isDisabled = false;
31
- }
32
-
33
- disable() {
34
- if (this._isDisabled)
35
- return false;
36
-
37
- this._isDisabled = true;
38
- }
39
-
40
- _addBaseObject() {
41
- this._baseObject = new PIXI.Graphics();
42
-
43
- this._baseObject.lineStyle(0);
44
- this._baseObject.beginFill(0xffffff);
45
- this._baseObject.drawRect(0, 0, this.width, this.height);
46
- this._baseObject.endFill();
47
- this._baseObject.alpha = 0;
48
- this._baseObject.cacheAsBitmap = true;
49
-
50
- this._baseObject.interactive = true;
51
- this._baseObject.buttonMode = true;
52
-
53
- this._baseObject
54
- .on('pointerup', this._onPressUp.bind(this))
55
- .on('pointerover', this._onOver.bind(this))
56
- .on('pointerout', this._onOut.bind(this))
57
- .on('touchmove', this._onTouchmove.bind(this));
58
- };
59
-
60
- _onTouchmove(event) {
61
- const position = this._getEventLocalPosition(event);
62
-
63
- if (this.onTouchMoveCallback)
64
- this.onTouchMoveCallback(position);
65
- }
66
-
67
- _onPressUp(event) {
68
- if (this._isDisabled)
69
- return false;
70
-
71
- if (this.action) {
72
- const position = this._getEventLocalPosition(event);
73
- this.action(position);
74
- }
75
- }
76
-
77
- _onOver() {
78
- if (this._isDisabled)
79
- return false;
80
-
81
- if (this.onOverCallback)
82
- this.onOverCallback();
83
- }
84
-
85
- _onOut() {
86
- if (this._isDisabled)
87
- return false;
88
-
89
- if (this.onOutCallback)
90
- this.onOutCallback();
91
- }
92
-
93
- _getEventLocalPosition(event) {
94
- const world = Urso.objects.getWorld();
95
- const worldScale = world._baseObject.scale;
96
-
97
- const x = event.data.global.x / worldScale.x;
98
- const y = event.data.global.y / worldScale.y;
99
-
100
- return { x, y };
101
- }
102
- }
103
-
104
- module.exports = ModulesObjectsModelsHitArea;
1
+ class ModulesObjectsModelsHitArea extends Urso.Core.Modules.Objects.BaseModel {
2
+ constructor(params) {
3
+ super(params);
4
+ this._isDisabled = false;
5
+
6
+ this.type = Urso.types.objects.HITAREA;
7
+
8
+ this._addBaseObject();
9
+
10
+ this.enable = this.enable.bind(this);
11
+ this.disable = this.disable.bind(this);
12
+ }
13
+
14
+ setupParams(params) {
15
+ super.setupParams(params);
16
+
17
+ //must have x,y, width, height
18
+ this.action = Urso.helper.recursiveGet(
19
+ 'action', params, (position) => { this.emit(Urso.events.MODULES_OBJECTS_HIT_AREA_PRESS, { position, name: this.name, class: this.class }) }
20
+ );
21
+ this.onOverCallback = Urso.helper.recursiveGet('onOverCallback', params, false);
22
+ this.onOutCallback = Urso.helper.recursiveGet('onOutCallback', params, false);
23
+ this.onTouchMoveCallback = Urso.helper.recursiveGet('onTouchMoveCallback', params, false);
24
+ }
25
+
26
+ enable() {
27
+ if (!this._isDisabled)
28
+ return false;
29
+
30
+ this._isDisabled = false;
31
+ }
32
+
33
+ disable() {
34
+ if (this._isDisabled)
35
+ return false;
36
+
37
+ this._isDisabled = true;
38
+ }
39
+
40
+ _addBaseObject() {
41
+ this._baseObject = new PIXI.Graphics();
42
+
43
+ this._baseObject.lineStyle(0);
44
+ this._baseObject.beginFill(0xffffff);
45
+ this._baseObject.drawRect(0, 0, this.width, this.height);
46
+ this._baseObject.endFill();
47
+ this._baseObject.alpha = 0;
48
+ this._baseObject.cacheAsBitmap = true;
49
+
50
+ this._baseObject.interactive = true;
51
+ this._baseObject.buttonMode = true;
52
+
53
+ this._baseObject
54
+ .on('pointerup', this._onPressUp.bind(this))
55
+ .on('pointerover', this._onOver.bind(this))
56
+ .on('pointerout', this._onOut.bind(this))
57
+ .on('touchmove', this._onTouchmove.bind(this));
58
+ };
59
+
60
+ _onTouchmove(event) {
61
+ const position = this._getEventLocalPosition(event);
62
+
63
+ if (this.onTouchMoveCallback)
64
+ this.onTouchMoveCallback(position);
65
+ }
66
+
67
+ _onPressUp(event) {
68
+ if (this._isDisabled)
69
+ return false;
70
+
71
+ if (this.action) {
72
+ const position = this._getEventLocalPosition(event);
73
+ this.action(position);
74
+ }
75
+ }
76
+
77
+ _onOver() {
78
+ if (this._isDisabled)
79
+ return false;
80
+
81
+ if (this.onOverCallback)
82
+ this.onOverCallback();
83
+ }
84
+
85
+ _onOut() {
86
+ if (this._isDisabled)
87
+ return false;
88
+
89
+ if (this.onOutCallback)
90
+ this.onOutCallback();
91
+ }
92
+
93
+ _getEventLocalPosition(event) {
94
+ const world = Urso.objects.getWorld();
95
+ const worldScale = world._baseObject.scale;
96
+
97
+ const x = event.data.global.x / worldScale.x;
98
+ const y = event.data.global.y / worldScale.y;
99
+
100
+ return { x, y };
101
+ }
102
+ }
103
+
104
+ module.exports = ModulesObjectsModelsHitArea;
@@ -1,34 +1,34 @@
1
- class ModulesObjectsModelsImage extends Urso.Core.Modules.Objects.BaseModel {
2
- constructor(params) {
3
- super(params);
4
-
5
- this.type = Urso.types.objects.IMAGE;
6
- this._addBaseObject();
7
- }
8
-
9
- setupParams(params) {
10
- super.setupParams(params);
11
-
12
- this.assetKey = Urso.helper.recursiveGet('assetKey', params, false);
13
- }
14
-
15
- changeTexture(assetKey) {
16
- this.assetKey = assetKey;
17
-
18
- this._addBaseObject();
19
- }
20
-
21
- _addBaseObject() {
22
- let texture = Urso.cache.getTexture(this.assetKey)
23
-
24
- if (!texture)
25
- Urso.logger.error('ModulesObjectsModelsImage assets error: no image with key: ' + this.assetKey);
26
-
27
- if (!this._baseObject)
28
- this._baseObject = new PIXI.Sprite(texture);
29
- else
30
- this._baseObject.texture = texture;
31
- };
32
- }
33
-
34
- module.exports = ModulesObjectsModelsImage;
1
+ class ModulesObjectsModelsImage extends Urso.Core.Modules.Objects.BaseModel {
2
+ constructor(params) {
3
+ super(params);
4
+
5
+ this.type = Urso.types.objects.IMAGE;
6
+ this._addBaseObject();
7
+ }
8
+
9
+ setupParams(params) {
10
+ super.setupParams(params);
11
+
12
+ this.assetKey = Urso.helper.recursiveGet('assetKey', params, false);
13
+ }
14
+
15
+ changeTexture(assetKey) {
16
+ this.assetKey = assetKey;
17
+
18
+ this._addBaseObject();
19
+ }
20
+
21
+ _addBaseObject() {
22
+ let texture = Urso.cache.getTexture(this.assetKey)
23
+
24
+ if (!texture)
25
+ Urso.logger.error('ModulesObjectsModelsImage assets error: no image with key: ' + this.assetKey);
26
+
27
+ if (!this._baseObject)
28
+ this._baseObject = new PIXI.Sprite(texture);
29
+ else
30
+ this._baseObject.texture = texture;
31
+ };
32
+ }
33
+
34
+ module.exports = ModulesObjectsModelsImage;