Subversion Repository Public Repository

Nextrek

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
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
var ObjectManager;

ObjectManager = (function() {

  /**
  * Stores the current default ObjectManager.
  * @property current
  * @type gs.ObjectManager
  * @static
   */
  ObjectManager.current = null;


  /**
  * Manages game objects by updating if necessary and offering
  * methods to add or remove game objects. All game objects are sorted by
  * the order-property to give control over the update-order.
  *
  * A game object can registered under a unique ID and then easily accessed using
  * that ID. If an object gets registered, a global variable $<ID> is created
  * as well. However, that global variable is only for the use in property-bindings
  * used for In-Game UI. See ui.Component_BindingHandler.
  *
  * In addition, a game object can be assigned to a group like for example
  * a set of UI toggle-buttons can be assigned to the same group and then
  * easily accessed later using gs.ObjectManager.objectsByGroup method.
  *
  * @module gs
  * @class ObjectManager
  * @memberof gs
  * @constructor
  * @see ui.Component_BindingHandler
   */

  function ObjectManager() {

    /**
    * All game objects to manage.
    * @property objects
    * @type gs.Object_Base[]
     */
    this.objects = [];

    /**
    * All game objects by ID.
    * @property objectsById
    * @type Object
     */
    this.objectsById = {};

    /**
    * All game objects by group.
    * @property objectsByGroup_
    * @type Object
     */
    this.objectsByGroup_ = {};

    /**
    * Indicates if the ObjectManager is active. If <b>false</b> the game objects are not updated.
    * @property active
    * @type boolean
     */
    this.active = true;

    /**
    * Indicates if the ObjectManager needs to sort the game objects.
    * @property active
    * @type boolean
     */
    this.needsSort = true;
  }


  /**
  * Disposes the manager and all assigned game objects.
  *
  * @method dispose
   */

  ObjectManager.prototype.dispose = function() {
    var j, len, object, ref, results;
    ref = this.objects;
    results = [];
    for (j = 0, len = ref.length; j < len; j++) {
      object = ref[j];
      if (!object.disposed) {
        results.push(object.dispose());
      } else {
        results.push(void 0);
      }
    }
    return results;
  };


  /**
  * Disposes all assigned game objects.
  *
  * @method disposeObjects
   */

  ObjectManager.prototype.disposeObjects = function() {
    var j, k, keys, len, object, results;
    keys = Object.keys(this.objectsById);
    results = [];
    for (j = 0, len = keys.length; j < len; j++) {
      k = keys[j];
      object = this.objectsById[k];
      if (object && !object.disposed) {
        results.push(object.dispose());
      } else {
        results.push(void 0);
      }
    }
    return results;
  };


  /**
  * Registers an object.
  *
  * @method registerObject
   */

  ObjectManager.prototype.registerObject = function(object) {
    if (object.id != null) {
      if (!this.objectsById[object.id]) {
        this.objectsById[object.id] = [];
      }
      this.objectsById[object.id].push(object);
      return window["$" + object.id] = object;
    }
  };


  /**
  * Unregisters an object.
  *
  * @method unregisterObject
   */

  ObjectManager.prototype.unregisterObject = function(object) {
    var objects;
    if ((object != null ? object.id : void 0) != null) {
      objects = this.objectsById[object.id];
      if (objects) {
        objects.remove(object);
        if (objects.length > 0) {
          window["$" + object.id] = objects.last();
        } else {
          delete window["$" + object.id];
        }
      }
    }
    return null;
  };


  /**
  * Adds a game object to the manager. The game object is then automatically updated by the manager.
  *
  * @method addObject
  * @param {gs.Object_Base} object - The game object to add.
   */

  ObjectManager.prototype.addObject = function(object) {
    return this.add(object);
  };


  /**
  * Removes a game object to the manager. The game object is then no longer automatically updated or disposed by the manager.
  *
  * @method removeObject
  * @param {gs.Object_Base} object - The game object to remove.
   */

  ObjectManager.prototype.removeObject = function(object) {
    return this.remove(object);
  };


  /**
  * Adds a game object to the manager. The game object is then automatically updated by the manager.
  *
  * @method add
  * @param {gs.Object_Base} object - The game object to add.
   */

  ObjectManager.prototype.add = function(object) {
    this.objects.push(object);
    this.needsSort = true;
    this.registerObject(object);
    return this.addToGroup(object, object.group);
  };


  /**
  * Removes a game object to the manager. The game object is then no longer automatically updated or disposed by the manager.
  *
  * @method remove
  * @param {gs.Object_Base} object - The game object to remove.
   */

  ObjectManager.prototype.remove = function(object) {
    var ref;
    if (object) {
      this.objects.remove(object);
      this.unregisterObject(object);
      if (object.group != null) {
        return (ref = this.objectsByGroup[object.group]) != null ? ref.remove(object) : void 0;
      }
    }
  };


  /**
  * Gets an object by ID.
  *
  * @method objectById
  * @param {String} id - The ID of the game object to get. 
  * @return {gs.Object_Base} The game object or <b>null</b> if no game object is registered for the specified ID.
   */

  ObjectManager.prototype.objectById = function(id) {
    var ref;
    return (ref = this.objectsById[id]) != null ? ref.last() : void 0;
  };


  /**
  * Gets an object by ID.
  *
  * @method byId
  * @param {String} id - The ID of the game object to get. 
  * @return {gs.Object_Base} The game object or <b>null</b> if no game object is registered for the specified ID.
   */

  ObjectManager.prototype.byId = function(id) {
    var ref;
    return (ref = this.objectsById[id]) != null ? ref.last() : void 0;
  };


  /**
  * Sets the object for an ID.
  *
  * @method setObjectById
  * @param {gs.Object_Base} object - The game object to set.
  * @param {String} id - The ID for the game object.
   */

  ObjectManager.prototype.setObjectById = function(object, id) {
    object.id = id;
    if (!this.objectsById[id]) {
      this.objectsById[id] = [object];
    } else {
      this.objectsById[id].push(object);
    }
    return window["$" + id] = object;
  };


  /**
  * Adds an object to a specified object-group.
  *
  * @method addToGroup
  * @param {gs.Object_Base} object - The game object to add.
  * @param {String} group - The group to assign game object to.
   */

  ObjectManager.prototype.addToGroup = function(object, group) {
    var ref;
    if (group != null) {
      if ((ref = this.objectsByGroup_[object.group]) != null) {
        ref.remove(object);
      }
      if (!this.objectsByGroup_[group]) {
        this.objectsByGroup_[group] = [];
      }
      return this.objectsByGroup_[group].push(object);
    }
  };


  /**
  * Gets all object of a specified object-group.
  *
  * @method objectsByGroup
  * @param {String} group - The object-group.
  * @return {gs.Object_Base[]} The game objects belonging to the specified group.
   */

  ObjectManager.prototype.objectsByGroup = function(group) {
    return this.objectsByGroup_[group] || [];
  };


  /**
  * Updates the manager and all assigned game objects in the right order.
  *
  * @method update
   */

  ObjectManager.prototype.update = function() {
    var i, object;
    i = 0;
    if (this.needsSort) {
      this.objects.sort(function(a, b) {
        if (a.order < b.order) {
          return 1;
        } else if (a.order > b.order) {
          return -1;
        } else {
          return 0;
        }
      });
      this.needsSort = false;
    }
    while (i < this.objects.length) {
      object = this.objects[i];
      if (object.disposed) {
        this.removeObject(object);
      } else {
        if (object.active) {
          object.update();
        }
        i++;
      }
    }
    return null;
  };

  return ObjectManager;

})();

