Subversion Repository Public Repository

Nextrek

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
{
    "uid": "DA213629K6807A40ABS819CEB68756DF5543",
    "isLoaded": true,
    "lastModificationTime": 0,
    "items": {
        "name": "Component_ImageMap",
        "type": "game_script",
        "order": 9,
        "content": "# ===================================================================\n#\n#   Script: Component_ImageMap\n#\n#   $$COPYRIGHT$$\n#\n# ===================================================================\nclass Component_ImageMap extends gs.Component_Visual\n    ###*\n    * Called if this object instance is restored from a data-bundle. It can be used\n    * re-assign event-handler, anonymous functions, etc.\n    * \n    * @method onDataBundleRestore.\n    * @param Object data - The data-bundle\n    * @param gs.ObjectCodecContext context - The codec-context.\n    ###\n    onDataBundleRestore: (data, context) ->\n        @setupEventHandlers()\n        @object.addObject(@ground)\n        \n        bitmap = ResourceManager.getBitmap(\"Graphics/Pictures/#{@object.images[0]}\")\n        ground = new gs.Bitmap(bitmap.width, bitmap.height)\n        ground.blt(0, 0, bitmap, new Rect(0, 0, bitmap.width, bitmap.height))\n        @ground.bitmap = ground\n        \n        @setupHotspots(@hotspots)\n\n    ###*\n    * A component which turns a game object into an interactive image-map.\n    *\n    * @module gs\n    * @class Component_ImageMap\n    * @extends gs.Component_Visual\n    * @memberof gs\n    ###\n    constructor: ->\n        super\n        \n        ###*\n        * The ground/base image.\n        * @property ground\n        * @type gs.Object_Picture\n        * @default null\n        ###\n        @ground = null\n        \n        ###*\n        * An array of different hotspots.\n        * @property hotspots\n        * @type gs.Object_Picture[]\n        * @default null\n        ###\n        @hotspots = null\n       \n        ###*\n        * The variable context used if a hotspot needs to deal with local variables.\n        * @property variableContext\n        * @type Object\n        * @default null\n        ###\n        @variableContext = null\n        \n        ###*\n        * Indicates if the image-map is active. An in-active image-map doesn't respond\n        * to any input-event. Hover effects are still working.\n        * @property active\n        * @type boolean\n        * @default yes\n        ###\n        @active = yes\n       \n    ###*\n    * Adds event-handler for mouse/touch events to update the component only if \n    * a user-action happened.\n    *\n    * @method setupEventHandlers\n    ### \n    setupEventHandlers: ->\n        gs.GlobalEventManager.offByOwner(\"mouseUp\", @object)\n        gs.GlobalEventManager.on \"mouseUp\", ((e) => \n            contains = Rect.contains(@object.dstRect.x, @object.dstRect.y, \n                         @object.dstRect.width, @object.dstRect.height,\n                         Input.Mouse.x - @object.origin.x, Input.Mouse.y - @object.origin.y)\n            \n            if contains and @active\n                for hotspot in @hotspots\n                    if @checkHotspotAction(hotspot) \n                        e.breakChain = yes\n                        if hotspot.data.bindToSwitch\n                            hotspot.selected = !hotspot.selected\n                        @executeHotspotAction(hotspot)\n                \n        ), null, @object\n        \n    \n    ###*\n    * Initializes the image-map. Creates the background and hotspots.\n    *\n    * @method setup\n    ###\n    setup: ->\n        @setupEventHandlers()\n        @object.rIndex = 11000 # Receive Input Events first\n        bitmap = ResourceManager.getBitmap(\"Graphics/Pictures/#{@object.images[0]}\")\n        bitmap.makeMutable()\n        ground = new gs.Bitmap(bitmap.width, bitmap.height)\n        ground.blt(0, 0, bitmap, new Rect(0, 0, bitmap.width, bitmap.height))\n        \n        @ground = new gs.Object_Picture()\n        @ground.bitmap = ground\n        @ground.image = null\n        @ground.zIndex = @object.zIndex\n        @ground.imageHandling = gs.ImageHandling.CUSTOM_SIZE\n        @object.addObject(@ground)\n        \n        @setupHotspots()\n        \n        @ground.srcRect.set(0, 0, ground.width, ground.height)\n        @ground.dstRect.width = ground.width\n        @ground.dstRect.height = ground.height\n        @ground.update()\n        \n        @object.dstRect.width = @ground.dstRect.width\n        @object.dstRect.height = @ground.dstRect.height\n    \n    ###*\n    * Sets up the hotspots on the image-map. Each hotspot is a gs.Object_ImageMapHotspot\n    * object.\n    *\n    * @method setupHotspots\n    ###\n    setupHotspots: (hotspots) ->\n        @hotspots = @object.hotspots.select (v, i) => \n            @ground.bitmap.clearRect(v.x, v.y, v.size.width, v.size.height)\n            picture = new gs.Object_ImageMapHotspot()\n            picture.fixedSize = true\n            picture.srcRect = new Rect(v.x, v.y, v.size.width, v.size.height)\n            picture.dstRect = new Rect(v.x, v.y, v.size.width, v.size.height)\n            picture.imageHandling = gs.ImageHandling.CUSTOM_SIZE\n            picture.zIndex = @object.zIndex + 1\n            picture.selected = hotspots?[i]?.selected ? no\n            picture.hovered = no\n            picture.enabled = hotspots?[i]?.enabled ? yes\n            picture.actions = v.data.actions\n            picture.data = v.data\n            picture.commonEventId = v.commonEventId\n            picture.anchor.set(0.5, 0.5)\n            @object.addObject(picture)\n            \n            return picture\n            \n    ###*\n    * Initializes the image-map. Frees ground image.\n    *\n    * @method dispose\n    ###\n    dispose: ->\n        super\n        gs.GlobalEventManager.offByOwner(\"mouseUp\", @object)\n        @ground.bitmap.dispose()\n        \n    ###*\n    * Executes a hotspot's associated action. Depending on the configuration a hotspot\n    * can trigger a common-event or turn on a switch for example.\n    *\n    * @method executeHotspotAction\n    * @param {gs.Object_Picture} hotspot - The hotspot where the image should be updated.\n    * @protected\n    ###\n    executeHotspotAction: (hotspot) ->\n        GameManager.variableStore.setupTempVariables(@variableContext)\n        if hotspot.data.bindToSwitch\n            domain = GameManager.variableStore.domain\n            GameManager.variableStore.setBooleanValueTo(hotspot.data.switch, hotspot.selected)\n        if hotspot.data.bindValueTo\n            domain = GameManager.variableStore.domain\n            GameManager.variableStore.setNumberValueTo(hotspot.data.bindValueVariable, hotspot.data.bindValue)\n            \n        AudioManager.playSound(hotspot.data.onClickSound)\n        switch hotspot.data.action\n            when 1 # Jump To\n                @object.events?.emit(\"jumpTo\", @object, { label: hotspot.data.label })\n            when 2 # Call Common Event\n                @object.events?.emit(\"callCommonEvent\", @object, { commonEventId: hotspot.data.commonEventId, finish: hotspot.data.finish })\n            when 3 # UI Action\n                @object.events?.emit(\"action\", @object, { actions: hotspot.data.actions })\n        \n        if hotspot.data.finish\n            @object.events?.emit(\"finish\", @object)\n            \n    \n    ###*\n    * Checks if a hotspot's associated action needs to be executed. Depending on the configuration a hotspot\n    * can trigger a common-event or turn on a switch for example.\n    *\n    * @method updateHotspotAction\n    * @param {gs.Object_Picture} hotspot - The hotspot where the image should be updated.\n    * @return {boolean} If <b>true</b> the hotspot's action needs to be executed. Otherwise <b>false</b>.\n    * @protected\n    ###\n    checkHotspotAction: (hotspot) ->\n        result = no\n        hovered = hotspot.dstRect.contains(Input.Mouse.x - hotspot.origin.x, Input.Mouse.y - hotspot.origin.y)\n        \n        if hovered and hotspot.enabled and Input.Mouse.buttons[Input.Mouse.LEFT] == 2\n            result = yes\n            \n        return result\n            \n    ###*\n    * Updates a hotspot's image. Depending on the state the image of a hotspot can\n    * change for example if the mouse hovers over a hotspot.\n    *\n    * @method updateHotspotImage\n    * @param {gs.Object_Picture} hotspot - The hotspot where the image should be updated.\n    * @param {boolean} hovered - Indicates if the hotspot is hovered by mouse/touch cursor.\n    * @protected\n    ###\n    updateHotspotImage: (hotspot, hovered) ->\n        baseImage = if hotspot.enabled then @object.images[2] || @object.images[0] else @object.images[0] \n        if hovered and hotspot.enabled\n            if hotspot.selected\n                hotspot.image = @object.images[4] || @object.images[1] || baseImage\n            else\n                hotspot.image = @object.images[1] || baseImage\n        else\n            if hotspot.selected\n                hotspot.image = @object.images[3] || baseImage\n            else\n                hotspot.image = baseImage\n                \n    \n    ###*\n    * Updates a hotspot.\n    *\n    * @method updateHotspot\n    * @param {gs.Object_Picture} hotspot - The hotspot to update.\n    * @protected\n    ###            \n    updateHotspot: (hotspot) ->\n        hotspot.visible = @object.visible\n        hotspot.opacity = @object.opacity\n        hotspot.tone.setFromObject(@object.tone)\n        hotspot.color.setFromObject(@object.color)\n        if hotspot.data.bindEnabledState\n            GameManager.variableStore.setupTempVariables(@variableContext)\n            hotspot.enabled = GameManager.variableStore.booleanValueOf(hotspot.data.enabledSwitch)\n        if hotspot.data.bindToSwitch\n            GameManager.variableStore.setupTempVariables(@variableContext)\n            hotspot.selected = GameManager.variableStore.booleanValueOf(hotspot.data.switch)\n        hovered = hotspot.dstRect.contains(Input.Mouse.x - hotspot.origin.x, Input.Mouse.y - hotspot.origin.y)\n        if hovered != hotspot.hovered\n            hotspot.hovered = hovered\n            AudioManager.playSound(hotspot.data.onHoverSound) if hovered\n        @updateHotspotImage(hotspot, hovered)       \n        hotspot.update()        \n     \n    ###*\n    * Updates the ground-image.\n    *\n    * @method updateGround\n    * @protected\n    ###   \n    updateGround: ->\n        @ground.visible = @object.visible\n        @ground.opacity = @object.opacity\n        @ground.anchor.x = 0.5\n        @ground.anchor.y = 0.5\n        @ground.tone.setFromObject(@object.tone)\n        @ground.color.setFromObject(@object.color)\n        @ground.update()\n        \n    ###*\n    * Updates the image-map's ground and all hotspots.\n    *\n    * @method update\n    ###\n    update: ->\n        super()\n        \n        @updateGround()\n        \n        for hotspot in @hotspots\n            @updateHotspot(hotspot)\n            \n        return null\n                \ngs.Component_ImageMap = Component_ImageMap",
        "parentId": "D3325122KACDEA4515SB731E37A42B9D779F",
        "folder": false,
        "compiledContent": "var Component_ImageMap,\n  extend = function(child, parent) { for (var key in parent) { if (hasProp.call(parent, key)) child[key] = parent[key]; } function ctor() { this.constructor = child; } ctor.prototype = parent.prototype; child.prototype = new ctor(); child.__super__ = parent.prototype; return child; },\n  hasProp = {}.hasOwnProperty;\n\nComponent_ImageMap = (function(superClass) {\n  extend(Component_ImageMap, superClass);\n\n\n  /**\n  * Called if this object instance is restored from a data-bundle. It can be used\n  * re-assign event-handler, anonymous functions, etc.\n  * \n  * @method onDataBundleRestore.\n  * @param Object data - The data-bundle\n  * @param gs.ObjectCodecContext context - The codec-context.\n   */\n\n  Component_ImageMap.prototype.onDataBundleRestore = function(data, context) {\n    var bitmap, ground;\n    this.setupEventHandlers();\n    this.object.addObject(this.ground);\n    bitmap = ResourceManager.getBitmap(\"Graphics/Pictures/\" + this.object.images[0]);\n    ground = new gs.Bitmap(bitmap.width, bitmap.height);\n    ground.blt(0, 0, bitmap, new Rect(0, 0, bitmap.width, bitmap.height));\n    this.ground.bitmap = ground;\n    return this.setupHotspots(this.hotspots);\n  };\n\n\n  /**\n  * A component which turns a game object into an interactive image-map.\n  *\n  * @module gs\n  * @class Component_ImageMap\n  * @extends gs.Component_Visual\n  * @memberof gs\n   */\n\n  function Component_ImageMap() {\n    Component_ImageMap.__super__.constructor.apply(this, arguments);\n\n    /**\n    * The ground/base image.\n    * @property ground\n    * @type gs.Object_Picture\n    * @default null\n     */\n    this.ground = null;\n\n    /**\n    * An array of different hotspots.\n    * @property hotspots\n    * @type gs.Object_Picture[]\n    * @default null\n     */\n    this.hotspots = null;\n\n    /**\n    * The variable context used if a hotspot needs to deal with local variables.\n    * @property variableContext\n    * @type Object\n    * @default null\n     */\n    this.variableContext = null;\n\n    /**\n    * Indicates if the image-map is active. An in-active image-map doesn't respond\n    * to any input-event. Hover effects are still working.\n    * @property active\n    * @type boolean\n    * @default yes\n     */\n    this.active = true;\n  }\n\n\n  /**\n  * Adds event-handler for mouse/touch events to update the component only if \n  * a user-action happened.\n  *\n  * @method setupEventHandlers\n   */\n\n  Component_ImageMap.prototype.setupEventHandlers = function() {\n    gs.GlobalEventManager.offByOwner(\"mouseUp\", this.object);\n    return gs.GlobalEventManager.on(\"mouseUp\", ((function(_this) {\n      return function(e) {\n        var contains, hotspot, j, len, ref, results;\n        contains = Rect.contains(_this.object.dstRect.x, _this.object.dstRect.y, _this.object.dstRect.width, _this.object.dstRect.height, Input.Mouse.x - _this.object.origin.x, Input.Mouse.y - _this.object.origin.y);\n        if (contains && _this.active) {\n          ref = _this.hotspots;\n          results = [];\n          for (j = 0, len = ref.length; j < len; j++) {\n            hotspot = ref[j];\n            if (_this.checkHotspotAction(hotspot)) {\n              e.breakChain = true;\n              if (hotspot.data.bindToSwitch) {\n                hotspot.selected = !hotspot.selected;\n              }\n              results.push(_this.executeHotspotAction(hotspot));\n            } else {\n              results.push(void 0);\n            }\n          }\n          return results;\n        }\n      };\n    })(this)), null, this.object);\n  };\n\n\n  /**\n  * Initializes the image-map. Creates the background and hotspots.\n  *\n  * @method setup\n   */\n\n  Component_ImageMap.prototype.setup = function() {\n    var bitmap, ground;\n    this.setupEventHandlers();\n    this.object.rIndex = 11000;\n    bitmap = ResourceManager.getBitmap(\"Graphics/Pictures/\" + this.object.images[0]);\n    bitmap.makeMutable();\n    ground = new gs.Bitmap(bitmap.width, bitmap.height);\n    ground.blt(0, 0, bitmap, new Rect(0, 0, bitmap.width, bitmap.height));\n    this.ground = new gs.Object_Picture();\n    this.ground.bitmap = ground;\n    this.ground.image = null;\n    this.ground.zIndex = this.object.zIndex;\n    this.ground.imageHandling = gs.ImageHandling.CUSTOM_SIZE;\n    this.object.addObject(this.ground);\n    this.setupHotspots();\n    this.ground.srcRect.set(0, 0, ground.width, ground.height);\n    this.ground.dstRect.width = ground.width;\n    this.ground.dstRect.height = ground.height;\n    this.ground.update();\n    this.object.dstRect.width = this.ground.dstRect.width;\n    return this.object.dstRect.height = this.ground.dstRect.height;\n  };\n\n\n  /**\n  * Sets up the hotspots on the image-map. Each hotspot is a gs.Object_ImageMapHotspot\n  * object.\n  *\n  * @method setupHotspots\n   */\n\n  Component_ImageMap.prototype.setupHotspots = function(hotspots) {\n    return this.hotspots = this.object.hotspots.select((function(_this) {\n      return function(v, i) {\n        var picture, ref, ref1, ref2, ref3;\n        _this.ground.bitmap.clearRect(v.x, v.y, v.size.width, v.size.height);\n        picture = new gs.Object_ImageMapHotspot();\n        picture.fixedSize = true;\n        picture.srcRect = new Rect(v.x, v.y, v.size.width, v.size.height);\n        picture.dstRect = new Rect(v.x, v.y, v.size.width, v.size.height);\n        picture.imageHandling = gs.ImageHandling.CUSTOM_SIZE;\n        picture.zIndex = _this.object.zIndex + 1;\n        picture.selected = (ref = hotspots != null ? (ref1 = hotspots[i]) != null ? ref1.selected : void 0 : void 0) != null ? ref : false;\n        picture.hovered = false;\n        picture.enabled = (ref2 = hotspots != null ? (ref3 = hotspots[i]) != null ? ref3.enabled : void 0 : void 0) != null ? ref2 : true;\n        picture.actions = v.data.actions;\n        picture.data = v.data;\n        picture.commonEventId = v.commonEventId;\n        picture.anchor.set(0.5, 0.5);\n        _this.object.addObject(picture);\n        return picture;\n      };\n    })(this));\n  };\n\n\n  /**\n  * Initializes the image-map. Frees ground image.\n  *\n  * @method dispose\n   */\n\n  Component_ImageMap.prototype.dispose = function() {\n    Component_ImageMap.__super__.dispose.apply(this, arguments);\n    gs.GlobalEventManager.offByOwner(\"mouseUp\", this.object);\n    return this.ground.bitmap.dispose();\n  };\n\n\n  /**\n  * Executes a hotspot's associated action. Depending on the configuration a hotspot\n  * can trigger a common-event or turn on a switch for example.\n  *\n  * @method executeHotspotAction\n  * @param {gs.Object_Picture} hotspot - The hotspot where the image should be updated.\n  * @protected\n   */\n\n  Component_ImageMap.prototype.executeHotspotAction = function(hotspot) {\n    var domain, ref, ref1, ref2, ref3;\n    GameManager.variableStore.setupTempVariables(this.variableContext);\n    if (hotspot.data.bindToSwitch) {\n      domain = GameManager.variableStore.domain;\n      GameManager.variableStore.setBooleanValueTo(hotspot.data[\"switch\"], hotspot.selected);\n    }\n    if (hotspot.data.bindValueTo) {\n      domain = GameManager.variableStore.domain;\n      GameManager.variableStore.setNumberValueTo(hotspot.data.bindValueVariable, hotspot.data.bindValue);\n    }\n    AudioManager.playSound(hotspot.data.onClickSound);\n    switch (hotspot.data.action) {\n      case 1:\n        if ((ref = this.object.events) != null) {\n          ref.emit(\"jumpTo\", this.object, {\n            label: hotspot.data.label\n          });\n        }\n        break;\n      case 2:\n        if ((ref1 = this.object.events) != null) {\n          ref1.emit(\"callCommonEvent\", this.object, {\n            commonEventId: hotspot.data.commonEventId,\n            finish: hotspot.data.finish\n          });\n        }\n        break;\n      case 3:\n        if ((ref2 = this.object.events) != null) {\n          ref2.emit(\"action\", this.object, {\n            actions: hotspot.data.actions\n          });\n        }\n    }\n    if (hotspot.data.finish) {\n      return (ref3 = this.object.events) != null ? ref3.emit(\"finish\", this.object) : void 0;\n    }\n  };\n\n\n  /**\n  * Checks if a hotspot's associated action needs to be executed. Depending on the configuration a hotspot\n  * can trigger a common-event or turn on a switch for example.\n  *\n  * @method updateHotspotAction\n  * @param {gs.Object_Picture} hotspot - The hotspot where the image should be updated.\n  * @return {boolean} If <b>true</b> the hotspot's action needs to be executed. Otherwise <b>false</b>.\n  * @protected\n   */\n\n  Component_ImageMap.prototype.checkHotspotAction = function(hotspot) {\n    var hovered, result;\n    result = false;\n    hovered = hotspot.dstRect.contains(Input.Mouse.x - hotspot.origin.x, Input.Mouse.y - hotspot.origin.y);\n    if (hovered && hotspot.enabled && Input.Mouse.buttons[Input.Mouse.LEFT] === 2) {\n      result = true;\n    }\n    return result;\n  };\n\n\n  /**\n  * Updates a hotspot's image. Depending on the state the image of a hotspot can\n  * change for example if the mouse hovers over a hotspot.\n  *\n  * @method updateHotspotImage\n  * @param {gs.Object_Picture} hotspot - The hotspot where the image should be updated.\n  * @param {boolean} hovered - Indicates if the hotspot is hovered by mouse/touch cursor.\n  * @protected\n   */\n\n  Component_ImageMap.prototype.updateHotspotImage = function(hotspot, hovered) {\n    var baseImage;\n    baseImage = hotspot.enabled ? this.object.images[2] || this.object.images[0] : this.object.images[0];\n    if (hovered && hotspot.enabled) {\n      if (hotspot.selected) {\n        return hotspot.image = this.object.images[4] || this.object.images[1] || baseImage;\n      } else {\n        return hotspot.image = this.object.images[1] || baseImage;\n      }\n    } else {\n      if (hotspot.selected) {\n        return hotspot.image = this.object.images[3] || baseImage;\n      } else {\n        return hotspot.image = baseImage;\n      }\n    }\n  };\n\n\n  /**\n  * Updates a hotspot.\n  *\n  * @method updateHotspot\n  * @param {gs.Object_Picture} hotspot - The hotspot to update.\n  * @protected\n   */\n\n  Component_ImageMap.prototype.updateHotspot = function(hotspot) {\n    var hovered;\n    hotspot.visible = this.object.visible;\n    hotspot.opacity = this.object.opacity;\n    hotspot.tone.setFromObject(this.object.tone);\n    hotspot.color.setFromObject(this.object.color);\n    if (hotspot.data.bindEnabledState) {\n      GameManager.variableStore.setupTempVariables(this.variableContext);\n      hotspot.enabled = GameManager.variableStore.booleanValueOf(hotspot.data.enabledSwitch);\n    }\n    if (hotspot.data.bindToSwitch) {\n      GameManager.variableStore.setupTempVariables(this.variableContext);\n      hotspot.selected = GameManager.variableStore.booleanValueOf(hotspot.data[\"switch\"]);\n    }\n    hovered = hotspot.dstRect.contains(Input.Mouse.x - hotspot.origin.x, Input.Mouse.y - hotspot.origin.y);\n    if (hovered !== hotspot.hovered) {\n      hotspot.hovered = hovered;\n      if (hovered) {\n        AudioManager.playSound(hotspot.data.onHoverSound);\n      }\n    }\n    this.updateHotspotImage(hotspot, hovered);\n    return hotspot.update();\n  };\n\n\n  /**\n  * Updates the ground-image.\n  *\n  * @method updateGround\n  * @protected\n   */\n\n  Component_ImageMap.prototype.updateGround = function() {\n    this.ground.visible = this.object.visible;\n    this.ground.opacity = this.object.opacity;\n    this.ground.anchor.x = 0.5;\n    this.ground.anchor.y = 0.5;\n    this.ground.tone.setFromObject(this.object.tone);\n    this.ground.color.setFromObject(this.object.color);\n    return this.ground.update();\n  };\n\n\n  /**\n  * Updates the image-map's ground and all hotspots.\n  *\n  * @method update\n   */\n\n  Component_ImageMap.prototype.update = function() {\n    var hotspot, j, len, ref;\n    Component_ImageMap.__super__.update.call(this);\n    this.updateGround();\n    ref = this.hotspots;\n    for (j = 0, len = ref.length; j < len; j++) {\n      hotspot = ref[j];\n      this.updateHotspot(hotspot);\n    }\n    return null;\n  };\n\n  return Component_ImageMap;\n\n})(gs.Component_Visual);\n\ngs.Component_ImageMap = Component_ImageMap;\n\n//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"","sourceRoot":"","sources":[""],"names":[],"mappings":"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","sourcesContent":["# ===================================================================\n#\n#   Script: Component_ImageMap\n#\n#   $$COPYRIGHT$$\n#\n# ===================================================================\nclass Component_ImageMap extends gs.Component_Visual\n    ###*\n    * Called if this object instance is restored from a data-bundle. It can be used\n    * re-assign event-handler, anonymous functions, etc.\n    * \n    * @method onDataBundleRestore.\n    * @param Object data - The data-bundle\n    * @param gs.ObjectCodecContext context - The codec-context.\n    ###\n    onDataBundleRestore: (data, context) ->\n        @setupEventHandlers()\n        @object.addObject(@ground)\n        \n        bitmap = ResourceManager.getBitmap(\"Graphics/Pictures/#{@object.images[0]}\")\n        ground = new gs.Bitmap(bitmap.width, bitmap.height)\n        ground.blt(0, 0, bitmap, new Rect(0, 0, bitmap.width, bitmap.height))\n        @ground.bitmap = ground\n        \n        @setupHotspots(@hotspots)\n\n    ###*\n    * A component which turns a game object into an interactive image-map.\n    *\n    * @module gs\n    * @class Component_ImageMap\n    * @extends gs.Component_Visual\n    * @memberof gs\n    ###\n    constructor: ->\n        super\n        \n        ###*\n        * The ground/base image.\n        * @property ground\n        * @type gs.Object_Picture\n        * @default null\n        ###\n        @ground = null\n        \n        ###*\n        * An array of different hotspots.\n        * @property hotspots\n        * @type gs.Object_Picture[]\n        * @default null\n        ###\n        @hotspots = null\n       \n        ###*\n        * The variable context used if a hotspot needs to deal with local variables.\n        * @property variableContext\n        * @type Object\n        * @default null\n        ###\n        @variableContext = null\n        \n        ###*\n        * Indicates if the image-map is active. An in-active image-map doesn't respond\n        * to any input-event. Hover effects are still working.\n        * @property active\n        * @type boolean\n        * @default yes\n        ###\n        @active = yes\n       \n    ###*\n    * Adds event-handler for mouse/touch events to update the component only if \n    * a user-action happened.\n    *\n    * @method setupEventHandlers\n    ### \n    setupEventHandlers: ->\n        gs.GlobalEventManager.offByOwner(\"mouseUp\", @object)\n        gs.GlobalEventManager.on \"mouseUp\", ((e) => \n            contains = Rect.contains(@object.dstRect.x, @object.dstRect.y, \n                         @object.dstRect.width, @object.dstRect.height,\n                         Input.Mouse.x - @object.origin.x, Input.Mouse.y - @object.origin.y)\n            \n            if contains and @active\n                for hotspot in @hotspots\n                    if @checkHotspotAction(hotspot) \n                        e.breakChain = yes\n                        if hotspot.data.bindToSwitch\n                            hotspot.selected = !hotspot.selected\n                        @executeHotspotAction(hotspot)\n                \n        ), null, @object\n        \n    \n    ###*\n    * Initializes the image-map. Creates the background and hotspots.\n    *\n    * @method setup\n    ###\n    setup: ->\n        @setupEventHandlers()\n        @object.rIndex = 11000 # Receive Input Events first\n        bitmap = ResourceManager.getBitmap(\"Graphics/Pictures/#{@object.images[0]}\")\n        bitmap.makeMutable()\n        ground = new gs.Bitmap(bitmap.width, bitmap.height)\n        ground.blt(0, 0, bitmap, new Rect(0, 0, bitmap.width, bitmap.height))\n        \n        @ground = new gs.Object_Picture()\n        @ground.bitmap = ground\n        @ground.image = null\n        @ground.zIndex = @object.zIndex\n        @ground.imageHandling = gs.ImageHandling.CUSTOM_SIZE\n        @object.addObject(@ground)\n        \n        @setupHotspots()\n        \n        @ground.srcRect.set(0, 0, ground.width, ground.height)\n        @ground.dstRect.width = ground.width\n        @ground.dstRect.height = ground.height\n        @ground.update()\n        \n        @object.dstRect.width = @ground.dstRect.width\n        @object.dstRect.height = @ground.dstRect.height\n    \n    ###*\n    * Sets up the hotspots on the image-map. Each hotspot is a gs.Object_ImageMapHotspot\n    * object.\n    *\n    * @method setupHotspots\n    ###\n    setupHotspots: (hotspots) ->\n        @hotspots = @object.hotspots.select (v, i) => \n            @ground.bitmap.clearRect(v.x, v.y, v.size.width, v.size.height)\n            picture = new gs.Object_ImageMapHotspot()\n            picture.fixedSize = true\n            picture.srcRect = new Rect(v.x, v.y, v.size.width, v.size.height)\n            picture.dstRect = new Rect(v.x, v.y, v.size.width, v.size.height)\n            picture.imageHandling = gs.ImageHandling.CUSTOM_SIZE\n            picture.zIndex = @object.zIndex + 1\n            picture.selected = hotspots?[i]?.selected ? no\n            picture.hovered = no\n            picture.enabled = hotspots?[i]?.enabled ? yes\n            picture.actions = v.data.actions\n            picture.data = v.data\n            picture.commonEventId = v.commonEventId\n            picture.anchor.set(0.5, 0.5)\n            @object.addObject(picture)\n            \n            return picture\n            \n    ###*\n    * Initializes the image-map. Frees ground image.\n    *\n    * @method dispose\n    ###\n    dispose: ->\n        super\n        gs.GlobalEventManager.offByOwner(\"mouseUp\", @object)\n        @ground.bitmap.dispose()\n        \n    ###*\n    * Executes a hotspot's associated action. Depending on the configuration a hotspot\n    * can trigger a common-event or turn on a switch for example.\n    *\n    * @method executeHotspotAction\n    * @param {gs.Object_Picture} hotspot - The hotspot where the image should be updated.\n    * @protected\n    ###\n    executeHotspotAction: (hotspot) ->\n        GameManager.variableStore.setupTempVariables(@variableContext)\n        if hotspot.data.bindToSwitch\n            domain = GameManager.variableStore.domain\n            GameManager.variableStore.setBooleanValueTo(hotspot.data.switch, hotspot.selected)\n        if hotspot.data.bindValueTo\n            domain = GameManager.variableStore.domain\n            GameManager.variableStore.setNumberValueTo(hotspot.data.bindValueVariable, hotspot.data.bindValue)\n            \n        AudioManager.playSound(hotspot.data.onClickSound)\n        switch hotspot.data.action\n            when 1 # Jump To\n                @object.events?.emit(\"jumpTo\", @object, { label: hotspot.data.label })\n            when 2 # Call Common Event\n                @object.events?.emit(\"callCommonEvent\", @object, { commonEventId: hotspot.data.commonEventId, finish: hotspot.data.finish })\n            when 3 # UI Action\n                @object.events?.emit(\"action\", @object, { actions: hotspot.data.actions })\n        \n        if hotspot.data.finish\n            @object.events?.emit(\"finish\", @object)\n            \n    \n    ###*\n    * Checks if a hotspot's associated action needs to be executed. Depending on the configuration a hotspot\n    * can trigger a common-event or turn on a switch for example.\n    *\n    * @method updateHotspotAction\n    * @param {gs.Object_Picture} hotspot - The hotspot where the image should be updated.\n    * @return {boolean} If <b>true</b> the hotspot's action needs to be executed. Otherwise <b>false</b>.\n    * @protected\n    ###\n    checkHotspotAction: (hotspot) ->\n        result = no\n        hovered = hotspot.dstRect.contains(Input.Mouse.x - hotspot.origin.x, Input.Mouse.y - hotspot.origin.y)\n        \n        if hovered and hotspot.enabled and Input.Mouse.buttons[Input.Mouse.LEFT] == 2\n            result = yes\n            \n        return result\n            \n    ###*\n    * Updates a hotspot's image. Depending on the state the image of a hotspot can\n    * change for example if the mouse hovers over a hotspot.\n    *\n    * @method updateHotspotImage\n    * @param {gs.Object_Picture} hotspot - The hotspot where the image should be updated.\n    * @param {boolean} hovered - Indicates if the hotspot is hovered by mouse/touch cursor.\n    * @protected\n    ###\n    updateHotspotImage: (hotspot, hovered) ->\n        baseImage = if hotspot.enabled then @object.images[2] || @object.images[0] else @object.images[0] \n        if hovered and hotspot.enabled\n            if hotspot.selected\n                hotspot.image = @object.images[4] || @object.images[1] || baseImage\n            else\n                hotspot.image = @object.images[1] || baseImage\n        else\n            if hotspot.selected\n                hotspot.image = @object.images[3] || baseImage\n            else\n                hotspot.image = baseImage\n                \n    \n    ###*\n    * Updates a hotspot.\n    *\n    * @method updateHotspot\n    * @param {gs.Object_Picture} hotspot - The hotspot to update.\n    * @protected\n    ###            \n    updateHotspot: (hotspot) ->\n        hotspot.visible = @object.visible\n        hotspot.opacity = @object.opacity\n        hotspot.tone.setFromObject(@object.tone)\n        hotspot.color.setFromObject(@object.color)\n        if hotspot.data.bindEnabledState\n            GameManager.variableStore.setupTempVariables(@variableContext)\n            hotspot.enabled = GameManager.variableStore.booleanValueOf(hotspot.data.enabledSwitch)\n        if hotspot.data.bindToSwitch\n            GameManager.variableStore.setupTempVariables(@variableContext)\n            hotspot.selected = GameManager.variableStore.booleanValueOf(hotspot.data.switch)\n        hovered = hotspot.dstRect.contains(Input.Mouse.x - hotspot.origin.x, Input.Mouse.y - hotspot.origin.y)\n        if hovered != hotspot.hovered\n            hotspot.hovered = hovered\n            AudioManager.playSound(hotspot.data.onHoverSound) if hovered\n        @updateHotspotImage(hotspot, hovered)       \n        hotspot.update()        \n     \n    ###*\n    * Updates the ground-image.\n    *\n    * @method updateGround\n    * @protected\n    ###   \n    updateGround: ->\n        @ground.visible = @object.visible\n        @ground.opacity = @object.opacity\n        @ground.anchor.x = 0.5\n        @ground.anchor.y = 0.5\n        @ground.tone.setFromObject(@object.tone)\n        @ground.color.setFromObject(@object.color)\n        @ground.update()\n        \n    ###*\n    * Updates the image-map's ground and all hotspots.\n    *\n    * @method update\n    ###\n    update: ->\n        super()\n        \n        @updateGround()\n        \n        for hotspot in @hotspots\n            @updateHotspot(hotspot)\n            \n        return null\n                \ngs.Component_ImageMap = Component_ImageMap"]}\n//# sourceURL=Component_ImageMap_110.js"
    },
    "summary": [
        "name",
        "type",
        "order"
    ]
}

Commits for Nextrek/s2s/data/DA213629K6807A40ABS819CEB68756DF5543.json

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