-
Notifications
You must be signed in to change notification settings - Fork 0
/
runtimebehavior.js
136 lines (115 loc) · 3.75 KB
/
runtimebehavior.js
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
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
/*
* GDevelop JS Platform
* Copyright 2013-2016 Florian Rival ([email protected]). All rights reserved.
* This project is released under the MIT License.
*/
/**
* RuntimeBehavior represents a behavior being used by a RuntimeObject.
*
* @class RuntimeBehavior
* @memberof gdjs
* @param {gdjs.RuntimeScene} runtimeScene The scene owning the object of the behavior
* @param {Object} behaviorData The object used to setup the behavior
* @param {gdjs.RuntimeObject} owner The object owning the behavior
*/
gdjs.RuntimeBehavior = function(runtimeScene, behaviorData, owner)
{
this.name = behaviorData.name || "";
this.type = behaviorData.type || "";
this._nameId = gdjs.RuntimeObject.getNameIdentifier(this.name);
this._activated = true;
this.owner = owner;
};
/**
* Get the name of the behavior.
* @return {string} The behavior's name.
*/
gdjs.RuntimeBehavior.prototype.getName = function() {
return this.name;
};
/**
* Get the name identifier of the behavior.
* @return {number} The behavior's name identifier.
*/
gdjs.RuntimeBehavior.prototype.getNameId = function() {
return this._nameId;
};
/**
* Called at each frame before events. Call doStepPreEvents.<br>
* Behaviors writers: Please do not redefine this method. Redefine doStepPreEvents instead.
* @param {gdjs.RuntimeScene} runtimeScene The runtimeScene owning the object
*/
gdjs.RuntimeBehavior.prototype.stepPreEvents = function(runtimeScene) {
if ( this._activated ) {
var profiler = runtimeScene.getProfiler();
if (profiler) profiler.begin(this.name);
this.doStepPreEvents(runtimeScene);
if (profiler) profiler.end(this.name);
}
};
/**
* Called at each frame after events. Call doStepPostEvents.<br>
* Behaviors writers: Please do not redefine this method. Redefine doStepPreEvents instead.
* @param {gdjs.RuntimeScene} runtimeScene The runtimeScene owning the object
*/
gdjs.RuntimeBehavior.prototype.stepPostEvents = function(runtimeScene) {
if ( this._activated ) {
var profiler = runtimeScene.getProfiler();
if (profiler) profiler.begin(this.name);
this.doStepPostEvents(runtimeScene);
if (profiler) profiler.end(this.name);
}
};
/**
* De/Activate the behavior
* @param {boolean} enable true to enable the behavior, false to disable it
*/
gdjs.RuntimeBehavior.prototype.activate = function(enable) {
if ( enable === undefined ) enable = true;
if ( !this._activated && enable ) {
this._activated = true;
this.onActivate();
}
else if ( this._activated && !enable ) {
this._activated = false;
this.onDeActivate();
}
};
/**
* Return true if the behavior is activated
*/
gdjs.RuntimeBehavior.prototype.activated = function() {
return this._activated;
};
/**
* Behaviors writers: Reimplement this method to do extra work
* when the behavior is activated
*/
gdjs.RuntimeBehavior.prototype.onActivate = function() {
};
/**
* Behaviors writers: Reimplement this method to do extra work
* when the behavior is deactivated
*/
gdjs.RuntimeBehavior.prototype.onDeActivate = function() {
};
/**
* Behaviors writers: This method is called each tick before events are done.
* @param {gdjs.RuntimeScene} runtimeScene The runtimeScene owning the object
*/
gdjs.RuntimeBehavior.prototype.doStepPreEvents = function(runtimeScene) {
};
/**
* Behaviors writers: This method is called each tick after events are done.
* @param {gdjs.RuntimeScene} runtimeScene The runtimeScene owning the object
*/
gdjs.RuntimeBehavior.prototype.doStepPostEvents = function(runtimeScene) {
}
/**
* Behaviors writers: This method is called when the owner of the behavior
* is removed from its scene.
*/
gdjs.RuntimeBehavior.prototype.ownerRemovedFromScene = function() {
}
//Notify gdjs this.the runtimeBehavior exists.
gdjs.RuntimeBehavior.thisIsARuntimeBehaviorConstructor = "";