@urso/core 0.3.9 → 0.4.0

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 (144) hide show
  1. package/.babelrc +11 -11
  2. package/README.md +10 -10
  3. package/build/js/index.js +1 -1
  4. package/build/js/index.js.LICENSE.txt +29 -29
  5. package/package.json +51 -51
  6. package/src/js/app.js +77 -77
  7. package/src/js/components/_info.js +8 -8
  8. package/src/js/components/base/_info.js +3 -3
  9. package/src/js/components/base/controller.js +78 -78
  10. package/src/js/components/debug/_info.js +7 -7
  11. package/src/js/components/debug/controller.js +38 -38
  12. package/src/js/components/debug/coords.js +23 -23
  13. package/src/js/components/debug/fps.js +34 -34
  14. package/src/js/components/debug/template.js +55 -55
  15. package/src/js/components/debug/timescale.js +60 -60
  16. package/src/js/components/deviceRotate/_info.js +3 -3
  17. package/src/js/components/deviceRotate/controller.js +86 -86
  18. package/src/js/components/fullscreen/_info.js +6 -6
  19. package/src/js/components/fullscreen/android.js +104 -104
  20. package/src/js/components/fullscreen/controller.js +64 -64
  21. package/src/js/components/fullscreen/desktop.js +49 -49
  22. package/src/js/components/fullscreen/ios.js +111 -111
  23. package/src/js/components/loader/_info.js +4 -4
  24. package/src/js/components/loader/controller.js +66 -66
  25. package/src/js/components/loader/template.js +70 -70
  26. package/src/js/components/soundInitialPopup/_info.js +3 -3
  27. package/src/js/components/soundInitialPopup/controller.js +42 -42
  28. package/src/js/components/soundInitialPopup/template.js +109 -109
  29. package/src/js/components/stateDriven/_info.js +3 -3
  30. package/src/js/components/stateDriven/controller.js +118 -118
  31. package/src/js/config/load.js +5 -5
  32. package/src/js/config/main.js +10 -10
  33. package/src/js/extra/_info.js +22 -22
  34. package/src/js/extra/browserEvents.js +38 -38
  35. package/src/js/extra/setTimeout.js +7 -7
  36. package/src/js/index.js +8 -8
  37. package/src/js/lib/_info.js +13 -13
  38. package/src/js/lib/cache.js +105 -105
  39. package/src/js/lib/composition.js +85 -89
  40. package/src/js/lib/device.js +1286 -1276
  41. package/src/js/lib/helper.js +539 -539
  42. package/src/js/lib/loader.js +127 -127
  43. package/src/js/lib/localData.js +15 -15
  44. package/src/js/lib/logger.js +22 -22
  45. package/src/js/lib/math.js +35 -35
  46. package/src/js/lib/objectPool.js +54 -54
  47. package/src/js/lib/time.js +18 -18
  48. package/src/js/lib/tween.js +147 -147
  49. package/src/js/modules/_info.js +11 -11
  50. package/src/js/modules/assets/_info.js +7 -7
  51. package/src/js/modules/assets/baseModel.js +18 -18
  52. package/src/js/modules/assets/config.js +37 -35
  53. package/src/js/modules/assets/controller.js +46 -39
  54. package/src/js/modules/assets/models/_info.js +11 -11
  55. package/src/js/modules/assets/models/atlas.js +8 -8
  56. package/src/js/modules/assets/models/audiosprite.js +27 -27
  57. package/src/js/modules/assets/models/bitmapFont.js +8 -8
  58. package/src/js/modules/assets/models/container.js +16 -16
  59. package/src/js/modules/assets/models/font.js +8 -8
  60. package/src/js/modules/assets/models/image.js +13 -13
  61. package/src/js/modules/assets/models/json.js +8 -8
  62. package/src/js/modules/assets/models/sound.js +14 -14
  63. package/src/js/modules/assets/models/spine.js +14 -14
  64. package/src/js/modules/assets/service.js +356 -353
  65. package/src/js/modules/instances/_info.js +3 -3
  66. package/src/js/modules/instances/controller.js +251 -219
  67. package/src/js/modules/logic/_info.js +4 -4
  68. package/src/js/modules/logic/config/_info.js +2 -2
  69. package/src/js/modules/logic/config/sounds.js +23 -23
  70. package/src/js/modules/logic/controller.js +48 -48
  71. package/src/js/modules/logic/sounds.js +96 -96
  72. package/src/js/modules/objects/_info.js +11 -11
  73. package/src/js/modules/objects/baseModel.js +171 -161
  74. package/src/js/modules/objects/cache.js +99 -99
  75. package/src/js/modules/objects/controller.js +131 -121
  76. package/src/js/modules/objects/create.js +234 -230
  77. package/src/js/modules/objects/find.js +140 -140
  78. package/src/js/modules/objects/models/_info.js +24 -24
  79. package/src/js/modules/objects/models/atlasImage.js +50 -50
  80. package/src/js/modules/objects/models/bitmapText.js +23 -23
  81. package/src/js/modules/objects/models/button.js +184 -184
  82. package/src/js/modules/objects/models/buttonComposite.js +35 -35
  83. package/src/js/modules/objects/models/checkbox.js +96 -96
  84. package/src/js/modules/objects/models/collection.js +54 -54
  85. package/src/js/modules/objects/models/component.js +44 -44
  86. package/src/js/modules/objects/models/container.js +19 -19
  87. package/src/js/modules/objects/models/emitter.js +54 -54
  88. package/src/js/modules/objects/models/graphics.js +38 -38
  89. package/src/js/modules/objects/models/group.js +19 -19
  90. package/src/js/modules/objects/models/hitArea.js +104 -104
  91. package/src/js/modules/objects/models/image.js +34 -34
  92. package/src/js/modules/objects/models/imagesAnimation.js +113 -113
  93. package/src/js/modules/objects/models/mask.js +38 -38
  94. package/src/js/modules/objects/models/scrollbox.js +61 -61
  95. package/src/js/modules/objects/models/slider.js +223 -223
  96. package/src/js/modules/objects/models/spine.js +89 -89
  97. package/src/js/modules/objects/models/text.js +38 -38
  98. package/src/js/modules/objects/models/textInput.js +66 -66
  99. package/src/js/modules/objects/models/toggle.js +178 -178
  100. package/src/js/modules/objects/models/world.js +19 -19
  101. package/src/js/modules/objects/propertyAdapter.js +421 -421
  102. package/src/js/modules/objects/proxy.js +182 -182
  103. package/src/js/modules/objects/styles.js +116 -116
  104. package/src/js/modules/observer/_info.js +4 -4
  105. package/src/js/modules/observer/controller.js +99 -99
  106. package/src/js/modules/observer/events.js +38 -38
  107. package/src/js/modules/scenes/_info.js +8 -8
  108. package/src/js/modules/scenes/controller.js +46 -42
  109. package/src/js/modules/scenes/model.js +35 -35
  110. package/src/js/modules/scenes/pixiWrapper.js +202 -202
  111. package/src/js/modules/scenes/resolutions.js +172 -176
  112. package/src/js/modules/scenes/resolutionsConfig.js +73 -73
  113. package/src/js/modules/scenes/service.js +105 -92
  114. package/src/js/modules/soundManager/_info.js +3 -3
  115. package/src/js/modules/soundManager/controller.js +99 -99
  116. package/src/js/modules/soundManager/soundSprite.js +202 -202
  117. package/src/js/modules/statesManager/_info.js +12 -12
  118. package/src/js/modules/statesManager/action.js +60 -60
  119. package/src/js/modules/statesManager/actions/_info.js +3 -3
  120. package/src/js/modules/statesManager/all.js +23 -23
  121. package/src/js/modules/statesManager/configStates.js +71 -71
  122. package/src/js/modules/statesManager/controller.js +170 -170
  123. package/src/js/modules/statesManager/functionsStorage.js +82 -82
  124. package/src/js/modules/statesManager/helper.js +27 -27
  125. package/src/js/modules/statesManager/race.js +75 -75
  126. package/src/js/modules/statesManager/sequence.js +47 -47
  127. package/src/js/modules/template/_info.js +6 -6
  128. package/src/js/modules/template/controller.js +28 -28
  129. package/src/js/modules/template/model.js +11 -11
  130. package/src/js/modules/template/service.js +137 -125
  131. package/src/js/modules/template/types.js +44 -44
  132. package/src/js/modules/transport/_info.js +8 -8
  133. package/src/js/modules/transport/baseConnectionType.js +24 -24
  134. package/src/js/modules/transport/config.js +13 -13
  135. package/src/js/modules/transport/connectionTypes/_info.js +3 -3
  136. package/src/js/modules/transport/connectionTypes/websocket.js +74 -74
  137. package/src/js/modules/transport/connectionTypes/xhr.js +44 -44
  138. package/src/js/modules/transport/controller.js +48 -48
  139. package/src/js/modules/transport/decorator.js +17 -17
  140. package/src/js/modules/transport/service.js +153 -153
  141. package/src/js/templates/_info.js +4 -4
  142. package/src/js/templates/groups/_info.js +1 -1
  143. package/src/js/templates/scenes/_info.js +1 -1
  144. package/webpack.config.js +47 -47
