react-simple-game-engine 0.0.44 → 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 +0 -2
- package/lib/classes/particle-system.d.ts.map +1 -1
- 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 = {
|
@@ -23,7 +22,6 @@ export declare class ParticleSystem extends EntitySult<ParticleSystemInitialPara
|
|
23
22
|
private particleClass;
|
24
23
|
quantityPerFrame: number;
|
25
24
|
vecWeight: number;
|
26
|
-
camera: Camera;
|
27
25
|
active(): void;
|
28
26
|
initial({ forces, particleOptions, ...params }: ParticleSystemInitialParams): void;
|
29
27
|
update(): void;
|
@@ -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"}
|
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);
|