-
Notifications
You must be signed in to change notification settings - Fork 918
/
Copy pathdummyruntimebehavior.ts
57 lines (47 loc) · 1.78 KB
/
dummyruntimebehavior.ts
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
namespace gdjs {
const logger = new gdjs.Logger('Dummy behavior');
/**
* The DummyRuntimeBehavior changes a variable in the object that is owning
* it, at every tick before events are run, to set it to the string that was
* set in one of the behavior property.
* @ignore
*/
export class DummyRuntimeBehavior extends gdjs.RuntimeBehavior {
_textToSet: string;
constructor(
instanceContainer: gdjs.RuntimeInstanceContainer,
behaviorData: any,
owner: gdjs.RuntimeObject
) {
super(instanceContainer, behaviorData, owner);
// Here you can access to the behavior data (JSON declared in JsExtension.js)
// using behaviorData:
this._textToSet = behaviorData.property1;
// You can also run arbitrary code at the creation of the behavior:
logger.log('DummyRuntimeBehavior was created for object:', owner);
}
updateFromBehaviorData(oldBehaviorData, newBehaviorData): boolean {
if (oldBehaviorData.property1 !== newBehaviorData.property1) {
this._textToSet = newBehaviorData.property1;
}
// Return true to specify that the new behavior data have been applied
// (false if you can't do it, which will disable hot-reload for the behavior).
return true;
}
onDeActivate() {}
doStepPreEvents(instanceContainer: gdjs.RuntimeInstanceContainer) {
// This is run at every frame, before events are launched.
this.owner
.getVariables()
.get('VariableSetFromBehavior')
.setString(this._textToSet);
}
doStepPostEvents(instanceContainer: gdjs.RuntimeInstanceContainer) {
// This is run at every frame, after events are launched.
}
}
gdjs.registerBehavior(
'MyDummyExtension::DummyBehavior',
gdjs.DummyRuntimeBehavior
);
}