@urso/core 0.4.34 → 0.4.35

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 +127 -127
  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 +78 -78
  73. package/src/js/modules/instances/_info.js +3 -3
  74. package/src/js/modules/instances/controller.js +251 -251
  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 -96
  80. package/src/js/modules/objects/_info.js +11 -11
  81. package/src/js/modules/objects/baseModel.js +191 -191
  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 +196 -196
  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 +211 -211
  112. package/src/js/modules/objects/styles.js +119 -119
  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 -99
  125. package/src/js/modules/soundManager/soundSprite.js +243 -205
  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,54 +1,54 @@
1
- class ModulesObjectsModelsCollection {
2
- constructor(param) {
3
- this._children = param || [];
4
- this._setProperty = this._setProperty.bind(this);
5
-
6
- this._methods = {
7
- setProperty: this._setProperty,
8
- addClass: this._runFunc('addClass'),
9
- removeClass: this._runFunc('removeClass')
10
- };
11
-
12
- return this._makeCollection();
13
- }
14
-
15
- _makeCollection(){
16
- for (const propName in this._methods)
17
- this._defineProp(this._children, propName, this._methods[propName]);
18
-
19
- return this._children;
20
- }
21
-
22
- _defineProp(obj, propName, propVal){
23
- Object.defineProperty(obj, propName, {
24
- enumerable: false,
25
- configurable: false,
26
- writable: false,
27
- value: propVal
28
- });
29
- }
30
-
31
- _checkAllHasProperty(prop) {
32
- return this._children.every(child => child.hasOwnProperty(prop));
33
- }
34
-
35
- _setProperty(prop, value){
36
- const allHasProperty = this._checkAllHasProperty(prop);
37
-
38
- if(allHasProperty)
39
- this._children.forEach(child => { child[prop] = value; });
40
-
41
- return allHasProperty;
42
- }
43
-
44
- _runFunc(funcName){
45
- return param => {
46
- this._children.forEach(child => {
47
- if(child[funcName])
48
- child[funcName](param);
49
- });
50
- };
51
- }
52
- }
53
-
54
- module.exports = ModulesObjectsModelsCollection;
1
+ class ModulesObjectsModelsCollection {
2
+ constructor(param) {
3
+ this._children = param || [];
4
+ this._setProperty = this._setProperty.bind(this);
5
+
6
+ this._methods = {
7
+ setProperty: this._setProperty,
8
+ addClass: this._runFunc('addClass'),
9
+ removeClass: this._runFunc('removeClass')
10
+ };
11
+
12
+ return this._makeCollection();
13
+ }
14
+
15
+ _makeCollection(){
16
+ for (const propName in this._methods)
17
+ this._defineProp(this._children, propName, this._methods[propName]);
18
+
19
+ return this._children;
20
+ }
21
+
22
+ _defineProp(obj, propName, propVal){
23
+ Object.defineProperty(obj, propName, {
24
+ enumerable: false,
25
+ configurable: false,
26
+ writable: false,
27
+ value: propVal
28
+ });
29
+ }
30
+
31
+ _checkAllHasProperty(prop) {
32
+ return this._children.every(child => child.hasOwnProperty(prop));
33
+ }
34
+
35
+ _setProperty(prop, value){
36
+ const allHasProperty = this._checkAllHasProperty(prop);
37
+
38
+ if(allHasProperty)
39
+ this._children.forEach(child => { child[prop] = value; });
40
+
41
+ return allHasProperty;
42
+ }
43
+
44
+ _runFunc(funcName){
45
+ return param => {
46
+ this._children.forEach(child => {
47
+ if(child[funcName])
48
+ child[funcName](param);
49
+ });
50
+ };
51
+ }
52
+ }
53
+
54
+ module.exports = ModulesObjectsModelsCollection;
@@ -1,45 +1,45 @@
1
- class ModulesObjectsModelsComponent extends Urso.Core.Modules.Objects.BaseModel {
2
- constructor(params) {
3
- super(params);
4
-
5
- this.type = Urso.types.objects.COMPONENT;
6
- this.instance = null;
7
-
8
- //system
9
- this._controller = Urso.helper.recursiveGet('_controller', params, false); //will setup on create.
10
-
11
- this._addBaseObject();
12
- }
13
-
14
- setupParams(params) {
15
- super.setupParams(params);
16
-
17
- this.componentName = Urso.helper.recursiveGet('componentName', params, false);
18
- this.options = Urso.helper.recursiveGet('options', params, false);
19
- this.contents = Urso.helper.recursiveGet('contents', params, []);
20
- }
21
-
22
- _addBaseObject() {
23
- this._baseObject = new PIXI.Container();
24
-
25
- //all components must have name
26
- if (!this.name)
27
- this.name = 'component_' + this._uid;
28
-
29
- this._setComonFunctions();
30
- };
31
-
32
- _setComonFunctions() {
33
- this.instance = this._controller;
34
-
35
- this._setupFind(this.instance);
36
- }
37
-
38
- _setupFind(instance) {
39
- instance.common.find = (selector) => Urso.find(`^${this.name} ${selector}`);
40
- instance.common.findOne = (selector) => Urso.findOne(`^${this.name} ${selector}`);
41
- instance.common.findAll = (selector) => Urso.findAll(`^${this.name} ${selector}`);
42
- }
43
- }
44
-
1
+ class ModulesObjectsModelsComponent extends Urso.Core.Modules.Objects.BaseModel {
2
+ constructor(params) {
3
+ super(params);
4
+
5
+ this.type = Urso.types.objects.COMPONENT;
6
+ this.instance = null;
7
+
8
+ //system
9
+ this._controller = Urso.helper.recursiveGet('_controller', params, false); //will setup on create.
10
+
11
+ this._addBaseObject();
12
+ }
13
+
14
+ setupParams(params) {
15
+ super.setupParams(params);
16
+
17
+ this.componentName = Urso.helper.recursiveGet('componentName', params, false);
18
+ this.options = Urso.helper.recursiveGet('options', params, false);
19
+ this.contents = Urso.helper.recursiveGet('contents', params, []);
20
+ }
21
+
22
+ _addBaseObject() {
23
+ this._baseObject = new PIXI.Container();
24
+
25
+ //all components must have name
26
+ if (!this.name)
27
+ this.name = 'component_' + this._uid;
28
+
29
+ this._setComonFunctions();
30
+ };
31
+
32
+ _setComonFunctions() {
33
+ this.instance = this._controller;
34
+
35
+ this._setupFind(this.instance);
36
+ }
37
+
38
+ _setupFind(instance) {
39
+ instance.common.find = (selector) => Urso.find(`^${this.name} ${selector}`);
40
+ instance.common.findOne = (selector) => Urso.findOne(`^${this.name} ${selector}`);
41
+ instance.common.findAll = (selector) => Urso.findAll(`^${this.name} ${selector}`);
42
+ }
43
+ }
44
+
45
45
  module.exports = ModulesObjectsModelsComponent;
