@urso/core 0.8.21 → 0.9.1-dev

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 (134) hide show
  1. package/LICENSE +20 -20
  2. package/README.md +227 -227
  3. package/build/js/index.js +77212 -2
  4. package/package.json +36 -50
  5. package/src/js/app.js +105 -104
  6. package/src/js/components/base/controller.js +76 -78
  7. package/src/js/components/debug/controller.js +39 -39
  8. package/src/js/components/debug/coords.js +23 -23
  9. package/src/js/components/debug/fps.js +36 -36
  10. package/src/js/components/debug/template.js +55 -55
  11. package/src/js/components/debug/timescale.js +60 -60
  12. package/src/js/components/deviceRotate/controller.js +95 -95
  13. package/src/js/components/editor/api.js +127 -127
  14. package/src/js/components/editor/controller.js +13 -13
  15. package/src/js/components/fullscreen/android.js +104 -104
  16. package/src/js/components/fullscreen/controller.js +76 -76
  17. package/src/js/components/fullscreen/desktop.js +49 -49
  18. package/src/js/components/fullscreen/ios.js +115 -115
  19. package/src/js/components/layersSwitcher/config.js +26 -26
  20. package/src/js/components/layersSwitcher/controller.js +36 -36
  21. package/src/js/components/loader/controller.js +66 -66
  22. package/src/js/components/loader/template.js +71 -71
  23. package/src/js/components/soundInitialPopup/controller.js +43 -43
  24. package/src/js/components/soundInitialPopup/template.js +110 -110
  25. package/src/js/components/stateDriven/controller.js +123 -123
  26. package/src/js/config/load.js +325 -194
  27. package/src/js/config/main.js +17 -17
  28. package/src/js/extra/browserEvents.js +57 -57
  29. package/src/js/extra/main.js +23 -25
  30. package/src/js/extra/pixiPatch.js +173 -171
  31. package/src/js/index.js +7 -7
  32. package/src/js/lib/cache.js +199 -125
  33. package/src/js/lib/composition.js +85 -85
  34. package/src/js/lib/device.js +1215 -1215
  35. package/src/js/lib/helper.js +678 -678
  36. package/src/js/lib/loader.js +216 -218
  37. package/src/js/lib/localData.js +29 -29
  38. package/src/js/lib/logger.js +69 -69
  39. package/src/js/lib/math.js +161 -161
  40. package/src/js/lib/objectPool.js +208 -208
  41. package/src/js/lib/time.js +19 -19
  42. package/src/js/lib/tween.js +153 -153
  43. package/src/js/modules/assets/baseModel.js +21 -21
  44. package/src/js/modules/assets/config.js +38 -38
  45. package/src/js/modules/assets/controller.js +65 -65
  46. package/src/js/modules/assets/models/atlas.js +19 -19
  47. package/src/js/modules/assets/models/audiosprite.js +28 -28
  48. package/src/js/modules/assets/models/bitmapFont.js +11 -11
  49. package/src/js/modules/assets/models/container.js +19 -19
  50. package/src/js/modules/assets/models/font.js +11 -11
  51. package/src/js/modules/assets/models/html.js +11 -11
  52. package/src/js/modules/assets/models/image.js +17 -17
  53. package/src/js/modules/assets/models/json.js +11 -11
  54. package/src/js/modules/assets/models/jsonAtlas.js +11 -11
  55. package/src/js/modules/assets/models/sound.js +17 -17
  56. package/src/js/modules/assets/models/spine.js +18 -17
  57. package/src/js/modules/assets/models/spineAtlas.js +11 -0
  58. package/src/js/modules/assets/service.js +564 -553
  59. package/src/js/modules/i18n/config.js +17 -17
  60. package/src/js/modules/i18n/controller.js +71 -71
  61. package/src/js/modules/instances/controller.js +357 -357
  62. package/src/js/modules/logic/config/sounds.js +23 -23
  63. package/src/js/modules/logic/controller.js +52 -52
  64. package/src/js/modules/logic/main.js +8 -8
  65. package/src/js/modules/logic/sounds.js +103 -103
  66. package/src/js/modules/objects/baseModel.js +205 -207
  67. package/src/js/modules/objects/cache.js +99 -99
  68. package/src/js/modules/objects/config.js +10 -10
  69. package/src/js/modules/objects/controller.js +139 -139
  70. package/src/js/modules/objects/find.js +58 -58
  71. package/src/js/modules/objects/models/bitmapText.js +56 -49
  72. package/src/js/modules/objects/models/button.js +208 -209
  73. package/src/js/modules/objects/models/buttonComposite.js +38 -38
  74. package/src/js/modules/objects/models/checkbox.js +100 -100
  75. package/src/js/modules/objects/models/collection.js +56 -54
  76. package/src/js/modules/objects/models/component.js +48 -48
  77. package/src/js/modules/objects/models/container.js +22 -22
  78. package/src/js/modules/objects/models/emitterFx.js +103 -114
  79. package/src/js/modules/objects/models/graphics.js +40 -40
  80. package/src/js/modules/objects/models/group.js +22 -22
  81. package/src/js/modules/objects/models/hitArea.js +187 -187
  82. package/src/js/modules/objects/models/image.js +36 -36
  83. package/src/js/modules/objects/models/imagesAnimation.js +115 -115
  84. package/src/js/modules/objects/models/mask.js +40 -40
  85. package/src/js/modules/objects/models/nineSlicePlane.js +32 -32
  86. package/src/js/modules/objects/models/slider.js +357 -357
  87. package/src/js/modules/objects/models/spine.js +354 -339
  88. package/src/js/modules/objects/models/text.js +70 -70
  89. package/src/js/modules/objects/models/toggle.js +186 -186
  90. package/src/js/modules/objects/models/world.js +22 -22
  91. package/src/js/modules/objects/pool.js +68 -68
  92. package/src/js/modules/objects/propertyAdapter.js +592 -592
  93. package/src/js/modules/objects/proxy.js +299 -298
  94. package/src/js/modules/objects/selector.js +136 -136
  95. package/src/js/modules/objects/service.js +255 -254
  96. package/src/js/modules/objects/styles.js +210 -210
  97. package/src/js/modules/observer/controller.js +168 -168
  98. package/src/js/modules/observer/events.js +51 -56
  99. package/src/js/modules/scenes/controller.js +126 -127
  100. package/src/js/modules/scenes/model.js +28 -28
  101. package/src/js/modules/scenes/pixiWrapper.js +360 -351
  102. package/src/js/modules/scenes/resolutions.js +173 -173
  103. package/src/js/modules/scenes/resolutionsConfig.js +73 -73
  104. package/src/js/modules/scenes/service.js +144 -146
  105. package/src/js/modules/soundManager/controller.js +103 -103
  106. package/src/js/modules/soundManager/soundSprite.js +314 -314
  107. package/src/js/modules/statesManager/action.js +97 -97
  108. package/src/js/modules/statesManager/all.js +23 -23
  109. package/src/js/modules/statesManager/configStates.js +77 -77
  110. package/src/js/modules/statesManager/controller.js +219 -219
  111. package/src/js/modules/statesManager/functionsStorage.js +83 -83
  112. package/src/js/modules/statesManager/helper.js +27 -27
  113. package/src/js/modules/statesManager/race.js +91 -91
  114. package/src/js/modules/statesManager/sequence.js +48 -48
  115. package/src/js/modules/template/controller.js +28 -28
  116. package/src/js/modules/template/model.js +11 -11
  117. package/src/js/modules/template/service.js +137 -137
  118. package/src/js/modules/template/types.js +50 -49
  119. package/src/js/modules/transport/baseConnectionType.js +25 -25
  120. package/src/js/modules/transport/config.js +13 -13
  121. package/src/js/modules/transport/connectionTypes/websocket.js +77 -77
  122. package/src/js/modules/transport/connectionTypes/xhr.js +47 -47
  123. package/src/js/modules/transport/controller.js +48 -48
  124. package/src/js/modules/transport/decorator.js +17 -17
  125. package/src/js/modules/transport/service.js +150 -150
  126. package/vite.config.js +31 -0
  127. package/.babelrc +0 -12
  128. package/build/js/index.js.LICENSE.txt +0 -227
  129. package/src/js/modules/objects/models/atlasImage.js +0 -52
  130. package/src/js/modules/objects/models/dragContainer.js +0 -665
  131. package/src/js/modules/objects/models/emitter.js +0 -69
  132. package/src/js/modules/objects/models/scrollbox.js +0 -67
  133. package/src/js/modules/objects/models/textInput.js +0 -68
  134. package/webpack.config.js +0 -47
