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.
@@ -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;IAChE,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
+ {"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;AAE/B,OAAO,EAAE,MAAM,EAAE,MAAM,WAAW,CAAC;AACnC,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,QAAQ,CAAC,EAAE,CAAsD;IAEzE,SAAgB,GAAG,EAAG,MAAM,CAAC;IACtB,MAAM,EAAG,MAAM,CAAC;IAEvB,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,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"}
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;AAEpB,OAAO,EAAE,MAAM,EAAE,MAAM,UAAU,CAAC;AAClC,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;IACtB,MAAM,EAAG,MAAM,CAAC;IAEvB,MAAM;IAIN,OAAO,CAAC,EACN,MAAM,EACN,eAAoB,EACpB,GAAG,MAAM,EACV,EAAE,2BAA2B;IAS9B,MAAM;IAyBN,IAAI;CAKL"}
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"}
@@ -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({ camera: camera });
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":"AAGA,OAAO,EAAE,UAAU,EAAE,MAAM,wBAAwB,CAAC;AAEpD,qBAAa,eAAe;IAC1B,OAAO,CAAC,QAAQ,CAAoB;IAEpC,OAAO,CAAC,MAAM,CAAU;;IAsCxB,UAAU;IAKV,SAAS,CAAC,MAAM,EAAE,UAAU;IAQ5B,YAAY,CAAC,MAAM,EAAE,UAAU;IAO/B,MAAM;IAON,IAAI;CAKL"}
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
- if (entity instanceof Entity) {
48
- World.remove(this.engine.world, entity.body);
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);
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "react-simple-game-engine",
3
- "version": "0.0.44",
3
+ "version": "0.0.45",
4
4
  "description": "",
5
5
  "main": "lib/index.js",
6
6
  "types": "lib",