melonjs 15.1.4 → 15.1.5
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.
- package/dist/melonjs.mjs/_virtual/_commonjsHelpers.js +1 -1
- package/dist/melonjs.mjs/_virtual/earcut.js +1 -1
- package/dist/melonjs.mjs/_virtual/howler.js +1 -1
- package/dist/melonjs.mjs/_virtual/index.js +1 -1
- package/dist/melonjs.mjs/application/application.js +1 -1
- package/dist/melonjs.mjs/application/header.js +1 -1
- package/dist/melonjs.mjs/application/resize.js +1 -1
- package/dist/melonjs.mjs/application/settings.js +1 -1
- package/dist/melonjs.mjs/audio/audio.js +1 -1
- package/dist/melonjs.mjs/camera/camera2d.js +1 -1
- package/dist/melonjs.mjs/const.js +1 -1
- package/dist/melonjs.mjs/entity/entity.js +3 -6
- package/dist/melonjs.mjs/geometries/ellipse.js +1 -1
- package/dist/melonjs.mjs/geometries/line.js +1 -1
- package/dist/melonjs.mjs/geometries/path2d.js +5 -5
- package/dist/melonjs.mjs/geometries/point.js +1 -1
- package/dist/melonjs.mjs/geometries/poly.js +3 -3
- package/dist/melonjs.mjs/geometries/rectangle.js +1 -1
- package/dist/melonjs.mjs/geometries/roundrect.js +1 -1
- package/dist/melonjs.mjs/index.js +2 -2
- package/dist/melonjs.mjs/input/gamepad.js +1 -1
- package/dist/melonjs.mjs/input/input.js +1 -1
- package/dist/melonjs.mjs/input/keyboard.js +1 -1
- package/dist/melonjs.mjs/input/pointer.js +1 -1
- package/dist/melonjs.mjs/input/pointerevent.js +10 -10
- package/dist/melonjs.mjs/lang/console.js +1 -1
- package/dist/melonjs.mjs/lang/deprecated.js +1 -1
- package/dist/melonjs.mjs/level/level.js +1 -1
- package/dist/melonjs.mjs/level/tiled/TMXGroup.js +1 -1
- package/dist/melonjs.mjs/level/tiled/TMXLayer.js +4 -4
- package/dist/melonjs.mjs/level/tiled/TMXObject.js +1 -1
- package/dist/melonjs.mjs/level/tiled/TMXTile.js +1 -1
- package/dist/melonjs.mjs/level/tiled/TMXTileMap.js +1 -1
- package/dist/melonjs.mjs/level/tiled/TMXTileset.js +1 -1
- package/dist/melonjs.mjs/level/tiled/TMXTilesetGroup.js +1 -1
- package/dist/melonjs.mjs/level/tiled/TMXUtils.js +4 -4
- package/dist/melonjs.mjs/level/tiled/constants.js +1 -1
- package/dist/melonjs.mjs/level/tiled/renderer/TMXHexagonalRenderer.js +2 -2
- package/dist/melonjs.mjs/level/tiled/renderer/TMXIsometricRenderer.js +1 -1
- package/dist/melonjs.mjs/level/tiled/renderer/TMXOrthogonalRenderer.js +1 -1
- package/dist/melonjs.mjs/level/tiled/renderer/TMXRenderer.js +2 -1
- package/dist/melonjs.mjs/level/tiled/renderer/TMXStaggeredRenderer.js +1 -1
- package/dist/melonjs.mjs/level/tiled/renderer/autodetect.js +1 -1
- package/dist/melonjs.mjs/loader/cache.js +1 -1
- package/dist/melonjs.mjs/loader/loader.js +4 -3
- package/dist/melonjs.mjs/loader/loadingscreen.js +1 -1
- package/dist/melonjs.mjs/loader/melonjs_logo.png.js +1 -1
- package/dist/melonjs.mjs/loader/parser.js +1 -1
- package/dist/melonjs.mjs/loader/settings.js +1 -1
- package/dist/melonjs.mjs/math/color.js +1 -1
- package/dist/melonjs.mjs/math/math.js +1 -1
- package/dist/melonjs.mjs/math/matrix2.js +1 -1
- package/dist/melonjs.mjs/math/matrix3.js +1 -1
- package/dist/melonjs.mjs/math/observable_vector2.js +1 -1
- package/dist/melonjs.mjs/math/observable_vector3.js +1 -1
- package/dist/melonjs.mjs/math/vector2.js +1 -1
- package/dist/melonjs.mjs/math/vector3.js +1 -1
- package/dist/melonjs.mjs/node_modules/@teppeis/multimaps/dist/esm/arraymultimap.js +1 -1
- package/dist/melonjs.mjs/node_modules/@teppeis/multimaps/dist/esm/multimap.js +1 -1
- package/dist/melonjs.mjs/node_modules/earcut/src/earcut.js +1 -1
- package/dist/melonjs.mjs/node_modules/eventemitter3/index.js +1 -1
- package/dist/melonjs.mjs/node_modules/eventemitter3/index2.js +1 -1
- package/dist/melonjs.mjs/node_modules/howler/dist/howler.js +1 -1
- package/dist/melonjs.mjs/particles/emitter.js +1 -1
- package/dist/melonjs.mjs/particles/particle.js +1 -1
- package/dist/melonjs.mjs/particles/settings.js +1 -1
- package/dist/melonjs.mjs/physics/body.js +1 -1
- package/dist/melonjs.mjs/physics/bounds.js +2 -2
- package/dist/melonjs.mjs/physics/collision.js +1 -1
- package/dist/melonjs.mjs/physics/detector.js +2 -2
- package/dist/melonjs.mjs/physics/quadtree.js +2 -2
- package/dist/melonjs.mjs/physics/response.js +1 -1
- package/dist/melonjs.mjs/physics/sat.js +5 -4
- package/dist/melonjs.mjs/physics/world.js +1 -1
- package/dist/melonjs.mjs/plugin/plugin.js +3 -3
- package/dist/melonjs.mjs/renderable/collectable.js +1 -1
- package/dist/melonjs.mjs/renderable/colorlayer.js +1 -1
- package/dist/melonjs.mjs/renderable/container.js +35 -25
- package/dist/melonjs.mjs/renderable/dragndrop.js +1 -1
- package/dist/melonjs.mjs/renderable/imagelayer.js +1 -1
- package/dist/melonjs.mjs/renderable/light2d.js +1 -1
- package/dist/melonjs.mjs/renderable/nineslicesprite.js +1 -1
- package/dist/melonjs.mjs/renderable/renderable.js +6 -9
- package/dist/melonjs.mjs/renderable/sprite.js +1 -1
- package/dist/melonjs.mjs/renderable/trigger.js +1 -1
- package/dist/melonjs.mjs/renderable/ui/uibaseelement.js +7 -4
- package/dist/melonjs.mjs/renderable/ui/uispriteelement.js +8 -2
- package/dist/melonjs.mjs/renderable/ui/uitextbutton.js +1 -1
- package/dist/melonjs.mjs/state/stage.js +1 -1
- package/dist/melonjs.mjs/state/state.js +1 -1
- package/dist/melonjs.mjs/system/device.js +1 -1
- package/dist/melonjs.mjs/system/dom.js +1 -1
- package/dist/melonjs.mjs/system/event.js +1 -1
- package/dist/melonjs.mjs/system/platform.js +1 -1
- package/dist/melonjs.mjs/system/pooling.js +1 -1
- package/dist/melonjs.mjs/system/save.js +1 -1
- package/dist/melonjs.mjs/system/timer.js +1 -1
- package/dist/melonjs.mjs/text/bitmaptext.js +3 -3
- package/dist/melonjs.mjs/text/bitmaptextdata.js +1 -1
- package/dist/melonjs.mjs/text/glyph.js +1 -1
- package/dist/melonjs.mjs/text/text.js +2 -2
- package/dist/melonjs.mjs/text/textmetrics.js +1 -1
- package/dist/melonjs.mjs/text/textstyle.js +1 -1
- package/dist/melonjs.mjs/tweens/easing.js +1 -1
- package/dist/melonjs.mjs/tweens/interpolation.js +1 -1
- package/dist/melonjs.mjs/tweens/tween.js +1 -1
- package/dist/melonjs.mjs/utils/agent.js +1 -1
- package/dist/melonjs.mjs/utils/array.js +1 -1
- package/dist/melonjs.mjs/utils/file.js +1 -1
- package/dist/melonjs.mjs/utils/function.js +1 -1
- package/dist/melonjs.mjs/utils/string.js +1 -1
- package/dist/melonjs.mjs/utils/utils.js +1 -1
- package/dist/melonjs.mjs/video/canvas/canvas_renderer.js +3 -6
- package/dist/melonjs.mjs/video/renderer.js +1 -1
- package/dist/melonjs.mjs/video/texture/atlas.js +1 -1
- package/dist/melonjs.mjs/video/texture/cache.js +1 -1
- package/dist/melonjs.mjs/video/texture/canvas_texture.js +2 -2
- package/dist/melonjs.mjs/video/utils/autodetect.js +1 -1
- package/dist/melonjs.mjs/video/video.js +1 -1
- package/dist/melonjs.mjs/video/webgl/buffer/vertex.js +1 -1
- package/dist/melonjs.mjs/video/webgl/compositors/compositor.js +1 -1
- package/dist/melonjs.mjs/video/webgl/compositors/primitive_compositor.js +1 -1
- package/dist/melonjs.mjs/video/webgl/compositors/quad_compositor.js +1 -1
- package/dist/melonjs.mjs/video/webgl/glshader.js +1 -1
- package/dist/melonjs.mjs/video/webgl/shaders/primitive.frag.js +1 -1
- package/dist/melonjs.mjs/video/webgl/shaders/primitive.vert.js +1 -1
- package/dist/melonjs.mjs/video/webgl/shaders/quad.frag.js +1 -1
- package/dist/melonjs.mjs/video/webgl/shaders/quad.vert.js +1 -1
- package/dist/melonjs.mjs/video/webgl/utils/attributes.js +1 -1
- package/dist/melonjs.mjs/video/webgl/utils/precision.js +1 -1
- package/dist/melonjs.mjs/video/webgl/utils/program.js +1 -1
- package/dist/melonjs.mjs/video/webgl/utils/string.js +1 -1
- package/dist/melonjs.mjs/video/webgl/utils/uniforms.js +1 -1
- package/dist/melonjs.mjs/video/webgl/webgl_renderer.js +1 -1
- package/dist/melonjs.module.js +97 -84
- package/dist/types/loader/loader.d.ts +9 -4
- package/dist/types/renderable/renderable.d.ts +1 -1
- package/package.json +7 -7
- package/src/entity/entity.js +2 -5
- package/src/geometries/path2d.js +4 -4
- package/src/geometries/poly.js +2 -2
- package/src/input/pointerevent.js +9 -9
- package/src/level/tiled/TMXLayer.js +3 -3
- package/src/level/tiled/TMXUtils.js +3 -3
- package/src/level/tiled/renderer/TMXHexagonalRenderer.js +1 -1
- package/src/loader/loader.js +3 -2
- package/src/physics/bounds.js +1 -1
- package/src/physics/detector.js +1 -1
- package/src/physics/quadtree.js +1 -1
- package/src/physics/sat.js +3 -3
- package/src/renderable/container.js +34 -24
- package/src/renderable/renderable.js +5 -8
- package/src/renderable/ui/uibaseelement.js +6 -3
- package/src/renderable/ui/uispriteelement.js +7 -1
- package/src/text/bitmaptext.js +2 -2
- package/src/text/text.js +1 -1
- package/src/video/canvas/canvas_renderer.js +2 -5
- package/src/video/texture/canvas_texture.js +1 -1
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
/*!
|
|
2
|
-
* melonJS Game Engine - v15.1.
|
|
2
|
+
* melonJS Game Engine - v15.1.5
|
|
3
3
|
* http://www.melonjs.org
|
|
4
4
|
* melonjs is licensed under the MIT License.
|
|
5
5
|
* http://www.opensource.org/licenses/mit-license
|
|
@@ -197,7 +197,7 @@ import Vector2d from '../math/vector2.js';
|
|
|
197
197
|
this.clear();
|
|
198
198
|
}
|
|
199
199
|
for (let i = 0; i < vertices.length; i++) {
|
|
200
|
-
|
|
200
|
+
const vertex = vertices[i];
|
|
201
201
|
if (vertex.x > this.max.x) this.max.x = vertex.x;
|
|
202
202
|
if (vertex.x < this.min.x) this.min.x = vertex.x;
|
|
203
203
|
if (vertex.y > this.max.y) this.max.y = vertex.y;
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
/*!
|
|
2
|
-
* melonJS Game Engine - v15.1.
|
|
2
|
+
* melonJS Game Engine - v15.1.5
|
|
3
3
|
* http://www.melonjs.org
|
|
4
4
|
* melonjs is licensed under the MIT License.
|
|
5
5
|
* http://www.opensource.org/licenses/mit-license
|
|
@@ -177,7 +177,7 @@ class Detector {
|
|
|
177
177
|
if (objB.body && line.getBounds().overlaps(objB.getBounds())) {
|
|
178
178
|
|
|
179
179
|
// go trough all defined shapes in B (if any)
|
|
180
|
-
|
|
180
|
+
const bLen = objB.body.shapes.length;
|
|
181
181
|
if ( objB.body.shapes.length === 0) {
|
|
182
182
|
continue;
|
|
183
183
|
}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
/*!
|
|
2
|
-
* melonJS Game Engine - v15.1.
|
|
2
|
+
* melonJS Game Engine - v15.1.5
|
|
3
3
|
* http://www.melonjs.org
|
|
4
4
|
* melonjs is licensed under the MIT License.
|
|
5
5
|
* http://www.opensource.org/licenses/mit-license
|
|
@@ -359,7 +359,7 @@ let QT_VECTOR = new Vector2d();
|
|
|
359
359
|
*/
|
|
360
360
|
hasChildren() {
|
|
361
361
|
for (let i = 0; i < this.nodes.length; i = i + 1) {
|
|
362
|
-
|
|
362
|
+
const subnode = this.nodes[i];
|
|
363
363
|
if (subnode.length > 0 || subnode.objects.length > 0) {
|
|
364
364
|
return true;
|
|
365
365
|
}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
/*!
|
|
2
|
-
* melonJS Game Engine - v15.1.
|
|
2
|
+
* melonJS Game Engine - v15.1.5
|
|
3
3
|
* http://www.melonjs.org
|
|
4
4
|
* melonjs is licensed under the MIT License.
|
|
5
5
|
* http://www.opensource.org/licenses/mit-license
|
|
@@ -12,6 +12,7 @@ import Vector2d from '../math/vector2.js';
|
|
|
12
12
|
* Available under the MIT License - https://github.com/jriecken/sat-js
|
|
13
13
|
*/
|
|
14
14
|
|
|
15
|
+
|
|
15
16
|
/**
|
|
16
17
|
* Constants for Vornoi regions
|
|
17
18
|
* @ignore
|
|
@@ -65,7 +66,7 @@ function flattenPointsOn(points, normal, result) {
|
|
|
65
66
|
let len = points.length;
|
|
66
67
|
for (let i = 0; i < len; i++) {
|
|
67
68
|
// The magnitude of the projection of the point onto the normal
|
|
68
|
-
|
|
69
|
+
const dot = points[i].dot(normal);
|
|
69
70
|
if (dot < min) { min = dot; }
|
|
70
71
|
if (dot > max) { max = dot; }
|
|
71
72
|
}
|
|
@@ -312,8 +313,8 @@ function testPolygonEllipse(a, polyA, b, ellipseB, response) {
|
|
|
312
313
|
|
|
313
314
|
// For each edge in the polygon:
|
|
314
315
|
for (let i = 0; i < len; i++) {
|
|
315
|
-
|
|
316
|
-
|
|
316
|
+
const next = i === len - 1 ? 0 : i + 1;
|
|
317
|
+
const prev = i === 0 ? len - 1 : i - 1;
|
|
317
318
|
let overlap = 0;
|
|
318
319
|
let overlapN = null;
|
|
319
320
|
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
/*!
|
|
2
|
-
* melonJS Game Engine - v15.1.
|
|
2
|
+
* melonJS Game Engine - v15.1.5
|
|
3
3
|
* http://www.melonjs.org
|
|
4
4
|
* melonjs is licensed under the MIT License.
|
|
5
5
|
* http://www.opensource.org/licenses/mit-license
|
|
@@ -24,10 +24,10 @@ class BasePlugin {
|
|
|
24
24
|
* this can be overridden by the plugin
|
|
25
25
|
* @public
|
|
26
26
|
* @type {string}
|
|
27
|
-
* @default "15.1.
|
|
27
|
+
* @default "15.1.5"
|
|
28
28
|
* @name plugin.Base#version
|
|
29
29
|
*/
|
|
30
|
-
this.version = "15.1.
|
|
30
|
+
this.version = "15.1.5";
|
|
31
31
|
}
|
|
32
32
|
}
|
|
33
33
|
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
/*!
|
|
2
|
-
* melonJS Game Engine - v15.1.
|
|
2
|
+
* melonJS Game Engine - v15.1.5
|
|
3
3
|
* http://www.melonjs.org
|
|
4
4
|
* melonjs is licensed under the MIT License.
|
|
5
5
|
* http://www.opensource.org/licenses/mit-license
|
|
@@ -200,10 +200,16 @@ let globalFloatingCounter = 0;
|
|
|
200
200
|
}
|
|
201
201
|
}
|
|
202
202
|
|
|
203
|
+
// add the new child
|
|
203
204
|
child.ancestor = this;
|
|
204
205
|
this.getChildren().push(child);
|
|
206
|
+
|
|
207
|
+
// update child bounds to reflect the new ancestor
|
|
205
208
|
if (typeof child.updateBounds === "function") {
|
|
206
|
-
|
|
209
|
+
if (this.isFloating === true) {
|
|
210
|
+
// only parent container can be floating
|
|
211
|
+
child.floating = false;
|
|
212
|
+
}
|
|
207
213
|
child.updateBounds();
|
|
208
214
|
}
|
|
209
215
|
|
|
@@ -224,12 +230,7 @@ let globalFloatingCounter = 0;
|
|
|
224
230
|
child.onActivateEvent();
|
|
225
231
|
}
|
|
226
232
|
|
|
227
|
-
// force
|
|
228
|
-
if (this.isAttachedToRoot() === true) {
|
|
229
|
-
this.isDirty = true;
|
|
230
|
-
}
|
|
231
|
-
|
|
232
|
-
// force bounds update if required
|
|
233
|
+
// force container bounds update if required
|
|
233
234
|
if (this.enableChildBoundsUpdate === true) {
|
|
234
235
|
this.updateBounds();
|
|
235
236
|
}
|
|
@@ -252,6 +253,9 @@ let globalFloatingCounter = 0;
|
|
|
252
253
|
}
|
|
253
254
|
}
|
|
254
255
|
|
|
256
|
+
// mark the container for repaint
|
|
257
|
+
this.isDirty = true;
|
|
258
|
+
|
|
255
259
|
// triggered callback if defined
|
|
256
260
|
this.onChildChange.call(this, this.getChildren().length - 1);
|
|
257
261
|
|
|
@@ -278,20 +282,25 @@ let globalFloatingCounter = 0;
|
|
|
278
282
|
child.GUID = utils.createGUID();
|
|
279
283
|
}
|
|
280
284
|
}
|
|
281
|
-
child.ancestor = this;
|
|
282
285
|
|
|
286
|
+
// add the new child
|
|
287
|
+
child.ancestor = this;
|
|
283
288
|
this.getChildren().splice(index, 0, child);
|
|
284
289
|
|
|
285
|
-
|
|
286
|
-
|
|
290
|
+
// update child bounds to reflect the new ancestor
|
|
291
|
+
if (typeof child.updateBounds === "function") {
|
|
292
|
+
if (this.isFloating === true) {
|
|
293
|
+
// only parent container can be floating
|
|
294
|
+
child.floating = false;
|
|
295
|
+
}
|
|
296
|
+
child.updateBounds();
|
|
287
297
|
}
|
|
288
298
|
|
|
289
|
-
|
|
290
|
-
|
|
291
|
-
this.isDirty = true;
|
|
299
|
+
if (typeof child.onActivateEvent === "function" && this.isAttachedToRoot()) {
|
|
300
|
+
child.onActivateEvent();
|
|
292
301
|
}
|
|
293
302
|
|
|
294
|
-
// force bounds update if required
|
|
303
|
+
// force container bounds update if required
|
|
295
304
|
if (this.enableChildBoundsUpdate === true) {
|
|
296
305
|
this.updateBounds();
|
|
297
306
|
}
|
|
@@ -314,6 +323,9 @@ let globalFloatingCounter = 0;
|
|
|
314
323
|
}
|
|
315
324
|
}
|
|
316
325
|
|
|
326
|
+
// mark the container for repaint
|
|
327
|
+
this.isDirty = true;
|
|
328
|
+
|
|
317
329
|
// triggered callback if defined
|
|
318
330
|
this.onChildChange.call(this, index);
|
|
319
331
|
|
|
@@ -538,10 +550,9 @@ let globalFloatingCounter = 0;
|
|
|
538
550
|
}
|
|
539
551
|
|
|
540
552
|
/**
|
|
541
|
-
* update the bounding box for this
|
|
542
|
-
* @
|
|
543
|
-
* @
|
|
544
|
-
* @returns {Bounds} this shape bounding box Rectangle object
|
|
553
|
+
* update the bounding box for this container.
|
|
554
|
+
* @param {boolean} [absolute=true] - update the bounds size and position in (world) absolute coordinates
|
|
555
|
+
* @returns {Bounds} this container bounding box Rectangle object
|
|
545
556
|
*/
|
|
546
557
|
updateBounds(absolute = true) {
|
|
547
558
|
let bounds = this.getBounds();
|
|
@@ -552,13 +563,14 @@ let globalFloatingCounter = 0;
|
|
|
552
563
|
if (this.enableChildBoundsUpdate === true) {
|
|
553
564
|
this.forEach((child) => {
|
|
554
565
|
if (child.isRenderable) {
|
|
555
|
-
let childBounds = child.
|
|
566
|
+
let childBounds = child.updateBounds(true);
|
|
556
567
|
if (childBounds.isFinite()) {
|
|
557
568
|
bounds.addBounds(childBounds);
|
|
558
569
|
}
|
|
559
570
|
}
|
|
560
571
|
});
|
|
561
572
|
}
|
|
573
|
+
|
|
562
574
|
return bounds;
|
|
563
575
|
}
|
|
564
576
|
|
|
@@ -682,16 +694,14 @@ let globalFloatingCounter = 0;
|
|
|
682
694
|
child.ancestor = undefined;
|
|
683
695
|
}
|
|
684
696
|
|
|
685
|
-
// force repaint in case this is a static non-animated object
|
|
686
|
-
if (this.isAttachedToRoot() === true) {
|
|
687
|
-
this.isDirty = true;
|
|
688
|
-
}
|
|
689
|
-
|
|
690
697
|
// force bounds update if required
|
|
691
698
|
if (this.enableChildBoundsUpdate === true) {
|
|
692
699
|
this.updateBounds();
|
|
693
700
|
}
|
|
694
701
|
|
|
702
|
+
// mark the container for repaint
|
|
703
|
+
this.isDirty = true;
|
|
704
|
+
|
|
695
705
|
// triggered callback if defined
|
|
696
706
|
this.onChildChange.call(this, childIndex);
|
|
697
707
|
}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
/*!
|
|
2
|
-
* melonJS Game Engine - v15.1.
|
|
2
|
+
* melonJS Game Engine - v15.1.5
|
|
3
3
|
* http://www.melonjs.org
|
|
4
4
|
* melonjs is licensed under the MIT License.
|
|
5
5
|
* http://www.opensource.org/licenses/mit-license
|
|
@@ -270,12 +270,12 @@ import { releaseAllPointerEvents } from '../input/pointerevent.js';
|
|
|
270
270
|
}
|
|
271
271
|
|
|
272
272
|
/**
|
|
273
|
-
* Whether the renderable object is floating, or contained in a floating container
|
|
273
|
+
* Whether the renderable object is floating (i.e. used screen coordinates), or contained in a floating parent container
|
|
274
274
|
* @see Renderable#floating
|
|
275
275
|
* @type {boolean}
|
|
276
276
|
*/
|
|
277
277
|
get isFloating() {
|
|
278
|
-
return this.floating === true || (typeof this.ancestor !== "undefined" && this.ancestor.
|
|
278
|
+
return this.floating === true || (typeof this.ancestor !== "undefined" && this.ancestor.isFloating === true);
|
|
279
279
|
}
|
|
280
280
|
|
|
281
281
|
/**
|
|
@@ -584,11 +584,8 @@ import { releaseAllPointerEvents } from '../input/pointerevent.js';
|
|
|
584
584
|
}
|
|
585
585
|
|
|
586
586
|
if (absolute === true) {
|
|
587
|
-
|
|
588
|
-
|
|
589
|
-
bounds.translate(this.ancestor.getAbsolutePosition());
|
|
590
|
-
}
|
|
591
|
-
|
|
587
|
+
var absPos = this.getAbsolutePosition();
|
|
588
|
+
bounds.centerOn(absPos.x + bounds.x + bounds.width / 2, absPos.y + bounds.y + bounds.height / 2);
|
|
592
589
|
}
|
|
593
590
|
return bounds;
|
|
594
591
|
|
|
@@ -617,7 +614,7 @@ import { releaseAllPointerEvents } from '../input/pointerevent.js';
|
|
|
617
614
|
}
|
|
618
615
|
// XXX Cache me or something
|
|
619
616
|
this._absPos.set(this.pos.x, this.pos.y);
|
|
620
|
-
if (typeof this.ancestor !== "undefined" && typeof this.ancestor.
|
|
617
|
+
if (typeof this.ancestor !== "undefined" && typeof this.ancestor.getAbsolutePosition === "function" && this.floating !== true) {
|
|
621
618
|
this._absPos.add(this.ancestor.getAbsolutePosition());
|
|
622
619
|
}
|
|
623
620
|
return this._absPos;
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
/*!
|
|
2
|
-
* melonJS Game Engine - v15.1.
|
|
2
|
+
* melonJS Game Engine - v15.1.5
|
|
3
3
|
* http://www.melonjs.org
|
|
4
4
|
* melonjs is licensed under the MIT License.
|
|
5
5
|
* http://www.opensource.org/licenses/mit-license
|
|
@@ -71,7 +71,7 @@ import { registerPointerEvent, releasePointerEvent } from '../../input/pointerev
|
|
|
71
71
|
|
|
72
72
|
/**
|
|
73
73
|
* UI base elements use screen coordinates by default
|
|
74
|
-
* (Note: any child elements added to a UIBaseElement should
|
|
74
|
+
* (Note: any child elements added to a UIBaseElement should have their floating property to false)
|
|
75
75
|
* @see Renderable.floating
|
|
76
76
|
* @type {boolean}
|
|
77
77
|
* @default true
|
|
@@ -83,6 +83,9 @@ import { registerPointerEvent, releasePointerEvent } from '../../input/pointerev
|
|
|
83
83
|
|
|
84
84
|
// enable event detection
|
|
85
85
|
this.isKinematic = false;
|
|
86
|
+
|
|
87
|
+
// update container and children bounds automatically
|
|
88
|
+
this.enableChildBoundsUpdate = true;
|
|
86
89
|
}
|
|
87
90
|
|
|
88
91
|
/**
|
|
@@ -117,7 +120,7 @@ import { registerPointerEvent, releasePointerEvent } from '../../input/pointerev
|
|
|
117
120
|
* @returns {boolean} return false if we need to stop propagating the event
|
|
118
121
|
*/
|
|
119
122
|
onClick(event) { // eslint-disable-line no-unused-vars
|
|
120
|
-
return
|
|
123
|
+
return true;
|
|
121
124
|
}
|
|
122
125
|
|
|
123
126
|
/**
|
|
@@ -210,7 +213,7 @@ import { registerPointerEvent, releasePointerEvent } from '../../input/pointerev
|
|
|
210
213
|
* @returns {boolean} return false if we need to stop propagating the event
|
|
211
214
|
*/
|
|
212
215
|
onRelease() {
|
|
213
|
-
return
|
|
216
|
+
return true;
|
|
214
217
|
}
|
|
215
218
|
|
|
216
219
|
/**
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
/*!
|
|
2
|
-
* melonJS Game Engine - v15.1.
|
|
2
|
+
* melonJS Game Engine - v15.1.5
|
|
3
3
|
* http://www.melonjs.org
|
|
4
4
|
* melonjs is licensed under the MIT License.
|
|
5
5
|
* http://www.opensource.org/licenses/mit-license
|
|
@@ -80,7 +80,13 @@ import { registerPointerEvent, releasePointerEvent } from '../../input/pointerev
|
|
|
80
80
|
this.holdTimeout = -1;
|
|
81
81
|
this.released = true;
|
|
82
82
|
|
|
83
|
-
|
|
83
|
+
/**
|
|
84
|
+
* if this UISpriteElement should use screen coordinates or local coordinates
|
|
85
|
+
* (Note: any UISpriteElement elements added to a floating parent container should have their floating property to false)
|
|
86
|
+
* @see Renderable.floating
|
|
87
|
+
* @type {boolean}
|
|
88
|
+
* @default true
|
|
89
|
+
*/
|
|
84
90
|
this.floating = true;
|
|
85
91
|
|
|
86
92
|
// enable event detection
|