@@ -1,223 +1,223 @@
1
- class ModulesObjectsModelsSlider extends Urso.Core.Modules.Objects.BaseModel {
2
- constructor(params) {
3
- super(params);
4
-
5
- this.type = Urso.types.objects.SLIDER;
6
- this._sliderBg = null;
7
- this._sliderHandle = null;
8
- this._baseObject = null;
9
- this._handleIsPulling = false;
10
-
11
- this._setVariables();
12
- this._addBaseObject();
13
- this._createSliderTextures();
14
- this._createValueText();
15
- this._setDefaultValue();
16
- }
17
-
18
- setupParams(params) {
19
- super.setupParams(params);
20
- this.contents = [];
21
- this.points = Urso.helper.recursiveGet('points', params, [0, 1]);
22
- this.defaultValue = Urso.helper.recursiveGet('defaultValue', params, this.points[0]);
23
- this.bgTexture = Urso.helper.recursiveGet('bgTexture', params, false);
24
- this.fillTexture = Urso.helper.recursiveGet('fillTexture', params, false);
25
- this.handleTexture = Urso.helper.recursiveGet('handleTexture', params, false);
26
- this.minValueTextModel = Urso.helper.recursiveGet('minValueTextModel', params, false);
27
- this.maxValueTextModel = Urso.helper.recursiveGet('maxValueTextModel', params, false);
28
- this.currentValueTextModel = Urso.helper.recursiveGet('currentValueTextModel', params, false);
29
- this.isVertical = Urso.helper.recursiveGet('isVertical', params, false);
30
- }
31
-
32
- _setVariables() {
33
- if(this.isVertical) {
34
- this.positionKey = 'y';
35
- this.targetObjParam = 'height';
36
- }else {
37
- this.positionKey = 'x';
38
- this.targetObjParam = 'width';
39
- }
40
- }
41
-
42
- _createSliderTextures() {
43
- this._sliderBg = this._createTexture(this.bgTexture);
44
-
45
- if(this.fillTexture)
46
- this._fillTexture = this._createFillTexture(this.fillTexture);
47
-
48
- this._sliderHandle = this._createTexture(this.handleTexture);
49
-
50
- this._setEvents(this._sliderBg._baseObject);
51
- this._setEvents(this._sliderHandle._baseObject);
52
- }
53
-
54
- _createFillTexture(model){
55
- const fillTexture = this._createTexture(model);
56
- const { width, height } = fillTexture._baseObject;
57
- this._fillMask = Urso.objects.create({
58
- type: Urso.types.objects.GRAPHICS,
59
- figure: {
60
- rectangle: [0, 0, width, height]
61
- },
62
- x: -width * fillTexture.anchorX,
63
- y: -height * fillTexture.anchorY,
64
- }, this);
65
-
66
- fillTexture._baseObject.mask = this._fillMask._baseObject;
67
- return fillTexture
68
- }
69
-
70
- _createValueText() {
71
- if (this.minValueTextModel) {
72
- this.minValueText = Urso.objects.create(this.minValueTextModel, this);
73
- this.minValueText.text = this.points[0];
74
- }
75
-
76
- if (this.maxValueTextModel) {
77
- this.maxValueText = Urso.objects.create(this.maxValueTextModel, this);
78
- this.maxValueText.text = this.points.length <= 2 ? '100' : this.points[this.points.length - 1];
79
- }
80
-
81
- if(this.currentValueTextModel){
82
- this.currentValueText = Urso.objects.create(this.currentValueTextModel, this);
83
- }
84
- }
85
-
86
- _createTexture(model) {
87
- if (model.type === Urso.types.objects.GRAPHICS || model.type === Urso.types.objects.IMAGE)
88
- return Urso.objects.create(model, this);
89
- else
90
- Urso.logger.error('ModulesObjectsModelsSlider objects error: textures should be GRAPHICS or IMAGE type');
91
- }
92
-
93
- _setEvents(obj) {
94
- obj.interactive = true;
95
- obj.buttonMode = true;
96
-
97
- obj
98
- .on('pointerdown', this._onPointerDown.bind(this))
99
- .on('pointerup', this._onPointerUp.bind(this))
100
- .on('pointerupoutside', this._onPointerUp.bind(this))
101
- .on('touchmove', this._onTouchmove.bind(this));
102
- };
103
-
104
- _onTouchmove(event) {
105
- const position = this._getEventLocalPosition(event);
106
- this._onPointerMove(position);
107
- }
108
-
109
- _getEventLocalPosition(event) {
110
- const world = Urso.objects.getWorld();
111
- const worldScale = world._baseObject.scale;
112
-
113
- const x = event.data.global.x / worldScale.x;
114
- const y = event.data.global.y / worldScale.y;
115
-
116
- return { x, y };
117
- }
118
-
119
- _addBaseObject() {
120
- this._baseObject = new PIXI.Container();
121
- };
122
-
123
- _onPointerDown(obj) {
124
- if (obj.target === this._sliderHandle._baseObject)
125
- this._handleIsDragging = true;
126
- }
127
-
128
- _onPointerMove({ x, y }) {
129
- if (!this._handleIsDragging)
130
- return
131
-
132
- const value = this.isVertical ? y : x;
133
-
134
- if (value < this[this.positionKey])
135
- this._sliderHandle[this.positionKey] = 0;
136
- else if (value >= this[this.positionKey] + this._sliderBg._baseObject[this.targetObjParam])
137
- this._sliderHandle[this.positionKey] = this._sliderBg._baseObject[this.targetObjParam];
138
- else
139
- this._sliderHandle[this.positionKey] = value - this[this.positionKey];
140
-
141
- this._setFillMask();
142
-
143
- const data = { class: this.class, name: this.name, position: this._sliderHandle[this.positionKey] };
144
- this.emit(Urso.events.MODULES_OBJECTS_SLIDER_HANDLE_MOVE, data)
145
- }
146
-
147
- _onPointerUp(obj) {
148
- this._handleIsDragging = false;
149
- let targetObj;
150
-
151
- if (obj.target === this._sliderBg._baseObject)
152
- targetObj = obj.data.getLocalPosition(obj.target)
153
- else
154
- targetObj = this._sliderHandle;
155
-
156
- const {x, y} = targetObj;
157
- const value = this.isVertical ? y : x;
158
- this._dropHandle(value);
159
- }
160
-
161
- _setDefaultValue(){
162
- if(!this.points.includes(this.defaultValue))
163
- this.defaultValue = this.points[0];
164
-
165
- let value = this.points.indexOf(this.defaultValue) *
166
- this._sliderBg._baseObject[this.targetObjParam] / (this.points.length - 1);
167
-
168
- this._setNewValue(value, this.defaultValue);
169
- }
170
-
171
- _dropHandle(givenValue) {
172
- let value;
173
- let coord;
174
-
175
- if(this.points.length <= 2){
176
- coord = givenValue;
177
- value = ~~(100 / this._sliderBg._baseObject[this.targetObjParam] * givenValue);
178
- }
179
- // calculate closest point
180
- else{
181
- for (let i = 0; i < this.points.length; i++) {
182
- let pointCoord = i * this._sliderBg._baseObject[this.targetObjParam] / (this.points.length - 1);
183
-
184
- if (typeof (coord) === 'number' && givenValue - pointCoord < coord - givenValue) {
185
- coord = coord;
186
- } else {
187
- coord = pointCoord;
188
- value = this.points[i];
189
- }
190
- }
191
- }
192
- const data = { class: this.class, name: this.name, position: coord, value: value };
193
-
194
- this.emit(Urso.events.MODULES_OBJECTS_SLIDER_HANDLE_DROP, data);
195
- this._setNewValue(coord, value);
196
- }
197
-
198
- _setFillMask(){
199
- if(!this._fillMask)
200
- return
201
-
202
- const progress = (this._sliderHandle[this.positionKey] - this._sliderBg[this.positionKey]) *
203
- 100 / this._fillTexture._baseObject[this.targetObjParam] * 0.01;
204
-
205
- const scaleKey = this.isVertical ? 'scaleY' : 'scaleX';
206
- this._fillMask[scaleKey] = progress;
207
- }
208
-
209
- _setNewValue(coord, value){
210
- this._sliderHandle[this.positionKey] = coord;
211
-
212
- if (this.currentValueText)
213
- this.currentValueText.text = value;
214
-
215
- this._setFillMask();
216
- }
217
-
218
- _subscribeOnce() {
219
- this.addListener(Urso.events.MODULES_SCENES_MOUSE_NEW_POSITION, this._onPointerMove.bind(this));
220
- }
221
- }
222
-
223
- module.exports = ModulesObjectsModelsSlider;
1
+ class ModulesObjectsModelsSlider extends Urso.Core.Modules.Objects.BaseModel {
2
+ constructor(params) {
3
+ super(params);
4
+
5
+ this.type = Urso.types.objects.SLIDER;
6
+ this._sliderBg = null;
7
+ this._sliderHandle = null;
8
+ this._baseObject = null;
9
+ this._handleIsPulling = false;
10
+
11
+ this._setVariables();
12
+ this._addBaseObject();
13
+ this._createSliderTextures();
14
+ this._createValueText();
15
+ this._setDefaultValue();
16
+ }
17
+
18
+ setupParams(params) {
19
+ super.setupParams(params);
20
+ this.contents = [];
21
+ this.points = Urso.helper.recursiveGet('points', params, [0, 1]);
22
+ this.defaultValue = Urso.helper.recursiveGet('defaultValue', params, this.points[0]);
23
+ this.bgTexture = Urso.helper.recursiveGet('bgTexture', params, false);
24
+ this.fillTexture = Urso.helper.recursiveGet('fillTexture', params, false);
25
+ this.handleTexture = Urso.helper.recursiveGet('handleTexture', params, false);
26
+ this.minValueTextModel = Urso.helper.recursiveGet('minValueTextModel', params, false);
27
+ this.maxValueTextModel = Urso.helper.recursiveGet('maxValueTextModel', params, false);
28
+ this.currentValueTextModel = Urso.helper.recursiveGet('currentValueTextModel', params, false);
29
+ this.isVertical = Urso.helper.recursiveGet('isVertical', params, false);
30
+ }
31
+
32
+ _setVariables() {
33
+ if(this.isVertical) {
34
+ this.positionKey = 'y';
35
+ this.targetObjParam = 'height';
36
+ }else {
37
+ this.positionKey = 'x';
38
+ this.targetObjParam = 'width';
39
+ }
40
+ }
41
+
42
+ _createSliderTextures() {
43
+ this._sliderBg = this._createTexture(this.bgTexture);
44
+
45
+ if(this.fillTexture)
46
+ this._fillTexture = this._createFillTexture(this.fillTexture);
47
+
48
+ this._sliderHandle = this._createTexture(this.handleTexture);
49
+
50
+ this._setEvents(this._sliderBg._baseObject);
51
+ this._setEvents(this._sliderHandle._baseObject);
52
+ }
53
+
54
+ _createFillTexture(model){
55
+ const fillTexture = this._createTexture(model);
56
+ const { width, height } = fillTexture._baseObject;
57
+ this._fillMask = Urso.objects.create({
58
+ type: Urso.types.objects.GRAPHICS,
59
+ figure: {
60
+ rectangle: [0, 0, width, height]
61
+ },
62
+ x: -width * fillTexture.anchorX,
63
+ y: -height * fillTexture.anchorY,
64
+ }, this);
65
+
66
+ fillTexture._baseObject.mask = this._fillMask._baseObject;
67
+ return fillTexture
68
+ }
69
+
70
+ _createValueText() {
71
+ if (this.minValueTextModel) {
72
+ this.minValueText = Urso.objects.create(this.minValueTextModel, this);
73
+ this.minValueText.text = this.points[0];
74
+ }
75
+
76
+ if (this.maxValueTextModel) {
77
+ this.maxValueText = Urso.objects.create(this.maxValueTextModel, this);
78
+ this.maxValueText.text = this.points.length <= 2 ? '100' : this.points[this.points.length - 1];
79
+ }
80
+
81
+ if(this.currentValueTextModel){
82
+ this.currentValueText = Urso.objects.create(this.currentValueTextModel, this);
83
+ }
84
+ }
85
+
86
+ _createTexture(model) {
87
+ if (model.type === Urso.types.objects.GRAPHICS || model.type === Urso.types.objects.IMAGE)
88
+ return Urso.objects.create(model, this);
89
+ else
90
+ Urso.logger.error('ModulesObjectsModelsSlider objects error: textures should be GRAPHICS or IMAGE type');
91
+ }
92
+
93
+ _setEvents(obj) {
94
+ obj.interactive = true;
95
+ obj.buttonMode = true;
96
+
97
+ obj
98
+ .on('pointerdown', this._onPointerDown.bind(this))
99
+ .on('pointerup', this._onPointerUp.bind(this))
100
+ .on('pointerupoutside', this._onPointerUp.bind(this))
101
+ .on('touchmove', this._onTouchmove.bind(this));
102
+ };
103
+
104
+ _onTouchmove(event) {
105
+ const position = this._getEventLocalPosition(event);
106
+ this._onPointerMove(position);
107
+ }
108
+
109
+ _getEventLocalPosition(event) {
110
+ const world = Urso.objects.getWorld();
111
+ const worldScale = world._baseObject.scale;
112
+
113
+ const x = event.data.global.x / worldScale.x;
114
+ const y = event.data.global.y / worldScale.y;
115
+
116
+ return { x, y };
117
+ }
118
+
119
+ _addBaseObject() {
120
+ this._baseObject = new PIXI.Container();
121
+ };
122
+
123
+ _onPointerDown(obj) {
124
+ if (obj.target === this._sliderHandle._baseObject)
125
+ this._handleIsDragging = true;
126
+ }
127
+
128
+ _onPointerMove({ x, y }) {
129
+ if (!this._handleIsDragging)
130
+ return
131
+
132
+ const value = this.isVertical ? y : x;
133
+
134
+ if (value < this[this.positionKey])
135
+ this._sliderHandle[this.positionKey] = 0;
136
+ else if (value >= this[this.positionKey] + this._sliderBg._baseObject[this.targetObjParam])
137
+ this._sliderHandle[this.positionKey] = this._sliderBg._baseObject[this.targetObjParam];
138
+ else
139
+ this._sliderHandle[this.positionKey] = value - this[this.positionKey];
140
+
141
+ this._setFillMask();
142
+
143
+ const data = { class: this.class, name: this.name, position: this._sliderHandle[this.positionKey] };
144
+ this.emit(Urso.events.MODULES_OBJECTS_SLIDER_HANDLE_MOVE, data)
145
+ }
146
+
147
+ _onPointerUp(obj) {
148
+ this._handleIsDragging = false;
149
+ let targetObj;
150
+
151
+ if (obj.target === this._sliderBg._baseObject)
152
+ targetObj = obj.data.getLocalPosition(obj.target)
153
+ else
154
+ targetObj = this._sliderHandle;
155
+
156
+ const {x, y} = targetObj;
157
+ const value = this.isVertical ? y : x;
158
+ this._dropHandle(value);
159
+ }
160
+
161
+ _setDefaultValue(){
162
+ if(!this.points.includes(this.defaultValue))
163
+ this.defaultValue = this.points[0];
164
+
165
+ let value = this.points.indexOf(this.defaultValue) *
166
+ this._sliderBg._baseObject[this.targetObjParam] / (this.points.length - 1);
167
+
168
+ this._setNewValue(value, this.defaultValue);
169
+ }
170
+
171
+ _dropHandle(givenValue) {
172
+ let value;
173
+ let coord;
174
+
175
+ if(this.points.length <= 2){
176
+ coord = givenValue;
177
+ value = ~~(100 / this._sliderBg._baseObject[this.targetObjParam] * givenValue);
178
+ }
179
+ // calculate closest point
180
+ else{
181
+ for (let i = 0; i < this.points.length; i++) {
182
+ let pointCoord = i * this._sliderBg._baseObject[this.targetObjParam] / (this.points.length - 1);
183
+
184
+ if (typeof (coord) === 'number' && givenValue - pointCoord < coord - givenValue) {
185
+ coord = coord;
186
+ } else {
187
+ coord = pointCoord;
188
+ value = this.points[i];
189
+ }
190
+ }
191
+ }
192
+ const data = { class: this.class, name: this.name, position: coord, value: value };
193
+
194
+ this.emit(Urso.events.MODULES_OBJECTS_SLIDER_HANDLE_DROP, data);
195
+ this._setNewValue(coord, value);
196
+ }
197
+
198
+ _setFillMask(){
199
+ if(!this._fillMask)
200
+ return
201
+
202
+ const progress = (this._sliderHandle[this.positionKey] - this._sliderBg[this.positionKey]) *
203
+ 100 / this._fillTexture._baseObject[this.targetObjParam] * 0.01;
204
+
205
+ const scaleKey = this.isVertical ? 'scaleY' : 'scaleX';
206
+ this._fillMask[scaleKey] = progress;
207
+ }
208
+
209
+ _setNewValue(coord, value){
210
+ this._sliderHandle[this.positionKey] = coord;
211
+
212
+ if (this.currentValueText)
213
+ this.currentValueText.text = value;
214
+
215
+ this._setFillMask();
216
+ }
217
+
218
+ _subscribeOnce() {
219
+ this.addListener(Urso.events.MODULES_SCENES_MOUSE_NEW_POSITION, this._onPointerMove.bind(this));
220
+ }
221
+ }
222
+
223
+ module.exports = ModulesObjectsModelsSlider;
@@ -1,89 +1,89 @@
1
- class ModulesObjectsModelsSpine extends Urso.Core.Modules.Objects.BaseModel {
2
- constructor(params) {
3
- super(params);
4
-
5
- this.type = Urso.types.objects.SPINE;
6
- this._addBaseObject();
7
- }
8
-
9
- setupParams(params) {
10
- super.setupParams(params);
11
-
12
- this.assetKey = Urso.helper.recursiveGet('assetKey', params, false);
13
-
14
- this.animation = {
15
- timeScale: Urso.helper.recursiveGet('animation.timeScale', params, 1),
16
- name: Urso.helper.recursiveGet('animation.name', params, false),
17
- loop: Urso.helper.recursiveGet('animation.loop', params, false),
18
- onComplete: Urso.helper.recursiveGet('animation.onComplete', params, false)
19
- };
20
-
21
- params.animation = this.animation; //we redefine original property here
22
- }
23
-
24
- play(animationName, loopFlag = false, track = 0) {
25
- this._baseObject.state.setAnimation(track, animationName, loopFlag);
26
- }
27
-
28
- addToSlot(object, slotName) {
29
- const spine = this._baseObject;
30
- const slotIndex = spine.spineData.slots.findIndex(({ name }) => name === slotName);
31
- const currentSlot = spine.slotContainers[slotIndex];
32
-
33
- if (currentSlot) {
34
- object._baseObject.scale.y = -1;
35
-
36
- Urso.objects.removeChild(object.parent, object)
37
- currentSlot.addChild(object._baseObject);
38
- } else {
39
- Urso.logger.warn('ModulesObjectsModelsSpine addToSlot error: no spine slot ' + slotName);
40
- }
41
- }
42
-
43
- /**
44
- *
45
- * @param {*} config
46
- * @param {boolean} [noObjectCreate] dont use this flag out of core
47
- *
48
- * config keys:
49
- timeScale
50
- onComplete
51
- */
52
- setAnimationConfig(config = {}, noObjectCreate) {
53
- this.animation = {
54
- ...this.animation,
55
- ...config
56
- };
57
-
58
- /*if (config.timeScale)
59
- this._baseObject.state.timeScale = config.timeScale;*/ //deprecated - now we use getTimeScale getter
60
-
61
- if (config.onComplete) {
62
- this._baseObject.state.clearListeners();
63
- this._baseObject.state.addListener({ complete: this.animation.onComplete });
64
- }
65
- }
66
-
67
- _addBaseObject() {
68
- let spineAsset = Urso.cache.getSpine(this.assetKey);
69
-
70
- if (!spineAsset)
71
- Urso.logger.error('ModulesObjectsModelsSpine assets error: no spine object ' + this.assetKey);
72
-
73
- this._baseObject = new PIXI.spine.Spine(spineAsset.spineData);
74
- //this._baseObject.state.timeScale = this.animation.timeScale;
75
- Object.defineProperty(this._baseObject.state, 'timeScale', { get: this.getTimeScale.bind(this) });
76
-
77
- if (this.animation.onComplete)
78
- this._baseObject.state.addListener({ complete: this.animation.onComplete });
79
-
80
- if (this.animation.name)
81
- this.play(this.animation.name, this.animation.loop);
82
- };
83
-
84
- getTimeScale() {
85
- return Urso.scenes.timeScale * this.animation.timeScale;
86
- }
87
- }
88
-
89
- module.exports = ModulesObjectsModelsSpine;
1
+ class ModulesObjectsModelsSpine extends Urso.Core.Modules.Objects.BaseModel {
2
+ constructor(params) {
3
+ super(params);
4
+
5
+ this.type = Urso.types.objects.SPINE;
6
+ this._addBaseObject();
7
+ }
8
+
9
+ setupParams(params) {
10
+ super.setupParams(params);
11
+
12
+ this.assetKey = Urso.helper.recursiveGet('assetKey', params, false);
13
+
14
+ this.animation = {
15
+ timeScale: Urso.helper.recursiveGet('animation.timeScale', params, 1),
16
+ name: Urso.helper.recursiveGet('animation.name', params, false),
17
+ loop: Urso.helper.recursiveGet('animation.loop', params, false),
18
+ onComplete: Urso.helper.recursiveGet('animation.onComplete', params, false)
19
+ };
20
+
21
+ params.animation = this.animation; //we redefine original property here
22
+ }
23
+
24
+ play(animationName, loopFlag = false, track = 0) {
25
+ this._baseObject.state.setAnimation(track, animationName, loopFlag);
26
+ }
27
+
28
+ addToSlot(object, slotName) {
29
+ const spine = this._baseObject;
30
+ const slotIndex = spine.spineData.slots.findIndex(({ name }) => name === slotName);
31
+ const currentSlot = spine.slotContainers[slotIndex];
32
+
33
+ if (currentSlot) {
34
+ object._baseObject.scale.y = -1;
35
+
36
+ Urso.objects.removeChild(object.parent, object)
37
+ currentSlot.addChild(object._baseObject);
38
+ } else {
39
+ Urso.logger.warn('ModulesObjectsModelsSpine addToSlot error: no spine slot ' + slotName);
40
+ }
41
+ }
42
+
43
+ /**
44
+ *
45
+ * @param {*} config
46
+ * @param {boolean} [noObjectCreate] dont use this flag out of core
47
+ *
48
+ * config keys:
49
+ timeScale
50
+ onComplete
51
+ */
52
+ setAnimationConfig(config = {}, noObjectCreate) {
53
+ this.animation = {
54
+ ...this.animation,
55
+ ...config
56
+ };
57
+
58
+ /*if (config.timeScale)
59
+ this._baseObject.state.timeScale = config.timeScale;*/ //deprecated - now we use getTimeScale getter
60
+
61
+ if (config.onComplete) {
62
+ this._baseObject.state.clearListeners();
63
+ this._baseObject.state.addListener({ complete: this.animation.onComplete });
64
+ }
65
+ }
66
+
67
+ _addBaseObject() {
68
+ let spineAsset = Urso.cache.getSpine(this.assetKey);
69
+
70
+ if (!spineAsset)
71
+ Urso.logger.error('ModulesObjectsModelsSpine assets error: no spine object ' + this.assetKey);
72
+
73
+ this._baseObject = new PIXI.spine.Spine(spineAsset.spineData);
74
+ //this._baseObject.state.timeScale = this.animation.timeScale;
75
+ Object.defineProperty(this._baseObject.state, 'timeScale', { get: this.getTimeScale.bind(this) });
76
+
77
+ if (this.animation.onComplete)
78
+ this._baseObject.state.addListener({ complete: this.animation.onComplete });
79
+
80
+ if (this.animation.name)
81
+ this.play(this.animation.name, this.animation.loop);
82
+ };
83
+
84
+ getTimeScale() {
85
+ return Urso.scenes.timeScale * this.animation.timeScale;
86
+ }
87
+ }
88
+
89
+ module.exports = ModulesObjectsModelsSpine;