1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
|
{
"uid": "960AB145K44D2A495DS9C83E4AECD84B7EDD",
"isLoaded": true,
"lastModificationTime": 0,
"items": {
"name": "Component_TilingPlane",
"type": "game_script",
"order": 7,
"content": "# ===================================================================\n#\n# Script: Component_TilingPlane\n#\n# $$COPYRIGHT$$\n#\n# ===================================================================\nclass Component_TilingPlane extends gs.Component_Sprite\n ###*\n * A tiling plane component tiles the image of the game object endless over the screen. The\n * tiling can be vertical, horizontal or both. The sprite can be managed or\n * unmanaged. A managed sprite is automatically added to the graphics-system\n * and processed every frame until it gets disposed. An unmanaged sprite needs\n * to be added and removed manually.\n *\n * @module gs\n * @class Component_TilingPlane\n * @extends gs.Component_Sprite\n * @memberof gs\n * @constructor\n * @param {boolean} managed - Indicates if the sprite is managed by the graphics system.\n ###\n constructor: (managed) ->\n @sprite = null\n @tilingPlane = null\n @tilingSprite = @sprite\n @image = null\n @video = null\n @imageFolder = \"Graphics/Pictures\"\n @visible = yes\n @looping = vertical: no, horizontal: no\n \n ###*\n * Creates sprite object.\n *\n * @method setupSprite\n ###\n setupSprite: ->\n if !@sprite\n @sprite = new gs.Sprite(Graphics.viewport, managed ? yes)\n @tilingSprite = @sprite\n \n ###*\n * Updates the padding.\n *\n * @method updatePadding\n ###\n updatePadding: ->\n if @object.padding?\n @sprite.rect.x += @object.padding.left\n @sprite.rect.y += @object.padding.top\n @sprite.rect.width -= @object.padding.left+@object.padding.right\n @sprite.rect.height -= @object.padding.bottom+@object.padding.bottom\n \n ###*\n * Updates the source- and destination-rectangle of the game object so that\n * the associated bitmap fits in. \n *\n * @method updateRect\n ###\n updateRect: ->\n if @sprite.bitmap?\n @object.srcRect = new Rect(0, 0, @sprite.bitmap.width, @sprite.bitmap.height)\n @object.dstRect.width = @object.srcRect.width\n @object.dstRect.height = @object.srcRect.height\n \n ###*\n * Updates the sprite properties from the game object properties.\n *\n * @method updateProperties\n ###\n updateProperties: ->\n super()\n \n @sprite.vertical = @looping.vertical\n @sprite.horizontal = @looping.horizontal\n @sprite.x = @object.dstRect.x\n @sprite.y = @object.dstRect.y\n \n ###*\n * Updates the optional sprite properties from the game object properties.\n * @method updateOptionalProperties\n ### \n updateOptionalProperties: ->\n super()\n \n @sprite.zoomX = @object.zoom.x\n @sprite.zoomY = @object.zoom.y\n \n ###*\n * Updates the tiling-plane component by updating its visibility, image, padding and\n * properties. To save performance, a gs.TilingPlane is only used if looping is enabled. Otherwise\n * a regular sprite is used.\n * @method update\n ### \n update: ->\n if @tilingSprite and (@looping.vertical or @looping.horizontal)\n @tilingSprite.dispose()\n @tilingPlane = new gs.TilingPlane(null, @tilingSprite.managed)\n @tilingSprite = null\n @sprite = @tilingPlane\n @image = null\n \n if @tilingPlane and not (@looping.vertical or @looping.horizontal)\n @tilingPlane.dispose()\n @tilingSprite = new gs.Sprite(null, @tilingPlane.managed)\n @tilingPlane = null\n @sprite = @tilingSprite\n @image = null\n \n super\n \n \ngs.Component_TilingPlane = Component_TilingPlane\n",
"parentId": "D3325122KACDEA4515SB731E37A42B9D779F",
"folder": false,
"compiledContent": "var Component_TilingPlane,\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_TilingPlane = (function(superClass) {\n extend(Component_TilingPlane, superClass);\n\n\n /**\n * A tiling plane component tiles the image of the game object endless over the screen. The\n * tiling can be vertical, horizontal or both. The sprite can be managed or\n * unmanaged. A managed sprite is automatically added to the graphics-system\n * and processed every frame until it gets disposed. An unmanaged sprite needs\n * to be added and removed manually.\n *\n * @module gs\n * @class Component_TilingPlane\n * @extends gs.Component_Sprite\n * @memberof gs\n * @constructor\n * @param {boolean} managed - Indicates if the sprite is managed by the graphics system.\n */\n\n function Component_TilingPlane(managed) {\n this.sprite = null;\n this.tilingPlane = null;\n this.tilingSprite = this.sprite;\n this.image = null;\n this.video = null;\n this.imageFolder = \"Graphics/Pictures\";\n this.visible = true;\n this.looping = {\n vertical: false,\n horizontal: false\n };\n }\n\n\n /**\n * Creates sprite object.\n *\n * @method setupSprite\n */\n\n Component_TilingPlane.prototype.setupSprite = function() {\n if (!this.sprite) {\n this.sprite = new gs.Sprite(Graphics.viewport, typeof managed !== \"undefined\" && managed !== null ? managed : true);\n return this.tilingSprite = this.sprite;\n }\n };\n\n\n /**\n * Updates the padding.\n *\n * @method updatePadding\n */\n\n Component_TilingPlane.prototype.updatePadding = function() {\n if (this.object.padding != null) {\n this.sprite.rect.x += this.object.padding.left;\n this.sprite.rect.y += this.object.padding.top;\n this.sprite.rect.width -= this.object.padding.left + this.object.padding.right;\n return this.sprite.rect.height -= this.object.padding.bottom + this.object.padding.bottom;\n }\n };\n\n\n /**\n * Updates the source- and destination-rectangle of the game object so that\n * the associated bitmap fits in. \n *\n * @method updateRect\n */\n\n Component_TilingPlane.prototype.updateRect = function() {\n if (this.sprite.bitmap != null) {\n this.object.srcRect = new Rect(0, 0, this.sprite.bitmap.width, this.sprite.bitmap.height);\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 * Updates the sprite properties from the game object properties.\n *\n * @method updateProperties\n */\n\n Component_TilingPlane.prototype.updateProperties = function() {\n Component_TilingPlane.__super__.updateProperties.call(this);\n this.sprite.vertical = this.looping.vertical;\n this.sprite.horizontal = this.looping.horizontal;\n this.sprite.x = this.object.dstRect.x;\n return this.sprite.y = this.object.dstRect.y;\n };\n\n\n /**\n * Updates the optional sprite properties from the game object properties.\n * @method updateOptionalProperties\n */\n\n Component_TilingPlane.prototype.updateOptionalProperties = function() {\n Component_TilingPlane.__super__.updateOptionalProperties.call(this);\n this.sprite.zoomX = this.object.zoom.x;\n return this.sprite.zoomY = this.object.zoom.y;\n };\n\n\n /**\n * Updates the tiling-plane component by updating its visibility, image, padding and\n * properties. To save performance, a gs.TilingPlane is only used if looping is enabled. Otherwise\n * a regular sprite is used.\n * @method update\n */\n\n Component_TilingPlane.prototype.update = function() {\n if (this.tilingSprite && (this.looping.vertical || this.looping.horizontal)) {\n this.tilingSprite.dispose();\n this.tilingPlane = new gs.TilingPlane(null, this.tilingSprite.managed);\n this.tilingSprite = null;\n this.sprite = this.tilingPlane;\n this.image = null;\n }\n if (this.tilingPlane && !(this.looping.vertical || this.looping.horizontal)) {\n this.tilingPlane.dispose();\n this.tilingSprite = new gs.Sprite(null, this.tilingPlane.managed);\n this.tilingPlane = null;\n this.sprite = this.tilingSprite;\n this.image = null;\n }\n return Component_TilingPlane.__super__.update.apply(this, arguments);\n };\n\n return Component_TilingPlane;\n\n})(gs.Component_Sprite);\n\ngs.Component_TilingPlane = Component_TilingPlane;\n\n//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"","sourceRoot":"","sources":[""],"names":[],"mappings":"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","sourcesContent":["# ===================================================================\n#\n#   Script: Component_TilingPlane\n#\n#   $$COPYRIGHT$$\n#\n# ===================================================================\nclass Component_TilingPlane extends gs.Component_Sprite\n    ###*\n    * A tiling plane component tiles the image of the game object endless over the screen. The\n    * tiling can be vertical, horizontal or both. The sprite can be managed or\n    * unmanaged. A managed sprite is automatically added to the graphics-system\n    * and processed every frame until it gets disposed. An unmanaged sprite needs\n    * to be added and removed manually.\n    *\n    * @module gs\n    * @class Component_TilingPlane\n    * @extends gs.Component_Sprite\n    * @memberof gs\n    * @constructor\n    * @param {boolean} managed - Indicates if the sprite is managed by the graphics system.\n    ###\n    constructor: (managed) ->\n        @sprite = null\n        @tilingPlane = null\n        @tilingSprite = @sprite\n        @image = null\n        @video = null\n        @imageFolder = \"Graphics/Pictures\"\n        @visible = yes\n        @looping = vertical: no, horizontal: no\n    \n    ###*\n    * Creates sprite object.\n    *\n    * @method setupSprite\n    ###\n    setupSprite: ->\n        if !@sprite\n            @sprite = new gs.Sprite(Graphics.viewport, managed ? yes)\n            @tilingSprite = @sprite\n        \n    ###*\n    * Updates the padding.\n    *\n    * @method updatePadding\n    ###\n    updatePadding: ->\n        if @object.padding?\n            @sprite.rect.x += @object.padding.left\n            @sprite.rect.y += @object.padding.top\n            @sprite.rect.width -= @object.padding.left+@object.padding.right\n            @sprite.rect.height -= @object.padding.bottom+@object.padding.bottom\n            \n    ###*\n    * Updates the source- and destination-rectangle of the game object so that\n    * the associated bitmap fits in. \n    *\n    * @method updateRect\n    ###\n    updateRect: ->\n        if @sprite.bitmap?\n            @object.srcRect = new Rect(0, 0, @sprite.bitmap.width, @sprite.bitmap.height)\n            @object.dstRect.width = @object.srcRect.width\n            @object.dstRect.height = @object.srcRect.height\n            \n    ###*\n    * Updates the sprite properties from the game object properties.\n    *\n    * @method updateProperties\n    ###\n    updateProperties: ->\n        super()\n        \n        @sprite.vertical = @looping.vertical\n        @sprite.horizontal = @looping.horizontal\n        @sprite.x = @object.dstRect.x\n        @sprite.y = @object.dstRect.y\n    \n    ###*\n    * Updates the optional sprite properties from the game object properties.\n    * @method updateOptionalProperties\n    ###    \n    updateOptionalProperties: ->\n        super()\n        \n        @sprite.zoomX = @object.zoom.x\n        @sprite.zoomY = @object.zoom.y\n        \n    ###*\n    * Updates the tiling-plane component by updating its visibility, image, padding and\n    * properties. To save performance, a gs.TilingPlane is only used if looping is enabled. Otherwise\n    * a regular sprite is used.\n    * @method update\n    ###    \n    update: ->\n        if @tilingSprite and (@looping.vertical or @looping.horizontal)\n            @tilingSprite.dispose()\n            @tilingPlane = new gs.TilingPlane(null, @tilingSprite.managed)\n            @tilingSprite = null\n            @sprite = @tilingPlane\n            @image = null\n            \n        if @tilingPlane and not (@looping.vertical or @looping.horizontal)\n            @tilingPlane.dispose()\n            @tilingSprite = new gs.Sprite(null, @tilingPlane.managed)\n            @tilingPlane = null\n            @sprite = @tilingSprite\n            @image = null\n            \n        super\n        \n        \ngs.Component_TilingPlane = Component_TilingPlane\n"]}\n//# sourceURL=Component_TilingPlane_88.js"
},
"summary": [
"name",
"type",
"order"
]
}
|