react-simple-game-engine 0.1.24 → 0.1.27
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.d.ts +5 -5
- package/lib/classes/entities/entity.d.ts.map +1 -1
- package/lib/classes/entities/entity.js +7 -7
- package/lib/classes/logic-component.d.ts +4 -2
- package/lib/classes/logic-component.d.ts.map +1 -1
- package/lib/classes/logic-component.js +9 -1
- package/lib/classes/prefab.d.ts +7 -0
- package/lib/classes/prefab.d.ts.map +1 -0
- package/lib/classes/prefab.js +24 -0
- package/lib/classes/scene.d.ts +6 -0
- package/lib/classes/scene.d.ts.map +1 -1
- package/lib/classes/scene.js +12 -1
- package/package.json +1 -1
@@ -4,7 +4,7 @@ import { CreateBodyDefine, EntityInitial, EntityPrepare, MasterBody, Sound } fro
|
|
4
4
|
import { EntitySult } from "./entity-sult";
|
5
5
|
import { LogicComponent } from "../logic-component";
|
6
6
|
declare type TimerJobListener = () => void;
|
7
|
-
declare type
|
7
|
+
declare type TerminateOptions = {
|
8
8
|
duration?: number;
|
9
9
|
effect: EntitySult | LogicComponent<EntitySult>;
|
10
10
|
};
|
@@ -14,7 +14,7 @@ export declare abstract class Entity<P extends Record<string, any> = Record<stri
|
|
14
14
|
private _children;
|
15
15
|
private _props;
|
16
16
|
private timerJobListeners;
|
17
|
-
private
|
17
|
+
private isTerminate;
|
18
18
|
enabledGravity: boolean;
|
19
19
|
sound?: Sound;
|
20
20
|
set sprite(sprite: Sprite<any>);
|
@@ -24,12 +24,12 @@ export declare abstract class Entity<P extends Record<string, any> = Record<stri
|
|
24
24
|
get children(): EntitySult<any>[];
|
25
25
|
get props(): P;
|
26
26
|
/**
|
27
|
-
* @param {
|
28
|
-
* #duration: time to disappear from the world in seconds, default: 2 seconds
|
27
|
+
* @param {TerminateOptions} options
|
28
|
+
* #duration: time to disappear from the world in seconds, default: 0.2 seconds
|
29
29
|
* #effect: effect to showing on duration time
|
30
30
|
* @void
|
31
31
|
*/
|
32
|
-
|
32
|
+
terminate(options?: TerminateOptions): void;
|
33
33
|
/**
|
34
34
|
* @param {string} name
|
35
35
|
* @param {number} interval in seconds
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"entity.d.ts","sourceRoot":"","sources":["../../../src/classes/entities/entity.ts"],"names":[],"mappings":"AAAA,OAAO,MAAwB,MAAM,WAAW,CAAC;AAEjD,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;AAC3C,OAAO,EAAE,cAAc,EAAE,MAAM,oBAAoB,CAAC;AAGpD,aAAK,gBAAgB,GAAG,MAAM,IAAI,CAAC;AAEnC,aAAK,
|
1
|
+
{"version":3,"file":"entity.d.ts","sourceRoot":"","sources":["../../../src/classes/entities/entity.ts"],"names":[],"mappings":"AAAA,OAAO,MAAwB,MAAM,WAAW,CAAC;AAEjD,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;AAC3C,OAAO,EAAE,cAAc,EAAE,MAAM,oBAAoB,CAAC;AAGpD,aAAK,gBAAgB,GAAG,MAAM,IAAI,CAAC;AAEnC,aAAK,gBAAgB,GAAG;IACtB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,MAAM,EAAE,UAAU,GAAG,cAAc,CAAC,UAAU,CAAC,CAAC;CACjD,CAAC;AAEF,8BAAsB,MAAM,CAC1B,CAAC,SAAS,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,GAAG,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CACnD,SAAQ,UAAU,CAAC,aAAa,CAAC,MAAM,CAAC,CAAC;IACzC,OAAO,CAAC,KAAK,CAAc;IAC3B,OAAO,CAAC,OAAO,CAAe;IAC9B,OAAO,CAAC,SAAS,CAAoB;IACrC,OAAO,CAAC,MAAM,CAAkB;IAChC,OAAO,CAAC,iBAAiB,CAQlB;IACP,OAAO,CAAC,WAAW,CAAS;IAErB,cAAc,EAAE,OAAO,CAAQ;IAC/B,KAAK,CAAC,EAAE,KAAK,CAAC;IAErB,IAAI,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,GAAG,CAAC,EAG7B;IAED,IAAI,MAAM,IALS,MAAM,CAAC,GAAG,CAAC,CAO7B;IAED,IAAI,QAAQ,kBAEX;IAED,IAAI,IAAI,eAEP;IAED,IAAI,QAAQ,sBAEX;IAED,IAAI,KAAK,MAER;IAED;;;;;OAKG;IACH,SAAS,CAAC,OAAO,CAAC,EAAE,gBAAgB;IAoBpC;;;;;OAKG;IACH,OAAO,CACL,IAAI,EAAE,MAAM,EACZ,QAAQ,EAAE,MAAM,EAChB,GAAG,EAAE,gBAAgB,EACrB,UAAU,UAAQ;IAcpB,QAAQ,CAAC,MAAM,EAAE,UAAU,GAAG,cAAc,CAAC,UAAU,CAAC;IASxD,WAAW,CAAC,MAAM,EAAE,UAAU;IAQ9B,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,EACxC,OAAO,CAAC,EAAE,gBAAgB,CAAC,aAAa,CAAC,GACxC,MAAM,CAAC,IAAI;IAEd,OAAO,CAAC,EACN,SAAS,EACT,MAAM,EAAE,eAAe,EACvB,WAAW,EACX,KAAU,EACV,GAAG,MAAM,EACV,EAAE,aAAa,CAAC,IAAI,CAAC;IAiDtB,SAAS,CAAC,QAAQ,CAAC,SAAS,IAAI,aAAa,CAAC,IAAI,CAAC;IACnD,SAAS,CAAC,SAAS,IAAI,aAAa,CAAC,IAAI,CAAC;IAI1C,MAAM;IAiBN,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"}
|
@@ -46,7 +46,7 @@ var Entity = /** @class */ (function (_super) {
|
|
46
46
|
_this._children = [];
|
47
47
|
_this._props = {};
|
48
48
|
_this.timerJobListeners = {};
|
49
|
-
_this.
|
49
|
+
_this.isTerminate = false;
|
50
50
|
_this.enabledGravity = true;
|
51
51
|
return _this;
|
52
52
|
}
|
@@ -90,16 +90,16 @@ var Entity = /** @class */ (function (_super) {
|
|
90
90
|
configurable: true
|
91
91
|
});
|
92
92
|
/**
|
93
|
-
* @param {
|
94
|
-
* #duration: time to disappear from the world in seconds, default: 2 seconds
|
93
|
+
* @param {TerminateOptions} options
|
94
|
+
* #duration: time to disappear from the world in seconds, default: 0.2 seconds
|
95
95
|
* #effect: effect to showing on duration time
|
96
96
|
* @void
|
97
97
|
*/
|
98
|
-
Entity.prototype.
|
98
|
+
Entity.prototype.terminate = function (options) {
|
99
99
|
var _this = this;
|
100
100
|
if (options) {
|
101
|
-
var _a = options.duration, duration = _a === void 0 ? 2 : _a, effect = options.effect;
|
102
|
-
this.
|
101
|
+
var _a = options.duration, duration = _a === void 0 ? 0.2 : _a, effect = options.effect;
|
102
|
+
this.isTerminate = true;
|
103
103
|
Body.setVelocity(this.body, {
|
104
104
|
y: 0,
|
105
105
|
x: 0,
|
@@ -173,7 +173,7 @@ var Entity = /** @class */ (function (_super) {
|
|
173
173
|
return {};
|
174
174
|
};
|
175
175
|
Entity.prototype.update = function () {
|
176
|
-
if (this.
|
176
|
+
if (!this.isTerminate) {
|
177
177
|
this.onUpdate();
|
178
178
|
}
|
179
179
|
for (var name_1 in this.timerJobListeners) {
|
@@ -2,8 +2,10 @@ import { Initialler } from "../export-interfaces";
|
|
2
2
|
import { Configable } from "../export-types";
|
3
3
|
import { WorldManagement } from "./world-management";
|
4
4
|
export declare class LogicComponent<C extends Initialler = Initialler> {
|
5
|
-
private configale;
|
6
|
-
|
5
|
+
private readonly configale;
|
6
|
+
private readonly _isPrefab?;
|
7
|
+
constructor(configale: Configable<C>, _isPrefab?: boolean | undefined);
|
8
|
+
get isPrefab(): boolean | undefined;
|
7
9
|
output({ worldManagement, ...extraParams }?: {
|
8
10
|
worldManagement?: WorldManagement;
|
9
11
|
} & Record<string, any>): C;
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"logic-component.d.ts","sourceRoot":"","sources":["../../src/classes/logic-component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,sBAAsB,CAAC;AAClD,OAAO,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAC;AAK7C,OAAO,EAAE,eAAe,EAAE,MAAM,oBAAoB,CAAC;AAErD,qBAAa,cAAc,CAAC,CAAC,SAAS,UAAU,GAAG,UAAU;
|
1
|
+
{"version":3,"file":"logic-component.d.ts","sourceRoot":"","sources":["../../src/classes/logic-component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,sBAAsB,CAAC;AAClD,OAAO,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAC;AAK7C,OAAO,EAAE,eAAe,EAAE,MAAM,oBAAoB,CAAC;AAErD,qBAAa,cAAc,CAAC,CAAC,SAAS,UAAU,GAAG,UAAU;IAEzD,OAAO,CAAC,QAAQ,CAAC,SAAS;IAC1B,OAAO,CAAC,QAAQ,CAAC,SAAS,CAAC;gBADV,SAAS,EAAE,UAAU,CAAC,CAAC,CAAC,EACxB,SAAS,CAAC,qBAAS;IAGtC,IAAI,QAAQ,wBAEX;IAED,MAAM,CAAC,EACL,eAAe,EACf,GAAG,WAAW,EACf,GAAE;QAAE,eAAe,CAAC,EAAE,eAAe,CAAA;KAAE,GAAG,MAAM,CAAC,MAAM,EAAE,GAAG,CAAM;CAapE"}
|
@@ -12,9 +12,17 @@ var __rest = (this && this.__rest) || function (s, e) {
|
|
12
12
|
import { copyProperties } from "../utils";
|
13
13
|
import { EntitySult } from "./entities/entity-sult";
|
14
14
|
var LogicComponent = /** @class */ (function () {
|
15
|
-
function LogicComponent(configale) {
|
15
|
+
function LogicComponent(configale, _isPrefab) {
|
16
16
|
this.configale = configale;
|
17
|
+
this._isPrefab = _isPrefab;
|
17
18
|
}
|
19
|
+
Object.defineProperty(LogicComponent.prototype, "isPrefab", {
|
20
|
+
get: function () {
|
21
|
+
return this._isPrefab;
|
22
|
+
},
|
23
|
+
enumerable: false,
|
24
|
+
configurable: true
|
25
|
+
});
|
18
26
|
LogicComponent.prototype.output = function (_a) {
|
19
27
|
if (_a === void 0) { _a = {}; }
|
20
28
|
var worldManagement = _a.worldManagement, extraParams = __rest(_a, ["worldManagement"]);
|
@@ -0,0 +1,7 @@
|
|
1
|
+
import { Initialler } from "../export-interfaces";
|
2
|
+
import { Configable } from "../export-types";
|
3
|
+
import { LogicComponent } from "./logic-component";
|
4
|
+
export declare class Prefab<C extends Initialler = Initialler> extends LogicComponent<C> {
|
5
|
+
constructor(configale: Configable<C>);
|
6
|
+
}
|
7
|
+
//# sourceMappingURL=prefab.d.ts.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"prefab.d.ts","sourceRoot":"","sources":["../../src/classes/prefab.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,sBAAsB,CAAC;AAClD,OAAO,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAC;AAE7C,OAAO,EAAE,cAAc,EAAE,MAAM,mBAAmB,CAAC;AAEnD,qBAAa,MAAM,CACjB,CAAC,SAAS,UAAU,GAAG,UAAU,CACjC,SAAQ,cAAc,CAAC,CAAC,CAAC;gBACb,SAAS,EAAE,UAAU,CAAC,CAAC,CAAC;CAGrC"}
|
@@ -0,0 +1,24 @@
|
|
1
|
+
var __extends = (this && this.__extends) || (function () {
|
2
|
+
var extendStatics = function (d, b) {
|
3
|
+
extendStatics = Object.setPrototypeOf ||
|
4
|
+
({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
|
5
|
+
function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };
|
6
|
+
return extendStatics(d, b);
|
7
|
+
};
|
8
|
+
return function (d, b) {
|
9
|
+
if (typeof b !== "function" && b !== null)
|
10
|
+
throw new TypeError("Class extends value " + String(b) + " is not a constructor or null");
|
11
|
+
extendStatics(d, b);
|
12
|
+
function __() { this.constructor = d; }
|
13
|
+
d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
|
14
|
+
};
|
15
|
+
})();
|
16
|
+
import { LogicComponent } from "./logic-component";
|
17
|
+
var Prefab = /** @class */ (function (_super) {
|
18
|
+
__extends(Prefab, _super);
|
19
|
+
function Prefab(configale) {
|
20
|
+
return _super.call(this, configale, true) || this;
|
21
|
+
}
|
22
|
+
return Prefab;
|
23
|
+
}(LogicComponent));
|
24
|
+
export { Prefab };
|
package/lib/classes/scene.d.ts
CHANGED
@@ -3,6 +3,8 @@ import { Camera } from "./camera";
|
|
3
3
|
import { LogicComponent } from "./logic-component";
|
4
4
|
import { SceneManagement } from "./scene-management";
|
5
5
|
import { EntitySult } from "./entities/entity-sult";
|
6
|
+
import { Prefab } from "./prefab";
|
7
|
+
import { Initialler } from "../export-interfaces";
|
6
8
|
declare type LoadAssetsListener = (loadedAssets: boolean) => void;
|
7
9
|
declare type EntityPropsChangeListener<V = any> = (value: V) => void;
|
8
10
|
export declare abstract class Scene<UIP = any> {
|
@@ -11,6 +13,7 @@ export declare abstract class Scene<UIP = any> {
|
|
11
13
|
private _loadedAssets;
|
12
14
|
private loadAssetsListener;
|
13
15
|
private entityPropsChangeListeners;
|
16
|
+
private readonly prefabs;
|
14
17
|
assetsDelay: number;
|
15
18
|
tag: string;
|
16
19
|
manager: SceneManagement;
|
@@ -30,6 +33,9 @@ export declare abstract class Scene<UIP = any> {
|
|
30
33
|
switchToScene(tag: string): void;
|
31
34
|
loadAssets(delay?: number): Promise<void>;
|
32
35
|
onLoadAssets(): Promise<void>;
|
36
|
+
getPrefab<C extends Initialler>(Class: {
|
37
|
+
new (): Prefab<C>;
|
38
|
+
}): Prefab<Initialler<any>> | undefined;
|
33
39
|
bootstrap(camera: Camera): void;
|
34
40
|
protected onDraw(): void;
|
35
41
|
protected onUpdate(): void;
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"scene.d.ts","sourceRoot":"","sources":["../../src/classes/scene.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,OAAO,CAAC;AAEtC,OAAO,EAAE,MAAM,EAAE,MAAM,UAAU,CAAC;AAClC,OAAO,EAAE,cAAc,EAAE,MAAM,mBAAmB,CAAC;AACnD,OAAO,EAAE,eAAe,EAAE,MAAM,oBAAoB,CAAC;AAErD,OAAO,EAAE,UAAU,EAAE,MAAM,wBAAwB,CAAC;
|
1
|
+
{"version":3,"file":"scene.d.ts","sourceRoot":"","sources":["../../src/classes/scene.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,OAAO,CAAC;AAEtC,OAAO,EAAE,MAAM,EAAE,MAAM,UAAU,CAAC;AAClC,OAAO,EAAE,cAAc,EAAE,MAAM,mBAAmB,CAAC;AACnD,OAAO,EAAE,eAAe,EAAE,MAAM,oBAAoB,CAAC;AAErD,OAAO,EAAE,UAAU,EAAE,MAAM,wBAAwB,CAAC;AAGpD,OAAO,EAAE,MAAM,EAAE,MAAM,UAAU,CAAC;AAClC,OAAO,EAAE,UAAU,EAAE,MAAM,sBAAsB,CAAC;AAElD,aAAK,kBAAkB,GAAG,CAAC,YAAY,EAAE,OAAO,KAAK,IAAI,CAAC;AAC1D,aAAK,yBAAyB,CAAC,CAAC,GAAG,GAAG,IAAI,CAAC,KAAK,EAAE,CAAC,KAAK,IAAI,CAAC;AAE7D,8BAAsB,KAAK,CAAC,GAAG,GAAG,GAAG;IACnC,OAAO,CAAC,EAAE,CAAqB;IAC/B,OAAO,CAAC,eAAe,CAAmB;IAC1C,OAAO,CAAC,aAAa,CAAW;IAChC,OAAO,CAAC,kBAAkB,CAAsB;IAChD,OAAO,CAAC,0BAA0B,CAG3B;IACP,OAAO,CAAC,QAAQ,CAAC,OAAO,CAAgB;IAEjC,WAAW,EAAE,MAAM,CAAK;IACxB,GAAG,EAAE,MAAM,CAAC;IACZ,OAAO,EAAG,eAAe,CAAC;IACjC,SAAgB,SAAS,EAAE,MAAM,CAA8C;aAC/D,aAAa,CAAC,MAAM,EAAE,MAAM,GAAG,cAAc,CAAC,UAAU,CAAC,EAAE;;IAS3E,IAAI,EAAE,uBAGL;IAED,IAAI,OAAO,QAEV;IAED,SAAS,CAAC,MAAM;IAEhB,SAAS,CAAC,UAAU;IAIpB,IAAI,YAAY,IAIuB,OAAO,CAF7C;IAED,OAAO,KAAK,YAAY,QAGvB;IAED,6BAA6B,CAAC,CAAC,GAAG,GAAG,EAAE,IAAI,EAAE,MAAM,EAAE,KAAK,EAAE,CAAC;IAO7D,2BAA2B,CAAC,CAAC,GAAG,GAAG,EACjC,IAAI,EAAE,MAAM,EACZ,IAAI,EAAE,yBAAyB,CAAC,CAAC,CAAC;IAepC,iBAAiB,CAAC,IAAI,EAAE,kBAAkB;IAI1C,UAAU;IAIV,aAAa,CAAC,GAAG,EAAE,MAAM;IAInB,UAAU,CAAC,KAAK,CAAC,EAAE,MAAM;IAczB,YAAY;IAElB,SAAS,CAAC,CAAC,SAAS,UAAU,EAAE,KAAK,EAAE;QAAE,QAAQ,MAAM,CAAC,CAAC,CAAC,CAAA;KAAE;IAI5D,SAAS,CAAC,MAAM,EAAE,MAAM;IAiBxB,SAAS,CAAC,MAAM;IAChB,SAAS,CAAC,QAAQ;IAElB,MAAM;CAUP"}
|
package/lib/classes/scene.js
CHANGED
@@ -39,6 +39,7 @@ import { tick } from "../utils";
|
|
39
39
|
var Scene = /** @class */ (function () {
|
40
40
|
function Scene() {
|
41
41
|
this.entityPropsChangeListeners = {};
|
42
|
+
this.prefabs = [];
|
42
43
|
this.assetsDelay = 0;
|
43
44
|
this.sessionId = "".concat(Math.random(), "-").concat(new Date().getTime());
|
44
45
|
this.tag = this.constructor.tag;
|
@@ -134,9 +135,19 @@ var Scene = /** @class */ (function () {
|
|
134
135
|
return [2 /*return*/];
|
135
136
|
}); });
|
136
137
|
};
|
138
|
+
Scene.prototype.getPrefab = function (Class) {
|
139
|
+
return this.prefabs.find(function (pf) { return pf instanceof Class; });
|
140
|
+
};
|
137
141
|
Scene.prototype.bootstrap = function (camera) {
|
142
|
+
var _this = this;
|
138
143
|
this.worldManagement = new WorldManagement(camera, this);
|
139
|
-
var components = this.getComponents(camera)
|
144
|
+
var components = this.getComponents(camera).filter(function (comp) {
|
145
|
+
if (comp.isPrefab) {
|
146
|
+
_this.prefabs.push(comp);
|
147
|
+
return false;
|
148
|
+
}
|
149
|
+
return true;
|
150
|
+
});
|
140
151
|
for (var _i = 0, components_1 = components; _i < components_1.length; _i++) {
|
141
152
|
var component = components_1[_i];
|
142
153
|
var entity = component.output({
|