react-simple-game-engine 0.0.42 → 0.0.45
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/lib/classes/entities/entity-sult.d.ts +2 -0
- package/lib/classes/entities/entity-sult.d.ts.map +1 -1
- package/lib/classes/entities/entity.d.ts +4 -2
- package/lib/classes/entities/entity.d.ts.map +1 -1
- package/lib/classes/entities/entity.js +19 -0
- package/lib/classes/particle-system.d.ts +4 -5
- package/lib/classes/particle-system.d.ts.map +1 -1
- package/lib/classes/particle-system.js +3 -8
- package/lib/classes/particle.d.ts +1 -1
- package/lib/classes/particle.d.ts.map +1 -1
- package/lib/classes/particle.js +2 -2
- package/lib/classes/scene.js +2 -2
- package/lib/classes/world-management.d.ts +3 -1
- package/lib/classes/world-management.d.ts.map +1 -1
- package/lib/classes/world-management.js +14 -4
- package/package.json +1 -1
@@ -1,6 +1,8 @@
|
|
1
1
|
import { Initialler } from "../../export-interfaces";
|
2
|
+
import { Camera } from "../camera";
|
2
3
|
import { WorldManagement } from "../world-management";
|
3
4
|
export declare abstract class EntitySult<P = any> implements Initialler<P> {
|
5
|
+
camera: Camera;
|
4
6
|
abstract update(): void;
|
5
7
|
abstract draw(): void;
|
6
8
|
abstract active(worldManagement: WorldManagement): void;
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"entity-sult.d.ts","sourceRoot":"","sources":["../../../src/classes/entities/entity-sult.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,yBAAyB,CAAC;AACrD,OAAO,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAC;AAEtD,8BAAsB,UAAU,CAAC,CAAC,GAAG,GAAG,CAAE,YAAW,UAAU,CAAC,CAAC,CAAC;
|
1
|
+
{"version":3,"file":"entity-sult.d.ts","sourceRoot":"","sources":["../../../src/classes/entities/entity-sult.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,yBAAyB,CAAC;AACrD,OAAO,EAAE,MAAM,EAAE,MAAM,WAAW,CAAC;AACnC,OAAO,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAC;AAEtD,8BAAsB,UAAU,CAAC,CAAC,GAAG,GAAG,CAAE,YAAW,UAAU,CAAC,CAAC,CAAC;IACzD,MAAM,EAAG,MAAM,CAAC;IACvB,QAAQ,CAAC,MAAM,IAAI,IAAI;IACvB,QAAQ,CAAC,IAAI,IAAI,IAAI;IACrB,QAAQ,CAAC,MAAM,CAAC,eAAe,EAAE,eAAe,GAAG,IAAI;IACvD,OAAO,CAAC,MAAM,EAAE,CAAC;CAClB"}
|
@@ -1,5 +1,4 @@
|
|
1
1
|
import Matter from "matter-js";
|
2
|
-
import { Camera } from "../camera";
|
3
2
|
import { WorldManagement } from "../world-management";
|
4
3
|
import { Sprite } from "../sprites/sprite";
|
5
4
|
import { CreateBodyDefine, EntityInitial, EntityPrepare, MasterBody, Sound } from "../../export-types";
|
@@ -7,9 +6,9 @@ import { EntitySult } from "./entity-sult";
|
|
7
6
|
export declare abstract class Entity<SpriteType extends Sprite<any> = any> extends EntitySult<EntityInitial<Entity>> {
|
8
7
|
private _body;
|
9
8
|
private _sprite;
|
9
|
+
private _children;
|
10
10
|
private readonly id;
|
11
11
|
readonly tag: string;
|
12
|
-
camera: Camera;
|
13
12
|
protected worldManagement: WorldManagement;
|
14
13
|
protected sound?: Sound;
|
15
14
|
constructor();
|
@@ -17,6 +16,9 @@ export declare abstract class Entity<SpriteType extends Sprite<any> = any> exten
|
|
17
16
|
get sprite(): SpriteType;
|
18
17
|
get position(): Matter.Vector;
|
19
18
|
get body(): MasterBody;
|
19
|
+
get children(): EntitySult<any>[];
|
20
|
+
addChild(entity: EntitySult): void;
|
21
|
+
removeChild(entity: EntitySult): void;
|
20
22
|
active(worldManagement: WorldManagement): void;
|
21
23
|
onActive(): void;
|
22
24
|
createBody(transform: CreateBodyDefine["transform"], options?: CreateBodyDefine["bodyOptions"]): MasterBody;
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"entity.d.ts","sourceRoot":"","sources":["../../../src/classes/entities/entity.ts"],"names":[],"mappings":"AAAA,OAAO,MAAM,MAAM,WAAW,CAAC;
|
1
|
+
{"version":3,"file":"entity.d.ts","sourceRoot":"","sources":["../../../src/classes/entities/entity.ts"],"names":[],"mappings":"AAAA,OAAO,MAAM,MAAM,WAAW,CAAC;AAG/B,OAAO,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAC;AAEtD,OAAO,EAAE,MAAM,EAAE,MAAM,mBAAmB,CAAC;AAG3C,OAAO,EACL,gBAAgB,EAChB,aAAa,EACb,aAAa,EACb,UAAU,EACV,KAAK,EACN,MAAM,oBAAoB,CAAC;AAC5B,OAAO,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;AAE3C,8BAAsB,MAAM,CAC1B,UAAU,SAAS,MAAM,CAAC,GAAG,CAAC,GAAG,GAAG,CACpC,SAAQ,UAAU,CAAC,aAAa,CAAC,MAAM,CAAC,CAAC;IACzC,OAAO,CAAC,KAAK,CAAc;IAC3B,OAAO,CAAC,OAAO,CAAc;IAC7B,OAAO,CAAC,SAAS,CAAoB;IACrC,OAAO,CAAC,QAAQ,CAAC,EAAE,CAAsD;IAEzE,SAAgB,GAAG,EAAG,MAAM,CAAC;IAE7B,SAAS,CAAC,eAAe,EAAG,eAAe,CAAC;IAC5C,SAAS,CAAC,KAAK,CAAC,EAAE,KAAK,CAAC;;IAOxB,IAAI,MAAM,CAAC,MAAM,EAAE,UAAU,EAG5B;IAED,IAAI,MAAM,IALS,UAAU,CAO5B;IAED,IAAI,QAAQ,kBAEX;IAED,IAAI,IAAI,eAEP;IAED,IAAI,QAAQ,sBAEX;IAED,QAAQ,CAAC,MAAM,EAAE,UAAU;IAK3B,WAAW,CAAC,MAAM,EAAE,UAAU;IAQ9B,MAAM,CAAC,eAAe,EAAE,eAAe;IAKvC,QAAQ;IAER,UAAU,CACR,SAAS,EAAE,gBAAgB,CAAC,WAAW,CAAC,EACxC,OAAO,CAAC,EAAE,gBAAgB,CAAC,aAAa,CAAC;IAO3C,SAAS,CAAC,QAAQ,CAAC,YAAY,CAC7B,SAAS,EAAE,gBAAgB,CAAC,WAAW,CAAC,GAAG,SAAS,EACpD,OAAO,CAAC,EAAE,gBAAgB,CAAC,aAAa,CAAC,GACxC,MAAM,CAAC,IAAI;IAEd,OAAO,CAAC,EACN,KAAK,EACL,SAAc,EACd,MAAM,EAAE,eAAe,EACvB,WAAgB,GACjB,EAAE,aAAa,CAAC,IAAI,CAAC;IAgCtB,SAAS,CAAC,QAAQ,CAAC,SAAS,IAAI,aAAa,CAAC,IAAI,CAAC;IACnD,SAAS,CAAC,SAAS,IAAI,aAAa,CAAC,IAAI,CAAC;IAI1C,MAAM;IAGN,QAAQ;IAER,IAAI;IAIJ,QAAQ,CAAC,0BAA0B,IAAI;QAAE,KAAK,EAAE,MAAM,CAAC;QAAC,MAAM,EAAE,MAAM,CAAA;KAAE;IAExE,WAAW,CAAC,MAAM,EAAE,MAAM;IAC1B,cAAc,CAAC,MAAM,EAAE,MAAM;IAC7B,iBAAiB,CAAC,MAAM,EAAE,MAAM;CACjC"}
|
@@ -41,6 +41,7 @@ var Entity = /** @class */ (function (_super) {
|
|
41
41
|
__extends(Entity, _super);
|
42
42
|
function Entity() {
|
43
43
|
var _this = _super.call(this) || this;
|
44
|
+
_this._children = [];
|
44
45
|
_this.id = "".concat(Math.random(), "-").concat(new Date().getTime());
|
45
46
|
_this.tag = _this.constructor.tag;
|
46
47
|
return _this;
|
@@ -70,6 +71,24 @@ var Entity = /** @class */ (function (_super) {
|
|
70
71
|
enumerable: false,
|
71
72
|
configurable: true
|
72
73
|
});
|
74
|
+
Object.defineProperty(Entity.prototype, "children", {
|
75
|
+
get: function () {
|
76
|
+
return this._children;
|
77
|
+
},
|
78
|
+
enumerable: false,
|
79
|
+
configurable: true
|
80
|
+
});
|
81
|
+
Entity.prototype.addChild = function (entity) {
|
82
|
+
this.children.push(entity);
|
83
|
+
this.worldManagement.addEntity(entity);
|
84
|
+
};
|
85
|
+
Entity.prototype.removeChild = function (entity) {
|
86
|
+
var delIndex = this.children.indexOf(entity);
|
87
|
+
if (delIndex > -1) {
|
88
|
+
this.children.splice(delIndex, 1);
|
89
|
+
this.worldManagement.removeEntity(entity);
|
90
|
+
}
|
91
|
+
};
|
73
92
|
Entity.prototype.active = function (worldManagement) {
|
74
93
|
console.log("Initted ".concat(this.tag, " entity (id : ").concat(this.id, ")"));
|
75
94
|
this.worldManagement = worldManagement;
|
@@ -1,5 +1,4 @@
|
|
1
1
|
import p5 from "p5";
|
2
|
-
import { Camera } from "./camera";
|
3
2
|
import { EntitySult } from "./entities/entity-sult";
|
4
3
|
import { Particle, ParticleInitialParams } from "./particle";
|
5
4
|
declare type ParticleClass = {
|
@@ -8,9 +7,10 @@ declare type ParticleClass = {
|
|
8
7
|
declare type ParticleOptions = Omit<ParticleInitialParams, "vec" | "angle" | "camera"> & {
|
9
8
|
x?: number;
|
10
9
|
y?: number;
|
11
|
-
particleClass?: ParticleClass;
|
12
10
|
};
|
13
|
-
declare type ParticleSystemInitialParams =
|
11
|
+
declare type ParticleSystemInitialParams = {
|
12
|
+
particleClass?: ParticleClass;
|
13
|
+
particleOptions?: ParticleOptions;
|
14
14
|
quantityPerFrame?: number;
|
15
15
|
vecWeight?: number;
|
16
16
|
forces?: p5.Vector[];
|
@@ -22,9 +22,8 @@ export declare class ParticleSystem extends EntitySult<ParticleSystemInitialPara
|
|
22
22
|
private particleClass;
|
23
23
|
quantityPerFrame: number;
|
24
24
|
vecWeight: number;
|
25
|
-
camera: Camera;
|
26
25
|
active(): void;
|
27
|
-
initial({
|
26
|
+
initial({ forces, particleOptions, ...params }: ParticleSystemInitialParams): void;
|
28
27
|
update(): void;
|
29
28
|
draw(): void;
|
30
29
|
}
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"particle-system.d.ts","sourceRoot":"","sources":["../../src/classes/particle-system.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,IAAI,CAAC;
|
1
|
+
{"version":3,"file":"particle-system.d.ts","sourceRoot":"","sources":["../../src/classes/particle-system.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,IAAI,CAAC;AAGpB,OAAO,EAAE,UAAU,EAAE,MAAM,wBAAwB,CAAC;AACpD,OAAO,EAAE,QAAQ,EAAE,qBAAqB,EAAE,MAAM,YAAY,CAAC;AAE7D,aAAK,aAAa,GAAG;IACnB,KAAK,GAAG,IAAI,EAAE,qBAAqB,CAAC,OAAO,QAAQ,CAAC,GAAG,QAAQ,CAAC;CACjE,CAAC;AAEF,aAAK,eAAe,GAAG,IAAI,CACzB,qBAAqB,EACrB,KAAK,GAAG,OAAO,GAAG,QAAQ,CAC3B,GAAG;IACF,CAAC,CAAC,EAAE,MAAM,CAAC;IACX,CAAC,CAAC,EAAE,MAAM,CAAC;CACZ,CAAC;AAEF,aAAK,2BAA2B,GAAG;IACjC,aAAa,CAAC,EAAE,aAAa,CAAC;IAC9B,eAAe,CAAC,EAAE,eAAe,CAAC;IAClC,gBAAgB,CAAC,EAAE,MAAM,CAAC;IAC1B,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,MAAM,CAAC,EAAE,EAAE,CAAC,MAAM,EAAE,CAAC;CACtB,CAAC;AAEF,qBAAa,cAAe,SAAQ,UAAU,CAAC,2BAA2B,CAAC;IACzE,OAAO,CAAC,SAAS,CAAkB;IACnC,OAAO,CAAC,MAAM,CAAmB;IACjC,OAAO,CAAC,eAAe,CAGrB;IACF,OAAO,CAAC,aAAa,CAA2B;IAEzC,gBAAgB,EAAE,MAAM,CAAM;IAC9B,SAAS,EAAE,MAAM,CAAK;IAE7B,MAAM;IAIN,OAAO,CAAC,EACN,MAAM,EACN,eAAoB,EACpB,GAAG,MAAM,EACV,EAAE,2BAA2B;IAS9B,MAAM;IAyBN,IAAI;CAKL"}
|
@@ -59,14 +59,9 @@ var ParticleSystem = /** @class */ (function (_super) {
|
|
59
59
|
};
|
60
60
|
ParticleSystem.prototype.initial = function (_a) {
|
61
61
|
var _b;
|
62
|
-
var
|
63
|
-
copyProperties(this.particleOptions,
|
64
|
-
|
65
|
-
this.quantityPerFrame = quantityPerFrame;
|
66
|
-
}
|
67
|
-
if (vecWeight != null) {
|
68
|
-
this.vecWeight = vecWeight;
|
69
|
-
}
|
62
|
+
var forces = _a.forces, _c = _a.particleOptions, particleOptions = _c === void 0 ? {} : _c, params = __rest(_a, ["forces", "particleOptions"]);
|
63
|
+
copyProperties(this.particleOptions, particleOptions);
|
64
|
+
copyProperties(this, params);
|
70
65
|
if (forces) {
|
71
66
|
(_b = this.forces).push.apply(_b, forces);
|
72
67
|
}
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"particle.d.ts","sourceRoot":"","sources":["../../src/classes/particle.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,IAAI,CAAC;AACpB,OAAO,EAAE,UAAU,EAAE,MAAM,sBAAsB,CAAC;AAClD,OAAO,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,iBAAiB,CAAC;AAEhD,OAAO,EAAE,MAAM,EAAE,MAAM,UAAU,CAAC;AAElC,oBAAY,qBAAqB,GAAG;IAClC,GAAG,CAAC,EAAE,EAAE,CAAC,MAAM,CAAC;IAChB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,KAAK,CAAC,EAAE,KAAK,CAAC;IACd,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,MAAM,EAAE,MAAM,CAAC;IACf,eAAe,CAAC,EAAE,OAAO,CAAC;CAC3B,CAAC;AAEF,qBAAa,QACX,SAAQ,EAAE,CAAC,MACX,YAAW,UAAU,CAAC,qBAAqB,CAAC;IAE5C,OAAO,CAAC,GAAG,CAAsC;IACjD,OAAO,CAAC,GAAG,CAAsC;IACjD,OAAO,CAAC,KAAK,CAAa;IACnB,MAAM,EAAG,MAAM,CAAC;IAChB,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,KAAK,EAAE,KAAK,CAAmB;IAC/B,IAAI,EAAE,MAAM,CAAK;IACjB,cAAc,EAAE,MAAM,CAAiB;IAE9C,OAAO,CAAC,eAAe,CAAkB;IACzC,OAAO,CAAC,SAAS,CAAa;IAE9B,IAAI,QAAQ,CAAC,QAAQ,EAAE,MAAM,EAG5B;IAED,IAAI,QAAQ,IALW,MAAM,CAO5B;IAED,OAAO,CAAC,EAAE,GAAG,EAAE,GAAG,MAAM,EAAE,EAAE,qBAAqB;IAOjD,UAAU,CAAC,KAAK,EAAE,EAAE,CAAC,MAAM;IAI3B,MAAM;IAIN,MAAM;IAQN,IAAI;
|
1
|
+
{"version":3,"file":"particle.d.ts","sourceRoot":"","sources":["../../src/classes/particle.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,IAAI,CAAC;AACpB,OAAO,EAAE,UAAU,EAAE,MAAM,sBAAsB,CAAC;AAClD,OAAO,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,iBAAiB,CAAC;AAEhD,OAAO,EAAE,MAAM,EAAE,MAAM,UAAU,CAAC;AAElC,oBAAY,qBAAqB,GAAG;IAClC,GAAG,CAAC,EAAE,EAAE,CAAC,MAAM,CAAC;IAChB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,KAAK,CAAC,EAAE,KAAK,CAAC;IACd,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,MAAM,EAAE,MAAM,CAAC;IACf,eAAe,CAAC,EAAE,OAAO,CAAC;CAC3B,CAAC;AAEF,qBAAa,QACX,SAAQ,EAAE,CAAC,MACX,YAAW,UAAU,CAAC,qBAAqB,CAAC;IAE5C,OAAO,CAAC,GAAG,CAAsC;IACjD,OAAO,CAAC,GAAG,CAAsC;IACjD,OAAO,CAAC,KAAK,CAAa;IACnB,MAAM,EAAG,MAAM,CAAC;IAChB,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,KAAK,EAAE,KAAK,CAAmB;IAC/B,IAAI,EAAE,MAAM,CAAK;IACjB,cAAc,EAAE,MAAM,CAAiB;IAE9C,OAAO,CAAC,eAAe,CAAkB;IACzC,OAAO,CAAC,SAAS,CAAa;IAE9B,IAAI,QAAQ,CAAC,QAAQ,EAAE,MAAM,EAG5B;IAED,IAAI,QAAQ,IALW,MAAM,CAO5B;IAED,OAAO,CAAC,EAAE,GAAG,EAAE,GAAG,MAAM,EAAE,EAAE,qBAAqB;IAOjD,UAAU,CAAC,KAAK,EAAE,EAAE,CAAC,MAAM;IAI3B,MAAM;IAIN,MAAM;IAQN,IAAI;IAmCJ,MAAM,CAAC,CAAC,EAAE,KAAK;CAGhB"}
|
package/lib/classes/particle.js
CHANGED
@@ -103,13 +103,13 @@ var Particle = /** @class */ (function (_super) {
|
|
103
103
|
this.sprite.height], false));
|
104
104
|
}
|
105
105
|
else {
|
106
|
+
Renderer.fill.apply(Renderer, color);
|
106
107
|
this.onDraw(color);
|
107
108
|
}
|
108
109
|
//
|
109
110
|
Renderer.pop();
|
110
111
|
};
|
111
|
-
Particle.prototype.onDraw = function (
|
112
|
-
Renderer.fill.apply(Renderer, color);
|
112
|
+
Particle.prototype.onDraw = function (_) {
|
113
113
|
Renderer.circle(0, 0, this.size);
|
114
114
|
};
|
115
115
|
return Particle;
|
package/lib/classes/scene.js
CHANGED
@@ -116,11 +116,11 @@ var Scene = /** @class */ (function () {
|
|
116
116
|
}); });
|
117
117
|
};
|
118
118
|
Scene.prototype.bootstrap = function (camera) {
|
119
|
-
this.worldManagement = new WorldManagement();
|
119
|
+
this.worldManagement = new WorldManagement(camera);
|
120
120
|
var components = this.getComponents(camera);
|
121
121
|
for (var _i = 0, components_1 = components; _i < components_1.length; _i++) {
|
122
122
|
var component = components_1[_i];
|
123
|
-
var entity = component.output(
|
123
|
+
var entity = component.output();
|
124
124
|
this.worldManagement.addEntity(entity);
|
125
125
|
}
|
126
126
|
};
|
@@ -1,8 +1,10 @@
|
|
1
|
+
import { Camera } from "./camera";
|
1
2
|
import { EntitySult } from "./entities/entity-sult";
|
2
3
|
export declare class WorldManagement {
|
4
|
+
private camera;
|
3
5
|
private entities;
|
4
6
|
private engine;
|
5
|
-
constructor();
|
7
|
+
constructor(camera: Camera);
|
6
8
|
destructor(): void;
|
7
9
|
addEntity(entity: EntitySult): void;
|
8
10
|
removeEntity(entity: EntitySult): void;
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"world-management.d.ts","sourceRoot":"","sources":["../../src/classes/world-management.ts"],"names":[],"mappings":"
|
1
|
+
{"version":3,"file":"world-management.d.ts","sourceRoot":"","sources":["../../src/classes/world-management.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,MAAM,EAAE,MAAM,UAAU,CAAC;AAElC,OAAO,EAAE,UAAU,EAAE,MAAM,wBAAwB,CAAC;AAEpD,qBAAa,eAAe;IAId,OAAO,CAAC,MAAM;IAH1B,OAAO,CAAC,QAAQ,CAAoB;IACpC,OAAO,CAAC,MAAM,CAAU;gBAEJ,MAAM,EAAE,MAAM;IAqClC,UAAU;IAKV,SAAS,CAAC,MAAM,EAAE,UAAU;IAU5B,YAAY,CAAC,MAAM,EAAE,UAAU;IAa/B,MAAM;IAON,IAAI;CAKL"}
|
@@ -1,7 +1,8 @@
|
|
1
1
|
import { Engine, World, Events } from "matter-js";
|
2
2
|
import { Entity } from "./entities/entity";
|
3
3
|
var WorldManagement = /** @class */ (function () {
|
4
|
-
function WorldManagement() {
|
4
|
+
function WorldManagement(camera) {
|
5
|
+
this.camera = camera;
|
5
6
|
this.entities = [];
|
6
7
|
this.engine = Engine.create();
|
7
8
|
Events.on(this.engine, "collisionStart", function (event) {
|
@@ -37,6 +38,8 @@ var WorldManagement = /** @class */ (function () {
|
|
37
38
|
Engine.clear(this.engine);
|
38
39
|
};
|
39
40
|
WorldManagement.prototype.addEntity = function (entity) {
|
41
|
+
// temp pass modifier
|
42
|
+
entity["camera"] = this.camera;
|
40
43
|
this.entities.push(entity);
|
41
44
|
if (entity instanceof Entity) {
|
42
45
|
World.add(this.engine.world, entity.body);
|
@@ -44,10 +47,17 @@ var WorldManagement = /** @class */ (function () {
|
|
44
47
|
entity.active(this);
|
45
48
|
};
|
46
49
|
WorldManagement.prototype.removeEntity = function (entity) {
|
47
|
-
|
48
|
-
|
50
|
+
var delIndex = this.entities.indexOf(entity);
|
51
|
+
if (delIndex > -1) {
|
52
|
+
if (entity instanceof Entity) {
|
53
|
+
World.remove(this.engine.world, entity.body);
|
54
|
+
for (var _i = 0, _a = entity.children; _i < _a.length; _i++) {
|
55
|
+
var child = _a[_i];
|
56
|
+
this.removeEntity(child);
|
57
|
+
}
|
58
|
+
}
|
59
|
+
this.entities.splice(this.entities.indexOf(entity), 1);
|
49
60
|
}
|
50
|
-
this.entities.splice(this.entities.indexOf(entity), 1);
|
51
61
|
};
|
52
62
|
WorldManagement.prototype.update = function () {
|
53
63
|
Engine.update(this.engine);
|