gs.ObjectManager = ObjectManager;

//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"","sourceRoot":"","sources":[""],"names":[],"mappings":"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","sourcesContent":["# ===================================================================\n#\n#   Script: ObjectManager\n#\n#   $$COPYRIGHT$$\n#\n# ===================================================================\nclass ObjectManager\n    ###*\n    * Stores the current default ObjectManager.\n    * @property current\n    * @type gs.ObjectManager\n    * @static\n    ### \n    @current: null\n    \n    ###*\n    * Manages game objects by updating if necessary and offering\n    * methods to add or remove game objects. All game objects are sorted by\n    * the order-property to give control over the update-order.\n    *\n    * A game object can registered under a unique ID and then easily accessed using\n    * that ID. If an object gets registered, a global variable $<ID> is created\n    * as well. However, that global variable is only for the use in property-bindings\n    * used for In-Game UI. See ui.Component_BindingHandler.\n    *\n    * In addition, a game object can be assigned to a group like for example\n    * a set of UI toggle-buttons can be assigned to the same group and then\n    * easily accessed later using gs.ObjectManager.objectsByGroup method.\n    *\n    * @module gs\n    * @class ObjectManager\n    * @memberof gs\n    * @constructor\n    * @see ui.Component_BindingHandler\n    ###\n    constructor: ->\n        ###*\n        * All game objects to manage.\n        * @property objects\n        * @type gs.Object_Base[]\n        ### \n        @objects = []\n        \n        ###*\n        * All game objects by ID.\n        * @property objectsById\n        * @type Object\n        ### \n        @objectsById = {}\n        \n        ###*\n        * All game objects by group.\n        * @property objectsByGroup_\n        * @type Object\n        ### \n        @objectsByGroup_ = {}\n        \n        ###*\n        * Indicates if the ObjectManager is active. If <b>false</b> the game objects are not updated.\n        * @property active\n        * @type boolean\n        ### \n        @active = yes\n        \n        ###*\n        * Indicates if the ObjectManager needs to sort the game objects.\n        * @property active\n        * @type boolean\n        ### \n        @needsSort = yes\n        \n    ###*\n    * Disposes the manager and all assigned game objects.\n    *\n    * @method dispose\n    ###\n    dispose: ->\n        for object in @objects\n            if not object.disposed\n                object.dispose()\n     \n    ###*\n    * Disposes all assigned game objects.\n    *\n    * @method disposeObjects\n    ###           \n    disposeObjects: ->\n        keys = Object.keys(@objectsById)\n        for k in keys\n            object = @objectsById[k]\n            if object and not object.disposed\n                object.dispose()\n    \n    ###*\n    * Registers an object.\n    *\n    * @method registerObject\n    ###\n    registerObject: (object) ->\n        if object.id?\n            if !@objectsById[object.id]\n                @objectsById[object.id] = []\n            @objectsById[object.id].push(object)\n            # FIXME: Should be handled by UiManager since it is UI specific.\n            window[\"$\"+object.id] = object\n    \n    ###*\n    * Unregisters an object.\n    *\n    * @method unregisterObject\n    ###        \n    unregisterObject: (object) ->\n        if object?.id?\n            objects = @objectsById[object.id]\n            if objects\n                objects.remove(object)\n                if objects.length > 0\n                    window[\"$\"+object.id] = objects.last()\n                else\n                    delete window[\"$\"+object.id]\n        return null\n    \n    ###*\n    * Adds a game object to the manager. The game object is then automatically updated by the manager.\n    *\n    * @method addObject\n    * @param {gs.Object_Base} object - The game object to add.\n    ###        \n    addObject: (object) -> @add(object)\n    \n    ###*\n    * Removes a game object to the manager. The game object is then no longer automatically updated or disposed by the manager.\n    *\n    * @method removeObject\n    * @param {gs.Object_Base} object - The game object to remove.\n    ###        \n    removeObject: (object) -> @remove(object)\n    \n    ###*\n    * Adds a game object to the manager. The game object is then automatically updated by the manager.\n    *\n    * @method add\n    * @param {gs.Object_Base} object - The game object to add.\n    ### \n    add: (object) -> \n        #@objects.splice(0, 0, object)\n        @objects.push(object)\n        @needsSort = yes\n        @registerObject(object)\n        @addToGroup(object, object.group)\n        \n    ###*\n    * Removes a game object to the manager. The game object is then no longer automatically updated or disposed by the manager.\n    *\n    * @method remove\n    * @param {gs.Object_Base} object - The game object to remove.\n    ### \n    remove: (object) -> \n        if object\n            @objects.remove(object)\n            @unregisterObject(object)\n            if object.group?\n                @objectsByGroup[object.group]?.remove(object)\n    \n    ###*\n    * Gets an object by ID.\n    *\n    * @method objectById\n    * @param {String} id - The ID of the game object to get. \n    * @return {gs.Object_Base} The game object or <b>null</b> if no game object is registered for the specified ID.\n    ###         \n    objectById: (id) -> @objectsById[id]?.last()\n    \n    ###*\n    * Gets an object by ID.\n    *\n    * @method byId\n    * @param {String} id - The ID of the game object to get. \n    * @return {gs.Object_Base} The game object or <b>null</b> if no game object is registered for the specified ID.\n    ### \n    byId: (id) -> @objectsById[id]?.last()\n    \n    ###*\n    * Sets the object for an ID.\n    *\n    * @method setObjectById\n    * @param {gs.Object_Base} object - The game object to set.\n    * @param {String} id - The ID for the game object. \n    ### \n    setObjectById: (object, id) -> \n        object.id = id\n        if !@objectsById[id]\n            @objectsById[id] = [object]\n        else\n            @objectsById[id].push(object)\n            \n        window[\"$\"+id] = object\n    \n    ###*\n    * Adds an object to a specified object-group.\n    *\n    * @method addToGroup\n    * @param {gs.Object_Base} object - The game object to add.\n    * @param {String} group - The group to assign game object to. \n    ### \n    addToGroup: (object, group) ->\n        if group?\n            @objectsByGroup_[object.group]?.remove(object)\n            if !@objectsByGroup_[group]\n                @objectsByGroup_[group] = []\n            @objectsByGroup_[group].push(object)\n    \n    ###*\n    * Gets all object of a specified object-group.\n    *\n    * @method objectsByGroup\n    * @param {String} group - The object-group.\n    * @return {gs.Object_Base[]} The game objects belonging to the specified group.\n    ###         \n    objectsByGroup: (group) -> @objectsByGroup_[group] || []\n    \n    \n    ###*\n    * Updates the manager and all assigned game objects in the right order.\n    *\n    * @method update\n    ###  \n    update: -> \n        i = 0\n        \n        if @needsSort\n            @objects.sort (a, b) ->\n                if a.order < b.order\n                    return 1\n                else if a.order > b.order\n                    return -1\n                else\n                    return 0\n            @needsSort = no\n                \n        while i < @objects.length\n            object = @objects[i]\n            if object.disposed\n                @removeObject(object)\n            else \n                object.update() if object.active\n                i++\n            \n        return null\n        \ngs.ObjectManager = ObjectManager #new ObjectManager()"]}
//# sourceURL=ObjectManager_6.js

Commits for Nextrek/s2s/development/ObjectManager_8DBB050CK548EA49A5S800AE8C9C8A84C8B9.js

Diff revisions: vs.
Revision Author Commited Message
1084 MOliva picture MOliva Fri 11 May, 2018 12:41:55 +0000