@@ -1,20 +1,20 @@
1
- class ModulesObjectsModelsContainer extends Urso.Core.Modules.Objects.BaseModel {
2
- constructor(params) {
3
- super(params);
4
-
5
- this.type = Urso.types.objects.CONTAINER;
6
- this._addBaseObject();
7
- }
8
-
9
- setupParams(params) {
10
- super.setupParams(params);
11
-
12
- this.contents = Urso.helper.recursiveGet('contents', params, []);
13
- }
14
-
15
- _addBaseObject() {
16
- this._baseObject = new PIXI.Container();
17
- };
18
- }
19
-
1
+ class ModulesObjectsModelsContainer extends Urso.Core.Modules.Objects.BaseModel {
2
+ constructor(params) {
3
+ super(params);
4
+
5
+ this.type = Urso.types.objects.CONTAINER;
6
+ this._addBaseObject();
7
+ }
8
+
9
+ setupParams(params) {
10
+ super.setupParams(params);
11
+
12
+ this.contents = Urso.helper.recursiveGet('contents', params, []);
13
+ }
14
+
15
+ _addBaseObject() {
16
+ this._baseObject = new PIXI.Container();
17
+ };
18
+ }
19
+
20
20
  module.exports = ModulesObjectsModelsContainer
@@ -1,54 +1,54 @@
1
- class ModulesObjectsModelsEmitter extends Urso.Core.Modules.Objects.BaseModel {
2
- constructor(params) {
3
- super(params);
4
-
5
- this.type = Urso.types.objects.EMITTER;
6
-
7
- this.emitter = null;
8
-
9
- this._addBaseObject();
10
- this._addEmitter();
11
- }
12
-
13
- setupParams(params) {
14
- super.setupParams(params);
15
-
16
- this.autostart = Urso.helper.recursiveGet('autostart', params, false);
17
- this.cfg = Urso.helper.recursiveGet('cfg', params, false); // json asset key with emitter config
18
- this.textures = Urso.helper.recursiveGet('textures', params, []); // array of image asset keys
19
- }
20
-
21
- _addBaseObject() {
22
- this._baseObject = new PIXI.ParticleContainer();
23
- this._baseObject.setProperties({
24
- scale: true,
25
- position: true,
26
- rotation: true,
27
- uvs: true,
28
- alpha: true,
29
- });
30
- };
31
-
32
- _addEmitter() {
33
- const cfg = Urso.cache.getJson(this.cfg);
34
- const textures = [];
35
-
36
- if (!cfg || !cfg.data)
37
- throw new SyntaxError(`Config error in ${this.name} emitter`);
38
-
39
- for (const textureName of this.textures) {
40
- const texture = Urso.cache.getTexture(textureName);
41
- if (texture)
42
- textures.push(texture);
43
- }
44
- this.emitter = new PIXI.particles.Emitter(this._baseObject, textures, cfg.data);
45
- this.emitter.emit = this.autostart;
46
- this.emitter.autoUpdate = true;
47
- }
48
-
49
- play() {
50
- this.emitter.emit = true;
51
- }
52
- }
53
-
54
- module.exports = ModulesObjectsModelsEmitter;
1
+ class ModulesObjectsModelsEmitter extends Urso.Core.Modules.Objects.BaseModel {
2
+ constructor(params) {
3
+ super(params);
4
+
5
+ this.type = Urso.types.objects.EMITTER;
6
+
7
+ this.emitter = null;
8
+
9
+ this._addBaseObject();
10
+ this._addEmitter();
11
+ }
12
+
13
+ setupParams(params) {
14
+ super.setupParams(params);
15
+
16
+ this.autostart = Urso.helper.recursiveGet('autostart', params, false);
17
+ this.cfg = Urso.helper.recursiveGet('cfg', params, false); // json asset key with emitter config
18
+ this.textures = Urso.helper.recursiveGet('textures', params, []); // array of image asset keys
19
+ }
20
+
21
+ _addBaseObject() {
22
+ this._baseObject = new PIXI.ParticleContainer();
23
+ this._baseObject.setProperties({
24
+ scale: true,
25
+ position: true,
26
+ rotation: true,
27
+ uvs: true,
28
+ alpha: true,
29
+ });
30
+ };
31
+
32
+ _addEmitter() {
33
+ const cfg = Urso.cache.getJson(this.cfg);
34
+ const textures = [];
35
+
36
+ if (!cfg || !cfg.data)
37
+ throw new SyntaxError(`Config error in ${this.name} emitter`);
38
+
39
+ for (const textureName of this.textures) {
40
+ const texture = Urso.cache.getTexture(textureName);
41
+ if (texture)
42
+ textures.push(texture);
43
+ }
44
+ this.emitter = new PIXI.particles.Emitter(this._baseObject, textures, cfg.data);
45
+ this.emitter.emit = this.autostart;
46
+ this.emitter.autoUpdate = true;
47
+ }
48
+
49
+ play() {
50
+ this.emitter.emit = true;
51
+ }
52
+ }
53
+
54
+ module.exports = ModulesObjectsModelsEmitter;
@@ -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;