1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
|
{
"uid": "D1E8BD12K8995A47C7S86E8E89AD5013D83D",
"isLoaded": true,
"lastModificationTime": 0,
"items": {
"name": "Component_MaskAnimation",
"type": "game_script",
"order": 2,
"content": "# ===================================================================\n#\n# Script: Component_MaskAnimation\n#\n# $$COPYRIGHT$$\n#\n# ===================================================================\nclass Component_MaskAnimation extends gs.Component_Animation\n ###*\n * Executes a mask-animation on a game-object.\n *\n * @module gs\n * @class Component_MaskAnimation\n * @extends gs.Component_Animation\n * @memberof gs\n * @constructor\n ###\n constructor: (data) ->\n super\n \n @easing = new gs.Easing(null, data?.easing)\n @callback = null\n @animationType = data?.animationType || 0\n \n ###*\n * Serializes the mask-animation into a data-bundle.\n *\n * @method toDataBundle\n ### \n toDataBundle: ->\n easing: @easing,\n animationType: @animationType\n \n ###*\n * Updates the mask-animation.\n *\n * @method update\n ### \n update: ->\n super()\n if not @easing.isRunning then return\n \n @easing.updateValue()\n @object.mask.value = @easing.value\n \n if not @easing.isRunning\n if @animationType < 1\n @object.mask.source = null\n @object.mask.vague = 0\n @animationType = 0\n @callback?(@object, this)\n \n ###*\n * Lets the game object appear on screen using a masking-effect.\n *\n * @method maskIn\n * @param {gs.Mask} mask The mask used for the animation.\n * @param {number} duration The duration in frames.\n * @param {Object} easingType The easing-type.\n * @param {function} [callback] An optional callback-function called when the animation is finished. \n ### \n maskIn: (mask, duration, easing, callback) ->\n @easing.type = easing\n @animationType = 0\n @callback = callback\n \n if duration == 0 or @isInstantSkip()\n @callback?(@object, this)\n else\n @object.mask.type = 1\n @object.mask.source = ResourceManager.getBitmap(\"Graphics/Masks/#{mask.graphic?.name}\")\n @object.mask.vague = mask.vague\n @object.mask.value = 255\n \n @easing.startValue(255, -255 - mask.vague, duration)\n \n ###*\n * Lets the game object disappear from screen using a masking-effect.\n *\n * @method maskIn\n * @param {gs.Mask} mask The mask used for the animation.\n * @param {number} duration The duration in frames.\n * @param {Object} easingType The easing-type.\n * @param {function} [callback] An optional callback-function called when the animation is finished. \n ### \n maskOut: (mask, duration, easing, callback) ->\n @easing.type = easing\n @animationType = 0\n @callback = callback\n \n if duration == 0 or @isInstantSkip()\n @callback?(@object, this)\n else\n @object.mask.type = 1\n @object.mask.source = ResourceManager.getBitmap(\"Graphics/Masks/#{mask.graphic?.name}\")\n @object.mask.vague = mask.vague\n @object.mask.value = 0\n \n @easing.startValue(-mask.vague, 255 + mask.vague, duration)\n \n ###*\n * Description follows...\n *\n * @method maskTo\n * @param {gs.Mask} mask The mask used for the animation.\n * @param {number} duration The duration in frames.\n * @param {Object} easingType The easing-type.\n * @param {function} [callback] An optional callback-function called when the animation is finished. \n ### \n maskTo: (mask, duration, easing, callback) ->\n @easing.type = easing\n @animationType = 1\n @callback = callback\n\n @object.mask.type = 1\n\n # FIXME: Doubled code, see CommandInterpreter.commandMaskPicture\n if mask.sourceType == 0\n @object.mask.source = ResourceManager.getBitmap(\"Graphics/Masks/#{mask.graphic?.name}\")\n else\n if @object.mask.source?.videoElement?\n @object.mask.source.pause()\n \n @object.mask.source = ResourceManager.getVideo(\"Movies/#{mask.video.name}\")\n @object.mask.source?.play()\n @object.mask.source?.loop = true\n \n @object.mask.vague = mask.vague\n\n if duration == 0 or @isInstantSkip()\n @animationType = 0\n @object.mask.value = mask.value\n @callback?(@object, this)\n else\n @easing.startValue(@object.mask.value, mask.value - @object.mask.value, duration)\n \ngs.Component_MaskAnimation = Component_MaskAnimation",
"parentId": "A8E9945CKEE5CA4855SAC81E480CB8098E0E",
"folder": false,
"compiledContent": "var Component_MaskAnimation,\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_MaskAnimation = (function(superClass) {\n extend(Component_MaskAnimation, superClass);\n\n\n /**\n * Executes a mask-animation on a game-object.\n *\n * @module gs\n * @class Component_MaskAnimation\n * @extends gs.Component_Animation\n * @memberof gs\n * @constructor\n */\n\n function Component_MaskAnimation(data) {\n Component_MaskAnimation.__super__.constructor.apply(this, arguments);\n this.easing = new gs.Easing(null, data != null ? data.easing : void 0);\n this.callback = null;\n this.animationType = (data != null ? data.animationType : void 0) || 0;\n }\n\n\n /**\n * Serializes the mask-animation into a data-bundle.\n *\n * @method toDataBundle\n */\n\n Component_MaskAnimation.prototype.toDataBundle = function() {\n return {\n easing: this.easing,\n animationType: this.animationType\n };\n };\n\n\n /**\n * Updates the mask-animation.\n *\n * @method update\n */\n\n Component_MaskAnimation.prototype.update = function() {\n Component_MaskAnimation.__super__.update.call(this);\n if (!this.easing.isRunning) {\n return;\n }\n this.easing.updateValue();\n this.object.mask.value = this.easing.value;\n if (!this.easing.isRunning) {\n if (this.animationType < 1) {\n this.object.mask.source = null;\n this.object.mask.vague = 0;\n }\n this.animationType = 0;\n return typeof this.callback === \"function\" ? this.callback(this.object, this) : void 0;\n }\n };\n\n\n /**\n * Lets the game object appear on screen using a masking-effect.\n *\n * @method maskIn\n * @param {gs.Mask} mask The mask used for the animation.\n * @param {number} duration The duration in frames.\n * @param {Object} easingType The easing-type.\n * @param {function} [callback] An optional callback-function called when the animation is finished.\n */\n\n Component_MaskAnimation.prototype.maskIn = function(mask, duration, easing, callback) {\n var ref;\n this.easing.type = easing;\n this.animationType = 0;\n this.callback = callback;\n if (duration === 0 || this.isInstantSkip()) {\n return typeof this.callback === \"function\" ? this.callback(this.object, this) : void 0;\n } else {\n this.object.mask.type = 1;\n this.object.mask.source = ResourceManager.getBitmap(\"Graphics/Masks/\" + ((ref = mask.graphic) != null ? ref.name : void 0));\n this.object.mask.vague = mask.vague;\n this.object.mask.value = 255;\n return this.easing.startValue(255, -255 - mask.vague, duration);\n }\n };\n\n\n /**\n * Lets the game object disappear from screen using a masking-effect.\n *\n * @method maskIn\n * @param {gs.Mask} mask The mask used for the animation.\n * @param {number} duration The duration in frames.\n * @param {Object} easingType The easing-type.\n * @param {function} [callback] An optional callback-function called when the animation is finished.\n */\n\n Component_MaskAnimation.prototype.maskOut = function(mask, duration, easing, callback) {\n var ref;\n this.easing.type = easing;\n this.animationType = 0;\n this.callback = callback;\n if (duration === 0 || this.isInstantSkip()) {\n return typeof this.callback === \"function\" ? this.callback(this.object, this) : void 0;\n } else {\n this.object.mask.type = 1;\n this.object.mask.source = ResourceManager.getBitmap(\"Graphics/Masks/\" + ((ref = mask.graphic) != null ? ref.name : void 0));\n this.object.mask.vague = mask.vague;\n this.object.mask.value = 0;\n return this.easing.startValue(-mask.vague, 255 + mask.vague, duration);\n }\n };\n\n\n /**\n * Description follows...\n *\n * @method maskTo\n * @param {gs.Mask} mask The mask used for the animation.\n * @param {number} duration The duration in frames.\n * @param {Object} easingType The easing-type.\n * @param {function} [callback] An optional callback-function called when the animation is finished.\n */\n\n Component_MaskAnimation.prototype.maskTo = function(mask, duration, easing, callback) {\n var ref, ref1, ref2, ref3;\n this.easing.type = easing;\n this.animationType = 1;\n this.callback = callback;\n this.object.mask.type = 1;\n if (mask.sourceType === 0) {\n this.object.mask.source = ResourceManager.getBitmap(\"Graphics/Masks/\" + ((ref = mask.graphic) != null ? ref.name : void 0));\n } else {\n if (((ref1 = this.object.mask.source) != null ? ref1.videoElement : void 0) != null) {\n this.object.mask.source.pause();\n }\n this.object.mask.source = ResourceManager.getVideo(\"Movies/\" + mask.video.name);\n if ((ref2 = this.object.mask.source) != null) {\n ref2.play();\n }\n if ((ref3 = this.object.mask.source) != null) {\n ref3.loop = true;\n }\n }\n this.object.mask.vague = mask.vague;\n if (duration === 0 || this.isInstantSkip()) {\n this.animationType = 0;\n this.object.mask.value = mask.value;\n return typeof this.callback === \"function\" ? this.callback(this.object, this) : void 0;\n } else {\n return this.easing.startValue(this.object.mask.value, mask.value - this.object.mask.value, duration);\n }\n };\n\n return Component_MaskAnimation;\n\n})(gs.Component_Animation);\n\ngs.Component_MaskAnimation = Component_MaskAnimation;\n\n//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"","sourceRoot":"","sources":[""],"names":[],"mappings":"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","sourcesContent":["# ===================================================================\n#\n#   Script: Component_MaskAnimation\n#\n#   $$COPYRIGHT$$\n#\n# ===================================================================\nclass Component_MaskAnimation extends gs.Component_Animation\n    ###*\n    * Executes a mask-animation on a game-object.\n    *\n    * @module gs\n    * @class Component_MaskAnimation\n    * @extends gs.Component_Animation\n    * @memberof gs\n    * @constructor\n    ###\n    constructor: (data) ->\n        super\n        \n        @easing = new gs.Easing(null, data?.easing)\n        @callback = null\n        @animationType = data?.animationType || 0\n    \n    ###*\n    * Serializes the mask-animation into a data-bundle.\n    *\n    * @method toDataBundle\n    ###        \n    toDataBundle: ->\n        easing: @easing,\n        animationType: @animationType\n    \n    ###*\n    * Updates the mask-animation.\n    *\n    * @method update\n    ###    \n    update: ->\n        super()\n        if not @easing.isRunning then return\n        \n        @easing.updateValue()\n        @object.mask.value = @easing.value\n        \n        if not @easing.isRunning\n            if @animationType < 1\n                @object.mask.source = null\n                @object.mask.vague = 0\n            @animationType = 0\n            @callback?(@object, this)\n    \n    ###*\n    * Lets the game object appear on screen using a masking-effect.\n    *\n    * @method maskIn\n    * @param {gs.Mask} mask The mask used for the animation.\n    * @param {number} duration The duration in frames.\n    * @param {Object} easingType The easing-type.\n    * @param {function} [callback] An optional callback-function called when the animation is finished. \n    ###       \n    maskIn: (mask, duration, easing, callback) ->\n        @easing.type = easing\n        @animationType = 0\n        @callback = callback\n        \n        if duration == 0 or @isInstantSkip()\n            @callback?(@object, this)\n        else\n            @object.mask.type = 1\n            @object.mask.source = ResourceManager.getBitmap(\"Graphics/Masks/#{mask.graphic?.name}\")\n            @object.mask.vague = mask.vague\n            @object.mask.value = 255\n            \n            @easing.startValue(255, -255 - mask.vague, duration)\n    \n    ###*\n    * Lets the game object disappear from screen using a masking-effect.\n    *\n    * @method maskIn\n    * @param {gs.Mask} mask The mask used for the animation.\n    * @param {number} duration The duration in frames.\n    * @param {Object} easingType The easing-type.\n    * @param {function} [callback] An optional callback-function called when the animation is finished. \n    ###      \n    maskOut: (mask, duration, easing, callback) ->\n        @easing.type = easing\n        @animationType = 0\n        @callback = callback\n        \n        if duration == 0 or @isInstantSkip()\n            @callback?(@object, this)\n        else\n            @object.mask.type = 1\n            @object.mask.source = ResourceManager.getBitmap(\"Graphics/Masks/#{mask.graphic?.name}\")\n            @object.mask.vague = mask.vague\n            @object.mask.value = 0\n            \n            @easing.startValue(-mask.vague, 255 + mask.vague, duration)\n    \n    ###*\n    * Description follows...\n    *\n    * @method maskTo\n    * @param {gs.Mask} mask The mask used for the animation.\n    * @param {number} duration The duration in frames.\n    * @param {Object} easingType The easing-type.\n    * @param {function} [callback] An optional callback-function called when the animation is finished. \n    ###       \n    maskTo: (mask, duration, easing, callback) ->\n        @easing.type = easing\n        @animationType = 1\n        @callback = callback\n\n        @object.mask.type = 1\n\n        # FIXME: Doubled code, see CommandInterpreter.commandMaskPicture\n        if mask.sourceType == 0\n            @object.mask.source = ResourceManager.getBitmap(\"Graphics/Masks/#{mask.graphic?.name}\")\n        else\n            if @object.mask.source?.videoElement?\n                @object.mask.source.pause()\n                \n            @object.mask.source = ResourceManager.getVideo(\"Movies/#{mask.video.name}\")\n            @object.mask.source?.play()\n            @object.mask.source?.loop = true\n            \n        @object.mask.vague = mask.vague\n\n        if duration == 0 or @isInstantSkip()\n            @animationType = 0\n            @object.mask.value = mask.value\n            @callback?(@object, this)\n        else\n            @easing.startValue(@object.mask.value, mask.value - @object.mask.value, duration)\n        \ngs.Component_MaskAnimation = Component_MaskAnimation"]}\n//# sourceURL=Component_MaskAnimation_37.js"
},
"summary": [
"name",
"type",
"order"
]
}
|