bard-legends-framework 0.5.0 → 0.6.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.
- package/dist/physics/entity-types/physics-entity.js +3 -4
- package/dist/physics/entity-types/physics-entity.js.map +1 -1
- package/dist/physics/index.d.ts +0 -1
- package/dist/physics/index.js +1 -3
- package/dist/physics/index.js.map +1 -1
- package/dist/physics/interfaces.d.ts +1 -0
- package/dist/physics/interfaces.js.map +1 -1
- package/dist/physics/libs/p2js.helper.d.ts +0 -1
- package/dist/physics/libs/p2js.helper.js +0 -5
- package/dist/physics/libs/p2js.helper.js.map +1 -1
- package/dist/physics/libs/physics-body-groups.d.ts +1 -15
- package/dist/physics/libs/physics-body-groups.js +0 -73
- package/dist/physics/libs/physics-body-groups.js.map +1 -1
- package/dist/physics/module//342/232/234/357/270/217gateways/controllers/physics-internal.controller.d.ts +6 -2
- package/dist/physics/module//342/232/234/357/270/217gateways/controllers/physics-internal.controller.js +13 -4
- package/dist/physics/module//342/232/234/357/270/217gateways/controllers/physics-internal.controller.js.map +1 -1
- package/dist/physics/module//342/232/234/357/270/217gateways/controllers/physics.controller.d.ts +7 -5
- package/dist/physics/module//342/232/234/357/270/217gateways/controllers/physics.controller.js +13 -6
- package/dist/physics/module//342/232/234/357/270/217gateways/controllers/physics.controller.js.map +1 -1
- package/dist/physics/module//342/232/234/357/270/217gateways/dtos/requests.dto.d.ts +3 -0
- package/dist/physics/module//342/232/234/357/270/217gateways/dtos/shared-interfaces.dto.d.ts +2 -0
- package/dist/physics/module//342/232/234/357/270/217gateways/dtos/shared-interfaces.dto.js.map +1 -1
- package/dist/physics/module//342/232/234/357/270/217gateways/physics-internal.gateway.d.ts +3 -1
- package/dist/physics/module//342/232/234/357/270/217gateways/physics-internal.gateway.js +8 -2
- package/dist/physics/module//342/232/234/357/270/217gateways/physics-internal.gateway.js.map +1 -1
- package/dist/physics/module//342/232/234/357/270/217gateways/physics.gateway.d.ts +2 -2
- package/dist/physics/module//342/232/234/357/270/217gateways/physics.gateway.js +5 -2
- package/dist/physics/module//342/232/234/357/270/217gateways/physics.gateway.js.map +1 -1
- package/dist/physics/module//360/237/223/220services/collision/collisions.service.js +7 -0
- package/dist/physics/module//360/237/223/220services/collision/collisions.service.js.map +1 -1
- package/dist/physics/module//360/237/223/220services/collision/physics-body-group.service.d.ts +11 -0
- package/dist/physics/module//360/237/223/220services/collision/physics-body-group.service.js +59 -0
- package/dist/physics/module//360/237/223/220services/collision/physics-body-group.service.js.map +1 -0
- package/dist/physics/module//360/237/223/220services/creation/border.service.d.ts +2 -1
- package/dist/physics/module//360/237/223/220services/creation/border.service.js +7 -8
- package/dist/physics/module//360/237/223/220services/creation/border.service.js.map +1 -1
- package/dist/physics/module//360/237/223/220services/creation/physics-world.service.d.ts +3 -1
- package/dist/physics/module//360/237/223/220services/creation/physics-world.service.js +11 -4
- package/dist/physics/module//360/237/223/220services/creation/physics-world.service.js.map +1 -1
- package/dist/physics/module//360/237/223/220services/creation/shape-creation.service.d.ts +1 -1
- package/dist/physics/module//360/237/223/220services/creation/shape-creation.service.js +19 -15
- package/dist/physics/module//360/237/223/220services/creation/shape-creation.service.js.map +1 -1
- package/dist/physics/module//360/237/223/220services/impact/eliptic-explosion.service.d.ts +18 -0
- package/dist/physics/module//360/237/223/220services/impact/eliptic-explosion.service.js +107 -0
- package/dist/physics/module//360/237/223/220services/impact/eliptic-explosion.service.js.map +1 -0
- package/dist/physics/module//360/237/223/220services/impact/explosion.service.d.ts +18 -0
- package/dist/physics/module//360/237/223/220services/impact/explosion.service.js +93 -0
- package/dist/physics/module//360/237/223/220services/impact/explosion.service.js.map +1 -0
- package/dist/physics/module//360/237/223/220services/impact/impact.service.d.ts +5 -0
- package/dist/physics/module//360/237/223/220services/impact/impact.service.js +23 -0
- package/dist/physics/module//360/237/223/220services/impact/impact.service.js.map +1 -0
- package/dist/physics/module//360/237/223/220services/impact/ray-cast-hit-converter.d.ts +9 -0
- package/dist/physics/module//360/237/223/220services/impact/ray-cast-hit-converter.js +83 -0
- package/dist/physics/module//360/237/223/220services/impact/ray-cast-hit-converter.js.map +1 -0
- package/dist/physics/module//360/237/223/220services/path-finding/availability-grid-cache.service.d.ts +15 -0
- package/dist/physics/module//360/237/223/220services/path-finding/availability-grid-cache.service.js +51 -0
- package/dist/physics/module//360/237/223/220services/path-finding/availability-grid-cache.service.js.map +1 -0
- package/dist/physics/module//360/237/223/220services/path-finding/availability-grid.service.d.ts +6 -1
- package/dist/physics/module//360/237/223/220services/path-finding/availability-grid.service.js +18 -7
- package/dist/physics/module//360/237/223/220services/path-finding/availability-grid.service.js.map +1 -1
- package/dist/physics/module//360/237/223/220services/path-finding/path-finder.service.d.ts +1 -2
- package/dist/physics/module//360/237/223/220services/path-finding/path-finder.service.js +2 -6
- package/dist/physics/module//360/237/223/220services/path-finding/path-finder.service.js.map +1 -1
- package/dist/physics/module//360/237/223/220services/ray-casting/ray-casting.service.d.ts +3 -0
- package/dist/physics/module//360/237/223/220services/ray-casting/ray-casting.service.js +13 -6
- package/dist/physics/module//360/237/223/220services/ray-casting/ray-casting.service.js.map +1 -1
- package/dist/physics/module//360/237/247/212entities/physics-world.entity.d.ts +6 -4
- package/dist/physics/module//360/237/247/212entities/physics-world.entity.js +8 -3
- package/dist/physics/module//360/237/247/212entities/physics-world.entity.js.map +1 -1
- package/package.json +1 -1
- package/package.json.bak +1 -1
|
@@ -6,7 +6,6 @@ const physics_internal_gateway_1 = require("../module/\u269C\uFE0Fgateways/physi
|
|
|
6
6
|
const p2js_helper_1 = require("../libs/p2js.helper");
|
|
7
7
|
const game_entities_1 = require("../../game-entities");
|
|
8
8
|
const update_cycle_1 = require("../../game-entities/update-cycle");
|
|
9
|
-
const physics_body_groups_1 = require("../libs/physics-body-groups");
|
|
10
9
|
class PhysicsEntity extends game_entities_1.Entity {
|
|
11
10
|
static { this.p2BodyIdToPhysicsBody = new Map(); }
|
|
12
11
|
static { this.physicsEntities = new Map(); }
|
|
@@ -58,9 +57,9 @@ class PhysicsEntity extends game_entities_1.Entity {
|
|
|
58
57
|
this.type = type;
|
|
59
58
|
this.physicsBodyGroup = physicsEntityDefinition.shapeDefinition.group;
|
|
60
59
|
this.includeInPathfinding = physicsEntityDefinition.includeOnPathfinding;
|
|
61
|
-
this.physicsGroup =
|
|
62
|
-
this.physicsMask =
|
|
63
|
-
this.p2Body = this.physicsInternalGateway.createBody(physicsEntityDefinition, material, materialDefinition, this.type);
|
|
60
|
+
this.physicsGroup = this.physicsInternalGateway.getGroupConstant(this.physicsWorldId, this.physicsBodyGroup);
|
|
61
|
+
this.physicsMask = this.physicsInternalGateway.getMaskConstant(this.physicsWorldId, this.physicsBodyGroup);
|
|
62
|
+
this.p2Body = this.physicsInternalGateway.createBody(this.physicsWorldId, physicsEntityDefinition, material, materialDefinition, this.type);
|
|
64
63
|
this._area = this.p2Body.getArea();
|
|
65
64
|
this._mass = this.p2Body.mass;
|
|
66
65
|
this.p2Body.position = p2js_helper_1.P2JSHelper.vectorToArray(physicsEntityDefinition.position);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"physics-entity.js","sourceRoot":"","sources":["../../../src/physics/entity-types/physics-entity.ts"],"names":[],"mappings":";;;AAAA,6CAAqC;AAGrC,sGAAuF;AAEvF,qDAAiD;AAEjD,uDAAsD;AACtD,mEAA+D;
|
|
1
|
+
{"version":3,"file":"physics-entity.js","sourceRoot":"","sources":["../../../src/physics/entity-types/physics-entity.ts"],"names":[],"mappings":"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"}
|
package/dist/physics/index.d.ts
CHANGED
|
@@ -2,6 +2,5 @@ export { MovableEntity } from './entity-types/movable-entity';
|
|
|
2
2
|
export { MovablePhysicsEntity } from './entity-types/movable-physics-entity';
|
|
3
3
|
export { ImmovablePhysicsEntity } from './entity-types/immovable-physics-entity';
|
|
4
4
|
export { PhysicsEntity } from './entity-types/physics-entity';
|
|
5
|
-
export { PhysicsBodyGroup } from './libs/physics-body-groups';
|
|
6
5
|
export * from './module/⚜️gateways/index';
|
|
7
6
|
export * from './interfaces';
|
package/dist/physics/index.js
CHANGED
|
@@ -14,7 +14,7 @@ var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
|
14
14
|
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
15
|
};
|
|
16
16
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
-
exports.
|
|
17
|
+
exports.PhysicsEntity = exports.ImmovablePhysicsEntity = exports.MovablePhysicsEntity = exports.MovableEntity = void 0;
|
|
18
18
|
var movable_entity_1 = require("./entity-types/movable-entity");
|
|
19
19
|
Object.defineProperty(exports, "MovableEntity", { enumerable: true, get: function () { return movable_entity_1.MovableEntity; } });
|
|
20
20
|
var movable_physics_entity_1 = require("./entity-types/movable-physics-entity");
|
|
@@ -23,8 +23,6 @@ var immovable_physics_entity_1 = require("./entity-types/immovable-physics-entit
|
|
|
23
23
|
Object.defineProperty(exports, "ImmovablePhysicsEntity", { enumerable: true, get: function () { return immovable_physics_entity_1.ImmovablePhysicsEntity; } });
|
|
24
24
|
var physics_entity_1 = require("./entity-types/physics-entity");
|
|
25
25
|
Object.defineProperty(exports, "PhysicsEntity", { enumerable: true, get: function () { return physics_entity_1.PhysicsEntity; } });
|
|
26
|
-
var physics_body_groups_1 = require("./libs/physics-body-groups");
|
|
27
|
-
Object.defineProperty(exports, "PhysicsBodyGroup", { enumerable: true, get: function () { return physics_body_groups_1.PhysicsBodyGroup; } });
|
|
28
26
|
__exportStar(require("./module/\u269C\uFE0Fgateways/index"), exports);
|
|
29
27
|
__exportStar(require("./interfaces"), exports);
|
|
30
28
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/physics/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;AAAA,gEAA8D;AAArD,+GAAA,aAAa,OAAA;AACtB,gFAA6E;AAApE,8HAAA,oBAAoB,OAAA;AAC7B,oFAAiF;AAAxE,kIAAA,sBAAsB,OAAA;AAC/B,gEAA8D;AAArD,+GAAA,aAAa,OAAA;AAEtB,
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/physics/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;AAAA,gEAA8D;AAArD,+GAAA,aAAa,OAAA;AACtB,gFAA6E;AAApE,8HAAA,oBAAoB,OAAA;AAC7B,oFAAiF;AAAxE,kIAAA,sBAAsB,OAAA;AAC/B,gEAA8D;AAArD,+GAAA,aAAa,OAAA;AAEtB,sEAA0C;AAC1C,+CAA6B"}
|
|
@@ -11,6 +11,7 @@ export interface PhysicsBodyDTO {
|
|
|
11
11
|
export interface CollisionDetails {
|
|
12
12
|
readonly body: PhysicsBodyDTO;
|
|
13
13
|
readonly getPositionReletiveToObject: () => Vector;
|
|
14
|
+
readonly getPositionOnWorld: () => Vector;
|
|
14
15
|
readonly position: Vector;
|
|
15
16
|
readonly mass: number;
|
|
16
17
|
readonly area: number;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"interfaces.js","sourceRoot":"","sources":["../../src/physics/interfaces.ts"],"names":[],"mappings":";;;
|
|
1
|
+
{"version":3,"file":"interfaces.js","sourceRoot":"","sources":["../../src/physics/interfaces.ts"],"names":[],"mappings":";;;AA4BA,IAAY,gBAKX;AALD,WAAY,gBAAgB;IAC1B,mCAAe,CAAA;IACf,qCAAiB,CAAA;IACjB,uCAAmB,CAAA;IACnB,2CAAuB,CAAA;AACzB,CAAC,EALW,gBAAgB,gCAAhB,gBAAgB,QAK3B"}
|
|
@@ -4,7 +4,6 @@ export declare class P2JSHelper {
|
|
|
4
4
|
static aabbToBoundingBox(aabb: p2.AABB): Rectangle;
|
|
5
5
|
static arrayToVector(array: [number, number]): Vector;
|
|
6
6
|
static vectorToArray(vector: Vector): [number, number];
|
|
7
|
-
static pushBody(body: p2.Body, hitPosition: Vector, hitDirection: Vector, severity: number): void;
|
|
8
7
|
static arePhysicsGroupsCollidable(groupA: number, maskA: number, groupB: number, maskB: number): boolean;
|
|
9
8
|
static canCollideWith(p2BodyA: p2.Body, p2BodyB: p2.Body): boolean;
|
|
10
9
|
static cloneP2Body(p2Body: p2.Body): p2.Body;
|
|
@@ -25,11 +25,6 @@ class P2JSHelper {
|
|
|
25
25
|
static vectorToArray(vector) {
|
|
26
26
|
return [vector.x, vector.y];
|
|
27
27
|
}
|
|
28
|
-
static pushBody(body, hitPosition, hitDirection, severity) {
|
|
29
|
-
let impulse = hitDirection.normalize(severity);
|
|
30
|
-
let relativePoint = [hitPosition.x - body.position[0], hitPosition.y - body.position[1]];
|
|
31
|
-
body.applyImpulse(this.vectorToArray(impulse), relativePoint);
|
|
32
|
-
}
|
|
33
28
|
static arePhysicsGroupsCollidable(groupA, maskA, groupB, maskB) {
|
|
34
29
|
// eslint-disable-next-line no-bitwise
|
|
35
30
|
return (groupA & maskB) !== 0 && (groupB & maskA) !== 0;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"p2js.helper.js","sourceRoot":"","sources":["../../../src/physics/libs/p2js.helper.ts"],"names":[],"mappings":";;;;;;AAAA,6CAAgD;AAChD,4CAAoB;AAEpB,MAAa,UAAU;IACrB,MAAM,CAAC,iBAAiB,CAAC,IAAa;QACpC,OAAO,uBAAS,CAAC,QAAQ,CAAC;YACxB,OAAO,EAAE;gBACP,CAAC,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC;gBACrB,CAAC,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC;aACtB;YACD,WAAW,EAAE;gBACX,CAAC,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC;gBACrB,CAAC,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC;aACtB;SACF,CAAC,CAAC;IACL,CAAC;IAED,MAAM,CAAC,aAAa,CAAC,KAAuB;QAC1C,OAAO,IAAI,oBAAM,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC;IACxC,CAAC;IAED,MAAM,CAAC,aAAa,CAAC,MAAc;QACjC,OAAO,CAAC,MAAM,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC,CAAC,CAAC;IAC9B,CAAC;IAED,MAAM,CAAC,
|
|
1
|
+
{"version":3,"file":"p2js.helper.js","sourceRoot":"","sources":["../../../src/physics/libs/p2js.helper.ts"],"names":[],"mappings":";;;;;;AAAA,6CAAgD;AAChD,4CAAoB;AAEpB,MAAa,UAAU;IACrB,MAAM,CAAC,iBAAiB,CAAC,IAAa;QACpC,OAAO,uBAAS,CAAC,QAAQ,CAAC;YACxB,OAAO,EAAE;gBACP,CAAC,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC;gBACrB,CAAC,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC;aACtB;YACD,WAAW,EAAE;gBACX,CAAC,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC;gBACrB,CAAC,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC;aACtB;SACF,CAAC,CAAC;IACL,CAAC;IAED,MAAM,CAAC,aAAa,CAAC,KAAuB;QAC1C,OAAO,IAAI,oBAAM,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC;IACxC,CAAC;IAED,MAAM,CAAC,aAAa,CAAC,MAAc;QACjC,OAAO,CAAC,MAAM,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC,CAAC,CAAC;IAC9B,CAAC;IAED,MAAM,CAAC,0BAA0B,CAAC,MAAc,EAAE,KAAa,EAAE,MAAc,EAAE,KAAa;QAC5F,sCAAsC;QACtC,OAAO,CAAC,MAAM,GAAG,KAAK,CAAC,KAAK,CAAC,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC,KAAK,CAAC,CAAC;IAC1D,CAAC;IAED,MAAM,CAAC,cAAc,CAAC,OAAgB,EAAE,OAAgB;QACtD,OAAO,OAAO,CAAC,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE,CAClC,OAAO,CAAC,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE,CAC3B,UAAU,CAAC,0BAA0B,CACnC,MAAM,CAAC,cAAc,EACrB,MAAM,CAAC,aAAa,EACpB,MAAM,CAAC,cAAc,EACrB,MAAM,CAAC,aAAa,CACrB,CACF,CACF,CAAC;IACJ,CAAC;IAED,MAAM,CAAC,WAAW,CAAC,MAAe;QAChC,IAAI,KAAK,GAAG,IAAI,YAAE,CAAC,IAAI,CAAC;YACtB,QAAQ,EAAE,MAAM,CAAC,QAAQ;YACzB,KAAK,EAAE,MAAM,CAAC,KAAK;YACnB,IAAI,EAAE,MAAM,CAAC,IAAI;SAClB,CAAC,CAAC;QACH,KAAK,CAAC,MAAM,GAAG,MAAM,CAAC,MAAM,CAAC;QAC7B,OAAO,KAAK,CAAC;IACf,CAAC;CACF;AAjDD,gCAiDC"}
|
|
@@ -1,15 +1 @@
|
|
|
1
|
-
export
|
|
2
|
-
none = 0,
|
|
3
|
-
border = 1,
|
|
4
|
-
friend = 2,
|
|
5
|
-
friendProjectile = 3,
|
|
6
|
-
enemy = 4,
|
|
7
|
-
enemyProjectile = 5,
|
|
8
|
-
neutral = 6,
|
|
9
|
-
explosion = 7
|
|
10
|
-
}
|
|
11
|
-
export declare class PhysicsBodyGroups {
|
|
12
|
-
static getGroupConstant(group: PhysicsBodyGroup): number;
|
|
13
|
-
static getMaskConstant(group: PhysicsBodyGroup): number;
|
|
14
|
-
static canCollide(group1: PhysicsBodyGroup, group2: PhysicsBodyGroup): boolean;
|
|
15
|
-
}
|
|
1
|
+
export type PhysicsBodyGroup = string;
|
|
@@ -1,76 +1,3 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.PhysicsBodyGroups = exports.PhysicsBodyGroup = void 0;
|
|
4
|
-
/* eslint-disable no-bitwise */
|
|
5
|
-
const BORDER_GROUP = 1 << 0; // 0b0001;
|
|
6
|
-
const FRIEND_GROUP = 1 << 1; // 0b0010;
|
|
7
|
-
const FRIEND_PROJECTILE_GROUP = 1 << 2; // 0b0100;
|
|
8
|
-
const ENEMY_GROUP = 1 << 3; // 0b1000;
|
|
9
|
-
const ENEMY_PROJECTILE_GROUP = 1 << 4;
|
|
10
|
-
const NEUTRAL_GROUP = 1 << 5;
|
|
11
|
-
const EXPLOSION_GROUP = 1 << 6;
|
|
12
|
-
const BORDER_MASK = FRIEND_GROUP | FRIEND_PROJECTILE_GROUP | ENEMY_GROUP | ENEMY_PROJECTILE_GROUP | NEUTRAL_GROUP;
|
|
13
|
-
const FRIEND_MASK = ENEMY_GROUP | ENEMY_PROJECTILE_GROUP | NEUTRAL_GROUP | BORDER_GROUP | EXPLOSION_GROUP;
|
|
14
|
-
const FRIEND_PROJECTILE_MASK = ENEMY_GROUP | NEUTRAL_GROUP | BORDER_GROUP;
|
|
15
|
-
const ENEMY_MASK = FRIEND_GROUP | FRIEND_PROJECTILE_GROUP | NEUTRAL_GROUP | BORDER_GROUP | EXPLOSION_GROUP;
|
|
16
|
-
const ENEMY_PROJECTILE_MASK = FRIEND_GROUP | NEUTRAL_GROUP | BORDER_GROUP;
|
|
17
|
-
const NEUTRAL_MASK = FRIEND_GROUP | FRIEND_PROJECTILE_GROUP | ENEMY_GROUP | ENEMY_PROJECTILE_GROUP | NEUTRAL_GROUP | BORDER_GROUP | EXPLOSION_GROUP;
|
|
18
|
-
const EXPLOSION_MASK = FRIEND_GROUP | ENEMY_GROUP | NEUTRAL_GROUP;
|
|
19
|
-
var PhysicsBodyGroup;
|
|
20
|
-
(function (PhysicsBodyGroup) {
|
|
21
|
-
PhysicsBodyGroup[PhysicsBodyGroup["none"] = 0] = "none";
|
|
22
|
-
PhysicsBodyGroup[PhysicsBodyGroup["border"] = 1] = "border";
|
|
23
|
-
PhysicsBodyGroup[PhysicsBodyGroup["friend"] = 2] = "friend";
|
|
24
|
-
PhysicsBodyGroup[PhysicsBodyGroup["friendProjectile"] = 3] = "friendProjectile";
|
|
25
|
-
PhysicsBodyGroup[PhysicsBodyGroup["enemy"] = 4] = "enemy";
|
|
26
|
-
PhysicsBodyGroup[PhysicsBodyGroup["enemyProjectile"] = 5] = "enemyProjectile";
|
|
27
|
-
PhysicsBodyGroup[PhysicsBodyGroup["neutral"] = 6] = "neutral";
|
|
28
|
-
PhysicsBodyGroup[PhysicsBodyGroup["explosion"] = 7] = "explosion";
|
|
29
|
-
})(PhysicsBodyGroup || (exports.PhysicsBodyGroup = PhysicsBodyGroup = {}));
|
|
30
|
-
class PhysicsBodyGroups {
|
|
31
|
-
static getGroupConstant(group) {
|
|
32
|
-
switch (group) {
|
|
33
|
-
case PhysicsBodyGroup.none:
|
|
34
|
-
return 0;
|
|
35
|
-
case PhysicsBodyGroup.border:
|
|
36
|
-
return BORDER_GROUP;
|
|
37
|
-
case PhysicsBodyGroup.friend:
|
|
38
|
-
return FRIEND_GROUP;
|
|
39
|
-
case PhysicsBodyGroup.friendProjectile:
|
|
40
|
-
return FRIEND_PROJECTILE_GROUP;
|
|
41
|
-
case PhysicsBodyGroup.enemy:
|
|
42
|
-
return ENEMY_GROUP;
|
|
43
|
-
case PhysicsBodyGroup.enemyProjectile:
|
|
44
|
-
return ENEMY_PROJECTILE_GROUP;
|
|
45
|
-
case PhysicsBodyGroup.neutral:
|
|
46
|
-
return NEUTRAL_GROUP;
|
|
47
|
-
case PhysicsBodyGroup.explosion:
|
|
48
|
-
return EXPLOSION_GROUP;
|
|
49
|
-
}
|
|
50
|
-
}
|
|
51
|
-
static getMaskConstant(group) {
|
|
52
|
-
switch (group) {
|
|
53
|
-
case PhysicsBodyGroup.none:
|
|
54
|
-
return 0;
|
|
55
|
-
case PhysicsBodyGroup.border:
|
|
56
|
-
return BORDER_MASK;
|
|
57
|
-
case PhysicsBodyGroup.friend:
|
|
58
|
-
return FRIEND_MASK;
|
|
59
|
-
case PhysicsBodyGroup.friendProjectile:
|
|
60
|
-
return FRIEND_PROJECTILE_MASK;
|
|
61
|
-
case PhysicsBodyGroup.enemy:
|
|
62
|
-
return ENEMY_MASK;
|
|
63
|
-
case PhysicsBodyGroup.enemyProjectile:
|
|
64
|
-
return ENEMY_PROJECTILE_MASK;
|
|
65
|
-
case PhysicsBodyGroup.neutral:
|
|
66
|
-
return NEUTRAL_MASK;
|
|
67
|
-
case PhysicsBodyGroup.explosion:
|
|
68
|
-
return EXPLOSION_MASK;
|
|
69
|
-
}
|
|
70
|
-
}
|
|
71
|
-
static canCollide(group1, group2) {
|
|
72
|
-
return (PhysicsBodyGroups.getMaskConstant(group1) & PhysicsBodyGroups.getGroupConstant(group2)) !== 0;
|
|
73
|
-
}
|
|
74
|
-
}
|
|
75
|
-
exports.PhysicsBodyGroups = PhysicsBodyGroups;
|
|
76
3
|
//# sourceMappingURL=physics-body-groups.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"physics-body-groups.js","sourceRoot":"","sources":["../../../src/physics/libs/physics-body-groups.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"physics-body-groups.js","sourceRoot":"","sources":["../../../src/physics/libs/physics-body-groups.ts"],"names":[],"mappings":""}
|
|
@@ -7,15 +7,19 @@ import { PhysicsWorldService } from '../../📐services/creation/physics-world.s
|
|
|
7
7
|
import { ShapeCreationService } from '../../📐services/creation/shape-creation.service';
|
|
8
8
|
import { MaterialDefinition } from '../dtos/shared-interfaces.dto';
|
|
9
9
|
import { PhysicsQueryService } from '../../📐services/query/physics-query.service';
|
|
10
|
+
import { PhysicsBodyGroupService } from '../../📐services/collision/physics-body-group.service';
|
|
10
11
|
export declare class PhysicsInternalController {
|
|
11
12
|
private physicsWorldService;
|
|
12
13
|
private physicsMaterialsService;
|
|
13
14
|
private shapeCreationService;
|
|
14
15
|
private physicsQueryService;
|
|
15
|
-
|
|
16
|
-
|
|
16
|
+
private physicsBodyGroupService;
|
|
17
|
+
constructor(physicsWorldService: PhysicsWorldService, physicsMaterialsService: MaterialsService, shapeCreationService: ShapeCreationService, physicsQueryService: PhysicsQueryService, physicsBodyGroupService: PhysicsBodyGroupService);
|
|
18
|
+
createBody(physicsWorldId: string, physicsEntityDefinition: PhysicsEntityDefinition, material: p2.Material, materialDefinition: MaterialDefinition, type: 'dynamic' | 'static'): p2.Body;
|
|
17
19
|
getMaterial(physicsWorldId: string, name: string): p2.Material;
|
|
18
20
|
getMaterialDefinition(physicsWorldId: string, name: string): MaterialDefinition;
|
|
21
|
+
getGroupConstant(physicsWorldId: string, group: PhysicsBodyGroup): number;
|
|
22
|
+
getMaskConstant(physicsWorldId: string, group: PhysicsBodyGroup): number;
|
|
19
23
|
addBody(physicsWorldId: string, body: p2.Body, addInEmptySpace: boolean, physicsBodyGroup: PhysicsBodyGroup, includeOnPathfinding: boolean): boolean;
|
|
20
24
|
removeBody(physicsWorldId: string, p2Body: p2.Body): void;
|
|
21
25
|
subscribeToPhysicsStep(physicsWorldId: string, callback: ActionListenerCallbackFunction<{
|
|
@@ -16,15 +16,17 @@ const shape_creation_service_1 = require("../../\uD83D\uDCD0services/creation/sh
|
|
|
16
16
|
const game_entities_1 = require("../../../../game-entities");
|
|
17
17
|
const physics_internal_gateway_1 = require("../physics-internal.gateway");
|
|
18
18
|
const physics_query_service_1 = require("../../\uD83D\uDCD0services/query/physics-query.service");
|
|
19
|
+
const physics_body_group_service_1 = require("../../\uD83D\uDCD0services/collision/physics-body-group.service");
|
|
19
20
|
let PhysicsInternalController = class PhysicsInternalController {
|
|
20
|
-
constructor(physicsWorldService, physicsMaterialsService, shapeCreationService, physicsQueryService) {
|
|
21
|
+
constructor(physicsWorldService, physicsMaterialsService, shapeCreationService, physicsQueryService, physicsBodyGroupService) {
|
|
21
22
|
this.physicsWorldService = physicsWorldService;
|
|
22
23
|
this.physicsMaterialsService = physicsMaterialsService;
|
|
23
24
|
this.shapeCreationService = shapeCreationService;
|
|
24
25
|
this.physicsQueryService = physicsQueryService;
|
|
26
|
+
this.physicsBodyGroupService = physicsBodyGroupService;
|
|
25
27
|
}
|
|
26
|
-
createBody(physicsEntityDefinition, material, materialDefinition, type) {
|
|
27
|
-
return this.shapeCreationService.createBody(physicsEntityDefinition, material, materialDefinition, type);
|
|
28
|
+
createBody(physicsWorldId, physicsEntityDefinition, material, materialDefinition, type) {
|
|
29
|
+
return this.shapeCreationService.createBody(physicsWorldId, physicsEntityDefinition, material, materialDefinition, type);
|
|
28
30
|
}
|
|
29
31
|
getMaterial(physicsWorldId, name) {
|
|
30
32
|
return this.physicsMaterialsService.getMaterial(physicsWorldId, name);
|
|
@@ -32,6 +34,12 @@ let PhysicsInternalController = class PhysicsInternalController {
|
|
|
32
34
|
getMaterialDefinition(physicsWorldId, name) {
|
|
33
35
|
return this.physicsMaterialsService.getMaterialDefinition(physicsWorldId, name);
|
|
34
36
|
}
|
|
37
|
+
getGroupConstant(physicsWorldId, group) {
|
|
38
|
+
return this.physicsBodyGroupService.getGroupConstant(physicsWorldId, group);
|
|
39
|
+
}
|
|
40
|
+
getMaskConstant(physicsWorldId, group) {
|
|
41
|
+
return this.physicsBodyGroupService.getMaskConstant(physicsWorldId, group);
|
|
42
|
+
}
|
|
35
43
|
addBody(physicsWorldId, body, addInEmptySpace, physicsBodyGroup, includeOnPathfinding) {
|
|
36
44
|
return this.physicsWorldService.addBody(physicsWorldId, body, addInEmptySpace, physicsBodyGroup, includeOnPathfinding);
|
|
37
45
|
}
|
|
@@ -48,6 +56,7 @@ exports.PhysicsInternalController = PhysicsInternalController = __decorate([
|
|
|
48
56
|
__metadata("design:paramtypes", [physics_world_service_1.PhysicsWorldService,
|
|
49
57
|
materials_service_1.MaterialsService,
|
|
50
58
|
shape_creation_service_1.ShapeCreationService,
|
|
51
|
-
physics_query_service_1.PhysicsQueryService
|
|
59
|
+
physics_query_service_1.PhysicsQueryService,
|
|
60
|
+
physics_body_group_service_1.PhysicsBodyGroupService])
|
|
52
61
|
], PhysicsInternalController);
|
|
53
62
|
//# sourceMappingURL=physics-internal.controller.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"physics-internal.controller.js","sourceRoot":"","sources":["../../../../../src/physics/module/⚜️gateways/controllers/physics-internal.controller.ts"],"names":[],"mappings":";;;;;;;;;;;;AAIA,6FAA+E;AAC/E,qGAAsF;AACtF,uGAAwF;AACxF,6DAAgE;AAChE,0EAA4E;AAE5E,kGAAmF;
|
|
1
|
+
{"version":3,"file":"physics-internal.controller.js","sourceRoot":"","sources":["../../../../../src/physics/module/⚜️gateways/controllers/physics-internal.controller.ts"],"names":[],"mappings":";;;;;;;;;;;;AAIA,6FAA+E;AAC/E,qGAAsF;AACtF,uGAAwF;AACxF,6DAAgE;AAChE,0EAA4E;AAE5E,kGAAmF;AACnF,gHAAgG;AAGzF,IAAM,yBAAyB,GAA/B,MAAM,yBAAyB;IACpC,YACU,mBAAwC,EACxC,uBAAyC,EACzC,oBAA0C,EAC1C,mBAAwC,EACxC,uBAAgD;QAJhD,wBAAmB,GAAnB,mBAAmB,CAAqB;QACxC,4BAAuB,GAAvB,uBAAuB,CAAkB;QACzC,yBAAoB,GAApB,oBAAoB,CAAsB;QAC1C,wBAAmB,GAAnB,mBAAmB,CAAqB;QACxC,4BAAuB,GAAvB,uBAAuB,CAAyB;IACvD,CAAC;IAEJ,UAAU,CACR,cAAsB,EACtB,uBAAgD,EAChD,QAAqB,EACrB,kBAAsC,EACtC,IAA0B;QAE1B,OAAO,IAAI,CAAC,oBAAoB,CAAC,UAAU,CAAC,cAAc,EAAE,uBAAuB,EAAE,QAAQ,EAAE,kBAAkB,EAAE,IAAI,CAAC,CAAC;IAC3H,CAAC;IAED,WAAW,CAAC,cAAsB,EAAE,IAAY;QAC9C,OAAO,IAAI,CAAC,uBAAuB,CAAC,WAAW,CAAC,cAAc,EAAE,IAAI,CAAC,CAAC;IACxE,CAAC;IAED,qBAAqB,CAAC,cAAsB,EAAE,IAAY;QACxD,OAAO,IAAI,CAAC,uBAAuB,CAAC,qBAAqB,CAAC,cAAc,EAAE,IAAI,CAAC,CAAC;IAClF,CAAC;IAED,gBAAgB,CAAC,cAAsB,EAAE,KAAuB;QAC9D,OAAO,IAAI,CAAC,uBAAuB,CAAC,gBAAgB,CAAC,cAAc,EAAE,KAAK,CAAC,CAAC;IAC9E,CAAC;IAED,eAAe,CAAC,cAAsB,EAAE,KAAuB;QAC7D,OAAO,IAAI,CAAC,uBAAuB,CAAC,eAAe,CAAC,cAAc,EAAE,KAAK,CAAC,CAAC;IAC7E,CAAC;IAED,OAAO,CACL,cAAsB,EACtB,IAAa,EACb,eAAwB,EACxB,gBAAkC,EAClC,oBAA6B;QAE7B,OAAO,IAAI,CAAC,mBAAmB,CAAC,OAAO,CAAC,cAAc,EAAE,IAAI,EAAE,eAAe,EAAE,gBAAgB,EAAE,oBAAoB,CAAC,CAAC;IACzH,CAAC;IAED,UAAU,CAAC,cAAsB,EAAE,MAAe;QAChD,IAAI,CAAC,mBAAmB,CAAC,UAAU,CAAC,cAAc,EAAE,MAAM,CAAC,CAAC;IAC9D,CAAC;IAED,sBAAsB,CACpB,cAAsB,EACtB,QAAyE;QAEzE,OAAO,IAAI,CAAC,mBAAmB,CAAC,sBAAsB,CAAC,cAAc,EAAE,QAAQ,CAAC,CAAC;IACnF,CAAC;CACF,CAAA;AAvDY,8DAAyB;oCAAzB,yBAAyB;IADrC,IAAA,mCAAmB,EAAC,EAAE,cAAc,EAAE,wDAA6B,EAAE,CAAC;qCAGtC,2CAAmB;QACf,oCAAgB;QACnB,6CAAoB;QACrB,2CAAmB;QACf,oDAAuB;GAN/C,yBAAyB,CAuDrC"}
|
package/dist/physics/module//342/232/234/357/270/217gateways/controllers/physics.controller.d.ts
CHANGED
|
@@ -6,10 +6,11 @@ import { PathFinderResult } from '../../../../utilities/libraries/grid-algorithm
|
|
|
6
6
|
import { PathFinderService } from '../../📐services/path-finding/path-finder.service';
|
|
7
7
|
import { TestVisualsService } from '../../📐services/test-visuals/test-visuals.service';
|
|
8
8
|
import { ExplosionHit, MapSizeDTO } from '../dtos/responses.dto';
|
|
9
|
-
import { ExplosionService } from '../../📐services/explosions/explosion.service';
|
|
10
|
-
import { ElipticExplosionService } from '../../📐services/explosions/eliptic-explosion.service';
|
|
11
9
|
import { HitTestService } from '../../📐services/collision/hit-test.service';
|
|
12
10
|
import { PhysicsQueryService } from '../../📐services/query/physics-query.service';
|
|
11
|
+
import { ExplosionService } from '../../📐services/impact/explosion.service';
|
|
12
|
+
import { ElipticExplosionService } from '../../📐services/impact/eliptic-explosion.service';
|
|
13
|
+
import { ImpactService } from '../../📐services/impact/impact.service';
|
|
13
14
|
export declare class PhysicsController {
|
|
14
15
|
private physicsWorldService;
|
|
15
16
|
private pathFinderService;
|
|
@@ -18,15 +19,16 @@ export declare class PhysicsController {
|
|
|
18
19
|
private elipticExplosionService;
|
|
19
20
|
private hitTestService;
|
|
20
21
|
private physicsQueryService;
|
|
21
|
-
|
|
22
|
+
private impactService;
|
|
23
|
+
constructor(physicsWorldService: PhysicsWorldService, pathFinderService: PathFinderService, testVisualsService: TestVisualsService, explosionService: ExplosionService, elipticExplosionService: ElipticExplosionService, hitTestService: HitTestService, physicsQueryService: PhysicsQueryService, impactService: ImpactService);
|
|
22
24
|
createPhysicsWorld(request: CreatePhysicsWorldRequestDTO): string;
|
|
23
25
|
getMapSize(physicsWorldId: string): MapSizeDTO;
|
|
24
26
|
hitTest(physicsEntityId: string, options?: HitTestOptions): boolean;
|
|
25
|
-
findPath(physicsWorldId: string, startingPosition: Vector, target: Vector | string, options?: {
|
|
27
|
+
findPath(physicsWorldId: string, startingPosition: Vector, target: Vector | string, collidableWithGroup: PhysicsBodyGroup, options?: {
|
|
26
28
|
includeDiagonals?: boolean;
|
|
27
|
-
collidableWithGroup?: PhysicsBodyGroup;
|
|
28
29
|
}): PathFinderResult;
|
|
29
30
|
findPathDirection(physicsWorldId: string, startingPosition: Vector, target: Vector | string, collidableWithGroup: PhysicsBodyGroup): Radian | undefined;
|
|
31
|
+
applyImpulse(physicsEntityId: string, hitPosition: Vector, hitDirection: Vector, severity: number): void;
|
|
30
32
|
createExplosion(physicsWorldId: string, explosionCenter: Vector, radius: number, physicsBodyGroup: PhysicsBodyGroup, severity: number, options?: PhysicsExplosionOptions): ExplosionHit[];
|
|
31
33
|
createElipticExplosion(physicsWorldId: string, explosionCenter: Vector, rotation: Radian, size: Vector, physicsBodyGroup: PhysicsBodyGroup, severity: number, options?: PhysicsExplosionOptions): ExplosionHit[];
|
|
32
34
|
printPathfindingTestGrid(physicsWorldId: string, testLayerId: string, target: Vector | string, physicsBodyGroup: PhysicsBodyGroup, area: Rectangle, gridCellSize: number): void;
|
package/dist/physics/module//342/232/234/357/270/217gateways/controllers/physics.controller.js
CHANGED
|
@@ -15,13 +15,14 @@ const physics_world_service_1 = require("../../\uD83D\uDCD0services/creation/phy
|
|
|
15
15
|
const physics_gateway_1 = require("../physics.gateway");
|
|
16
16
|
const path_finder_service_1 = require("../../\uD83D\uDCD0services/path-finding/path-finder.service");
|
|
17
17
|
const test_visuals_service_1 = require("../../\uD83D\uDCD0services/test-visuals/test-visuals.service");
|
|
18
|
-
const explosion_service_1 = require("../../\uD83D\uDCD0services/explosions/explosion.service");
|
|
19
|
-
const eliptic_explosion_service_1 = require("../../\uD83D\uDCD0services/explosions/eliptic-explosion.service");
|
|
20
18
|
const hit_test_service_1 = require("../../\uD83D\uDCD0services/collision/hit-test.service");
|
|
21
19
|
const physics_query_service_1 = require("../../\uD83D\uDCD0services/query/physics-query.service");
|
|
22
20
|
const physics_entity_1 = require("../../../entity-types/physics-entity");
|
|
21
|
+
const explosion_service_1 = require("../../\uD83D\uDCD0services/impact/explosion.service");
|
|
22
|
+
const eliptic_explosion_service_1 = require("../../\uD83D\uDCD0services/impact/eliptic-explosion.service");
|
|
23
|
+
const impact_service_1 = require("../../\uD83D\uDCD0services/impact/impact.service");
|
|
23
24
|
let PhysicsController = class PhysicsController {
|
|
24
|
-
constructor(physicsWorldService, pathFinderService, testVisualsService, explosionService, elipticExplosionService, hitTestService, physicsQueryService) {
|
|
25
|
+
constructor(physicsWorldService, pathFinderService, testVisualsService, explosionService, elipticExplosionService, hitTestService, physicsQueryService, impactService) {
|
|
25
26
|
this.physicsWorldService = physicsWorldService;
|
|
26
27
|
this.pathFinderService = pathFinderService;
|
|
27
28
|
this.testVisualsService = testVisualsService;
|
|
@@ -29,6 +30,7 @@ let PhysicsController = class PhysicsController {
|
|
|
29
30
|
this.elipticExplosionService = elipticExplosionService;
|
|
30
31
|
this.hitTestService = hitTestService;
|
|
31
32
|
this.physicsQueryService = physicsQueryService;
|
|
33
|
+
this.impactService = impactService;
|
|
32
34
|
}
|
|
33
35
|
createPhysicsWorld(request) {
|
|
34
36
|
return this.physicsWorldService.createPhysicsWorld(request);
|
|
@@ -40,12 +42,16 @@ let PhysicsController = class PhysicsController {
|
|
|
40
42
|
let physicsEntity = physics_entity_1.PhysicsEntity.getPhysicsInstanceOrFail(physicsEntityId);
|
|
41
43
|
return this.hitTestService.hitTest(physicsEntity['p2Body'], options);
|
|
42
44
|
}
|
|
43
|
-
findPath(physicsWorldId, startingPosition, target, options) {
|
|
44
|
-
return this.pathFinderService.findPathAStar(physicsWorldId, startingPosition, target, options);
|
|
45
|
+
findPath(physicsWorldId, startingPosition, target, collidableWithGroup, options) {
|
|
46
|
+
return this.pathFinderService.findPathAStar(physicsWorldId, startingPosition, target, collidableWithGroup, options);
|
|
45
47
|
}
|
|
46
48
|
findPathDirection(physicsWorldId, startingPosition, target, collidableWithGroup) {
|
|
47
49
|
return this.pathFinderService.findPathDirection(physicsWorldId, startingPosition, target, collidableWithGroup);
|
|
48
50
|
}
|
|
51
|
+
applyImpulse(physicsEntityId, hitPosition, hitDirection, severity) {
|
|
52
|
+
let entity = physics_entity_1.PhysicsEntity.getPhysicsInstanceOrFail(physicsEntityId);
|
|
53
|
+
this.impactService.applyImpulse(entity['p2Body'], hitPosition, hitDirection, severity);
|
|
54
|
+
}
|
|
49
55
|
createExplosion(physicsWorldId, explosionCenter, radius, physicsBodyGroup, severity, options) {
|
|
50
56
|
return this.explosionService.createExplosion(physicsWorldId, explosionCenter, radius, physicsBodyGroup, severity, options);
|
|
51
57
|
}
|
|
@@ -65,6 +71,7 @@ exports.PhysicsController = PhysicsController = __decorate([
|
|
|
65
71
|
explosion_service_1.ExplosionService,
|
|
66
72
|
eliptic_explosion_service_1.ElipticExplosionService,
|
|
67
73
|
hit_test_service_1.HitTestService,
|
|
68
|
-
physics_query_service_1.PhysicsQueryService
|
|
74
|
+
physics_query_service_1.PhysicsQueryService,
|
|
75
|
+
impact_service_1.ImpactService])
|
|
69
76
|
], PhysicsController);
|
|
70
77
|
//# sourceMappingURL=physics.controller.js.map
|
package/dist/physics/module//342/232/234/357/270/217gateways/controllers/physics.controller.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"physics.controller.js","sourceRoot":"","sources":["../../../../../src/physics/module/⚜️gateways/controllers/physics.controller.ts"],"names":[],"mappings":";;;;;;;;;;;;AAEA,6DAAgE;AAChE,qGAAsF;AAEtF,wDAA2D;AAG3D,qGAAsF;AACtF,uGAAwF;AAExF
|
|
1
|
+
{"version":3,"file":"physics.controller.js","sourceRoot":"","sources":["../../../../../src/physics/module/⚜️gateways/controllers/physics.controller.ts"],"names":[],"mappings":";;;;;;;;;;;;AAEA,6DAAgE;AAChE,qGAAsF;AAEtF,wDAA2D;AAG3D,qGAAsF;AACtF,uGAAwF;AAExF,4FAA6E;AAC7E,kGAAmF;AACnF,yEAAqE;AACrE,2FAA6E;AAC7E,2GAA4F;AAC5F,qFAAuE;AAGhE,IAAM,iBAAiB,GAAvB,MAAM,iBAAiB;IAC5B,YACU,mBAAwC,EACxC,iBAAoC,EACpC,kBAAsC,EACtC,gBAAkC,EAClC,uBAAgD,EAChD,cAA8B,EAC9B,mBAAwC,EACxC,aAA4B;QAP5B,wBAAmB,GAAnB,mBAAmB,CAAqB;QACxC,sBAAiB,GAAjB,iBAAiB,CAAmB;QACpC,uBAAkB,GAAlB,kBAAkB,CAAoB;QACtC,qBAAgB,GAAhB,gBAAgB,CAAkB;QAClC,4BAAuB,GAAvB,uBAAuB,CAAyB;QAChD,mBAAc,GAAd,cAAc,CAAgB;QAC9B,wBAAmB,GAAnB,mBAAmB,CAAqB;QACxC,kBAAa,GAAb,aAAa,CAAe;IACnC,CAAC;IAEJ,kBAAkB,CAAC,OAAqC;QACtD,OAAO,IAAI,CAAC,mBAAmB,CAAC,kBAAkB,CAAC,OAAO,CAAC,CAAC;IAC9D,CAAC;IAED,UAAU,CAAC,cAAsB;QAC/B,OAAO,IAAI,CAAC,mBAAmB,CAAC,UAAU,CAAC,cAAc,CAAC,CAAC;IAC7D,CAAC;IAED,OAAO,CAAC,eAAuB,EAAE,OAAwB;QACvD,IAAI,aAAa,GAAG,8BAAa,CAAC,wBAAwB,CAAC,eAAe,CAAC,CAAC;QAC5E,OAAO,IAAI,CAAC,cAAc,CAAC,OAAO,CAAC,aAAa,CAAC,QAAQ,CAAC,EAAE,OAAO,CAAC,CAAC;IACvE,CAAC;IAED,QAAQ,CACN,cAAsB,EACtB,gBAAwB,EACxB,MAAuB,EACvB,mBAAqC,EACrC,OAAwC;QAExC,OAAO,IAAI,CAAC,iBAAiB,CAAC,aAAa,CAAC,cAAc,EAAE,gBAAgB,EAAE,MAAM,EAAE,mBAAmB,EAAE,OAAO,CAAC,CAAC;IACtH,CAAC;IAED,iBAAiB,CACf,cAAsB,EACtB,gBAAwB,EACxB,MAAuB,EACvB,mBAAqC;QAErC,OAAO,IAAI,CAAC,iBAAiB,CAAC,iBAAiB,CAAC,cAAc,EAAE,gBAAgB,EAAE,MAAM,EAAE,mBAAmB,CAAC,CAAC;IACjH,CAAC;IAED,YAAY,CAAC,eAAuB,EAAE,WAAmB,EAAE,YAAoB,EAAE,QAAgB;QAC/F,IAAI,MAAM,GAAG,8BAAa,CAAC,wBAAwB,CAAC,eAAe,CAAC,CAAC;QACrE,IAAI,CAAC,aAAa,CAAC,YAAY,CAAC,MAAM,CAAC,QAAQ,CAAC,EAAE,WAAW,EAAE,YAAY,EAAE,QAAQ,CAAC,CAAC;IACzF,CAAC;IAED,eAAe,CACb,cAAsB,EACtB,eAAuB,EACvB,MAAc,EACd,gBAAkC,EAClC,QAAgB,EAChB,OAAiC;QAEjC,OAAO,IAAI,CAAC,gBAAgB,CAAC,eAAe,CAAC,cAAc,EAAE,eAAe,EAAE,MAAM,EAAE,gBAAgB,EAAE,QAAQ,EAAE,OAAO,CAAC,CAAC;IAC7H,CAAC;IAED,sBAAsB,CACpB,cAAsB,EACtB,eAAuB,EACvB,QAAgB,EAChB,IAAY,EACZ,gBAAkC,EAClC,QAAgB,EAChB,OAAiC;QAEjC,OAAO,IAAI,CAAC,uBAAuB,CAAC,sBAAsB,CACxD,cAAc,EACd,eAAe,EACf,QAAQ,EACR,IAAI,EACJ,gBAAgB,EAChB,QAAQ,EACR,OAAO,CACR,CAAC;IACJ,CAAC;IAED,wBAAwB,CACtB,cAAsB,EACtB,WAAmB,EACnB,MAAuB,EACvB,gBAAkC,EAClC,IAAe,EACf,YAAoB;QAEpB,IAAI,CAAC,kBAAkB,CAAC,wBAAwB,CAAC,cAAc,EAAE,WAAW,EAAE,MAAM,EAAE,gBAAgB,EAAE,IAAI,EAAE,YAAY,CAAC,CAAC;IAC9H,CAAC;CACF,CAAA;AA1FY,8CAAiB;4BAAjB,iBAAiB;IAD7B,IAAA,mCAAmB,EAAC,EAAE,cAAc,EAAE,uCAAqB,EAAE,CAAC;qCAG9B,2CAAmB;QACrB,uCAAiB;QAChB,yCAAkB;QACpB,oCAAgB;QACT,mDAAuB;QAChC,iCAAc;QACT,2CAAmB;QACzB,8BAAa;GAT3B,iBAAiB,CA0F7B"}
|
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import { Vector, Radian } from 'helpers-lib';
|
|
2
2
|
import { BorderProperties, MaterialContactDefinition, MaterialDefinition } from './shared-interfaces.dto';
|
|
3
|
+
import { PhysicsBodyGroup } from '../../../libs/physics-body-groups';
|
|
3
4
|
export interface CreatePhysicsWorldRequestDTO {
|
|
4
5
|
readonly attachTo: string;
|
|
5
6
|
readonly mapSize: Vector;
|
|
@@ -7,6 +8,8 @@ export interface CreatePhysicsWorldRequestDTO {
|
|
|
7
8
|
readonly borderProperties: BorderProperties;
|
|
8
9
|
readonly materialDefinitions: ReadonlyArray<MaterialDefinition>;
|
|
9
10
|
readonly materialContactDefinitions: ReadonlyArray<MaterialContactDefinition>;
|
|
11
|
+
readonly physicsBodyGroups: ReadonlyArray<PhysicsBodyGroup>;
|
|
12
|
+
readonly interactingBodyGroups: ReadonlyArray<readonly [PhysicsBodyGroup, PhysicsBodyGroup]>;
|
|
10
13
|
}
|
|
11
14
|
export interface PhysicsExplosionOptions {
|
|
12
15
|
readonly testLayerId?: string;
|
package/dist/physics/module//342/232/234/357/270/217gateways/dtos/shared-interfaces.dto.d.ts
CHANGED
|
@@ -1,3 +1,4 @@
|
|
|
1
|
+
import { PhysicsBodyGroup } from '../../../libs/physics-body-groups';
|
|
1
2
|
export declare const BORDER_MATERIAL_NAME = "border";
|
|
2
3
|
export declare const SPEED_LIMIT = 0.8;
|
|
3
4
|
export declare const ROTATIONAL_SPEED_LIMIT = 0.01;
|
|
@@ -18,4 +19,5 @@ export interface BorderProperties {
|
|
|
18
19
|
readonly friction: number;
|
|
19
20
|
readonly bounciness: number;
|
|
20
21
|
readonly stiffness: number;
|
|
22
|
+
readonly borderBodyGroup: PhysicsBodyGroup;
|
|
21
23
|
}
|
package/dist/physics/module//342/232/234/357/270/217gateways/dtos/shared-interfaces.dto.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"shared-interfaces.dto.js","sourceRoot":"","sources":["../../../../../src/physics/module/⚜️gateways/dtos/shared-interfaces.dto.ts"],"names":[],"mappings":";;;
|
|
1
|
+
{"version":3,"file":"shared-interfaces.dto.js","sourceRoot":"","sources":["../../../../../src/physics/module/⚜️gateways/dtos/shared-interfaces.dto.ts"],"names":[],"mappings":";;;AAEa,QAAA,oBAAoB,GAAG,QAAQ,CAAC;AAChC,QAAA,WAAW,GAAG,GAAG,CAAC;AAClB,QAAA,sBAAsB,GAAG,IAAI,CAAC"}
|
|
@@ -6,9 +6,11 @@ import { PhysicsEntityDefinition } from '../../interfaces';
|
|
|
6
6
|
import { MaterialDefinition } from './dtos/shared-interfaces.dto';
|
|
7
7
|
export declare const PhysicsInternalControllerLink: ControllerLink;
|
|
8
8
|
export declare class PhysicsInternalGateway {
|
|
9
|
-
createBody(physicsEntityDefinition: PhysicsEntityDefinition, material: p2.Material, materialDefinition: MaterialDefinition, type: 'dynamic' | 'static'): p2.Body;
|
|
9
|
+
createBody(physicsWorldId: string, physicsEntityDefinition: PhysicsEntityDefinition, material: p2.Material, materialDefinition: MaterialDefinition, type: 'dynamic' | 'static'): p2.Body;
|
|
10
10
|
getMaterial(physicsWorldId: string, name: string): p2.Material;
|
|
11
11
|
getMaterialDefinition(physicsWorldId: string, name: string): MaterialDefinition;
|
|
12
|
+
getGroupConstant(physicsWorldId: string, group: PhysicsBodyGroup): number;
|
|
13
|
+
getMaskConstant(physicsWorldId: string, group: PhysicsBodyGroup): number;
|
|
12
14
|
addBody(physicsWorldId: string, body: p2.Body, addInEmptySpace: boolean, physicsBodyGroup: PhysicsBodyGroup, includeOnPathfinding: boolean): boolean;
|
|
13
15
|
removeBody(physicsWorldId: string, p2Body: p2.Body): void;
|
|
14
16
|
subscribeToPhysicsStep(physicsWorldId: string, callback: ActionListenerCallbackFunction<{
|
|
@@ -10,8 +10,8 @@ exports.PhysicsInternalGateway = exports.PhysicsInternalControllerLink = void 0;
|
|
|
10
10
|
const game_entities_1 = require("../../../game-entities");
|
|
11
11
|
exports.PhysicsInternalControllerLink = new game_entities_1.ControllerLink();
|
|
12
12
|
let PhysicsInternalGateway = class PhysicsInternalGateway {
|
|
13
|
-
createBody(physicsEntityDefinition, material, materialDefinition, type) {
|
|
14
|
-
return exports.PhysicsInternalControllerLink.trigger('createBody', physicsEntityDefinition, material, materialDefinition, type);
|
|
13
|
+
createBody(physicsWorldId, physicsEntityDefinition, material, materialDefinition, type) {
|
|
14
|
+
return exports.PhysicsInternalControllerLink.trigger('createBody', physicsWorldId, physicsEntityDefinition, material, materialDefinition, type);
|
|
15
15
|
}
|
|
16
16
|
getMaterial(physicsWorldId, name) {
|
|
17
17
|
return exports.PhysicsInternalControllerLink.trigger('getMaterial', physicsWorldId, name);
|
|
@@ -19,6 +19,12 @@ let PhysicsInternalGateway = class PhysicsInternalGateway {
|
|
|
19
19
|
getMaterialDefinition(physicsWorldId, name) {
|
|
20
20
|
return exports.PhysicsInternalControllerLink.trigger('getMaterialDefinition', physicsWorldId, name);
|
|
21
21
|
}
|
|
22
|
+
getGroupConstant(physicsWorldId, group) {
|
|
23
|
+
return exports.PhysicsInternalControllerLink.trigger('getGroupConstant', physicsWorldId, group);
|
|
24
|
+
}
|
|
25
|
+
getMaskConstant(physicsWorldId, group) {
|
|
26
|
+
return exports.PhysicsInternalControllerLink.trigger('getMaskConstant', physicsWorldId, group);
|
|
27
|
+
}
|
|
22
28
|
addBody(physicsWorldId, body, addInEmptySpace, physicsBodyGroup, includeOnPathfinding) {
|
|
23
29
|
return exports.PhysicsInternalControllerLink.trigger('addBody', physicsWorldId, body, addInEmptySpace, physicsBodyGroup, includeOnPathfinding);
|
|
24
30
|
}
|
package/dist/physics/module//342/232/234/357/270/217gateways/physics-internal.gateway.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"physics-internal.gateway.js","sourceRoot":"","sources":["../../../../src/physics/module/⚜️gateways/physics-internal.gateway.ts"],"names":[],"mappings":";;;;;;;;;AAEA,0DAA0E;AAK7D,QAAA,6BAA6B,GAAG,IAAI,8BAAc,EAAE,CAAC;AAG3D,IAAM,sBAAsB,GAA5B,MAAM,sBAAsB;IACjC,UAAU,CACR,uBAAgD,EAChD,QAAqB,EACrB,kBAAsC,EACtC,IAA0B;QAE1B,OAAO,qCAA6B,CAAC,OAAO,CAC1C,YAAY,EACZ,uBAAuB,EACvB,QAAQ,EACR,kBAAkB,EAClB,IAAI,CACL,CAAC;IACJ,CAAC;IAED,WAAW,CAAC,cAAsB,EAAE,IAAY;QAC9C,OAAO,qCAA6B,CAAC,OAAO,CAAc,aAAa,EAAE,cAAc,EAAE,IAAI,CAAC,CAAC;IACjG,CAAC;IAED,qBAAqB,CAAC,cAAsB,EAAE,IAAY;QACxD,OAAO,qCAA6B,CAAC,OAAO,CAAqB,uBAAuB,EAAE,cAAc,EAAE,IAAI,CAAC,CAAC;IAClH,CAAC;IAED,OAAO,CACL,cAAsB,EACtB,IAAa,EACb,eAAwB,EACxB,gBAAkC,EAClC,oBAA6B;QAE7B,OAAO,qCAA6B,CAAC,OAAO,CAC1C,SAAS,EACT,cAAc,EACd,IAAI,EACJ,eAAe,EACf,gBAAgB,EAChB,oBAAoB,CACrB,CAAC;IACJ,CAAC;IAED,UAAU,CAAC,cAAsB,EAAE,MAAe;QAChD,OAAO,qCAA6B,CAAC,OAAO,CAAO,YAAY,EAAE,cAAc,EAAE,MAAM,CAAC,CAAC;IAC3F,CAAC;IAED,sBAAsB,CACpB,cAAsB,EACtB,QAAyE;QAEzE,OAAO,qCAA6B,CAAC,OAAO,CAAqB,wBAAwB,EAAE,cAAc,EAAE,QAAQ,CAAC,CAAC;IACvH,CAAC;CACF,CAAA;
|
|
1
|
+
{"version":3,"file":"physics-internal.gateway.js","sourceRoot":"","sources":["../../../../src/physics/module/⚜️gateways/physics-internal.gateway.ts"],"names":[],"mappings":";;;;;;;;;AAEA,0DAA0E;AAK7D,QAAA,6BAA6B,GAAG,IAAI,8BAAc,EAAE,CAAC;AAG3D,IAAM,sBAAsB,GAA5B,MAAM,sBAAsB;IACjC,UAAU,CACR,cAAsB,EACtB,uBAAgD,EAChD,QAAqB,EACrB,kBAAsC,EACtC,IAA0B;QAE1B,OAAO,qCAA6B,CAAC,OAAO,CAC1C,YAAY,EACZ,cAAc,EACd,uBAAuB,EACvB,QAAQ,EACR,kBAAkB,EAClB,IAAI,CACL,CAAC;IACJ,CAAC;IAED,WAAW,CAAC,cAAsB,EAAE,IAAY;QAC9C,OAAO,qCAA6B,CAAC,OAAO,CAAc,aAAa,EAAE,cAAc,EAAE,IAAI,CAAC,CAAC;IACjG,CAAC;IAED,qBAAqB,CAAC,cAAsB,EAAE,IAAY;QACxD,OAAO,qCAA6B,CAAC,OAAO,CAAqB,uBAAuB,EAAE,cAAc,EAAE,IAAI,CAAC,CAAC;IAClH,CAAC;IAED,gBAAgB,CAAC,cAAsB,EAAE,KAAuB;QAC9D,OAAO,qCAA6B,CAAC,OAAO,CAAS,kBAAkB,EAAE,cAAc,EAAE,KAAK,CAAC,CAAC;IAClG,CAAC;IAED,eAAe,CAAC,cAAsB,EAAE,KAAuB;QAC7D,OAAO,qCAA6B,CAAC,OAAO,CAAS,iBAAiB,EAAE,cAAc,EAAE,KAAK,CAAC,CAAC;IACjG,CAAC;IAED,OAAO,CACL,cAAsB,EACtB,IAAa,EACb,eAAwB,EACxB,gBAAkC,EAClC,oBAA6B;QAE7B,OAAO,qCAA6B,CAAC,OAAO,CAC1C,SAAS,EACT,cAAc,EACd,IAAI,EACJ,eAAe,EACf,gBAAgB,EAChB,oBAAoB,CACrB,CAAC;IACJ,CAAC;IAED,UAAU,CAAC,cAAsB,EAAE,MAAe;QAChD,OAAO,qCAA6B,CAAC,OAAO,CAAO,YAAY,EAAE,cAAc,EAAE,MAAM,CAAC,CAAC;IAC3F,CAAC;IAED,sBAAsB,CACpB,cAAsB,EACtB,QAAyE;QAEzE,OAAO,qCAA6B,CAAC,OAAO,CAAqB,wBAAwB,EAAE,cAAc,EAAE,QAAQ,CAAC,CAAC;IACvH,CAAC;CACF,CAAA;AA7DY,wDAAsB;iCAAtB,sBAAsB;IADlC,IAAA,gCAAgB,GAAE;GACN,sBAAsB,CA6DlC"}
|
|
@@ -9,11 +9,11 @@ export declare class PhysicsGateway {
|
|
|
9
9
|
createPhysicsWorld(request: CreatePhysicsWorldRequestDTO): string;
|
|
10
10
|
getMapSize(physicsWorldId: string): MapSizeDTO;
|
|
11
11
|
hitTest(physicsEntityId: string, options?: HitTestOptions): boolean;
|
|
12
|
-
findPath(physicsWorldId: string, startingPosition: Vector, target: Vector | string, options?: {
|
|
12
|
+
findPath(physicsWorldId: string, startingPosition: Vector, target: Vector | string, collidableWithGroup: PhysicsBodyGroup, options?: {
|
|
13
13
|
includeDiagonals?: boolean;
|
|
14
|
-
collidableWithGroup?: PhysicsBodyGroup;
|
|
15
14
|
}): PathFinderResult;
|
|
16
15
|
findPathDirection(physicsWorldId: string, startingPosition: Vector, target: Vector | string, collidableWithGroup: PhysicsBodyGroup): Radian | undefined;
|
|
16
|
+
applyImpulse(physicsEntityId: string, hitPosition: Vector, hitDirection: Vector, severity: number): void;
|
|
17
17
|
createExplosion(physicsWorldId: string, explosionCenter: Vector, radius: number, physicsBodyGroup: PhysicsBodyGroup, severity: number, options?: PhysicsExplosionOptions): ExplosionHit[];
|
|
18
18
|
createElipticExplosion(physicsWorldId: string, explosionCenter: Vector, rotation: Radian, size: Vector, physicsBodyGroup: PhysicsBodyGroup, severity: number, options?: PhysicsExplosionOptions): ExplosionHit[];
|
|
19
19
|
printPathfindingTestGrid(physicsWorldId: string, testLayerId: string, target: Vector | string, physicsBodyGroup: PhysicsBodyGroup, area: Rectangle, gridCellSize?: number): void;
|
|
@@ -20,12 +20,15 @@ let PhysicsGateway = class PhysicsGateway {
|
|
|
20
20
|
hitTest(physicsEntityId, options) {
|
|
21
21
|
return exports.PhysicsControllerLink.trigger('hitTest', physicsEntityId, options);
|
|
22
22
|
}
|
|
23
|
-
findPath(physicsWorldId, startingPosition, target, options) {
|
|
24
|
-
return exports.PhysicsControllerLink.trigger('findPath', physicsWorldId, startingPosition, target, options);
|
|
23
|
+
findPath(physicsWorldId, startingPosition, target, collidableWithGroup, options) {
|
|
24
|
+
return exports.PhysicsControllerLink.trigger('findPath', physicsWorldId, startingPosition, target, collidableWithGroup, options);
|
|
25
25
|
}
|
|
26
26
|
findPathDirection(physicsWorldId, startingPosition, target, collidableWithGroup) {
|
|
27
27
|
return exports.PhysicsControllerLink.trigger('findPathDirection', physicsWorldId, startingPosition, target, collidableWithGroup);
|
|
28
28
|
}
|
|
29
|
+
applyImpulse(physicsEntityId, hitPosition, hitDirection, severity) {
|
|
30
|
+
return exports.PhysicsControllerLink.trigger('applyImpulse', physicsEntityId, hitPosition, hitDirection, severity);
|
|
31
|
+
}
|
|
29
32
|
createExplosion(physicsWorldId, explosionCenter, radius, physicsBodyGroup, severity, options) {
|
|
30
33
|
return exports.PhysicsControllerLink.trigger('createExplosion', physicsWorldId, explosionCenter, radius, physicsBodyGroup, severity, options);
|
|
31
34
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"physics.gateway.js","sourceRoot":"","sources":["../../../../src/physics/module/⚜️gateways/physics.gateway.ts"],"names":[],"mappings":";;;;;;;;;AAEA,0DAA0E;AAI1E,kGAAwF;AAG3E,QAAA,qBAAqB,GAAG,IAAI,8BAAc,EAAE,CAAC;AAGnD,IAAM,cAAc,GAApB,MAAM,cAAc;IACzB,kBAAkB,CAAC,OAAqC;QACtD,OAAO,6BAAqB,CAAC,OAAO,CAAS,oBAAoB,EAAE,OAAO,CAAC,CAAC;IAC9E,CAAC;IAED,UAAU,CAAC,cAAsB;QAC/B,OAAO,6BAAqB,CAAC,OAAO,CAAa,YAAY,EAAE,cAAc,CAAC,CAAC;IACjF,CAAC;IAED,OAAO,CAAC,eAAuB,EAAE,OAAwB;QACvD,OAAO,6BAAqB,CAAC,OAAO,CAAU,SAAS,EAAE,eAAe,EAAE,OAAO,CAAC,CAAC;IACrF,CAAC;IAED,QAAQ,CACN,cAAsB,EACtB,gBAAwB,EACxB,MAAuB,EACvB,
|
|
1
|
+
{"version":3,"file":"physics.gateway.js","sourceRoot":"","sources":["../../../../src/physics/module/⚜️gateways/physics.gateway.ts"],"names":[],"mappings":";;;;;;;;;AAEA,0DAA0E;AAI1E,kGAAwF;AAG3E,QAAA,qBAAqB,GAAG,IAAI,8BAAc,EAAE,CAAC;AAGnD,IAAM,cAAc,GAApB,MAAM,cAAc;IACzB,kBAAkB,CAAC,OAAqC;QACtD,OAAO,6BAAqB,CAAC,OAAO,CAAS,oBAAoB,EAAE,OAAO,CAAC,CAAC;IAC9E,CAAC;IAED,UAAU,CAAC,cAAsB;QAC/B,OAAO,6BAAqB,CAAC,OAAO,CAAa,YAAY,EAAE,cAAc,CAAC,CAAC;IACjF,CAAC;IAED,OAAO,CAAC,eAAuB,EAAE,OAAwB;QACvD,OAAO,6BAAqB,CAAC,OAAO,CAAU,SAAS,EAAE,eAAe,EAAE,OAAO,CAAC,CAAC;IACrF,CAAC;IAED,QAAQ,CACN,cAAsB,EACtB,gBAAwB,EACxB,MAAuB,EACvB,mBAAqC,EACrC,OAAwC;QAExC,OAAO,6BAAqB,CAAC,OAAO,CAClC,UAAU,EACV,cAAc,EACd,gBAAgB,EAChB,MAAM,EACN,mBAAmB,EACnB,OAAO,CACR,CAAC;IACJ,CAAC;IAED,iBAAiB,CACf,cAAsB,EACtB,gBAAwB,EACxB,MAAuB,EACvB,mBAAqC;QAErC,OAAO,6BAAqB,CAAC,OAAO,CAClC,mBAAmB,EACnB,cAAc,EACd,gBAAgB,EAChB,MAAM,EACN,mBAAmB,CACpB,CAAC;IACJ,CAAC;IAED,YAAY,CAAC,eAAuB,EAAE,WAAmB,EAAE,YAAoB,EAAE,QAAgB;QAC/F,OAAO,6BAAqB,CAAC,OAAO,CAAO,cAAc,EAAE,eAAe,EAAE,WAAW,EAAE,YAAY,EAAE,QAAQ,CAAC,CAAC;IACnH,CAAC;IAED,eAAe,CACb,cAAsB,EACtB,eAAuB,EACvB,MAAc,EACd,gBAAkC,EAClC,QAAgB,EAChB,OAAiC;QAEjC,OAAO,6BAAqB,CAAC,OAAO,CAClC,iBAAiB,EACjB,cAAc,EACd,eAAe,EACf,MAAM,EACN,gBAAgB,EAChB,QAAQ,EACR,OAAO,CACR,CAAC;IACJ,CAAC;IAED,sBAAsB,CACpB,cAAsB,EACtB,eAAuB,EACvB,QAAgB,EAChB,IAAY,EACZ,gBAAkC,EAClC,QAAgB,EAChB,OAAiC;QAEjC,OAAO,6BAAqB,CAAC,OAAO,CAClC,wBAAwB,EACxB,cAAc,EACd,eAAe,EACf,QAAQ,EACR,IAAI,EACJ,gBAAgB,EAChB,QAAQ,EACR,OAAO,CACR,CAAC;IACJ,CAAC;IAED,wBAAwB,CACtB,cAAsB,EACtB,WAAmB,EACnB,MAAuB,EACvB,gBAAkC,EAClC,IAAe,EACf,eAAuB,4CAAsB;QAE7C,OAAO,6BAAqB,CAAC,OAAO,CAClC,0BAA0B,EAC1B,cAAc,EACd,WAAW,EACX,MAAM,EACN,gBAAgB,EAChB,IAAI,EACJ,YAAY,CACb,CAAC;IACJ,CAAC;CACF,CAAA;AA3GY,wCAAc;yBAAd,cAAc;IAD1B,IAAA,gCAAgB,GAAE;GACN,cAAc,CA2G1B"}
|
|
@@ -78,6 +78,7 @@ let CollisionsService = class CollisionsService {
|
|
|
78
78
|
}
|
|
79
79
|
getCollisionDetail(physicsBodyDTOSelf, massSelf, contactPointSelf, normalSelf, areaSelf) {
|
|
80
80
|
let positionRelativeToObject;
|
|
81
|
+
let collisionPosition = contactPointSelf.add(physicsBodyDTOSelf.position);
|
|
81
82
|
return {
|
|
82
83
|
body: physicsBodyDTOSelf,
|
|
83
84
|
getPositionReletiveToObject: () => {
|
|
@@ -86,6 +87,12 @@ let CollisionsService = class CollisionsService {
|
|
|
86
87
|
}
|
|
87
88
|
return positionRelativeToObject;
|
|
88
89
|
},
|
|
90
|
+
getPositionOnWorld: () => {
|
|
91
|
+
if (!collisionPosition) {
|
|
92
|
+
collisionPosition = contactPointSelf.add(physicsBodyDTOSelf.position);
|
|
93
|
+
}
|
|
94
|
+
return collisionPosition;
|
|
95
|
+
},
|
|
89
96
|
position: contactPointSelf,
|
|
90
97
|
mass: massSelf,
|
|
91
98
|
area: areaSelf,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"collisions.service.js","sourceRoot":"","sources":["../../../../../src/physics/module/📐services/collision/collisions.service.ts"],"names":[],"mappings":"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
|
|
1
|
+
{"version":3,"file":"collisions.service.js","sourceRoot":"","sources":["../../../../../src/physics/module/📐services/collision/collisions.service.ts"],"names":[],"mappings":"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"}
|
package/dist/physics/module//360/237/223/220services/collision/physics-body-group.service.d.ts
ADDED
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { PhysicsBodyGroup } from '../../../libs/physics-body-groups';
|
|
2
|
+
import { PhysicsWorldEntity } from '../../🧊entities/physics-world.entity';
|
|
3
|
+
export declare class PhysicsBodyGroupService {
|
|
4
|
+
createBodyGroupsAndMasks(physicsBodyGroups: ReadonlyArray<PhysicsBodyGroup>, interactingBodyGroups: ReadonlyArray<readonly [PhysicsBodyGroup, PhysicsBodyGroup]>): {
|
|
5
|
+
readonly physicsBodyGroupToP2Group: Map<PhysicsBodyGroup, number>;
|
|
6
|
+
readonly physicsBodyGroupToP2Mask: Map<PhysicsBodyGroup, number>;
|
|
7
|
+
};
|
|
8
|
+
getGroupConstant(physicsWorldId: string, group: PhysicsBodyGroup): number;
|
|
9
|
+
getMaskConstant(physicsWorldId: string, group: PhysicsBodyGroup): number;
|
|
10
|
+
canCollide(physicsWorld: PhysicsWorldEntity, group1: PhysicsBodyGroup, group2: PhysicsBodyGroup): boolean;
|
|
11
|
+
}
|