@@ -1,187 +1,187 @@
1
- const ModulesObjectsBaseModel = require('./../baseModel');
2
-
3
- class ModulesObjectsModelsHitArea extends ModulesObjectsBaseModel {
4
-
5
- constructor(params) {
6
- super(params);
7
- this._isDisabled = false;
8
- this._isDown = false;
9
-
10
- this.type = Urso.types.objects.HITAREA;
11
-
12
- this._addBaseObject();
13
-
14
- this.enable = this.enable.bind(this);
15
- this.disable = this.disable.bind(this);
16
- }
17
-
18
- setupParams(params) {
19
- super.setupParams(params);
20
-
21
- //must have x,y, width, height
22
- this.action = Urso.helper.recursiveGet(
23
- 'action', params, (position) => { this.emit(Urso.events.MODULES_OBJECTS_HIT_AREA_PRESS, { position, name: this.name, class: this.class }) }
24
- );
25
- this.disableRightClick = Urso.helper.recursiveGet('disableRightClick', params, false);
26
- this.keyDownAction = Urso.helper.recursiveGet('keyDownAction', params, false);
27
- this.mouseOverAction = Urso.helper.recursiveGet('mouseOverAction', params, false);
28
- this.mouseOutAction = Urso.helper.recursiveGet('mouseOutAction', params, false);
29
- this.onTouchMoveCallback = Urso.helper.recursiveGet('onTouchMoveCallback', params, false);
30
- this.handlePointerUpOutside = Urso.helper.recursiveGet('handlePointerUpOutside', params, true);
31
- /**
32
- * customInteractionArea object ex:
33
- * Circle: { "type": "circle", "params": [0, 0, 100] }
34
- * Rectangle: { "type": "rectangle", "params": [0, 0, 100, 100] }
35
- * Polygon: {
36
- * "type": "polygon",
37
- * "params": [ 0, 0, 100, 0, 100, 100, 50, 150, 0, 100 ];
38
- * }
39
- * */
40
- this.customInteractionArea = Urso.helper.recursiveGet('customInteractionArea', params, null);
41
- }
42
-
43
- enable() {
44
- if (!this._isDisabled)
45
- return false;
46
-
47
- this._isDisabled = false;
48
- this._baseObject.interactive = true;
49
- }
50
-
51
- disable() {
52
- if (this._isDisabled)
53
- return false;
54
-
55
- this._isDisabled = true;
56
- this._baseObject.interactive = false;
57
- }
58
-
59
- _addBaseObject() {
60
- this._baseObject = new PIXI.Graphics();
61
-
62
- this._baseObject.lineStyle(0);
63
- this._baseObject.beginFill(0xffffff);
64
- this._baseObject.drawRect(0, 0, this.width, this.height);
65
- this._baseObject.endFill();
66
- this._baseObject.alpha = 0;
67
- this._baseObject.cacheAsBitmap = true;
68
-
69
- this._baseObject.interactive = true;
70
- this._baseObject.buttonMode = true;
71
-
72
- this._baseObject
73
- .on('pointerdown', this._onPressDown.bind(this))
74
- .on('pointerup', this._onPressUp.bind(this))
75
- .on('pointerupoutside', this._onPressUpOutside.bind(this))
76
- .on('pointerover', this._onOver.bind(this))
77
- .on('pointerout', this._onOut.bind(this))
78
- .on('touchmove', this._onTouchmove.bind(this));
79
-
80
- if (this.customInteractionArea)
81
- this._baseObject.hitArea = this._getHitAreaObject(this.customInteractionArea);
82
- }
83
-
84
- _onTouchmove(event) {
85
- if (this._isDisabled)
86
- return false;
87
-
88
- const position = this._getEventLocalPosition(event);
89
-
90
- if (this.onTouchMoveCallback)
91
- this.onTouchMoveCallback(position);
92
- }
93
-
94
- _onPressDown(event) {
95
- if (this._isDisabled)
96
- return false;
97
-
98
- if (this.disableRightClick && event.data.button !== 0)
99
- return;
100
-
101
- if (this._isDown)
102
- return false;
103
-
104
- this._isDown = true;
105
-
106
- if (this.keyDownAction) {
107
- const position = this._getEventLocalPosition(event);
108
- this.keyDownAction(position);
109
- }
110
- }
111
-
112
- _onPressUp(event) {
113
- if (this._isDisabled)
114
- return false;
115
-
116
- if (this.disableRightClick && event.data.button !== 0)
117
- return;
118
-
119
- if (!this._isDown)
120
- return false;
121
-
122
- this._isDown = false;
123
-
124
- if (this.action) {
125
- const position = this._getEventLocalPosition(event);
126
- this.action(position);
127
- }
128
- }
129
-
130
- _onPressUpOutside(event) {
131
- if (this.handlePointerUpOutside) {
132
- this._onPressUp(event);
133
- return;
134
- }
135
-
136
- if (this._isDisabled)
137
- return false;
138
-
139
- this._isDown = false;
140
- }
141
-
142
- _onOver() {
143
- if (this._isDisabled)
144
- return false;
145
-
146
- if (this.mouseOverAction)
147
- this.mouseOverAction();
148
- }
149
-
150
- _onOut() {
151
- if (this._isDisabled)
152
- return false;
153
-
154
- if (this.mouseOutAction)
155
- this.mouseOutAction();
156
- }
157
-
158
- _getEventLocalPosition(event) {
159
- const world = Urso.objects.getWorld();
160
- const worldScale = world._baseObject.scale;
161
-
162
- const x = event.data.global.x / worldScale.x;
163
- const y = event.data.global.y / worldScale.y;
164
-
165
- return { x, y };
166
- }
167
-
168
- _getHitAreaObject({ type, params }) {
169
- if (!type) {
170
- return null;
171
- }
172
-
173
- const objects = {
174
- 'rectangle': PIXI.Rectangle,
175
- 'circle': PIXI.Circle,
176
- 'polygon': PIXI.Polygon
177
- }
178
-
179
- if (!objects[type]) {
180
- return null;
181
- }
182
-
183
- return new objects[type](...params);
184
- }
185
- }
186
-
187
- module.exports = ModulesObjectsModelsHitArea;
1
+ import ModulesObjectsBaseModel from './../baseModel';
2
+
3
+ class ModulesObjectsModelsHitArea extends ModulesObjectsBaseModel {
4
+
5
+ constructor(params) {
6
+ super(params);
7
+ this._isDisabled = false;
8
+ this._isDown = false;
9
+
10
+ this.type = Urso.types.objects.HITAREA;
11
+
12
+ this._addBaseObject();
13
+
14
+ this.enable = this.enable.bind(this);
15
+ this.disable = this.disable.bind(this);
16
+ }
17
+
18
+ setupParams(params) {
19
+ super.setupParams(params);
20
+
21
+ //must have x,y, width, height
22
+ this.action = Urso.helper.recursiveGet(
23
+ 'action', params, (position) => { this.emit(Urso.events.MODULES_OBJECTS_HIT_AREA_PRESS, { position, name: this.name, class: this.class }) }
24
+ );
25
+ this.disableRightClick = Urso.helper.recursiveGet('disableRightClick', params, false);
26
+ this.keyDownAction = Urso.helper.recursiveGet('keyDownAction', params, false);
27
+ this.mouseOverAction = Urso.helper.recursiveGet('mouseOverAction', params, false);
28
+ this.mouseOutAction = Urso.helper.recursiveGet('mouseOutAction', params, false);
29
+ this.onTouchMoveCallback = Urso.helper.recursiveGet('onTouchMoveCallback', params, false);
30
+ this.handlePointerUpOutside = Urso.helper.recursiveGet('handlePointerUpOutside', params, true);
31
+ /**
32
+ * customInteractionArea object ex:
33
+ * Circle: { "type": "circle", "params": [0, 0, 100] }
34
+ * Rectangle: { "type": "rectangle", "params": [0, 0, 100, 100] }
35
+ * Polygon: {
36
+ * "type": "polygon",
37
+ * "params": [ 0, 0, 100, 0, 100, 100, 50, 150, 0, 100 ];
38
+ * }
39
+ * */
40
+ this.customInteractionArea = Urso.helper.recursiveGet('customInteractionArea', params, null);
41
+ }
42
+
43
+ enable() {
44
+ if (!this._isDisabled)
45
+ return false;
46
+
47
+ this._isDisabled = false;
48
+ this._baseObject.interactive = true;
49
+ }
50
+
51
+ disable() {
52
+ if (this._isDisabled)
53
+ return false;
54
+
55
+ this._isDisabled = true;
56
+ this._baseObject.interactive = false;
57
+ }
58
+
59
+ _addBaseObject() {
60
+ this._baseObject = new PIXI.Graphics();
61
+
62
+ this._baseObject.lineStyle(0);
63
+ this._baseObject.beginFill(0xffffff);
64
+ this._baseObject.drawRect(0, 0, this.width, this.height);
65
+ this._baseObject.endFill();
66
+ this._baseObject.alpha = 0;
67
+ this._baseObject.cacheAsBitmap = true;
68
+
69
+ this._baseObject.eventMode = 'static';
70
+ this._baseObject.cursor = 'pointer';
71
+
72
+ this._baseObject
73
+ .on('pointerdown', this._onPressDown.bind(this))
74
+ .on('pointerup', this._onPressUp.bind(this))
75
+ .on('pointerupoutside', this._onPressUpOutside.bind(this))
76
+ .on('pointerover', this._onOver.bind(this))
77
+ .on('pointerout', this._onOut.bind(this))
78
+ .on('touchmove', this._onTouchmove.bind(this));
79
+
80
+ if (this.customInteractionArea)
81
+ this._baseObject.hitArea = this._getHitAreaObject(this.customInteractionArea);
82
+ }
83
+
84
+ _onTouchmove(event) {
85
+ if (this._isDisabled)
86
+ return false;
87
+
88
+ const position = this._getEventLocalPosition(event);
89
+
90
+ if (this.onTouchMoveCallback)
91
+ this.onTouchMoveCallback(position);
92
+ }
93
+
94
+ _onPressDown(event) {
95
+ if (this._isDisabled)
96
+ return false;
97
+
98
+ if (this.disableRightClick && event.data.button !== 0)
99
+ return;
100
+
101
+ if (this._isDown)
102
+ return false;
103
+
104
+ this._isDown = true;
105
+
106
+ if (this.keyDownAction) {
107
+ const position = this._getEventLocalPosition(event);
108
+ this.keyDownAction(position);
109
+ }
110
+ }
111
+
112
+ _onPressUp(event) {
113
+ if (this._isDisabled)
114
+ return false;
115
+
116
+ if (this.disableRightClick && event.data.button !== 0)
117
+ return;
118
+
119
+ if (!this._isDown)
120
+ return false;
121
+
122
+ this._isDown = false;
123
+
124
+ if (this.action) {
125
+ const position = this._getEventLocalPosition(event);
126
+ this.action(position);
127
+ }
128
+ }
129
+
130
+ _onPressUpOutside(event) {
131
+ if (this.handlePointerUpOutside) {
132
+ this._onPressUp(event);
133
+ return;
134
+ }
135
+
136
+ if (this._isDisabled)
137
+ return false;
138
+
139
+ this._isDown = false;
140
+ }
141
+
142
+ _onOver() {
143
+ if (this._isDisabled)
144
+ return false;
145
+
146
+ if (this.mouseOverAction)
147
+ this.mouseOverAction();
148
+ }
149
+
150
+ _onOut() {
151
+ if (this._isDisabled)
152
+ return false;
153
+
154
+ if (this.mouseOutAction)
155
+ this.mouseOutAction();
156
+ }
157
+
158
+ _getEventLocalPosition(event) {
159
+ const world = Urso.objects.getWorld();
160
+ const worldScale = world._baseObject.scale;
161
+
162
+ const x = event.data.global.x / worldScale.x;
163
+ const y = event.data.global.y / worldScale.y;
164
+
165
+ return { x, y };
166
+ }
167
+
168
+ _getHitAreaObject({ type, params }) {
169
+ if (!type) {
170
+ return null;
171
+ }
172
+
173
+ const objects = {
174
+ 'rectangle': PIXI.Rectangle,
175
+ 'circle': PIXI.Circle,
176
+ 'polygon': PIXI.Polygon
177
+ }
178
+
179
+ if (!objects[type]) {
180
+ return null;
181
+ }
182
+
183
+ return new objects[type](...params);
184
+ }
185
+ }
186
+
187
+ export default ModulesObjectsModelsHitArea;
@@ -1,36 +1,36 @@
1
- const ModulesObjectsBaseModel = require('./../baseModel');
2
-
3
- class ModulesObjectsModelsImage extends ModulesObjectsBaseModel {
4
- constructor(params) {
5
- super(params);
6
-
7
- this.type = Urso.types.objects.IMAGE;
8
- this._addBaseObject();
9
- }
10
-
11
- setupParams(params) {
12
- super.setupParams(params);
13
-
14
- this.assetKey = Urso.helper.recursiveGet('assetKey', params, false);
15
- }
16
-
17
- changeTexture(assetKey) {
18
- this.assetKey = assetKey;
19
-
20
- this._addBaseObject();
21
- }
22
-
23
- _addBaseObject() {
24
- let texture = Urso.cache.getTexture(this.assetKey)
25
-
26
- if (!texture)
27
- Urso.logger.error('ModulesObjectsModelsImage assets error: no image with key: ' + this.assetKey);
28
-
29
- if (!this._baseObject)
30
- this._baseObject = new PIXI.Sprite(texture);
31
- else
32
- this._baseObject.texture = texture;
33
- };
34
- }
35
-
36
- module.exports = ModulesObjectsModelsImage;
1
+ import ModulesObjectsBaseModel from './../baseModel';
2
+
3
+ class ModulesObjectsModelsImage extends ModulesObjectsBaseModel {
4
+ constructor(params) {
5
+ super(params);
6
+
7
+ this.type = Urso.types.objects.IMAGE;
8
+ this._addBaseObject();
9
+ }
10
+
11
+ setupParams(params) {
12
+ super.setupParams(params);
13
+
14
+ this.assetKey = Urso.helper.recursiveGet('assetKey', params, false);
15
+ }
16
+
17
+ changeTexture(assetKey) {
18
+ this.assetKey = assetKey;
19
+
20
+ this._addBaseObject();
21
+ }
22
+
23
+ _addBaseObject() {
24
+ let texture = Urso.cache.getTexture(this.assetKey)
25
+
26
+ if (!texture)
27
+ Urso.logger.error('ModulesObjectsModelsImage assets error: no image with key: ' + this.assetKey);
28
+
29
+ if (!this._baseObject)
30
+ this._baseObject = new PIXI.Sprite(texture);
31
+ else
32
+ this._baseObject.texture = texture;
33
+ };
34
+ }
35
+
36
+ export default ModulesObjectsModelsImage;
@@ -1,115 +1,115 @@
1
- const ModulesObjectsBaseModel = require('./../baseModel');
2
-
3
- class ModulesObjectsModelsImagesAnimation extends ModulesObjectsBaseModel {
4
- constructor(params) {
5
- super(params);
6
-
7
- this.type = Urso.types.objects.IMAGESANIMATION;
8
-
9
- //sys
10
- this._tween = null;
11
- this._currentFrame = -1;
12
- this._defaultTexture;
13
- this._animationTextures = {};
14
-
15
- this._addBaseObject();
16
- }
17
-
18
- setupParams(params) {
19
- super.setupParams(params);
20
-
21
- this.assetKey = Urso.helper.recursiveGet('assetKey', params, false);
22
-
23
- this.duration = Urso.helper.recursiveGet('duration', params, 0);
24
- this.animationKeys = Urso.helper.recursiveGet('animationKeys', params, []);
25
- this.loop = Urso.helper.recursiveGet('loop', params, false);
26
- this.autostart = Urso.helper.recursiveGet('autostart', params, false);
27
- this.onComplete = Urso.helper.recursiveGet('onComplete', params, false);
28
- }
29
-
30
- _addBaseObject() {
31
- let texture = Urso.cache.getTexture(this.assetKey)
32
-
33
- if (!texture)
34
- Urso.logger.error('ModulesObjectsModelsImage assets error: no image ' + this.assetKey);
35
-
36
- this._defaultTexture = texture;
37
- this._baseObject = new PIXI.Sprite(this._defaultTexture);
38
-
39
- this._createAnimationTextures();
40
-
41
- if (this.autostart)
42
- this.start();
43
- };
44
-
45
- start() {
46
- this._createTween();
47
- };
48
-
49
- stop() {
50
- if (!this._tween)
51
- return false;
52
-
53
- this._stopAnimation();
54
- };
55
-
56
- _createAnimationTextures() {
57
- for (let key in this.animationKeys) {
58
- let texture = Urso.cache.getTexture(this.animationKeys[key]);
59
-
60
- if (!texture)
61
- continue;
62
-
63
- this._animationTextures[key] = texture;
64
- }
65
-
66
- return this._animationTextures;
67
- }
68
-
69
- _createTween() {
70
- const totalFrames = this.animationKeys.length;
71
- const tweenParams = { x: totalFrames, duration: this.duration / 1000, ease: "none" };
72
-
73
- if (this.loop)
74
- tweenParams.repeat = -1;
75
-
76
- this._tween = gsap.to({ x: 0 }, tweenParams);
77
-
78
- this._tween.eventCallback("onUpdate", this._onUpdate.bind(this));
79
-
80
- this._tween.eventCallback("onComplete", () => {
81
- this._baseObject.texture = this._defaultTexture;
82
- this._onComplete();
83
- });
84
- }
85
-
86
- _onUpdate() {
87
- if (!this._tween)
88
- return;
89
-
90
- let frameIndex = ~~this._tween.targets()[0].x;
91
- const totalFrames = this.animationKeys.length;
92
-
93
- const frameKey = this.animationKeys[frameIndex];
94
-
95
- if (this._currentFrame !== frameKey) {
96
- this._baseObject.texture = this._animationTextures[frameIndex];
97
- this._currentFrame = frameKey;
98
- }
99
- }
100
-
101
- _onComplete() {
102
- if (this.onComplete)
103
- this.onComplete();
104
- };
105
-
106
- _stopAnimation() {
107
- this._tween.kill();
108
- this._baseObject.texture = this._defaultTexture;
109
-
110
- this._onComplete();
111
- }
112
-
113
- }
114
-
115
- module.exports = ModulesObjectsModelsImagesAnimation;
1
+ import ModulesObjectsBaseModel from './../baseModel';
2
+
3
+ class ModulesObjectsModelsImagesAnimation extends ModulesObjectsBaseModel {
4
+ constructor(params) {
5
+ super(params);
6
+
7
+ this.type = Urso.types.objects.IMAGESANIMATION;
8
+
9
+ //sys
10
+ this._tween = null;
11
+ this._currentFrame = -1;
12
+ this._defaultTexture;
13
+ this._animationTextures = {};
14
+
15
+ this._addBaseObject();
16
+ }
17
+
18
+ setupParams(params) {
19
+ super.setupParams(params);
20
+
21
+ this.assetKey = Urso.helper.recursiveGet('assetKey', params, false);
22
+
23
+ this.duration = Urso.helper.recursiveGet('duration', params, 0);
24
+ this.animationKeys = Urso.helper.recursiveGet('animationKeys', params, []);
25
+ this.loop = Urso.helper.recursiveGet('loop', params, false);
26
+ this.autostart = Urso.helper.recursiveGet('autostart', params, false);
27
+ this.onComplete = Urso.helper.recursiveGet('onComplete', params, false);
28
+ }
29
+
30
+ _addBaseObject() {
31
+ let texture = Urso.cache.getTexture(this.assetKey)
32
+
33
+ if (!texture)
34
+ Urso.logger.error('ModulesObjectsModelsImage assets error: no image ' + this.assetKey);
35
+
36
+ this._defaultTexture = texture;
37
+ this._baseObject = new PIXI.Sprite(this._defaultTexture);
38
+
39
+ this._createAnimationTextures();
40
+
41
+ if (this.autostart)
42
+ this.start();
43
+ };
44
+
45
+ start() {
46
+ this._createTween();
47
+ };
48
+
49
+ stop() {
50
+ if (!this._tween)
51
+ return false;
52
+
53
+ this._stopAnimation();
54
+ };
55
+
56
+ _createAnimationTextures() {
57
+ for (let key in this.animationKeys) {
58
+ let texture = Urso.cache.getTexture(this.animationKeys[key]);
59
+
60
+ if (!texture)
61
+ continue;
62
+
63
+ this._animationTextures[key] = texture;
64
+ }
65
+
66
+ return this._animationTextures;
67
+ }
68
+
69
+ _createTween() {
70
+ const totalFrames = this.animationKeys.length;
71
+ const tweenParams = { x: totalFrames, duration: this.duration / 1000, ease: "none" };
72
+
73
+ if (this.loop)
74
+ tweenParams.repeat = -1;
75
+
76
+ this._tween = gsap.to({ x: 0 }, tweenParams);
77
+
78
+ this._tween.eventCallback("onUpdate", this._onUpdate.bind(this));
79
+
80
+ this._tween.eventCallback("onComplete", () => {
81
+ this._baseObject.texture = this._defaultTexture;
82
+ this._onComplete();
83
+ });
84
+ }
85
+
86
+ _onUpdate() {
87
+ if (!this._tween)
88
+ return;
89
+
90
+ let frameIndex = ~~this._tween.targets()[0].x;
91
+ const totalFrames = this.animationKeys.length;
92
+
93
+ const frameKey = this.animationKeys[frameIndex];
94
+
95
+ if (this._currentFrame !== frameKey) {
96
+ this._baseObject.texture = this._animationTextures[frameIndex];
97
+ this._currentFrame = frameKey;
98
+ }
99
+ }
100
+
101
+ _onComplete() {
102
+ if (this.onComplete)
103
+ this.onComplete();
104
+ };
105
+
106
+ _stopAnimation() {
107
+ this._tween.kill();
108
+ this._baseObject.texture = this._defaultTexture;
109
+
110
+ this._onComplete();
111
+ }
112
+
113
+ }
114
+
115
+ export default ModulesObjectsModelsImagesAnimation;