mani-game-engine 1.0.0-pre.3 → 1.0.0-pre.30
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/LICENSE +1 -1
- package/lib/clock.d.ts +34 -20
- package/lib/clock.js +55 -15
- package/lib/clock.js.map +1 -1
- package/lib/ecsInjector.d.ts +12 -6
- package/lib/ecsInjector.js +55 -29
- package/lib/ecsInjector.js.map +1 -1
- package/lib/entity.d.ts +8 -7
- package/lib/entity.js +29 -17
- package/lib/entity.js.map +1 -1
- package/lib/gameEngine.d.ts +44 -19
- package/lib/gameEngine.js +213 -103
- package/lib/gameEngine.js.map +1 -1
- package/lib/index.d.ts +9 -3
- package/lib/index.js +24 -5
- package/lib/index.js.map +1 -1
- package/lib/injector.d.ts +121 -0
- package/lib/injector.js +290 -0
- package/lib/injector.js.map +1 -0
- package/lib/scope/scopeContext.d.ts +57 -0
- package/lib/scope/scopeContext.js +255 -0
- package/lib/scope/scopeContext.js.map +1 -0
- package/lib/systemContext.d.ts +12 -0
- package/lib/systemContext.js +24 -0
- package/lib/systemContext.js.map +1 -0
- package/lib/types.d.ts +28 -9
- package/lib/types.js +17 -0
- package/lib/types.js.map +1 -1
- package/lib/utils/map2k.js +5 -1
- package/lib/utils/map2k.js.map +1 -1
- package/package.json +15 -21
- package/src/clock.ts +90 -29
- package/src/ecsInjector.ts +42 -19
- package/src/entity.ts +24 -14
- package/src/gameEngine.ts +271 -137
- package/src/index.ts +12 -3
- package/src/injector.ts +363 -0
- package/src/scope/scopeContext.ts +320 -0
- package/src/systemContext.ts +27 -0
- package/src/types.ts +27 -10
|
@@ -0,0 +1,255 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.ScopeContext = exports.SCOPE_CONTEXT = exports.OnScopeSignal = exports.scopeSignalHandlers = void 0;
|
|
4
|
+
const ecsInjector_1 = require("../ecsInjector");
|
|
5
|
+
const injector_1 = require("../injector");
|
|
6
|
+
exports.scopeSignalHandlers = new Map();
|
|
7
|
+
const OnScopeSignal = (id, options) => (target, propertyKey, descriptor) => {
|
|
8
|
+
if (target instanceof Function) {
|
|
9
|
+
throw new Error('only allowed on non static methods');
|
|
10
|
+
}
|
|
11
|
+
else {
|
|
12
|
+
const mappingList = injector_1.putIfAbsent(exports.scopeSignalHandlers, target.constructor, () => []);
|
|
13
|
+
mappingList.push([propertyKey, id, options]);
|
|
14
|
+
}
|
|
15
|
+
};
|
|
16
|
+
exports.OnScopeSignal = OnScopeSignal;
|
|
17
|
+
exports.SCOPE_CONTEXT = {
|
|
18
|
+
log: true,
|
|
19
|
+
};
|
|
20
|
+
class ScopeSignalBinding {
|
|
21
|
+
constructor(signalBinding, options) {
|
|
22
|
+
this.signalBinding = signalBinding;
|
|
23
|
+
this.keepAlive = options === null || options === void 0 ? void 0 : options.keepAlive;
|
|
24
|
+
this.group = options === null || options === void 0 ? void 0 : options.group;
|
|
25
|
+
}
|
|
26
|
+
activate() {
|
|
27
|
+
this.signalBinding.setActive(true);
|
|
28
|
+
}
|
|
29
|
+
deactivate() {
|
|
30
|
+
this.signalBinding.setActive(false);
|
|
31
|
+
}
|
|
32
|
+
detach() {
|
|
33
|
+
this.signalBinding.detach();
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
class ScopeStack {
|
|
37
|
+
constructor(rootScope) {
|
|
38
|
+
this.rootScope = rootScope;
|
|
39
|
+
this.stack = [];
|
|
40
|
+
this.queuedScopeChanges = [];
|
|
41
|
+
this.ongoingChange = false;
|
|
42
|
+
this.stack.push(rootScope);
|
|
43
|
+
}
|
|
44
|
+
get rootContext() {
|
|
45
|
+
return this.stack[0];
|
|
46
|
+
}
|
|
47
|
+
get activeContext() {
|
|
48
|
+
return this.stack[this.stack.length - 1];
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
class ScopeContext {
|
|
52
|
+
constructor(injector, scopeClass, mapping, parent) {
|
|
53
|
+
var _a, _b, _c, _d;
|
|
54
|
+
this.parent = parent;
|
|
55
|
+
this.signalBindings = [];
|
|
56
|
+
this.serviceBindings = [];
|
|
57
|
+
this.closed = false;
|
|
58
|
+
this.muteKeepAliveSignals = false;
|
|
59
|
+
if (!parent) {
|
|
60
|
+
this.stack = new ScopeStack(this);
|
|
61
|
+
}
|
|
62
|
+
else {
|
|
63
|
+
this.stack = parent.stack;
|
|
64
|
+
this.stack.stack.push(this);
|
|
65
|
+
}
|
|
66
|
+
this.injector = injector.createChild();
|
|
67
|
+
this.injector.map(scopeClass).toSingleton();
|
|
68
|
+
this.injector.map(ScopeContext).toValue(this);
|
|
69
|
+
mapping === null || mapping === void 0 ? void 0 : mapping({
|
|
70
|
+
injector: this.injector,
|
|
71
|
+
registerScopeService: serviceClass => {
|
|
72
|
+
this.injector.map(serviceClass).toSingleton();
|
|
73
|
+
this.mapServiceSignals(this.injector.get(serviceClass));
|
|
74
|
+
},
|
|
75
|
+
});
|
|
76
|
+
this.scope = this.injector.get(scopeClass);
|
|
77
|
+
this.mapScopeSignals();
|
|
78
|
+
this.updateSignalBindings();
|
|
79
|
+
(_b = (_a = this.scope).onEnter) === null || _b === void 0 ? void 0 : _b.call(_a);
|
|
80
|
+
(_d = (_c = this.scope).onActivate) === null || _d === void 0 ? void 0 : _d.call(_c);
|
|
81
|
+
}
|
|
82
|
+
get isRoot() {
|
|
83
|
+
return this === this.stack.rootScope;
|
|
84
|
+
}
|
|
85
|
+
get target() {
|
|
86
|
+
return this.stack.target;
|
|
87
|
+
}
|
|
88
|
+
get isActive() {
|
|
89
|
+
return this === this.stack.activeContext;
|
|
90
|
+
}
|
|
91
|
+
get activeContext() { return this.stack.activeContext; }
|
|
92
|
+
enterScope(scopeClass, mapping) {
|
|
93
|
+
let newContext;
|
|
94
|
+
const doChange = () => {
|
|
95
|
+
var _a, _b, _c, _d;
|
|
96
|
+
(_b = (_a = this.activeContext.scope).onSubExit) === null || _b === void 0 ? void 0 : _b.call(_a);
|
|
97
|
+
(_d = (_c = this.activeContext.scope).onDeactivate) === null || _d === void 0 ? void 0 : _d.call(_c);
|
|
98
|
+
newContext = new ScopeContext(this.activeContext.injector, scopeClass, mapping, this.activeContext);
|
|
99
|
+
this.logStack();
|
|
100
|
+
const nextChange = this.stack.queuedScopeChanges.shift();
|
|
101
|
+
if (nextChange) {
|
|
102
|
+
nextChange();
|
|
103
|
+
}
|
|
104
|
+
else {
|
|
105
|
+
this.stack.ongoingChange = false;
|
|
106
|
+
}
|
|
107
|
+
};
|
|
108
|
+
if (!this.stack.ongoingChange) {
|
|
109
|
+
this.stack.ongoingChange = true;
|
|
110
|
+
doChange();
|
|
111
|
+
}
|
|
112
|
+
else {
|
|
113
|
+
this.stack.queuedScopeChanges.push(doChange);
|
|
114
|
+
}
|
|
115
|
+
return newContext;
|
|
116
|
+
}
|
|
117
|
+
exitScope(target) {
|
|
118
|
+
const doChange = () => {
|
|
119
|
+
if (this.closed)
|
|
120
|
+
throw new Error(`Scope already closed`);
|
|
121
|
+
this.stack.target = target || this.scope.constructor;
|
|
122
|
+
while (true) {
|
|
123
|
+
const ctx = this.stack.stack.pop();
|
|
124
|
+
if (!ctx) {
|
|
125
|
+
throw new Error('no scope in stack');
|
|
126
|
+
}
|
|
127
|
+
ctx.exitThis();
|
|
128
|
+
if (ctx.scope.constructor === this.stack.target) {
|
|
129
|
+
break;
|
|
130
|
+
}
|
|
131
|
+
}
|
|
132
|
+
this.stack.target = undefined;
|
|
133
|
+
const nextChange = this.stack.queuedScopeChanges.shift();
|
|
134
|
+
if (nextChange) {
|
|
135
|
+
nextChange();
|
|
136
|
+
}
|
|
137
|
+
else {
|
|
138
|
+
this.stack.ongoingChange = false;
|
|
139
|
+
}
|
|
140
|
+
};
|
|
141
|
+
if (!this.stack.ongoingChange) {
|
|
142
|
+
this.stack.ongoingChange = true;
|
|
143
|
+
doChange();
|
|
144
|
+
}
|
|
145
|
+
else {
|
|
146
|
+
this.stack.queuedScopeChanges.push(doChange);
|
|
147
|
+
}
|
|
148
|
+
}
|
|
149
|
+
closeSubScopes() {
|
|
150
|
+
this.stack.target = this.scope.constructor;
|
|
151
|
+
while (!this.isActive) {
|
|
152
|
+
const ctx = this.stack.stack.pop();
|
|
153
|
+
if (!ctx) {
|
|
154
|
+
throw new Error('no scope in stack');
|
|
155
|
+
}
|
|
156
|
+
ctx.exitThis();
|
|
157
|
+
}
|
|
158
|
+
this.stack.target = undefined;
|
|
159
|
+
}
|
|
160
|
+
logStack() {
|
|
161
|
+
if (exports.SCOPE_CONTEXT.log) {
|
|
162
|
+
console.debug('%c' + this.stack.stack.map(c => c.scope.constructor.name).join(' -> '), 'color:yellow');
|
|
163
|
+
}
|
|
164
|
+
}
|
|
165
|
+
getStackClasses() {
|
|
166
|
+
return this.stack.stack.map(context => context.scope.constructor);
|
|
167
|
+
}
|
|
168
|
+
addScopeSignal(signal, callback, params) {
|
|
169
|
+
const signalBinding = new ScopeSignalBinding(signal.add(callback, params === null || params === void 0 ? void 0 : params.context), params);
|
|
170
|
+
this.signalBindings.push(signalBinding);
|
|
171
|
+
}
|
|
172
|
+
disableKeepAliveSignals() {
|
|
173
|
+
this.muteKeepAliveSignals = true;
|
|
174
|
+
this.updateSignalBindings();
|
|
175
|
+
}
|
|
176
|
+
enableKeepAliveSignals() {
|
|
177
|
+
this.muteKeepAliveSignals = false;
|
|
178
|
+
this.updateSignalBindings();
|
|
179
|
+
}
|
|
180
|
+
updateSignalBindings(muteKeepAlive = false) {
|
|
181
|
+
var _a;
|
|
182
|
+
for (const binding of this.signalBindings) {
|
|
183
|
+
if (this.isActive) {
|
|
184
|
+
binding.activate();
|
|
185
|
+
}
|
|
186
|
+
else if (muteKeepAlive) {
|
|
187
|
+
binding.deactivate();
|
|
188
|
+
}
|
|
189
|
+
else if (binding.keepAlive === true) {
|
|
190
|
+
binding.activate();
|
|
191
|
+
}
|
|
192
|
+
else if (!!(binding.keepAlive)) {
|
|
193
|
+
if (binding.keepAlive.indexOf(this.activeContext.scope.constructor) != -1) {
|
|
194
|
+
binding.activate();
|
|
195
|
+
}
|
|
196
|
+
else {
|
|
197
|
+
binding.deactivate();
|
|
198
|
+
}
|
|
199
|
+
}
|
|
200
|
+
else {
|
|
201
|
+
binding.deactivate();
|
|
202
|
+
}
|
|
203
|
+
}
|
|
204
|
+
muteKeepAlive = muteKeepAlive || this.muteKeepAliveSignals;
|
|
205
|
+
(_a = this.parent) === null || _a === void 0 ? void 0 : _a.updateSignalBindings(muteKeepAlive);
|
|
206
|
+
}
|
|
207
|
+
detachSignalBindings() {
|
|
208
|
+
for (const signalBinding of this.signalBindings) {
|
|
209
|
+
signalBinding.detach();
|
|
210
|
+
}
|
|
211
|
+
}
|
|
212
|
+
mapScopeSignals() {
|
|
213
|
+
const handlers = exports.scopeSignalHandlers.get(this.scope.constructor);
|
|
214
|
+
if (!handlers)
|
|
215
|
+
return;
|
|
216
|
+
for (const [field, id, options] of handlers) {
|
|
217
|
+
const signal = this.injector.getSignal(id);
|
|
218
|
+
const callback = this.scope[field];
|
|
219
|
+
this.addScopeSignal(signal, callback, Object.assign(Object.assign({}, options), { context: this.scope }));
|
|
220
|
+
}
|
|
221
|
+
}
|
|
222
|
+
mapServiceSignals(scopeService) {
|
|
223
|
+
const handlers = ecsInjector_1.signalHandlers.get(scopeService.constructor);
|
|
224
|
+
if (!handlers)
|
|
225
|
+
return;
|
|
226
|
+
for (const [field, id] of handlers) {
|
|
227
|
+
const signal = this.injector.getSignal(id);
|
|
228
|
+
const signalBinding = signal.add(scopeService[field], scopeService);
|
|
229
|
+
this.serviceBindings.push(signalBinding);
|
|
230
|
+
}
|
|
231
|
+
}
|
|
232
|
+
detachServiceBindings() {
|
|
233
|
+
for (const binding of this.serviceBindings) {
|
|
234
|
+
binding.detach();
|
|
235
|
+
}
|
|
236
|
+
this.serviceBindings = [];
|
|
237
|
+
}
|
|
238
|
+
exitThis() {
|
|
239
|
+
var _a, _b, _c, _d, _e, _f, _g, _h;
|
|
240
|
+
if (!this.parent) {
|
|
241
|
+
throw new Error('can\'t exit root scope?!');
|
|
242
|
+
}
|
|
243
|
+
this.logStack();
|
|
244
|
+
this.detachSignalBindings();
|
|
245
|
+
this.detachServiceBindings();
|
|
246
|
+
(_b = (_a = this.scope).onDeactivate) === null || _b === void 0 ? void 0 : _b.call(_a);
|
|
247
|
+
(_d = (_c = this.scope).onExit) === null || _d === void 0 ? void 0 : _d.call(_c);
|
|
248
|
+
this.parent.updateSignalBindings();
|
|
249
|
+
(_f = (_e = this.parent.scope).onSubReturn) === null || _f === void 0 ? void 0 : _f.call(_e);
|
|
250
|
+
(_h = (_g = this.parent.scope).onActivate) === null || _h === void 0 ? void 0 : _h.call(_g);
|
|
251
|
+
this.closed = true;
|
|
252
|
+
}
|
|
253
|
+
}
|
|
254
|
+
exports.ScopeContext = ScopeContext;
|
|
255
|
+
//# sourceMappingURL=scopeContext.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"scopeContext.js","sourceRoot":"","sources":["../../src/scope/scopeContext.ts"],"names":[],"mappings":";;;AACA,gDAA8C;AAC9C,0CAA4C;AAI/B,QAAA,mBAAmB,GAAG,IAAI,GAAG,EAA+C,CAAC;AAEnF,MAAM,aAAa,GAAG,CAAC,EAAM,EAAE,OAA4B,EAAE,EAAE,CAAC,CAAC,MAAW,EAAE,WAAmB,EAAE,UAA8B,EAAE,EAAE;IACxI,IAAI,MAAM,YAAY,QAAQ,EAAE;QAC5B,MAAM,IAAI,KAAK,CAAC,oCAAoC,CAAC,CAAC;KACzD;SAAM;QACH,MAAM,WAAW,GAAG,sBAAW,CAAC,2BAAmB,EAAE,MAAM,CAAC,WAAW,EAAE,GAAwC,EAAE,CAAC,EAAE,CAAC,CAAC;QACxH,WAAW,CAAC,IAAI,CAAC,CAAC,WAAW,EAAE,EAAE,EAAE,OAAO,CAAC,CAAC,CAAC;KAChD;AACL,CAAC,CAAC;AAPW,QAAA,aAAa,iBAOxB;AAEW,QAAA,aAAa,GAAG;IACzB,GAAG,EAAE,IAAI;CACZ,CAAC;AAYF,MAAM,kBAAkB;IAIpB,YAAoB,aAA4B,EAAE,OAA4B;QAA1D,kBAAa,GAAb,aAAa,CAAe;QAC5C,IAAI,CAAC,SAAS,GAAG,OAAO,aAAP,OAAO,uBAAP,OAAO,CAAE,SAAS,CAAC;QACpC,IAAI,CAAC,KAAK,GAAG,OAAO,aAAP,OAAO,uBAAP,OAAO,CAAE,KAAK,CAAC;IAChC,CAAC;IAED,QAAQ;QACJ,IAAI,CAAC,aAAa,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;IACvC,CAAC;IAED,UAAU;QACN,IAAI,CAAC,aAAa,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;IACxC,CAAC;IAED,MAAM;QACF,IAAI,CAAC,aAAa,CAAC,MAAM,EAAE,CAAC;IAChC,CAAC;CACJ;AAED,MAAM,UAAU;IAMZ,YAAqB,SAAuB;QAAvB,cAAS,GAAT,SAAS,CAAc;QALnC,UAAK,GAAmB,EAAE,CAAC;QACpC,uBAAkB,GAAe,EAAE,CAAC;QACpC,kBAAa,GAAG,KAAK,CAAC;QAIlB,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;IAC/B,CAAC;IAED,IAAI,WAAW;QACX,OAAO,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;IACzB,CAAC;IAED,IAAI,aAAa;QACb,OAAO,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;IAC7C,CAAC;CAEJ;AAYD,MAAa,YAAY;IAYrB,YAAY,QAAqB,EAAE,UAAiB,EAAE,OAAsB,EAAU,MAAqB;;QAArB,WAAM,GAAN,MAAM,CAAe;QAR1F,mBAAc,GAAyB,EAAE,CAAC;QAInD,oBAAe,GAAoB,EAAE,CAAC;QACtC,WAAM,GAAG,KAAK,CAAC;QACf,yBAAoB,GAAG,KAAK,CAAC;QAGjC,IAAI,CAAC,MAAM,EAAE;YACT,IAAI,CAAC,KAAK,GAAG,IAAI,UAAU,CAAC,IAAI,CAAC,CAAC;SAErC;aAAM;YACH,IAAI,CAAC,KAAK,GAAG,MAAM,CAAC,KAAK,CAAC;YAC1B,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;SAC/B;QAED,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC,WAAW,EAAE,CAAC;QAEvC,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC,WAAW,EAAE,CAAC;QAC5C,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,YAAY,CAAC,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;QAE9C,OAAO,aAAP,OAAO,uBAAP,OAAO,CAAG;YACN,QAAQ,EAAE,IAAI,CAAC,QAAQ;YACvB,oBAAoB,EAAE,YAAY,CAAC,EAAE;gBACjC,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,YAAY,CAAC,CAAC,WAAW,EAAE,CAAC;gBAC9C,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,YAAY,CAAC,CAAC,CAAC;YAC5D,CAAC;SACJ,CAAC,CAAC;QAEH,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,UAAU,CAAU,CAAC;QACpD,IAAI,CAAC,eAAe,EAAE,CAAC;QACvB,IAAI,CAAC,oBAAoB,EAAE,CAAC;QAE5B,MAAA,MAAA,IAAI,CAAC,KAAK,EAAC,OAAO,kDAAI,CAAC;QACvB,MAAA,MAAA,IAAI,CAAC,KAAK,EAAC,UAAU,kDAAI,CAAC;IAC9B,CAAC;IAED,IAAI,MAAM;QACN,OAAO,IAAI,KAAK,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC;IACzC,CAAC;IAGD,IAAI,MAAM;QACN,OAAO,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC;IAC7B,CAAC;IAED,IAAI,QAAQ;QACR,OAAO,IAAI,KAAK,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC;IAC7C,CAAC;IAED,IAAI,aAAa,KAAK,OAAO,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,CAAA,CAAC;IAOvD,UAAU,CAAC,UAAiB,EAAE,OAAsB;QAChD,IAAI,UAAU,CAAC;QACf,MAAM,QAAQ,GAAG,GAAG,EAAE;;YAElB,MAAA,MAAA,IAAI,CAAC,aAAa,CAAC,KAAK,EAAC,SAAS,kDAAI,CAAC;YACvC,MAAA,MAAA,IAAI,CAAC,aAAa,CAAC,KAAK,EAAC,YAAY,kDAAI,CAAC;YAE1C,UAAU,GAAG,IAAI,YAAY,CAAC,IAAI,CAAC,aAAa,CAAC,QAAQ,EAAE,UAAU,EAAE,OAAO,EAAE,IAAI,CAAC,aAAa,CAAC,CAAC;YAEpG,IAAI,CAAC,QAAQ,EAAE,CAAC;YAChB,MAAM,UAAU,GAAG,IAAI,CAAC,KAAK,CAAC,kBAAkB,CAAC,KAAK,EAAE,CAAC;YACzD,IAAI,UAAU,EAAE;gBACZ,UAAU,EAAE,CAAC;aAChB;iBAAM;gBACH,IAAI,CAAC,KAAK,CAAC,aAAa,GAAG,KAAK,CAAC;aACpC;QACL,CAAC,CAAC;QAEF,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,aAAa,EAAE;YAC3B,IAAI,CAAC,KAAK,CAAC,aAAa,GAAG,IAAI,CAAC;YAChC,QAAQ,EAAE,CAAC;SACd;aAAM;YACH,IAAI,CAAC,KAAK,CAAC,kBAAkB,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;SAChD;QACD,OAAO,UAAU,CAAC;IACtB,CAAC;IAKD,SAAS,CAAC,MAAc;QACpB,MAAM,QAAQ,GAAG,GAAG,EAAE;YAClB,IAAI,IAAI,CAAC,MAAM;gBAAE,MAAM,IAAI,KAAK,CAAC,sBAAsB,CAAC,CAAC;YAEzD,IAAI,CAAC,KAAK,CAAC,MAAM,GAAG,MAAM,IAAI,IAAI,CAAC,KAAK,CAAC,WAAW,CAAC;YACrD,OAAO,IAAI,EAAE;gBACT,MAAM,GAAG,GAAG,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,GAAG,EAAE,CAAC;gBACnC,IAAI,CAAC,GAAG,EAAE;oBACN,MAAM,IAAI,KAAK,CAAC,mBAAmB,CAAC,CAAC;iBACxC;gBACD,GAAI,CAAC,QAAQ,EAAE,CAAC;gBAChB,IAAI,GAAI,CAAC,KAAK,CAAC,WAAW,KAAK,IAAI,CAAC,KAAK,CAAC,MAAM,EAAE;oBAC9C,MAAM;iBACT;aACJ;YACD,IAAI,CAAC,KAAK,CAAC,MAAM,GAAG,SAAS,CAAC;YAC9B,MAAM,UAAU,GAAG,IAAI,CAAC,KAAK,CAAC,kBAAkB,CAAC,KAAK,EAAE,CAAC;YACzD,IAAI,UAAU,EAAE;gBACZ,UAAU,EAAE,CAAC;aAChB;iBAAM;gBACH,IAAI,CAAC,KAAK,CAAC,aAAa,GAAG,KAAK,CAAC;aACpC;QAEL,CAAC,CAAC;QACF,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,aAAa,EAAE;YAC3B,IAAI,CAAC,KAAK,CAAC,aAAa,GAAG,IAAI,CAAC;YAChC,QAAQ,EAAE,CAAC;SACd;aAAM;YACH,IAAI,CAAC,KAAK,CAAC,kBAAkB,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;SAChD;IACL,CAAC;IAED,cAAc;QACV,IAAI,CAAC,KAAK,CAAC,MAAM,GAAG,IAAI,CAAC,KAAK,CAAC,WAAW,CAAC;QAC3C,OAAO,CAAC,IAAI,CAAC,QAAQ,EAAE;YACnB,MAAM,GAAG,GAAG,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,GAAG,EAAE,CAAC;YACnC,IAAI,CAAC,GAAG,EAAE;gBACN,MAAM,IAAI,KAAK,CAAC,mBAAmB,CAAC,CAAC;aACxC;YACD,GAAG,CAAC,QAAQ,EAAE,CAAC;SAClB;QACD,IAAI,CAAC,KAAK,CAAC,MAAM,GAAG,SAAS,CAAC;IAClC,CAAC;IAEO,QAAQ;QACZ,IAAI,qBAAa,CAAC,GAAG,EAAE;YACnB,OAAO,CAAC,KAAK,CAAC,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE,cAAc,CAAC,CAAC;SAC1G;IACL,CAAC;IAED,eAAe;QACX,OAAO,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,GAAG,CAAC,OAAO,CAAC,EAAE,CAAC,OAAO,CAAC,KAAK,CAAC,WAAW,CAAC,CAAC;IACtE,CAAC;IAED,cAAc,CAAI,MAAiB,EAAE,QAA2B,EAAE,MAA8B;QAC5F,MAAM,aAAa,GAAG,IAAI,kBAAkB,CAAC,MAAM,CAAC,GAAG,CAAC,QAAQ,EAAE,MAAM,aAAN,MAAM,uBAAN,MAAM,CAAE,OAAO,CAAC,EAAE,MAAM,CAAC,CAAC;QAC5F,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;IAC5C,CAAC;IAED,uBAAuB;QACnB,IAAI,CAAC,oBAAoB,GAAG,IAAI,CAAC;QACjC,IAAI,CAAC,oBAAoB,EAAE,CAAC;IAChC,CAAC;IAED,sBAAsB;QAClB,IAAI,CAAC,oBAAoB,GAAG,KAAK,CAAC;QAClC,IAAI,CAAC,oBAAoB,EAAE,CAAC;IAChC,CAAC;IAEO,oBAAoB,CAAC,aAAa,GAAG,KAAK;;QAC9C,KAAK,MAAM,OAAO,IAAI,IAAI,CAAC,cAAc,EAAE;YACvC,IAAI,IAAI,CAAC,QAAQ,EAAE;gBACf,OAAO,CAAC,QAAQ,EAAE,CAAC;aACtB;iBAAM,IAAI,aAAa,EAAE;gBACtB,OAAO,CAAC,UAAU,EAAE,CAAC;aACxB;iBAAM,IAAI,OAAO,CAAC,SAAS,KAAK,IAAI,EAAE;gBACnC,OAAO,CAAC,QAAQ,EAAE,CAAC;aACtB;iBAAM,IAAI,CAAC,CAAC,CAAC,OAAO,CAAC,SAAS,CAAC,EAAE;gBAG9B,IAAI,OAAO,CAAC,SAAS,CAAC,OAAO,CAAC,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC,EAAE;oBACvE,OAAO,CAAC,QAAQ,EAAE,CAAC;iBACtB;qBAAM;oBACH,OAAO,CAAC,UAAU,EAAE,CAAC;iBACxB;aACJ;iBAAM;gBACH,OAAO,CAAC,UAAU,EAAE,CAAC;aACxB;SACJ;QACD,aAAa,GAAG,aAAa,IAAI,IAAI,CAAC,oBAAoB,CAAC;QAC3D,MAAA,IAAI,CAAC,MAAM,0CAAE,oBAAoB,CAAC,aAAa,CAAC,CAAC;IACrD,CAAC;IAEO,oBAAoB;QACxB,KAAK,MAAM,aAAa,IAAI,IAAI,CAAC,cAAc,EAAE;YAC7C,aAAa,CAAC,MAAM,EAAE,CAAC;SAC1B;IACL,CAAC;IAEO,eAAe;QACnB,MAAM,QAAQ,GAAG,2BAAmB,CAAC,GAAG,CAAC,IAAI,CAAC,KAAK,CAAC,WAAW,CAAC,CAAC;QACjE,IAAI,CAAC,QAAQ;YAAE,OAAO;QAEtB,KAAK,MAAM,CAAC,KAAK,EAAE,EAAE,EAAE,OAAO,CAAC,IAAI,QAAQ,EAAE;YACzC,MAAM,MAAM,GAAG,IAAI,CAAC,QAAQ,CAAC,SAAS,CAAC,EAAE,CAAC,CAAC;YAC3C,MAAM,QAAQ,GAAS,IAAI,CAAC,KAAM,CAAE,KAAK,CAAC,CAAC;YAC3C,IAAI,CAAC,cAAc,CAAC,MAAM,EAAE,QAAQ,kCAAM,OAAO,KAAE,OAAO,EAAE,IAAI,CAAC,KAAK,IAAE,CAAC;SAC5E;IACL,CAAC;IAEO,iBAAiB,CAAC,YAAoB;QAC1C,MAAM,QAAQ,GAAG,4BAAc,CAAC,GAAG,CAAC,YAAY,CAAC,WAAW,CAAC,CAAC;QAC9D,IAAI,CAAC,QAAQ;YAAE,OAAO;QAEtB,KAAK,MAAM,CAAC,KAAK,EAAE,EAAE,CAAC,IAAI,QAAQ,EAAE;YAChC,MAAM,MAAM,GAAG,IAAI,CAAC,QAAQ,CAAC,SAAS,CAAC,EAAE,CAAC,CAAC;YAC3C,MAAM,aAAa,GAAG,MAAM,CAAC,GAAG,CAAO,YAAa,CAAE,KAAK,CAAC,EAAE,YAAY,CAAC,CAAC;YAC5E,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;SAC5C;IACL,CAAC;IAEO,qBAAqB;QACzB,KAAK,MAAM,OAAO,IAAI,IAAI,CAAC,eAAe,EAAE;YACxC,OAAO,CAAC,MAAM,EAAE,CAAC;SACpB;QACD,IAAI,CAAC,eAAe,GAAG,EAAE,CAAC;IAC9B,CAAC;IAEO,QAAQ;;QAGZ,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE;YACd,MAAM,IAAI,KAAK,CAAC,0BAA0B,CAAC,CAAC;SAC/C;QACD,IAAI,CAAC,QAAQ,EAAE,CAAC;QAChB,IAAI,CAAC,oBAAoB,EAAE,CAAC;QAC5B,IAAI,CAAC,qBAAqB,EAAE,CAAC;QAC7B,MAAA,MAAA,IAAI,CAAC,KAAK,EAAC,YAAY,kDAAI,CAAC;QAC5B,MAAA,MAAA,IAAI,CAAC,KAAK,EAAC,MAAM,kDAAI,CAAC;QACtB,IAAI,CAAC,MAAM,CAAC,oBAAoB,EAAE,CAAC;QACnC,MAAA,MAAA,IAAI,CAAC,MAAM,CAAC,KAAK,EAAC,WAAW,kDAAI,CAAC;QAClC,MAAA,MAAA,IAAI,CAAC,MAAM,CAAC,KAAK,EAAC,UAAU,kDAAI,CAAC;QACjC,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC;IACvB,CAAC;CACJ;AA5OD,oCA4OC"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { System } from './types';
|
|
2
|
+
import { Signal, SignalCallback } from './index';
|
|
3
|
+
export declare class SystemContext<T extends System = System> {
|
|
4
|
+
readonly entity: Object;
|
|
5
|
+
readonly system: T;
|
|
6
|
+
private signalBindings;
|
|
7
|
+
constructor(entity: Object);
|
|
8
|
+
addSignalById<S>(signalId: string | symbol, callback: SignalCallback<S>, thisArg?: unknown): void;
|
|
9
|
+
addSignal<S>(signal: Signal<S>, callback: SignalCallback<S>, thisArg?: unknown): void;
|
|
10
|
+
addSignalOnce<S>(signal: Signal<S>, callback: SignalCallback<S>, thisArg?: unknown): void;
|
|
11
|
+
dispose(): void;
|
|
12
|
+
}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.SystemContext = void 0;
|
|
4
|
+
class SystemContext {
|
|
5
|
+
constructor(entity) {
|
|
6
|
+
this.entity = entity;
|
|
7
|
+
this.signalBindings = [];
|
|
8
|
+
}
|
|
9
|
+
addSignalById(signalId, callback, thisArg) {
|
|
10
|
+
this.signalBindings.push(this.entity.gameEngine.getSignal(signalId).add(callback, thisArg));
|
|
11
|
+
}
|
|
12
|
+
addSignal(signal, callback, thisArg) {
|
|
13
|
+
this.signalBindings.push(signal.add(callback, thisArg));
|
|
14
|
+
}
|
|
15
|
+
addSignalOnce(signal, callback, thisArg) {
|
|
16
|
+
this.signalBindings.push(signal.addOnce(callback, thisArg));
|
|
17
|
+
}
|
|
18
|
+
dispose() {
|
|
19
|
+
for (const binding of this.signalBindings)
|
|
20
|
+
binding.detach();
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
exports.SystemContext = SystemContext;
|
|
24
|
+
//# sourceMappingURL=systemContext.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"systemContext.js","sourceRoot":"","sources":["../src/systemContext.ts"],"names":[],"mappings":";;;AAGA,MAAa,aAAa;IAItB,YAAqB,MAAc;QAAd,WAAM,GAAN,MAAM,CAAQ;QAF3B,mBAAc,GAAoB,EAAE,CAAC;IAG7C,CAAC;IAGD,aAAa,CAAI,QAAyB,EAAE,QAA2B,EAAE,OAAiB;QACtF,IAAI,CAAC,cAAc,CAAC,IAAI,CAAG,IAAI,CAAC,MAAc,CAAC,UAAyB,CAAC,SAAS,CAAI,QAAQ,CAAC,CAAC,GAAG,CAAC,QAAQ,EAAE,OAAO,CAAC,CAAC,CAAC;IAC5H,CAAC;IAED,SAAS,CAAI,MAAiB,EAAE,QAA2B,EAAE,OAAiB;QAC1E,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,QAAQ,EAAE,OAAO,CAAC,CAAC,CAAC;IAC5D,CAAC;IAED,aAAa,CAAI,MAAiB,EAAE,QAA2B,EAAE,OAAiB;QAC9E,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,QAAQ,EAAE,OAAO,CAAC,CAAC,CAAC;IAChE,CAAC;IAED,OAAO;QACH,KAAK,MAAM,OAAO,IAAI,IAAI,CAAC,cAAc;YAAE,OAAO,CAAC,MAAM,EAAE,CAAC;IAChE,CAAC;CACJ;AAvBD,sCAuBC"}
|
package/lib/types.d.ts
CHANGED
|
@@ -1,32 +1,33 @@
|
|
|
1
1
|
import { GameEngine } from './gameEngine';
|
|
2
|
-
export interface
|
|
2
|
+
export interface System {
|
|
3
3
|
[propName: string]: any;
|
|
4
4
|
onPrepare?(): Promise<void>;
|
|
5
5
|
onStart?(): void;
|
|
6
6
|
onEnd?(): void;
|
|
7
|
-
onPreFixedUpdate?(): void;
|
|
8
|
-
onEarlyUpdate?(time: number, deltaTime: number): void;
|
|
7
|
+
onPreFixedUpdate?(time: number, deltaTime: number): void;
|
|
9
8
|
onFixedUpdate?(time: number, deltaTime: number): void;
|
|
10
|
-
onPrePhysicUpdate?(time: number, deltaTime: number): void;
|
|
11
9
|
onPhysicsUpdate?(time: number, deltaTime: number): void;
|
|
12
10
|
onUpdate?(time: number, deltaTime: number, alpha: number): void;
|
|
13
11
|
onLateUpdate?(time: number, deltaTime: number, alpha: number): void;
|
|
12
|
+
onPrePhysicsUpdate?(time: number, deltaTime: number): void;
|
|
14
13
|
onPostPhysicsUpdate?(time: number, deltaTime: number): void;
|
|
15
|
-
|
|
14
|
+
onLateFixedUpdate?(time: number, deltaTime: number): void;
|
|
15
|
+
onRender?(time: number, deltaTime: number, alpha: number): void;
|
|
16
16
|
}
|
|
17
|
-
export interface
|
|
17
|
+
export interface Service {
|
|
18
18
|
[propName: string]: any;
|
|
19
19
|
onPrepare?(): Promise<void>;
|
|
20
20
|
onStart?(): void;
|
|
21
21
|
onEnd?(): void;
|
|
22
|
-
onPreFixedUpdate?(): void;
|
|
22
|
+
onPreFixedUpdate?(time: number, deltaTime: number): void;
|
|
23
23
|
onPostPhysicsUpdate?(time: number, deltaTime: number): void;
|
|
24
|
+
onLateFixedUpdate?(time: number, deltaTime: number): void;
|
|
24
25
|
onFixedUpdate?(time: number, deltaTime: number): void;
|
|
25
|
-
onPrePhysicUpdate?(time: number, deltaTime: number): void;
|
|
26
26
|
onPhysicsUpdate?(time: number, deltaTime: number): void;
|
|
27
|
+
onPrePhysicsUpdate?(time: number, deltaTime: number): void;
|
|
27
28
|
onUpdate?(time: number, deltaTime: number, alpha: number): void;
|
|
28
29
|
onLateUpdate?(time: number, deltaTime: number, alpha: number): void;
|
|
29
|
-
onRender?(): void;
|
|
30
|
+
onRender?(time: number, deltaTime: number, alpha: number): void;
|
|
30
31
|
}
|
|
31
32
|
declare type GameEngineCallback = (gameEngine: GameEngine) => void;
|
|
32
33
|
export interface GameEnginePlugin {
|
|
@@ -46,9 +47,27 @@ export declare type OnFixedUpdateParams = {
|
|
|
46
47
|
time: number;
|
|
47
48
|
deltaTime: number;
|
|
48
49
|
};
|
|
50
|
+
export declare type OnEarlyUpdateParams = {
|
|
51
|
+
time: number;
|
|
52
|
+
deltaTime: number;
|
|
53
|
+
};
|
|
49
54
|
export declare type AsyncAction<T = unknown> = (gameEngine: GameEngine) => Promise<T>;
|
|
50
55
|
export declare type Action<T = any> = (gameEngine: GameEngine) => T;
|
|
51
56
|
export declare type Class<T = any> = {
|
|
52
57
|
new (...args: any[]): T;
|
|
53
58
|
};
|
|
59
|
+
export declare const EngineSignals: {
|
|
60
|
+
OnStart: symbol;
|
|
61
|
+
OnEnd: symbol;
|
|
62
|
+
OnUpdate: symbol;
|
|
63
|
+
OnLateUpdate: symbol;
|
|
64
|
+
OnFixedUpdate: symbol;
|
|
65
|
+
OnPreFixedUpdate: symbol;
|
|
66
|
+
OnPrePhysicsUpdate: symbol;
|
|
67
|
+
OnPhysicsUpdate: symbol;
|
|
68
|
+
OnPostPhysicsUpdate: symbol;
|
|
69
|
+
onLateFixedUpdate: symbol;
|
|
70
|
+
OnRender: symbol;
|
|
71
|
+
OnPrepare: symbol;
|
|
72
|
+
};
|
|
54
73
|
export {};
|
package/lib/types.js
CHANGED
|
@@ -1 +1,18 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.EngineSignals = void 0;
|
|
4
|
+
exports.EngineSignals = {
|
|
5
|
+
OnStart: Symbol('OnStart'),
|
|
6
|
+
OnEnd: Symbol('OnEnd'),
|
|
7
|
+
OnUpdate: Symbol('OnUpdate'),
|
|
8
|
+
OnLateUpdate: Symbol('OnLateUpdate'),
|
|
9
|
+
OnFixedUpdate: Symbol('OnFixedUpdate'),
|
|
10
|
+
OnPreFixedUpdate: Symbol('OnPreFixedUpdate'),
|
|
11
|
+
OnPrePhysicsUpdate: Symbol('OnPrePhysicsUpdate'),
|
|
12
|
+
OnPhysicsUpdate: Symbol('OnPhysicsUpdate'),
|
|
13
|
+
OnPostPhysicsUpdate: Symbol('OnPostPhysicsUpdate'),
|
|
14
|
+
onLateFixedUpdate: Symbol('onLateFixedUpdate'),
|
|
15
|
+
OnRender: Symbol('OnRender'),
|
|
16
|
+
OnPrepare: Symbol('OnPrepare'),
|
|
17
|
+
};
|
|
1
18
|
//# sourceMappingURL=types.js.map
|
package/lib/types.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"types.js","sourceRoot":"","sources":["../src/types.ts"],"names":[],"mappings":""}
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../src/types.ts"],"names":[],"mappings":";;;AAyEa,QAAA,aAAa,GAAG;IACzB,OAAO,EAAE,MAAM,CAAC,SAAS,CAAC;IAC1B,KAAK,EAAE,MAAM,CAAC,OAAO,CAAC;IACtB,QAAQ,EAAE,MAAM,CAAC,UAAU,CAAC;IAC5B,YAAY,EAAE,MAAM,CAAC,cAAc,CAAC;IACpC,aAAa,EAAE,MAAM,CAAC,eAAe,CAAC;IACtC,gBAAgB,EAAE,MAAM,CAAC,kBAAkB,CAAC;IAC5C,kBAAkB,EAAE,MAAM,CAAC,oBAAoB,CAAC;IAChD,eAAe,EAAE,MAAM,CAAC,iBAAiB,CAAC;IAC1C,mBAAmB,EAAE,MAAM,CAAC,qBAAqB,CAAC;IAClD,iBAAiB,EAAE,MAAM,CAAC,mBAAmB,CAAC;IAC9C,QAAQ,EAAE,MAAM,CAAC,UAAU,CAAC;IAC5B,SAAS,EAAE,MAAM,CAAC,WAAW,CAAC;CACjC,CAAC"}
|
package/lib/utils/map2k.js
CHANGED
|
@@ -1,4 +1,7 @@
|
|
|
1
|
-
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.Map2k = void 0;
|
|
4
|
+
class Map2k {
|
|
2
5
|
constructor() {
|
|
3
6
|
this.map = new Map();
|
|
4
7
|
}
|
|
@@ -37,4 +40,5 @@ export class Map2k {
|
|
|
37
40
|
}
|
|
38
41
|
}
|
|
39
42
|
}
|
|
43
|
+
exports.Map2k = Map2k;
|
|
40
44
|
//# sourceMappingURL=map2k.js.map
|
package/lib/utils/map2k.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"map2k.js","sourceRoot":"","sources":["../../src/utils/map2k.ts"],"names":[],"mappings":"AAAA,
|
|
1
|
+
{"version":3,"file":"map2k.js","sourceRoot":"","sources":["../../src/utils/map2k.ts"],"names":[],"mappings":";;;AAAA,MAAa,KAAK;IAAlB;QACI,QAAG,GAAG,IAAI,GAAG,EAAgB,CAAC;IAkDlC,CAAC;IAhDG,GAAG,CAAC,IAAO,EAAE,IAAO,EAAE,KAAQ;QAC1B,IAAI,KAAK,GAAG,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;QAC/B,IAAG,CAAC,KAAK,EAAE;YACP,KAAK,GAAG,IAAI,GAAG,EAAQ,CAAC;YACxB,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC;SAC7B;QACD,IAAI,MAAM,GAAG,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;QAChC,IAAG,CAAC,MAAM,EAAE;YACR,MAAM,GAAG,IAAI,GAAG,EAAQ,CAAC;YACzB,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,IAAI,EAAE,MAAM,CAAC,CAAC;SAC9B;QACD,KAAK,CAAC,GAAG,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC;QACvB,MAAM,CAAC,GAAG,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC;IAC5B,CAAC;IAaD,GAAG,CAAC,IAAO,EAAE,IAAO;QAChB,MAAM,KAAK,GAAG,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;QACjC,OAAO,KAAK,IAAI,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;IACpC,CAAC;IAED,MAAM,CAAC,IAAM,EAAE,IAAM;QACjB,IAAI,KAAK,GAAG,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;QAC/B,IAAI,KAAK,EAAE;YACP,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;YACnB,IAAI,KAAK,CAAC,IAAI,KAAK,CAAC,EAAE;gBAClB,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,IAAI,CAAC,CAAA;aACxB;SACJ;QACD,IAAI,MAAM,GAAG,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;QAChC,IAAI,MAAM,EAAE;YACR,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;YACpB,IAAI,MAAM,CAAC,IAAI,KAAK,CAAC,EAAE;gBACnB,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,IAAI,CAAC,CAAA;aACxB;SACJ;IACL,CAAC;CAEJ;AAnDD,sBAmDC"}
|
package/package.json
CHANGED
|
@@ -1,17 +1,17 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "mani-game-engine",
|
|
3
3
|
"author": "Jan Mankopf",
|
|
4
|
-
"version": "1.0.0-pre.
|
|
4
|
+
"version": "1.0.0-pre.30",
|
|
5
5
|
"description": "entity component system game engine for typescript",
|
|
6
6
|
"private": false,
|
|
7
7
|
"scripts": {
|
|
8
8
|
"build": "rimraf lib && tsc",
|
|
9
|
-
"watch": "
|
|
9
|
+
"watch": "tsc -w",
|
|
10
10
|
"test": "jest",
|
|
11
11
|
"test watch": "jest --watch",
|
|
12
12
|
"do-pre-publish": "npm publish --dry-run",
|
|
13
|
-
"
|
|
14
|
-
"
|
|
13
|
+
"version-up": "npm version prerelease",
|
|
14
|
+
"do-publish": "npm publish"
|
|
15
15
|
},
|
|
16
16
|
"main": "lib/index.js",
|
|
17
17
|
"files": [
|
|
@@ -21,25 +21,19 @@
|
|
|
21
21
|
"typings": "lib/index.d.ts",
|
|
22
22
|
"license": "MIT",
|
|
23
23
|
"devDependencies": {
|
|
24
|
-
"@fluffy-spoon/substitute": "^1.
|
|
25
|
-
"@types/jest": "^
|
|
26
|
-
"
|
|
27
|
-
"jasmine-core": "^3.4.0",
|
|
28
|
-
"jest": "^24.8.0",
|
|
29
|
-
"mani-signal": "^1.0.3",
|
|
30
|
-
"mocha": "^6.1.4",
|
|
31
|
-
"nyc": "^14.1.1",
|
|
24
|
+
"@fluffy-spoon/substitute": "^1.201.0",
|
|
25
|
+
"@types/jest": "^26.0.22",
|
|
26
|
+
"jest": "^26.6.3",
|
|
32
27
|
"reflect-metadata": "^0.1.13",
|
|
33
|
-
"rimraf": "^
|
|
34
|
-
"ts-jest": "^
|
|
35
|
-
"ts-node": "^
|
|
36
|
-
"
|
|
28
|
+
"rimraf": "^3.0.2",
|
|
29
|
+
"ts-jest": "^26.5.4",
|
|
30
|
+
"ts-node": "^9.1.1",
|
|
31
|
+
"tslib": "^2.2.0",
|
|
32
|
+
"typescript": "^4.2.4",
|
|
33
|
+
"mani-signal": "1.x"
|
|
37
34
|
},
|
|
38
35
|
"peerDependencies": {
|
|
39
|
-
"
|
|
40
|
-
"
|
|
41
|
-
},
|
|
42
|
-
"dependencies": {
|
|
43
|
-
"mani-injector": "^0.0.2"
|
|
36
|
+
"reflect-metadata": "0.x",
|
|
37
|
+
"mani-signal": "1.x"
|
|
44
38
|
}
|
|
45
39
|
}
|
package/src/clock.ts
CHANGED
|
@@ -1,10 +1,9 @@
|
|
|
1
1
|
import {Signal} from 'mani-signal';
|
|
2
|
+
import {OnEarlyUpdateParams, OnFixedUpdateParams, OnUpdateParams} from './types';
|
|
2
3
|
|
|
3
4
|
const MIN_TIME_SCALE = 0.00001;
|
|
4
5
|
|
|
5
|
-
type
|
|
6
|
-
type OnUpdateParams = { time: number, deltaTime: number, alpha: number; };
|
|
7
|
-
type OnFixedUpdateParams = { time: number, deltaTime: number; };
|
|
6
|
+
// type OnUpdateParams = { time: number, deltaTime: number, alpha: number; };
|
|
8
7
|
|
|
9
8
|
const defaultOptions = {
|
|
10
9
|
autoStart: true,
|
|
@@ -13,32 +12,38 @@ const defaultOptions = {
|
|
|
13
12
|
timeScale: 1,
|
|
14
13
|
};
|
|
15
14
|
|
|
15
|
+
export type Timeout = {
|
|
16
|
+
recall?: number;
|
|
17
|
+
callback: Function;
|
|
18
|
+
callTime: number;
|
|
19
|
+
};
|
|
16
20
|
export type GameClockOptions = Partial<typeof defaultOptions>;
|
|
17
21
|
|
|
18
|
-
export
|
|
22
|
+
export interface Clock {
|
|
23
|
+
|
|
24
|
+
onPrepare: Signal<unknown>;
|
|
25
|
+
onEarlyUpdate: Signal<OnEarlyUpdateParams>;
|
|
26
|
+
onUpdate: Signal<OnUpdateParams>;
|
|
27
|
+
onFixedUpdate: Signal<OnFixedUpdateParams>;
|
|
28
|
+
timeScale: number;
|
|
29
|
+
start(): this;
|
|
30
|
+
stop(): this;
|
|
31
|
+
dispose(): void;
|
|
32
|
+
setTimeout(callback: Function, delay: number): number;
|
|
33
|
+
setInterval(callback: Function, delay: number): number;
|
|
34
|
+
clearTimeout(timeoutId: number): boolean;
|
|
35
|
+
}
|
|
36
|
+
|
|
37
|
+
export class GameClock implements Clock {
|
|
38
|
+
private nextTimeoutId = 0;
|
|
39
|
+
private timeouts = new Map<number, Timeout>();
|
|
19
40
|
private isRunning = false;
|
|
20
41
|
private requestId = 0;
|
|
21
42
|
private currentTime = 0;
|
|
22
43
|
private accumulator = 0;
|
|
23
44
|
private gameTime = 0;
|
|
24
45
|
|
|
25
|
-
private
|
|
26
|
-
private maxFrameTime: number;
|
|
27
|
-
|
|
28
|
-
readonly onPrepare = new Signal();
|
|
29
|
-
readonly onEarlyUpdate = new Signal<OnEarlyUpdateParams>();
|
|
30
|
-
readonly onUpdate = new Signal<OnUpdateParams>();
|
|
31
|
-
readonly onFixedUpdate = new Signal<OnFixedUpdateParams>();
|
|
32
|
-
|
|
33
|
-
constructor(options?: GameClockOptions) {
|
|
34
|
-
const opts = {...defaultOptions, ...options} as Required<GameClockOptions>;
|
|
35
|
-
this.fixedDeltaTime = opts.fixedDeltaTime;
|
|
36
|
-
this.maxFrameTime = opts.maxFrameTime;
|
|
37
|
-
this.timeScale = opts.timeScale;
|
|
38
|
-
|
|
39
|
-
opts.autoStart && this.start();
|
|
40
|
-
}
|
|
41
|
-
|
|
46
|
+
private readonly _fixedDeltaTime: number;
|
|
42
47
|
private update = (time: number) => {
|
|
43
48
|
const newTime = time * 0.001;
|
|
44
49
|
if (!this.isRunning) {
|
|
@@ -58,22 +63,59 @@ export class Clock {
|
|
|
58
63
|
|
|
59
64
|
this.onPrepare.dispatch();
|
|
60
65
|
this.onEarlyUpdate.dispatch({time: this.gameTime, deltaTime: frameTime});
|
|
61
|
-
|
|
66
|
+
|
|
67
|
+
for (const [id, timeOut] of this.timeouts) {
|
|
68
|
+
if (this.gameTime >= timeOut.callTime) {
|
|
69
|
+
timeOut.callback();
|
|
70
|
+
if (timeOut.recall) {
|
|
71
|
+
timeOut.callTime += timeOut.recall;
|
|
72
|
+
} else {
|
|
73
|
+
this.timeouts.delete(id);
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
}
|
|
77
|
+
|
|
78
|
+
while (this.accumulator >= this._fixedDeltaTime) {
|
|
62
79
|
if (isMultipleFixedUpdate) {
|
|
63
80
|
this.onPrepare.dispatch();
|
|
64
81
|
}
|
|
65
|
-
this.onFixedUpdate.dispatch({time: this.gameTime, deltaTime: this.
|
|
82
|
+
this.onFixedUpdate.dispatch({time: this.gameTime, deltaTime: this._fixedDeltaTime});
|
|
66
83
|
isMultipleFixedUpdate = true;
|
|
67
|
-
this.accumulator -= this.
|
|
68
|
-
this.gameTime += this.
|
|
84
|
+
this.accumulator -= this._fixedDeltaTime;
|
|
85
|
+
this.gameTime += this._fixedDeltaTime;
|
|
69
86
|
}
|
|
70
|
-
const alpha = this.accumulator / this.
|
|
71
|
-
this.onUpdate.dispatch({time: this.gameTime + alpha * this.
|
|
87
|
+
const alpha = this.accumulator / this._fixedDeltaTime;
|
|
88
|
+
this.onUpdate.dispatch({time: this.gameTime + alpha * this._fixedDeltaTime, deltaTime: frameTime, alpha: alpha});
|
|
72
89
|
if (this.isRunning) {
|
|
73
90
|
this.requestId = requestAnimationFrame(this.update);
|
|
74
91
|
}
|
|
75
92
|
};
|
|
76
93
|
|
|
94
|
+
private readonly maxFrameTime: number;
|
|
95
|
+
|
|
96
|
+
readonly onPrepare = new Signal();
|
|
97
|
+
readonly onEarlyUpdate = new Signal<OnEarlyUpdateParams>();
|
|
98
|
+
readonly onUpdate = new Signal<OnUpdateParams>();
|
|
99
|
+
readonly onFixedUpdate = new Signal<OnFixedUpdateParams>();
|
|
100
|
+
|
|
101
|
+
constructor(options?: GameClockOptions) {
|
|
102
|
+
const opts = {...defaultOptions, ...options} as Required<GameClockOptions>;
|
|
103
|
+
this._fixedDeltaTime = opts.fixedDeltaTime;
|
|
104
|
+
this.maxFrameTime = opts.maxFrameTime;
|
|
105
|
+
this.timeScale = opts.timeScale;
|
|
106
|
+
|
|
107
|
+
opts.autoStart && this.start();
|
|
108
|
+
}
|
|
109
|
+
|
|
110
|
+
dispose(): void {
|
|
111
|
+
this.onPrepare.detachAll();
|
|
112
|
+
this.onEarlyUpdate.detachAll();
|
|
113
|
+
this.onUpdate.detachAll();
|
|
114
|
+
this.onFixedUpdate.detachAll();
|
|
115
|
+
}
|
|
116
|
+
|
|
117
|
+
get fixedDeltaTime(): number { return this._fixedDeltaTime; }
|
|
118
|
+
|
|
77
119
|
private _timeScale = 1;
|
|
78
120
|
|
|
79
121
|
get timeScale(): number {
|
|
@@ -92,11 +134,30 @@ export class Clock {
|
|
|
92
134
|
return this;
|
|
93
135
|
}
|
|
94
136
|
|
|
95
|
-
stop() {
|
|
137
|
+
stop(): this {
|
|
96
138
|
if (!this.isRunning) {
|
|
97
|
-
return;
|
|
139
|
+
return this;
|
|
98
140
|
}
|
|
99
141
|
this.isRunning = false;
|
|
100
142
|
cancelAnimationFrame(this.requestId);
|
|
143
|
+
return this;
|
|
144
|
+
}
|
|
145
|
+
|
|
146
|
+
setTimeout(callback: Function, delay: number) {
|
|
147
|
+
const timeOut: Timeout = {callback, callTime: this.gameTime + delay};
|
|
148
|
+
this.nextTimeoutId++;
|
|
149
|
+
this.timeouts.set(this.nextTimeoutId, timeOut);
|
|
150
|
+
return this.nextTimeoutId;
|
|
151
|
+
}
|
|
152
|
+
|
|
153
|
+
setInterval(callback: Function, delay: number) {
|
|
154
|
+
const timeOut: Timeout = {callback, callTime: this.gameTime + delay, recall: delay};
|
|
155
|
+
this.nextTimeoutId++;
|
|
156
|
+
this.timeouts.set(this.nextTimeoutId, timeOut);
|
|
157
|
+
return this.nextTimeoutId;
|
|
158
|
+
}
|
|
159
|
+
|
|
160
|
+
clearTimeout(timeoutId: number) {
|
|
161
|
+
return this.timeouts.delete(timeoutId);
|
|
101
162
|
}
|
|
102
163
|
}
|