Subversion Repository Public Repository

Nextrek

Diff Revisions 1085 vs 1086 for /s2s/data/B2F84FFAKF97DA4149SAB47E8B89F3C10D30.json

Diff revisions: vs.
  @@ -6,10 +6,10 @@
6 6 "name": "Component_Sprite",
7 7 "type": "game_script",
8 8 "order": 4,
9 - "content": "# ===================================================================\n#\n# Script: Component\n#\n# $$COPYRIGHT$$\n#\n# ===================================================================\nclass Component_Sprite 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 \n ###*\n * A sprite component to display an object on screen. It can be managed or\n * unmanaged. A managed sprite is automatically added to the graphics-system\n * and rendered every frame until it gets disposed. An unmanaged sprite needs\n * to be added and removed manually.\n *\n * @module gs\n * @class Component_Sprite\n * @extends gs.Component_Visual\n * @memberof gs\n * @constructor\n * @param {boolean} managed - Indicates if the sprite is managed by the graphics system.\n ###\n constructor: (managed) ->\n super()\n\n ###*\n * The native sprite object to display the game object on screen.\n *\n * @property sprite\n * @type Sprite\n * @protected\n ###\n @sprite = null\n \n ###*\n * The name of the image to display.\n *\n * @property image\n * @type string\n * @protected\n ###\n @image = null\n \n ###*\n * The name of the video to display.\n *\n * @property video\n * @type string\n * @protected\n ###\n @video = null\n \n ###*\n * The name of the folder from where the image should be loaded.\n *\n * @property image\n * @type string\n * @protected\n ###\n @imageFolder = \"Graphics/Pictures\"\n \n ###*\n * The visibility. If <b>false</b>, the sprite is not rendered.\n *\n * @property visible\n * @type boolean\n * @protected\n ###\n @visible = no\n\n ###*\n * Indicates if the image is loaded.\n *\n * @property imageLoaded\n * @type boolean\n * @protected\n ###\n @imageLoaded = no\n \n ###*\n * Disposes the sprite. If the sprite is managed, it will be automatically\n * removed from the graphics system and viewport.\n * @method dispose\n ###\n dispose: -> \n super\n \n if @sprite\n @sprite.dispose()\n \n if @sprite.video\n @sprite.video.stop()\n \n if not @sprite.managed\n @sprite.viewport?.removeGraphicObject(@sprite)\n Graphics.viewport?.removeGraphicObject(@sprite)\n \n ###*\n * Adds event-handlers for mouse/touch events\n *\n * @method setupEventHandlers\n ### \n setupEventHandlers: ->\n @sprite.onIndexChange = =>\n @object.rIndex = @sprite.index\n @object.needsUpdate = yes\n \n ###*\n * Setup the sprite.\n * @method setupSprite\n ### \n setupSprite: ->\n if !@sprite\n @sprite = new Sprite(Graphics.viewport, managed ? yes)\n \n ###*\n * Setup the sprite component. This method is automatically called by the\n * system.\n * @method setup\n ###\n setup: ->\n @isSetup = yes\n @setupSprite()\n @setupEventHandlers()\n @update()\n \n \n ###*\n * Updates the source- and destination-rectangle of the game object so that\n * the associated bitmap fits in. The imageHandling property controls how\n * the rectangles are resized.\n * @method updateRect\n ###\n updateRect: ->\n if @sprite.bitmap?\n if !@object.imageHandling\n @object.srcRect = new Rect(0, 0, @sprite.bitmap.width, @sprite.bitmap.height)\n if not @object.fixedSize\n @object.dstRect.width = @object.srcRect.width\n @object.dstRect.height = @object.srcRect.height\n else if @object.imageHandling == 1\n @object.srcRect = new Rect(0, 0, @sprite.bitmap.width, @sprite.bitmap.height / 2)\n if not @object.fixedSize\n @object.dstRect.width = @object.srcRect.width\n @object.dstRect.height = @object.srcRect.height\n else if @object.imageHandling == 2\n if not @object.fixedSize\n @object.dstRect.width = @object.srcRect.width\n @object.dstRect.height = @object.srcRect.height\n \n ###*\n * Updates the bitmap object from the associated image name. The imageFolder\n * property controls from which resource-folder the image will be loaded.\n * @method updateBitmap\n ###\n updateBitmap: ->\n @imageLoaded = no\n @image = @object.image\n \n if @object.image.startsWith(\"data:\") || @object.image.startsWith(\"$\")\n @sprite.bitmap = ResourceManager.getBitmap(@object.image)\n else\n @sprite.bitmap = ResourceManager.getBitmap(\"#{@object.imageFolder||@imageFolder}/#{@object.image}\")\n \n if @sprite.bitmap? \n if not @imageLoaded\n @imageLoaded = @sprite.bitmap.loaded\n else\n delete @sprite.bitmap.loaded_\n \n @object.bitmap = @sprite.bitmap\n \n ###*\n * Updates the video object from the associated video name. It also updates\n * the video-rendering process.\n * @method updateVideo\n ###\n updateVideo: ->\n if @object.video != @videoName\n @videoName = @object.video\n @sprite.video = ResourceManager.getVideo(\"Movies/#{@object.video}\")\n if @sprite.video?\n if $PARAMS.preview?.settings.musicDisabled\n @sprite.video.volume = 0\n @sprite.video.loop = @object.loop\n @sprite.video.play()\n \n @object.srcRect = new Rect(0, 0, @sprite.video.width, @sprite.video.height)\n if not @object.fixedSize\n @object.dstRect = new Rect(@object.dstRect.x, @object.dstRect.y, @sprite.video.width, @sprite.video.height)\n \n @sprite.video?.update()\n \n ###*\n * Updates the image if the game object has the image-property set.\n * @method updateImage\n ###\n updateImage: ->\n if @object.image?\n if @object.image != @image or (!@imageLoaded and @sprite.bitmap?.loaded)\n @updateBitmap()\n @updateRect()\n else if @object.bitmap? \n @sprite.bitmap = @object.bitmap\n else if @object.video? or @videoName != @object.video\n @updateVideo()\n else\n @image = null\n @object.bitmap = null\n @sprite.bitmap = null\n \n ###*\n * If the sprite is unmanaged, this method will update the visibility of the\n * sprite. If the sprite leaves the viewport, it will be removed to save \n * performance and automatically added back to the viewport if it enters\n * the viewport.\n * @method updateVisibility\n ###\n updateVisibility: ->\n if !@sprite.managed\n visible = Rect.intersect(@object.dstRect.x+@object.origin.x, @object.dstRect.y+@object.origin.y, @object.dstRect.width, @object.dstRect.height, \n 0, 0, Graphics.width, Graphics.height)\n if visible and !@visible\n (@object.viewport || Graphics.viewport).addGraphicObject(@sprite)\n @visible = yes\n \n if !visible and @visible\n (@object.viewport || Graphics.viewport).removeGraphicObject(@sprite)\n @visible = no\n \n \n ###*\n * Updates the padding.\n * @method updatePadding\n ###\n updatePadding: ->\n if @object.padding?\n @sprite.x += @object.padding.left\n @sprite.y += @object.padding.top\n @sprite.zoomX -= (@object.padding.left+@object.padding.right) / @object.srcRect.width\n @sprite.zoomY -= (@object.padding.bottom+@object.padding.bottom) / @object.srcRect.height\n \n ###*\n * Updates the sprite properties from the game object properties.\n * @method updateProperties\n ###\n updateProperties: ->\n @sprite.width = @object.dstRect.width\n @sprite.height = @object.dstRect.height\n @sprite.x = @object.dstRect.x \n @sprite.y = @object.dstRect.y\n @sprite.mask = @object.mask ? @mask\n @sprite.angle = @object.angle || 0\n @sprite.opacity = @object.opacity ? 255\n @sprite.clipRect = @object.clipRect\n @sprite.srcRect = @object.srcRect\n @sprite.blendingMode = @object.blendMode || 0\n @sprite.mirror = @object.mirror\n @sprite.visible = @object.visible and (!@object.parent or !@object.parent.visible? or @object.parent.visible)\n @sprite.ox = -@object.origin.x\n @sprite.oy = -@object.origin.y\n @sprite.z = (@object.zIndex || 0) + (if !@object.parent then 0 else @object.parent.zIndex || 0)\n \n ###*\n * Updates the optional sprite properties from the game object properties.\n * @method updateOptionalProperties\n ###\n updateOptionalProperties: ->\n if @object.tone?\n @sprite.tone = @object.tone\n if @object.color?\n @sprite.color = @object.color\n if @object.viewport?\n @sprite.viewport = @object.viewport\n if @object.effects?\n @sprite.effects = @object.effects\n if @object.anchor?\n @sprite.anchor.x = @object.anchor.x\n @sprite.anchor.y = @object.anchor.y\n if @object.positionAnchor?\n @sprite.positionAnchor = @object.positionAnchor\n if @object.zoom?\n @sprite.zoomX = @object.zoom.x\n @sprite.zoomY = @object.zoom.y\n if @object.motionBlur?\n @sprite.motionBlur = @object.motionBlur\n \n ###*\n * Updates the sprite component by updating its visibility, image, padding and\n * properties.\n * @method update\n ###\n update: ->\n super\n \n @setup() if not @isSetup\n @updateVisibility()\n @updateImage()\n @updateProperties()\n @updateOptionalProperties()\n @updatePadding()\n \n @object.rIndex = @sprite.index\n @sprite.update()\n \n\n###*\n* Enumeration of appearance animations. \n*\n* @module gs\n* @class AnimationTypes\n* @static\n* @memberof gs\n###\nclass AnimationTypes\n @initialize: -> \n ###*\n * An object appears or disappears by moving into or out of the screen.\n * @property MOVEMENT\n * @type number\n * @static\n * @final\n ###\n @MOVEMENT = 0\n ###*\n * An object appears or disappears using alpha-blending.\n * @property BLENDING\n * @type number\n * @static\n * @final\n ###\n @BLENDING = 1\n ###*\n * An object appears or disappears using a mask-image.\n * @property MASKING\n * @type number\n * @static\n * @final\n ###\n @MASKING = 2\n\nAnimationTypes.initialize() \ngs.AnimationTypes = AnimationTypes\ngs.Component_Sprite = Component_Sprite\n",
9 + "content": "# ===================================================================\n#\n# Script: Component\n#\n# $$COPYRIGHT$$\n#\n# ===================================================================\nclass Component_Sprite 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 \n ###*\n * A sprite component to display an object on screen. It can be managed or\n * unmanaged. A managed sprite is automatically added to the graphics-system\n * and rendered every frame until it gets disposed. An unmanaged sprite needs\n * to be added and removed manually.\n *\n * @module gs\n * @class Component_Sprite\n * @extends gs.Component_Visual\n * @memberof gs\n * @constructor\n * @param {boolean} managed - Indicates if the sprite is managed by the graphics system.\n ###\n constructor: (managed) ->\n super()\n\n ###*\n * The native sprite object to display the game object on screen.\n *\n * @property sprite\n * @type Sprite\n * @protected\n ###\n @sprite = null\n \n ###*\n * The name of the image to display.\n *\n * @property image\n * @type string\n * @protected\n ###\n @image = null\n \n ###*\n * The name of the video to display.\n *\n * @property video\n * @type string\n * @protected\n ###\n @video = null\n \n ###*\n * The name of the folder from where the image should be loaded.\n *\n * @property image\n * @type string\n * @protected\n ###\n @imageFolder = \"Graphics/Pictures\"\n \n ###*\n * The visibility. If <b>false</b>, the sprite is not rendered.\n *\n * @property visible\n * @type boolean\n * @protected\n ###\n @visible = no\n\n ###*\n * Indicates if the image is loaded.\n *\n * @property imageLoaded\n * @type boolean\n * @protected\n ###\n @imageLoaded = no\n \n \n \n ###*\n * Disposes the sprite. If the sprite is managed, it will be automatically\n * removed from the graphics system and viewport.\n * @method dispose\n ###\n dispose: -> \n super\n \n if @sprite\n @sprite.dispose()\n \n if @sprite.video\n @sprite.video.stop()\n \n if not @sprite.managed\n @sprite.viewport?.removeGraphicObject(@sprite)\n Graphics.viewport?.removeGraphicObject(@sprite)\n \n ###*\n * Adds event-handlers for mouse/touch events\n *\n * @method setupEventHandlers\n ### \n setupEventHandlers: ->\n @sprite.onIndexChange = =>\n @object.rIndex = @sprite.index\n @object.needsUpdate = yes\n \n ###*\n * Setup the sprite. \n * @method setupSprite\n ### \n setupSprite: ->\n if !@sprite\n @sprite = new gs.Sprite(Graphics.viewport, managed ? yes)\n \n ###*\n * Setup the sprite component. This method is automatically called by the\n * system.\n * @method setup\n ###\n setup: ->\n @isSetup = yes\n @setupSprite()\n @setupEventHandlers()\n @update()\n \n \n ###*\n * Updates the source- and destination-rectangle of the game object so that\n * the associated bitmap fits in. The imageHandling property controls how\n * the rectangles are resized.\n * @method updateRect\n ###\n updateRect: ->\n if @sprite.bitmap?\n if !@object.imageHandling\n @object.srcRect = new Rect(0, 0, @sprite.bitmap.width, @sprite.bitmap.height)\n if not @object.fixedSize\n @object.dstRect.width = @object.srcRect.width\n @object.dstRect.height = @object.srcRect.height\n else if @object.imageHandling == 1\n @object.srcRect = new Rect(0, 0, @sprite.bitmap.width, @sprite.bitmap.height / 2)\n if not @object.fixedSize\n @object.dstRect.width = @object.srcRect.width\n @object.dstRect.height = @object.srcRect.height\n else if @object.imageHandling == 2\n if not @object.fixedSize\n @object.dstRect.width = @object.srcRect.width\n @object.dstRect.height = @object.srcRect.height\n \n ###*\n * Updates the bitmap object from the associated image name. The imageFolder\n * property controls from which resource-folder the image will be loaded.\n * @method updateBitmap\n ###\n updateBitmap: ->\n @imageLoaded = no\n @image = @object.image\n \n if @object.image.startsWith(\"data:\") || @object.image.startsWith(\"$\")\n @sprite.bitmap = ResourceManager.getBitmap(@object.image)\n else\n @sprite.bitmap = ResourceManager.getBitmap(\"#{@object.imageFolder||@imageFolder}/#{@object.image}\")\n \n if @sprite.bitmap? \n if not @imageLoaded\n @imageLoaded = @sprite.bitmap.loaded\n else\n delete @sprite.bitmap.loaded_\n \n @object.bitmap = @sprite.bitmap\n \n ###*\n * Updates the video object from the associated video name. It also updates\n * the video-rendering process.\n * @method updateVideo\n ###\n updateVideo: ->\n if @object.video != @videoName\n @videoName = @object.video\n @sprite.video = ResourceManager.getVideo(\"Movies/#{@object.video}\")\n if @sprite.video?\n if $PARAMS.preview?.settings.musicDisabled\n @sprite.video.volume = 0\n @sprite.video.loop = @object.loop\n @sprite.video.play()\n \n @object.srcRect = new Rect(0, 0, @sprite.video.width, @sprite.video.height)\n if not @object.fixedSize\n @object.dstRect = new Rect(@object.dstRect.x, @object.dstRect.y, @sprite.video.width, @sprite.video.height)\n \n @sprite.video?.update()\n \n ###*\n * Updates the image if the game object has the image-property set.\n * @method updateImage\n ###\n updateImage: ->\n if @object.image?\n if @object.image != @image or (!@imageLoaded and @sprite.bitmap?.loaded)\n @updateBitmap()\n @updateRect()\n else if @object.bitmap? \n @sprite.bitmap = @object.bitmap\n else if @object.video? or @videoName != @object.video\n @updateVideo()\n else\n @image = null\n @object.bitmap = null\n @sprite.bitmap = null\n \n ###*\n * If the sprite is unmanaged, this method will update the visibility of the\n * sprite. If the sprite leaves the viewport, it will be removed to save \n * performance and automatically added back to the viewport if it enters\n * the viewport.\n * @method updateVisibility\n ###\n updateVisibility: ->\n if !@sprite.managed\n visible = Rect.intersect(@object.dstRect.x+@object.origin.x, @object.dstRect.y+@object.origin.y, @object.dstRect.width, @object.dstRect.height, \n 0, 0, Graphics.width, Graphics.height)\n if visible and !@visible\n (@object.viewport || Graphics.viewport).addGraphicObject(@sprite)\n @visible = yes\n \n if !visible and @visible\n (@object.viewport || Graphics.viewport).removeGraphicObject(@sprite)\n @visible = no\n \n \n ###*\n * Updates the padding.\n * @method updatePadding\n ###\n updatePadding: ->\n if @object.padding?\n @sprite.x += @object.padding.left\n @sprite.y += @object.padding.top\n @sprite.zoomX -= (@object.padding.left+@object.padding.right) / @object.srcRect.width\n @sprite.zoomY -= (@object.padding.bottom+@object.padding.bottom) / @object.srcRect.height\n \n ###*\n * Updates the sprite properties from the game object properties.\n * @method updateProperties\n ###\n updateProperties: ->\n @sprite.width = @object.dstRect.width\n @sprite.height = @object.dstRect.height\n @sprite.x = @object.dstRect.x \n @sprite.y = @object.dstRect.y\n @sprite.mask = @object.mask ? @mask\n @sprite.angle = @object.angle || 0\n @sprite.opacity = @object.opacity ? 255\n @sprite.clipRect = @object.clipRect\n @sprite.srcRect = @object.srcRect\n @sprite.blendingMode = @object.blendMode || 0\n @sprite.mirror = @object.mirror\n @sprite.visible = @object.visible and (!@object.parent or !@object.parent.visible? or @object.parent.visible)\n @sprite.ox = -@object.origin.x\n @sprite.oy = -@object.origin.y\n @sprite.z = (@object.zIndex || 0) + (if !@object.parent then 0 else @object.parent.zIndex || 0)\n \n ###*\n * Updates the optional sprite properties from the game object properties.\n * @method updateOptionalProperties\n ###\n updateOptionalProperties: ->\n if @object.tone?\n @sprite.tone = @object.tone\n if @object.color?\n @sprite.color = @object.color\n if @object.viewport?\n @sprite.viewport = @object.viewport\n if @object.effects?\n @sprite.effects = @object.effects\n if @object.anchor?\n @sprite.anchor.x = @object.anchor.x\n @sprite.anchor.y = @object.anchor.y\n if @object.positionAnchor?\n @sprite.positionAnchor = @object.positionAnchor\n if @object.zoom?\n @sprite.zoomX = @object.zoom.x\n @sprite.zoomY = @object.zoom.y\n if @object.motionBlur?\n @sprite.motionBlur = @object.motionBlur\n \n ###*\n * Updates the sprite component by updating its visibility, image, padding and\n * properties.\n * @method update\n ###\n update: ->\n super\n \n @setup() if not @isSetup\n @updateVisibility()\n @updateImage()\n @updateProperties()\n @updateOptionalProperties()\n @updatePadding()\n \n @object.rIndex = @sprite.index\n @sprite.update()\n \n\n###*\n* Enumeration of appearance animations. \n*\n* @module gs\n* @class AnimationTypes\n* @static\n* @memberof gs\n###\nclass AnimationTypes\n @initialize: -> \n ###*\n * An object appears or disappears by moving into or out of the screen.\n * @property MOVEMENT\n * @type number\n * @static\n * @final\n ###\n @MOVEMENT = 0\n ###*\n * An object appears or disappears using alpha-blending.\n * @property BLENDING\n * @type number\n * @static\n * @final\n ###\n @BLENDING = 1\n ###*\n * An object appears or disappears using a mask-image.\n * @property MASKING\n * @type number\n * @static\n * @final\n ###\n @MASKING = 2\n\nAnimationTypes.initialize() \ngs.AnimationTypes = AnimationTypes\ngs.Component_Sprite = Component_Sprite\n",
10 10 "parentId": "D3325122KACDEA4515SB731E37A42B9D779F",
11 11 "folder": false,
12 - "compiledContent": "var AnimationTypes, Component_Sprite,\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_Sprite = (function(superClass) {\n extend(Component_Sprite, 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_Sprite.prototype.onDataBundleRestore = function(data, context) {\n return this.setupEventHandlers();\n };\n\n\n /**\n * A sprite component to display an object on screen. It can be managed or\n * unmanaged. A managed sprite is automatically added to the graphics-system\n * and rendered every frame until it gets disposed. An unmanaged sprite needs\n * to be added and removed manually.\n *\n * @module gs\n * @class Component_Sprite\n * @extends gs.Component_Visual\n * @memberof gs\n * @constructor\n * @param {boolean} managed - Indicates if the sprite is managed by the graphics system.\n */\n\n function Component_Sprite(managed) {\n Component_Sprite.__super__.constructor.call(this);\n\n /**\n * The native sprite object to display the game object on screen.\n *\n * @property sprite\n * @type Sprite\n * @protected\n */\n this.sprite = null;\n\n /**\n * The name of the image to display.\n *\n * @property image\n * @type string\n * @protected\n */\n this.image = null;\n\n /**\n * The name of the video to display.\n *\n * @property video\n * @type string\n * @protected\n */\n this.video = null;\n\n /**\n * The name of the folder from where the image should be loaded.\n *\n * @property image\n * @type string\n * @protected\n */\n this.imageFolder = \"Graphics/Pictures\";\n\n /**\n * The visibility. If <b>false</b>, the sprite is not rendered.\n *\n * @property visible\n * @type boolean\n * @protected\n */\n this.visible = false;\n\n /**\n * Indicates if the image is loaded.\n *\n * @property imageLoaded\n * @type boolean\n * @protected\n */\n this.imageLoaded = false;\n }\n\n\n /**\n * Disposes the sprite. If the sprite is managed, it will be automatically\n * removed from the graphics system and viewport.\n * @method dispose\n */\n\n Component_Sprite.prototype.dispose = function() {\n var ref, ref1;\n Component_Sprite.__super__.dispose.apply(this, arguments);\n if (this.sprite) {\n this.sprite.dispose();\n if (this.sprite.video) {\n this.sprite.video.stop();\n }\n if (!this.sprite.managed) {\n if ((ref = this.sprite.viewport) != null) {\n ref.removeGraphicObject(this.sprite);\n }\n return (ref1 = Graphics.viewport) != null ? ref1.removeGraphicObject(this.sprite) : void 0;\n }\n }\n };\n\n\n /**\n * Adds event-handlers for mouse/touch events\n *\n * @method setupEventHandlers\n */\n\n Component_Sprite.prototype.setupEventHandlers = function() {\n return this.sprite.onIndexChange = (function(_this) {\n return function() {\n _this.object.rIndex = _this.sprite.index;\n return _this.object.needsUpdate = true;\n };\n })(this);\n };\n\n\n /**\n * Setup the sprite.\n * @method setupSprite\n */\n\n Component_Sprite.prototype.setupSprite = function() {\n if (!this.sprite) {\n return this.sprite = new Sprite(Graphics.viewport, typeof managed !== \"undefined\" && managed !== null ? managed : true);\n }\n };\n\n\n /**\n * Setup the sprite component. This method is automatically called by the\n * system.\n * @method setup\n */\n\n Component_Sprite.prototype.setup = function() {\n this.isSetup = true;\n this.setupSprite();\n this.setupEventHandlers();\n return this.update();\n };\n\n\n /**\n * Updates the source- and destination-rectangle of the game object so that\n * the associated bitmap fits in. The imageHandling property controls how\n * the rectangles are resized.\n * @method updateRect\n */\n\n Component_Sprite.prototype.updateRect = function() {\n if (this.sprite.bitmap != null) {\n if (!this.object.imageHandling) {\n this.object.srcRect = new Rect(0, 0, this.sprite.bitmap.width, this.sprite.bitmap.height);\n if (!this.object.fixedSize) {\n this.object.dstRect.width = this.object.srcRect.width;\n return this.object.dstRect.height = this.object.srcRect.height;\n }\n } else if (this.object.imageHandling === 1) {\n this.object.srcRect = new Rect(0, 0, this.sprite.bitmap.width, this.sprite.bitmap.height / 2);\n if (!this.object.fixedSize) {\n this.object.dstRect.width = this.object.srcRect.width;\n return this.object.dstRect.height = this.object.srcRect.height;\n }\n } else if (this.object.imageHandling === 2) {\n if (!this.object.fixedSize) {\n this.object.dstRect.width = this.object.srcRect.width;\n return this.object.dstRect.height = this.object.srcRect.height;\n }\n }\n }\n };\n\n\n /**\n * Updates the bitmap object from the associated image name. The imageFolder\n * property controls from which resource-folder the image will be loaded.\n * @method updateBitmap\n */\n\n Component_Sprite.prototype.updateBitmap = function() {\n this.imageLoaded = false;\n this.image = this.object.image;\n if (this.object.image.startsWith(\"data:\") || this.object.image.startsWith(\"$\")) {\n this.sprite.bitmap = ResourceManager.getBitmap(this.object.image);\n } else {\n this.sprite.bitmap = ResourceManager.getBitmap((this.object.imageFolder || this.imageFolder) + \"/\" + this.object.image);\n }\n if (this.sprite.bitmap != null) {\n if (!this.imageLoaded) {\n this.imageLoaded = this.sprite.bitmap.loaded;\n } else {\n delete this.sprite.bitmap.loaded_;\n }\n }\n return this.object.bitmap = this.sprite.bitmap;\n };\n\n\n /**\n * Updates the video object from the associated video name. It also updates\n * the video-rendering process.\n * @method updateVideo\n */\n\n Component_Sprite.prototype.updateVideo = function() {\n var ref, ref1;\n if (this.object.video !== this.videoName) {\n this.videoName = this.object.video;\n this.sprite.video = ResourceManager.getVideo(\"Movies/\" + this.object.video);\n if (this.sprite.video != null) {\n if ((ref = $PARAMS.preview) != null ? ref.settings.musicDisabled : void 0) {\n this.sprite.video.volume = 0;\n }\n this.sprite.video.loop = this.object.loop;\n this.sprite.video.play();\n this.object.srcRect = new Rect(0, 0, this.sprite.video.width, this.sprite.video.height);\n if (!this.object.fixedSize) {\n this.object.dstRect = new Rect(this.object.dstRect.x, this.object.dstRect.y, this.sprite.video.width, this.sprite.video.height);\n }\n }\n }\n return (ref1 = this.sprite.video) != null ? ref1.update() : void 0;\n };\n\n\n /**\n * Updates the image if the game object has the image-property set.\n * @method updateImage\n */\n\n Component_Sprite.prototype.updateImage = function() {\n var ref;\n if (this.object.image != null) {\n if (this.object.image !== this.image || (!this.imageLoaded && ((ref = this.sprite.bitmap) != null ? ref.loaded : void 0))) {\n this.updateBitmap();\n return this.updateRect();\n }\n } else if (this.object.bitmap != null) {\n return this.sprite.bitmap = this.object.bitmap;\n } else if ((this.object.video != null) || this.videoName !== this.object.video) {\n return this.updateVideo();\n } else {\n this.image = null;\n this.object.bitmap = null;\n return this.sprite.bitmap = null;\n }\n };\n\n\n /**\n * If the sprite is unmanaged, this method will update the visibility of the\n * sprite. If the sprite leaves the viewport, it will be removed to save \n * performance and automatically added back to the viewport if it enters\n * the viewport.\n * @method updateVisibility\n */\n\n Component_Sprite.prototype.updateVisibility = function() {\n var visible;\n if (!this.sprite.managed) {\n visible = Rect.intersect(this.object.dstRect.x + this.object.origin.x, this.object.dstRect.y + this.object.origin.y, this.object.dstRect.width, this.object.dstRect.height, 0, 0, Graphics.width, Graphics.height);\n if (visible && !this.visible) {\n (this.object.viewport || Graphics.viewport).addGraphicObject(this.sprite);\n this.visible = true;\n }\n if (!visible && this.visible) {\n (this.object.viewport || Graphics.viewport).removeGraphicObject(this.sprite);\n return this.visible = false;\n }\n }\n };\n\n\n /**\n * Updates the padding.\n * @method updatePadding\n */\n\n Component_Sprite.prototype.updatePadding = function() {\n if (this.object.padding != null) {\n this.sprite.x += this.object.padding.left;\n this.sprite.y += this.object.padding.top;\n this.sprite.zoomX -= (this.object.padding.left + this.object.padding.right) / this.object.srcRect.width;\n return this.sprite.zoomY -= (this.object.padding.bottom + this.object.padding.bottom) / this.object.srcRect.height;\n }\n };\n\n\n /**\n * Updates the sprite properties from the game object properties.\n * @method updateProperties\n */\n\n Component_Sprite.prototype.updateProperties = function() {\n var ref, ref1;\n this.sprite.width = this.object.dstRect.width;\n this.sprite.height = this.object.dstRect.height;\n this.sprite.x = this.object.dstRect.x;\n this.sprite.y = this.object.dstRect.y;\n this.sprite.mask = (ref = this.object.mask) != null ? ref : this.mask;\n this.sprite.angle = this.object.angle || 0;\n this.sprite.opacity = (ref1 = this.object.opacity) != null ? ref1 : 255;\n this.sprite.clipRect = this.object.clipRect;\n this.sprite.srcRect = this.object.srcRect;\n this.sprite.blendingMode = this.object.blendMode || 0;\n this.sprite.mirror = this.object.mirror;\n this.sprite.visible = this.object.visible && (!this.object.parent || (this.object.parent.visible == null) || this.object.parent.visible);\n this.sprite.ox = -this.object.origin.x;\n this.sprite.oy = -this.object.origin.y;\n return this.sprite.z = (this.object.zIndex || 0) + (!this.object.parent ? 0 : this.object.parent.zIndex || 0);\n };\n\n\n /**\n * Updates the optional sprite properties from the game object properties.\n * @method updateOptionalProperties\n */\n\n Component_Sprite.prototype.updateOptionalProperties = function() {\n if (this.object.tone != null) {\n this.sprite.tone = this.object.tone;\n }\n if (this.object.color != null) {\n this.sprite.color = this.object.color;\n }\n if (this.object.viewport != null) {\n this.sprite.viewport = this.object.viewport;\n }\n if (this.object.effects != null) {\n this.sprite.effects = this.object.effects;\n }\n if (this.object.anchor != null) {\n this.sprite.anchor.x = this.object.anchor.x;\n this.sprite.anchor.y = this.object.anchor.y;\n }\n if (this.object.positionAnchor != null) {\n this.sprite.positionAnchor = this.object.positionAnchor;\n }\n if (this.object.zoom != null) {\n this.sprite.zoomX = this.object.zoom.x;\n this.sprite.zoomY = this.object.zoom.y;\n }\n if (this.object.motionBlur != null) {\n return this.sprite.motionBlur = this.object.motionBlur;\n }\n };\n\n\n /**\n * Updates the sprite component by updating its visibility, image, padding and\n * properties.\n * @method update\n */\n\n Component_Sprite.prototype.update = function() {\n Component_Sprite.__super__.update.apply(this, arguments);\n if (!this.isSetup) {\n this.setup();\n }\n this.updateVisibility();\n this.updateImage();\n this.updateProperties();\n this.updateOptionalProperties();\n this.updatePadding();\n this.object.rIndex = this.sprite.index;\n return this.sprite.update();\n };\n\n return Component_Sprite;\n\n})(gs.Component_Visual);\n\n\n/**\n* Enumeration of appearance animations. \n*\n* @module gs\n* @class AnimationTypes\n* @static\n* @memberof gs\n */\n\nAnimationTypes = (function() {\n function AnimationTypes() {}\n\n AnimationTypes.initialize = function() {\n\n /**\n * An object appears or disappears by moving into or out of the screen.\n * @property MOVEMENT\n * @type number\n * @static\n * @final\n */\n this.MOVEMENT = 0;\n\n /**\n * An object appears or disappears using alpha-blending.\n * @property BLENDING\n * @type number\n * @static\n * @final\n */\n this.BLENDING = 1;\n\n /**\n * An object appears or disappears using a mask-image.\n * @property MASKING\n * @type number\n * @static\n * @final\n */\n return this.MASKING = 2;\n };\n\n return AnimationTypes;\n\n})();\n\nAnimationTypes.initialize();\n\ngs.AnimationTypes = AnimationTypes;\n\ngs.Component_Sprite = Component_Sprite;\n\n//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"","sourceRoot":"","sources":[""],"names":[],"mappings":"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","sourcesContent":["# ===================================================================\n#\n#   Script: Component\n#\n#   $$COPYRIGHT$$\n#\n# ===================================================================\nclass Component_Sprite 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        \n    ###*\n    * A sprite component to display an object on screen. It can be managed or\n    * unmanaged. A managed sprite is automatically added to the graphics-system\n    * and rendered every frame until it gets disposed. An unmanaged sprite needs\n    * to be added and removed manually.\n    *\n    * @module gs\n    * @class Component_Sprite\n    * @extends gs.Component_Visual\n    * @memberof gs\n    * @constructor\n    * @param {boolean} managed - Indicates if the sprite is managed by the graphics system.\n    ###\n    constructor: (managed) ->\n        super()\n\n        ###*\n        * The native sprite object to display the game object on screen.\n        *\n        * @property sprite\n        * @type Sprite\n        * @protected\n        ###\n        @sprite = null\n        \n        ###*\n        * The name of the image to display.\n        *\n        * @property image\n        * @type string\n        * @protected\n        ###\n        @image = null\n        \n        ###*\n        * The name of the video to display.\n        *\n        * @property video\n        * @type string\n        * @protected\n        ###\n        @video = null\n        \n        ###*\n        * The name of the folder from where the image should be loaded.\n        *\n        * @property image\n        * @type string\n        * @protected\n        ###\n        @imageFolder = \"Graphics/Pictures\"\n        \n        ###*\n        * The visibility. If <b>false</b>, the sprite is not rendered.\n        *\n        * @property visible\n        * @type boolean\n        * @protected\n        ###\n        @visible = no\n\n        ###*\n        * Indicates if the image is loaded.\n        *\n        * @property imageLoaded\n        * @type boolean\n        * @protected\n        ###\n        @imageLoaded = no\n        \n    ###*\n    * Disposes the sprite. If the sprite is managed, it will be automatically\n    * removed from the graphics system and viewport.\n    * @method dispose\n    ###\n    dispose: -> \n        super\n        \n        if @sprite\n            @sprite.dispose()\n            \n            if @sprite.video\n                @sprite.video.stop()\n            \n            if not @sprite.managed\n                @sprite.viewport?.removeGraphicObject(@sprite)\n                Graphics.viewport?.removeGraphicObject(@sprite)\n \n    ###*\n    * Adds event-handlers for mouse/touch events\n    *\n    * @method setupEventHandlers\n    ### \n    setupEventHandlers: ->\n        @sprite.onIndexChange = =>\n            @object.rIndex = @sprite.index\n            @object.needsUpdate = yes\n    \n    ###*\n    * Setup the sprite.\n    * @method setupSprite\n    ### \n    setupSprite: ->\n        if !@sprite\n            @sprite = new Sprite(Graphics.viewport, managed ? yes)\n            \n    ###*\n    * Setup the sprite component. This method is automatically called by the\n    * system.\n    * @method setup\n    ###\n    setup: ->\n        @isSetup = yes\n        @setupSprite()\n        @setupEventHandlers()\n        @update()\n        \n    \n    ###*\n    * Updates the source- and destination-rectangle of the game object so that\n    * the associated bitmap fits in. The imageHandling property controls how\n    * the rectangles are resized.\n    * @method updateRect\n    ###\n    updateRect: ->\n        if @sprite.bitmap?\n            if !@object.imageHandling\n                @object.srcRect = new Rect(0, 0, @sprite.bitmap.width, @sprite.bitmap.height)\n                if not @object.fixedSize\n                    @object.dstRect.width = @object.srcRect.width\n                    @object.dstRect.height = @object.srcRect.height\n            else if @object.imageHandling == 1\n                @object.srcRect = new Rect(0, 0, @sprite.bitmap.width, @sprite.bitmap.height / 2)\n                if not @object.fixedSize\n                    @object.dstRect.width = @object.srcRect.width\n                    @object.dstRect.height = @object.srcRect.height\n            else if @object.imageHandling == 2\n                if not @object.fixedSize\n                    @object.dstRect.width = @object.srcRect.width\n                    @object.dstRect.height = @object.srcRect.height\n                    \n    ###*\n    * Updates the bitmap object from the associated image name. The imageFolder\n    * property controls from which resource-folder the image will be loaded.\n    * @method updateBitmap\n    ###\n    updateBitmap: ->\n        @imageLoaded = no\n        @image = @object.image\n        \n        if @object.image.startsWith(\"data:\") || @object.image.startsWith(\"$\")\n            @sprite.bitmap = ResourceManager.getBitmap(@object.image)\n        else\n            @sprite.bitmap = ResourceManager.getBitmap(\"#{@object.imageFolder||@imageFolder}/#{@object.image}\")\n          \n        if @sprite.bitmap?  \n            if not @imageLoaded\n                @imageLoaded = @sprite.bitmap.loaded\n            else\n                delete @sprite.bitmap.loaded_\n            \n        @object.bitmap = @sprite.bitmap\n        \n    ###*\n    * Updates the video object from the associated video name. It also updates\n    * the video-rendering process.\n    * @method updateVideo\n    ###\n    updateVideo: ->\n        if @object.video != @videoName\n            @videoName = @object.video\n            @sprite.video = ResourceManager.getVideo(\"Movies/#{@object.video}\")\n            if @sprite.video?\n                if $PARAMS.preview?.settings.musicDisabled\n                    @sprite.video.volume = 0\n                @sprite.video.loop = @object.loop\n                @sprite.video.play()\n                \n                @object.srcRect = new Rect(0, 0, @sprite.video.width, @sprite.video.height)\n                if not @object.fixedSize\n                    @object.dstRect = new Rect(@object.dstRect.x, @object.dstRect.y, @sprite.video.width, @sprite.video.height)\n                \n        @sprite.video?.update()\n        \n    ###*\n    * Updates the image if the game object has the image-property set.\n    * @method updateImage\n    ###\n    updateImage: ->\n        if @object.image?\n            if @object.image != @image or (!@imageLoaded and @sprite.bitmap?.loaded)\n                @updateBitmap()\n                @updateRect()\n        else if @object.bitmap?    \n            @sprite.bitmap = @object.bitmap\n        else if @object.video? or @videoName != @object.video\n            @updateVideo()\n        else\n            @image = null\n            @object.bitmap = null\n            @sprite.bitmap = null\n            \n    ###*\n    * If the sprite is unmanaged, this method will update the visibility of the\n    * sprite. If the sprite leaves the viewport, it will be removed to save \n    * performance and automatically added back to the viewport if it enters\n    * the viewport.\n    * @method updateVisibility\n    ###\n    updateVisibility: ->\n        if !@sprite.managed\n            visible = Rect.intersect(@object.dstRect.x+@object.origin.x, @object.dstRect.y+@object.origin.y, @object.dstRect.width, @object.dstRect.height, \n                                     0, 0, Graphics.width, Graphics.height)\n            if visible and !@visible\n                (@object.viewport || Graphics.viewport).addGraphicObject(@sprite)\n                @visible = yes\n                \n            if !visible and @visible\n                (@object.viewport || Graphics.viewport).removeGraphicObject(@sprite)\n                @visible = no\n                \n      \n    ###*\n    * Updates the padding.\n    * @method updatePadding\n    ###\n    updatePadding: ->\n        if @object.padding?\n            @sprite.x += @object.padding.left\n            @sprite.y += @object.padding.top\n            @sprite.zoomX -= (@object.padding.left+@object.padding.right) / @object.srcRect.width\n            @sprite.zoomY -= (@object.padding.bottom+@object.padding.bottom) / @object.srcRect.height\n     \n    ###*\n    * Updates the sprite properties from the game object properties.\n    * @method updateProperties\n    ###\n    updateProperties: ->\n        @sprite.width = @object.dstRect.width\n        @sprite.height = @object.dstRect.height\n        @sprite.x = @object.dstRect.x \n        @sprite.y = @object.dstRect.y\n        @sprite.mask = @object.mask ? @mask\n        @sprite.angle = @object.angle || 0\n        @sprite.opacity = @object.opacity ? 255\n        @sprite.clipRect = @object.clipRect\n        @sprite.srcRect = @object.srcRect\n        @sprite.blendingMode = @object.blendMode || 0\n        @sprite.mirror = @object.mirror\n        @sprite.visible = @object.visible and (!@object.parent or !@object.parent.visible? or @object.parent.visible)\n        @sprite.ox = -@object.origin.x\n        @sprite.oy = -@object.origin.y\n        @sprite.z = (@object.zIndex || 0) + (if !@object.parent then 0 else @object.parent.zIndex || 0)\n        \n    ###*\n    * Updates the optional sprite properties from the game object properties.\n    * @method updateOptionalProperties\n    ###\n    updateOptionalProperties: ->\n        if @object.tone?\n            @sprite.tone = @object.tone\n        if @object.color?\n            @sprite.color = @object.color\n        if @object.viewport?\n            @sprite.viewport = @object.viewport\n        if @object.effects?\n            @sprite.effects = @object.effects\n        if @object.anchor?\n            @sprite.anchor.x = @object.anchor.x\n            @sprite.anchor.y = @object.anchor.y\n        if @object.positionAnchor?\n            @sprite.positionAnchor = @object.positionAnchor\n        if @object.zoom?\n            @sprite.zoomX = @object.zoom.x\n            @sprite.zoomY = @object.zoom.y\n        if @object.motionBlur?\n            @sprite.motionBlur = @object.motionBlur\n        \n    ###*\n    * Updates the sprite component by updating its visibility, image, padding and\n    * properties.\n    * @method update\n    ###\n    update: ->\n        super\n        \n        @setup() if not @isSetup\n        @updateVisibility()\n        @updateImage()\n        @updateProperties()\n        @updateOptionalProperties()\n        @updatePadding()\n        \n        @object.rIndex = @sprite.index\n        @sprite.update()\n        \n\n###*\n* Enumeration of appearance animations. \n*\n* @module gs\n* @class AnimationTypes\n* @static\n* @memberof gs\n###\nclass AnimationTypes\n    @initialize: ->    \n        ###*\n        * An object appears or disappears by moving into or out of the screen.\n        * @property MOVEMENT\n        * @type number\n        * @static\n        * @final\n        ###\n        @MOVEMENT = 0\n        ###*\n        * An object appears or disappears using alpha-blending.\n        * @property BLENDING\n        * @type number\n        * @static\n        * @final\n        ###\n        @BLENDING = 1\n        ###*\n        * An object appears or disappears using a mask-image.\n        * @property MASKING\n        * @type number\n        * @static\n        * @final\n        ###\n        @MASKING = 2\n\nAnimationTypes.initialize()    \ngs.AnimationTypes = AnimationTypes\ngs.Component_Sprite = Component_Sprite\n"]}\n//# sourceURL=Component_Sprite_59.js"
12 + "compiledContent": "var AnimationTypes, Component_Sprite,\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_Sprite = (function(superClass) {\n extend(Component_Sprite, 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_Sprite.prototype.onDataBundleRestore = function(data, context) {\n return this.setupEventHandlers();\n };\n\n\n /**\n * A sprite component to display an object on screen. It can be managed or\n * unmanaged. A managed sprite is automatically added to the graphics-system\n * and rendered every frame until it gets disposed. An unmanaged sprite needs\n * to be added and removed manually.\n *\n * @module gs\n * @class Component_Sprite\n * @extends gs.Component_Visual\n * @memberof gs\n * @constructor\n * @param {boolean} managed - Indicates if the sprite is managed by the graphics system.\n */\n\n function Component_Sprite(managed) {\n Component_Sprite.__super__.constructor.call(this);\n\n /**\n * The native sprite object to display the game object on screen.\n *\n * @property sprite\n * @type Sprite\n * @protected\n */\n this.sprite = null;\n\n /**\n * The name of the image to display.\n *\n * @property image\n * @type string\n * @protected\n */\n this.image = null;\n\n /**\n * The name of the video to display.\n *\n * @property video\n * @type string\n * @protected\n */\n this.video = null;\n\n /**\n * The name of the folder from where the image should be loaded.\n *\n * @property image\n * @type string\n * @protected\n */\n this.imageFolder = \"Graphics/Pictures\";\n\n /**\n * The visibility. If <b>false</b>, the sprite is not rendered.\n *\n * @property visible\n * @type boolean\n * @protected\n */\n this.visible = false;\n\n /**\n * Indicates if the image is loaded.\n *\n * @property imageLoaded\n * @type boolean\n * @protected\n */\n this.imageLoaded = false;\n }\n\n\n /**\n * Disposes the sprite. If the sprite is managed, it will be automatically\n * removed from the graphics system and viewport.\n * @method dispose\n */\n\n Component_Sprite.prototype.dispose = function() {\n var ref, ref1;\n Component_Sprite.__super__.dispose.apply(this, arguments);\n if (this.sprite) {\n this.sprite.dispose();\n if (this.sprite.video) {\n this.sprite.video.stop();\n }\n if (!this.sprite.managed) {\n if ((ref = this.sprite.viewport) != null) {\n ref.removeGraphicObject(this.sprite);\n }\n return (ref1 = Graphics.viewport) != null ? ref1.removeGraphicObject(this.sprite) : void 0;\n }\n }\n };\n\n\n /**\n * Adds event-handlers for mouse/touch events\n *\n * @method setupEventHandlers\n */\n\n Component_Sprite.prototype.setupEventHandlers = function() {\n return this.sprite.onIndexChange = (function(_this) {\n return function() {\n _this.object.rIndex = _this.sprite.index;\n return _this.object.needsUpdate = true;\n };\n })(this);\n };\n\n\n /**\n * Setup the sprite. \n * @method setupSprite\n */\n\n Component_Sprite.prototype.setupSprite = function() {\n if (!this.sprite) {\n return this.sprite = new gs.Sprite(Graphics.viewport, typeof managed !== \"undefined\" && managed !== null ? managed : true);\n }\n };\n\n\n /**\n * Setup the sprite component. This method is automatically called by the\n * system.\n * @method setup\n */\n\n Component_Sprite.prototype.setup = function() {\n this.isSetup = true;\n this.setupSprite();\n this.setupEventHandlers();\n return this.update();\n };\n\n\n /**\n * Updates the source- and destination-rectangle of the game object so that\n * the associated bitmap fits in. The imageHandling property controls how\n * the rectangles are resized.\n * @method updateRect\n */\n\n Component_Sprite.prototype.updateRect = function() {\n if (this.sprite.bitmap != null) {\n if (!this.object.imageHandling) {\n this.object.srcRect = new Rect(0, 0, this.sprite.bitmap.width, this.sprite.bitmap.height);\n if (!this.object.fixedSize) {\n this.object.dstRect.width = this.object.srcRect.width;\n return this.object.dstRect.height = this.object.srcRect.height;\n }\n } else if (this.object.imageHandling === 1) {\n this.object.srcRect = new Rect(0, 0, this.sprite.bitmap.width, this.sprite.bitmap.height / 2);\n if (!this.object.fixedSize) {\n this.object.dstRect.width = this.object.srcRect.width;\n return this.object.dstRect.height = this.object.srcRect.height;\n }\n } else if (this.object.imageHandling === 2) {\n if (!this.object.fixedSize) {\n this.object.dstRect.width = this.object.srcRect.width;\n return this.object.dstRect.height = this.object.srcRect.height;\n }\n }\n }\n };\n\n\n /**\n * Updates the bitmap object from the associated image name. The imageFolder\n * property controls from which resource-folder the image will be loaded.\n * @method updateBitmap\n */\n\n Component_Sprite.prototype.updateBitmap = function() {\n this.imageLoaded = false;\n this.image = this.object.image;\n if (this.object.image.startsWith(\"data:\") || this.object.image.startsWith(\"$\")) {\n this.sprite.bitmap = ResourceManager.getBitmap(this.object.image);\n } else {\n this.sprite.bitmap = ResourceManager.getBitmap((this.object.imageFolder || this.imageFolder) + \"/\" + this.object.image);\n }\n if (this.sprite.bitmap != null) {\n if (!this.imageLoaded) {\n this.imageLoaded = this.sprite.bitmap.loaded;\n } else {\n delete this.sprite.bitmap.loaded_;\n }\n }\n return this.object.bitmap = this.sprite.bitmap;\n };\n\n\n /**\n * Updates the video object from the associated video name. It also updates\n * the video-rendering process.\n * @method updateVideo\n */\n\n Component_Sprite.prototype.updateVideo = function() {\n var ref, ref1;\n if (this.object.video !== this.videoName) {\n this.videoName = this.object.video;\n this.sprite.video = ResourceManager.getVideo(\"Movies/\" + this.object.video);\n if (this.sprite.video != null) {\n if ((ref = $PARAMS.preview) != null ? ref.settings.musicDisabled : void 0) {\n this.sprite.video.volume = 0;\n }\n this.sprite.video.loop = this.object.loop;\n this.sprite.video.play();\n this.object.srcRect = new Rect(0, 0, this.sprite.video.width, this.sprite.video.height);\n if (!this.object.fixedSize) {\n this.object.dstRect = new Rect(this.object.dstRect.x, this.object.dstRect.y, this.sprite.video.width, this.sprite.video.height);\n }\n }\n }\n return (ref1 = this.sprite.video) != null ? ref1.update() : void 0;\n };\n\n\n /**\n * Updates the image if the game object has the image-property set.\n * @method updateImage\n */\n\n Component_Sprite.prototype.updateImage = function() {\n var ref;\n if (this.object.image != null) {\n if (this.object.image !== this.image || (!this.imageLoaded && ((ref = this.sprite.bitmap) != null ? ref.loaded : void 0))) {\n this.updateBitmap();\n return this.updateRect();\n }\n } else if (this.object.bitmap != null) {\n return this.sprite.bitmap = this.object.bitmap;\n } else if ((this.object.video != null) || this.videoName !== this.object.video) {\n return this.updateVideo();\n } else {\n this.image = null;\n this.object.bitmap = null;\n return this.sprite.bitmap = null;\n }\n };\n\n\n /**\n * If the sprite is unmanaged, this method will update the visibility of the\n * sprite. If the sprite leaves the viewport, it will be removed to save \n * performance and automatically added back to the viewport if it enters\n * the viewport.\n * @method updateVisibility\n */\n\n Component_Sprite.prototype.updateVisibility = function() {\n var visible;\n if (!this.sprite.managed) {\n visible = Rect.intersect(this.object.dstRect.x + this.object.origin.x, this.object.dstRect.y + this.object.origin.y, this.object.dstRect.width, this.object.dstRect.height, 0, 0, Graphics.width, Graphics.height);\n if (visible && !this.visible) {\n (this.object.viewport || Graphics.viewport).addGraphicObject(this.sprite);\n this.visible = true;\n }\n if (!visible && this.visible) {\n (this.object.viewport || Graphics.viewport).removeGraphicObject(this.sprite);\n return this.visible = false;\n }\n }\n };\n\n\n /**\n * Updates the padding.\n * @method updatePadding\n */\n\n Component_Sprite.prototype.updatePadding = function() {\n if (this.object.padding != null) {\n this.sprite.x += this.object.padding.left;\n this.sprite.y += this.object.padding.top;\n this.sprite.zoomX -= (this.object.padding.left + this.object.padding.right) / this.object.srcRect.width;\n return this.sprite.zoomY -= (this.object.padding.bottom + this.object.padding.bottom) / this.object.srcRect.height;\n }\n };\n\n\n /**\n * Updates the sprite properties from the game object properties.\n * @method updateProperties\n */\n\n Component_Sprite.prototype.updateProperties = function() {\n var ref, ref1;\n this.sprite.width = this.object.dstRect.width;\n this.sprite.height = this.object.dstRect.height;\n this.sprite.x = this.object.dstRect.x;\n this.sprite.y = this.object.dstRect.y;\n this.sprite.mask = (ref = this.object.mask) != null ? ref : this.mask;\n this.sprite.angle = this.object.angle || 0;\n this.sprite.opacity = (ref1 = this.object.opacity) != null ? ref1 : 255;\n this.sprite.clipRect = this.object.clipRect;\n this.sprite.srcRect = this.object.srcRect;\n this.sprite.blendingMode = this.object.blendMode || 0;\n this.sprite.mirror = this.object.mirror;\n this.sprite.visible = this.object.visible && (!this.object.parent || (this.object.parent.visible == null) || this.object.parent.visible);\n this.sprite.ox = -this.object.origin.x;\n this.sprite.oy = -this.object.origin.y;\n return this.sprite.z = (this.object.zIndex || 0) + (!this.object.parent ? 0 : this.object.parent.zIndex || 0);\n };\n\n\n /**\n * Updates the optional sprite properties from the game object properties.\n * @method updateOptionalProperties\n */\n\n Component_Sprite.prototype.updateOptionalProperties = function() {\n if (this.object.tone != null) {\n this.sprite.tone = this.object.tone;\n }\n if (this.object.color != null) {\n this.sprite.color = this.object.color;\n }\n if (this.object.viewport != null) {\n this.sprite.viewport = this.object.viewport;\n }\n if (this.object.effects != null) {\n this.sprite.effects = this.object.effects;\n }\n if (this.object.anchor != null) {\n this.sprite.anchor.x = this.object.anchor.x;\n this.sprite.anchor.y = this.object.anchor.y;\n }\n if (this.object.positionAnchor != null) {\n this.sprite.positionAnchor = this.object.positionAnchor;\n }\n if (this.object.zoom != null) {\n this.sprite.zoomX = this.object.zoom.x;\n this.sprite.zoomY = this.object.zoom.y;\n }\n if (this.object.motionBlur != null) {\n return this.sprite.motionBlur = this.object.motionBlur;\n }\n };\n\n\n /**\n * Updates the sprite component by updating its visibility, image, padding and\n * properties.\n * @method update\n */\n\n Component_Sprite.prototype.update = function() {\n Component_Sprite.__super__.update.apply(this, arguments);\n if (!this.isSetup) {\n this.setup();\n }\n this.updateVisibility();\n this.updateImage();\n this.updateProperties();\n this.updateOptionalProperties();\n this.updatePadding();\n this.object.rIndex = this.sprite.index;\n return this.sprite.update();\n };\n\n return Component_Sprite;\n\n})(gs.Component_Visual);\n\n\n/**\n* Enumeration of appearance animations. \n*\n* @module gs\n* @class AnimationTypes\n* @static\n* @memberof gs\n */\n\nAnimationTypes = (function() {\n function AnimationTypes() {}\n\n AnimationTypes.initialize = function() {\n\n /**\n * An object appears or disappears by moving into or out of the screen.\n * @property MOVEMENT\n * @type number\n * @static\n * @final\n */\n this.MOVEMENT = 0;\n\n /**\n * An object appears or disappears using alpha-blending.\n * @property BLENDING\n * @type number\n * @static\n * @final\n */\n this.BLENDING = 1;\n\n /**\n * An object appears or disappears using a mask-image.\n * @property MASKING\n * @type number\n * @static\n * @final\n */\n return this.MASKING = 2;\n };\n\n return AnimationTypes;\n\n})();\n\nAnimationTypes.initialize();\n\ngs.AnimationTypes = AnimationTypes;\n\ngs.Component_Sprite = Component_Sprite;\n\n//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"","sourceRoot":"","sources":[""],"names":[],"mappings":"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","sourcesContent":["# ===================================================================\n#\n#   Script: Component\n#\n#   $$COPYRIGHT$$\n#\n# ===================================================================\nclass Component_Sprite 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        \n    ###*\n    * A sprite component to display an object on screen. It can be managed or\n    * unmanaged. A managed sprite is automatically added to the graphics-system\n    * and rendered every frame until it gets disposed. An unmanaged sprite needs\n    * to be added and removed manually.\n    *\n    * @module gs\n    * @class Component_Sprite\n    * @extends gs.Component_Visual\n    * @memberof gs\n    * @constructor\n    * @param {boolean} managed - Indicates if the sprite is managed by the graphics system.\n    ###\n    constructor: (managed) ->\n        super()\n\n        ###*\n        * The native sprite object to display the game object on screen.\n        *\n        * @property sprite\n        * @type Sprite\n        * @protected\n        ###\n        @sprite = null\n        \n        ###*\n        * The name of the image to display.\n        *\n        * @property image\n        * @type string\n        * @protected\n        ###\n        @image = null\n        \n        ###*\n        * The name of the video to display.\n        *\n        * @property video\n        * @type string\n        * @protected\n        ###\n        @video = null\n        \n        ###*\n        * The name of the folder from where the image should be loaded.\n        *\n        * @property image\n        * @type string\n        * @protected\n        ###\n        @imageFolder = \"Graphics/Pictures\"\n        \n        ###*\n        * The visibility. If <b>false</b>, the sprite is not rendered.\n        *\n        * @property visible\n        * @type boolean\n        * @protected\n        ###\n        @visible = no\n\n        ###*\n        * Indicates if the image is loaded.\n        *\n        * @property imageLoaded\n        * @type boolean\n        * @protected\n        ###\n        @imageLoaded = no\n        \n        \n        \n    ###*\n    * Disposes the sprite. If the sprite is managed, it will be automatically\n    * removed from the graphics system and viewport.\n    * @method dispose\n    ###\n    dispose: -> \n        super\n        \n        if @sprite\n            @sprite.dispose()\n            \n            if @sprite.video\n                @sprite.video.stop()\n            \n            if not @sprite.managed\n                @sprite.viewport?.removeGraphicObject(@sprite)\n                Graphics.viewport?.removeGraphicObject(@sprite)\n \n    ###*\n    * Adds event-handlers for mouse/touch events\n    *\n    * @method setupEventHandlers\n    ### \n    setupEventHandlers: ->\n        @sprite.onIndexChange = =>\n            @object.rIndex = @sprite.index\n            @object.needsUpdate = yes\n    \n    ###*\n    * Setup the sprite. \n    * @method setupSprite\n    ### \n    setupSprite: ->\n        if !@sprite\n            @sprite = new gs.Sprite(Graphics.viewport, managed ? yes)\n            \n    ###*\n    * Setup the sprite component. This method is automatically called by the\n    * system.\n    * @method setup\n    ###\n    setup: ->\n        @isSetup = yes\n        @setupSprite()\n        @setupEventHandlers()\n        @update()\n        \n    \n    ###*\n    * Updates the source- and destination-rectangle of the game object so that\n    * the associated bitmap fits in. The imageHandling property controls how\n    * the rectangles are resized.\n    * @method updateRect\n    ###\n    updateRect: ->\n        if @sprite.bitmap?\n            if !@object.imageHandling\n                @object.srcRect = new Rect(0, 0, @sprite.bitmap.width, @sprite.bitmap.height)\n                if not @object.fixedSize\n                    @object.dstRect.width = @object.srcRect.width\n                    @object.dstRect.height = @object.srcRect.height\n            else if @object.imageHandling == 1\n                @object.srcRect = new Rect(0, 0, @sprite.bitmap.width, @sprite.bitmap.height / 2)\n                if not @object.fixedSize\n                    @object.dstRect.width = @object.srcRect.width\n                    @object.dstRect.height = @object.srcRect.height\n            else if @object.imageHandling == 2\n                if not @object.fixedSize\n                    @object.dstRect.width = @object.srcRect.width\n                    @object.dstRect.height = @object.srcRect.height\n                    \n    ###*\n    * Updates the bitmap object from the associated image name. The imageFolder\n    * property controls from which resource-folder the image will be loaded.\n    * @method updateBitmap\n    ###\n    updateBitmap: ->\n        @imageLoaded = no\n        @image = @object.image\n        \n        if @object.image.startsWith(\"data:\") || @object.image.startsWith(\"$\")\n            @sprite.bitmap = ResourceManager.getBitmap(@object.image)\n        else\n            @sprite.bitmap = ResourceManager.getBitmap(\"#{@object.imageFolder||@imageFolder}/#{@object.image}\")\n          \n        if @sprite.bitmap?  \n            if not @imageLoaded\n                @imageLoaded = @sprite.bitmap.loaded\n            else\n                delete @sprite.bitmap.loaded_\n            \n        @object.bitmap = @sprite.bitmap\n        \n    ###*\n    * Updates the video object from the associated video name. It also updates\n    * the video-rendering process.\n    * @method updateVideo\n    ###\n    updateVideo: ->\n        if @object.video != @videoName\n            @videoName = @object.video\n            @sprite.video = ResourceManager.getVideo(\"Movies/#{@object.video}\")\n            if @sprite.video?\n                if $PARAMS.preview?.settings.musicDisabled\n                    @sprite.video.volume = 0\n                @sprite.video.loop = @object.loop\n                @sprite.video.play()\n                \n                @object.srcRect = new Rect(0, 0, @sprite.video.width, @sprite.video.height)\n                if not @object.fixedSize\n                    @object.dstRect = new Rect(@object.dstRect.x, @object.dstRect.y, @sprite.video.width, @sprite.video.height)\n                \n        @sprite.video?.update()\n        \n    ###*\n    * Updates the image if the game object has the image-property set.\n    * @method updateImage\n    ###\n    updateImage: ->\n        if @object.image?\n            if @object.image != @image or (!@imageLoaded and @sprite.bitmap?.loaded)\n                @updateBitmap()\n                @updateRect()\n        else if @object.bitmap?    \n            @sprite.bitmap = @object.bitmap\n        else if @object.video? or @videoName != @object.video\n            @updateVideo()\n        else\n            @image = null\n            @object.bitmap = null\n            @sprite.bitmap = null\n            \n    ###*\n    * If the sprite is unmanaged, this method will update the visibility of the\n    * sprite. If the sprite leaves the viewport, it will be removed to save \n    * performance and automatically added back to the viewport if it enters\n    * the viewport.\n    * @method updateVisibility\n    ###\n    updateVisibility: ->\n        if !@sprite.managed\n            visible = Rect.intersect(@object.dstRect.x+@object.origin.x, @object.dstRect.y+@object.origin.y, @object.dstRect.width, @object.dstRect.height, \n                                     0, 0, Graphics.width, Graphics.height)\n            if visible and !@visible\n                (@object.viewport || Graphics.viewport).addGraphicObject(@sprite)\n                @visible = yes\n                \n            if !visible and @visible\n                (@object.viewport || Graphics.viewport).removeGraphicObject(@sprite)\n                @visible = no\n                \n      \n    ###*\n    * Updates the padding.\n    * @method updatePadding\n    ###\n    updatePadding: ->\n        if @object.padding?\n            @sprite.x += @object.padding.left\n            @sprite.y += @object.padding.top\n            @sprite.zoomX -= (@object.padding.left+@object.padding.right) / @object.srcRect.width\n            @sprite.zoomY -= (@object.padding.bottom+@object.padding.bottom) / @object.srcRect.height\n     \n    ###*\n    * Updates the sprite properties from the game object properties.\n    * @method updateProperties\n    ###\n    updateProperties: ->\n        @sprite.width = @object.dstRect.width\n        @sprite.height = @object.dstRect.height\n        @sprite.x = @object.dstRect.x \n        @sprite.y = @object.dstRect.y\n        @sprite.mask = @object.mask ? @mask\n        @sprite.angle = @object.angle || 0\n        @sprite.opacity = @object.opacity ? 255\n        @sprite.clipRect = @object.clipRect\n        @sprite.srcRect = @object.srcRect\n        @sprite.blendingMode = @object.blendMode || 0\n        @sprite.mirror = @object.mirror\n        @sprite.visible = @object.visible and (!@object.parent or !@object.parent.visible? or @object.parent.visible)\n        @sprite.ox = -@object.origin.x\n        @sprite.oy = -@object.origin.y\n        @sprite.z = (@object.zIndex || 0) + (if !@object.parent then 0 else @object.parent.zIndex || 0)\n        \n    ###*\n    * Updates the optional sprite properties from the game object properties.\n    * @method updateOptionalProperties\n    ###\n    updateOptionalProperties: ->\n        if @object.tone?\n            @sprite.tone = @object.tone\n        if @object.color?\n            @sprite.color = @object.color\n        if @object.viewport?\n            @sprite.viewport = @object.viewport\n        if @object.effects?\n            @sprite.effects = @object.effects\n        if @object.anchor?\n            @sprite.anchor.x = @object.anchor.x\n            @sprite.anchor.y = @object.anchor.y\n        if @object.positionAnchor?\n            @sprite.positionAnchor = @object.positionAnchor\n        if @object.zoom?\n            @sprite.zoomX = @object.zoom.x\n            @sprite.zoomY = @object.zoom.y\n        if @object.motionBlur?\n            @sprite.motionBlur = @object.motionBlur\n        \n    ###*\n    * Updates the sprite component by updating its visibility, image, padding and\n    * properties.\n    * @method update\n    ###\n    update: ->\n        super\n        \n        @setup() if not @isSetup\n        @updateVisibility()\n        @updateImage()\n        @updateProperties()\n        @updateOptionalProperties()\n        @updatePadding()\n        \n        @object.rIndex = @sprite.index\n        @sprite.update()\n        \n\n###*\n* Enumeration of appearance animations. \n*\n* @module gs\n* @class AnimationTypes\n* @static\n* @memberof gs\n###\nclass AnimationTypes\n    @initialize: ->    \n        ###*\n        * An object appears or disappears by moving into or out of the screen.\n        * @property MOVEMENT\n        * @type number\n        * @static\n        * @final\n        ###\n        @MOVEMENT = 0\n        ###*\n        * An object appears or disappears using alpha-blending.\n        * @property BLENDING\n        * @type number\n        * @static\n        * @final\n        ###\n        @BLENDING = 1\n        ###*\n        * An object appears or disappears using a mask-image.\n        * @property MASKING\n        * @type number\n        * @static\n        * @final\n        ###\n        @MASKING = 2\n\nAnimationTypes.initialize()    \ngs.AnimationTypes = AnimationTypes\ngs.Component_Sprite = Component_Sprite\n"]}\n//# sourceURL=Component_Sprite_59.js"
13 13 },
14 14 "summary": [
15 15 "name",