1
|
{"uid":"B54FB0D1K9DC1A4671S9BE6E84D78A18EAD1","isLoaded":true,"lastModificationTime":0,"items":{"name":"Component_LayoutBehavior","type":"game_script","order":3,"content":"# ===================================================================\n#\n# Script: Component_LayoutBehavior\n#\n# $$COPYRIGHT$$\n#\n# ===================================================================\nclass Component_LayoutBehavior extends gs.Component_Visual\n ###*\n * The base class of all layout-components. A layout-component is used\n * to layout assigned sub-objects in a specific way depending on the layout-type.\n * For example: A grid-layout layouts its sub-objects like a grid using rows\n * and columns. The game object needs a container-component.<br><br>\n *\n * A layout can also be configured as scrollable. In that case, layout's content\n * can be larger than the layout-bounds and is automatically clipped. The content\n * can be scrolled using mouse-wheel or touch-gesture.\n *\n * @module gs\n * @class Component_LayoutBehavior\n * @extends gs.Component\n * @memberof gs\n * @constructor\n ###\n constructor: ->\n ###*\n * Content size of the layout.\n * @property contentSize\n * @type gs.Size\n * @readOnly\n ###\n @contentSize = width: 0, height: 0\n\n ###*\n * Disposes the layout and all its sub-objects.\n *\n * @method dispose\n ### \n # FIXME: Is that still necessary? If the parent game object is disposed\n # all sub-objects are disposed as well.\n dispose: ->\n for control in @object.controls\n control?.dispose()\n \n ###*\n * Initializes the layout.\n *\n * @method setup\n ### \n setup: ->\n \n ###*\n * Sizes the layout to fit its content.\n *\n * @method sizeToFit\n * @abstract\n ### \n sizeToFit: ->\n \n ###*\n * Sort-Function to sort sub-objects by order-index.\n *\n * @method sort_\n * @protected\n * @param {gs.Object_Base} a Object A\n * @param {gs.Object_Base} b Object B\n ### \n sort_: (a, b) ->\n if a.order > b.order\n return -1\n else if a.order < b.order\n return 1\n else\n return 0\n \n ###*\n * Updates a specified control.\n *\n * @method updateControl\n * @protected\n * @param {gs.Object_Base} control The control to update\n ### \n updateControl: (control) ->\n @object.rIndex = Math.max(@object.rIndex, control.rIndex)\n \n if control.updateBehavior == ui.UpdateBehavior.CONTINUOUS\n control.needsUpdate = yes\n \n if control.inheritProperties\n control.ui.enabled = @object.ui.enabled\n control.opacity = @object.opacity\n control.zoom = @object.zoom\n control.color = @object.color\n control.tone = @object.tone\n control.angle = @object.angle\n control.anchor.x = @object.anchor.x\n control.anchor.y = @object.anchor.y\n \n \n if control.needsUpdate\n control.needsUpdate = no\n control.update()\n control.parent = @object\n \n \n if @object.clipRect?\n control.clipRect = @object.clipRect\n \n ###*\n * Updates the content size of the layout. Only works if scrolling is\n * enabled.\n *\n * @method updateContentSize\n * @protected\n ### \n updateContentSize: ->\n if @object.scrollable\n @contentSize.width = 0\n @contentSize.height = 0\n for control in @object.controls\n if control\n @contentSize.width += control.margin.left + control.dstRect.width + control.margin.right\n @contentSize.height += control.margin.top + control.dstRect.height + control.margin.bottom\n \n @object.contentHeight = @contentSize.height\n @object.contentWidth = @contentSize.width\n \n ###*\n * Updates scrolling.\n *\n * @method updateScroll\n ###\n updateScroll: ->\n if @object.scrollable\n @object.scrollableHeight = Math.max(0, @contentSize.height - @object.dstRect.height)\n if Input.Mouse.wheel <= -1\n @object.scrollOffsetY = Math.max(@object.scrollOffsetY - Input.Mouse.wheelSpeed * 0.1, 0)\n \n if Input.Mouse.wheel >= 1\n @object.scrollOffsetY = Math.min(@object.scrollOffsetY - Input.Mouse.wheelSpeed * 0.1, @object.scrollableHeight)\n \n \n @object.scrollOffsetY = Math.max(Math.min(@object.scrollOffsetY, @object.scrollableHeight), 0)\n \n ###*\n * Updates the layout's content.\n *\n * @method updateContent\n ### \n updateContent: ->\n \n ###*\n * Updates the layout.\n *\n * @method update\n ### \n update: ->\n super\n \n @updateContentSize()\n @updateScroll()\n \n \n #if @object.needsSort\n # @object.subObjects.sort(@sort_)\n # @object.needsSort = no\n \n \ngs.Component_LayoutBehavior = Component_LayoutBehavior","parentId":"01A95DA3K01E8A4CB4SBE17E790BCE1FC035","folder":false,"compiledContent":"var Component_LayoutBehavior,\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_LayoutBehavior = (function(superClass) {\n extend(Component_LayoutBehavior, superClass);\n\n\n /**\n * The base class of all layout-components. A layout-component is used\n * to layout assigned sub-objects in a specific way depending on the layout-type.\n * For example: A grid-layout layouts its sub-objects like a grid using rows\n * and columns. The game object needs a container-component.<br><br>\n *\n * A layout can also be configured as scrollable. In that case, layout's content\n * can be larger than the layout-bounds and is automatically clipped. The content\n * can be scrolled using mouse-wheel or touch-gesture.\n *\n * @module gs\n * @class Component_LayoutBehavior\n * @extends gs.Component\n * @memberof gs\n * @constructor\n */\n\n function Component_LayoutBehavior() {\n\n /**\n * Content size of the layout.\n * @property contentSize\n * @type gs.Size\n * @readOnly\n */\n this.contentSize = {\n width: 0,\n height: 0\n };\n }\n\n\n /**\n * Disposes the layout and all its sub-objects.\n *\n * @method dispose\n */\n\n Component_LayoutBehavior.prototype.dispose = function() {\n var control, i, len, ref, results;\n ref = this.object.controls;\n results = [];\n for (i = 0, len = ref.length; i < len; i++) {\n control = ref[i];\n results.push(control != null ? control.dispose() : void 0);\n }\n return results;\n };\n\n\n /**\n * Initializes the layout.\n *\n * @method setup\n */\n\n Component_LayoutBehavior.prototype.setup = function() {};\n\n\n /**\n * Sizes the layout to fit its content.\n *\n * @method sizeToFit\n * @abstract\n */\n\n Component_LayoutBehavior.prototype.sizeToFit = function() {};\n\n\n /**\n * Sort-Function to sort sub-objects by order-index.\n *\n * @method sort_\n * @protected\n * @param {gs.Object_Base} a Object A\n * @param {gs.Object_Base} b Object B\n */\n\n Component_LayoutBehavior.prototype.sort_ = function(a, b) {\n if (a.order > b.order) {\n return -1;\n } else if (a.order < b.order) {\n return 1;\n } else {\n return 0;\n }\n };\n\n\n /**\n * Updates a specified control.\n *\n * @method updateControl\n * @protected\n * @param {gs.Object_Base} control The control to update\n */\n\n Component_LayoutBehavior.prototype.updateControl = function(control) {\n this.object.rIndex = Math.max(this.object.rIndex, control.rIndex);\n if (control.updateBehavior === ui.UpdateBehavior.CONTINUOUS) {\n control.needsUpdate = true;\n }\n if (control.inheritProperties) {\n control.ui.enabled = this.object.ui.enabled;\n control.opacity = this.object.opacity;\n control.zoom = this.object.zoom;\n control.color = this.object.color;\n control.tone = this.object.tone;\n control.angle = this.object.angle;\n control.anchor.x = this.object.anchor.x;\n control.anchor.y = this.object.anchor.y;\n }\n if (control.needsUpdate) {\n control.needsUpdate = false;\n control.update();\n control.parent = this.object;\n }\n if (this.object.clipRect != null) {\n return control.clipRect = this.object.clipRect;\n }\n };\n\n\n /**\n * Updates the content size of the layout. Only works if scrolling is\n * enabled.\n *\n * @method updateContentSize\n * @protected\n */\n\n Component_LayoutBehavior.prototype.updateContentSize = function() {\n var control, i, len, ref;\n if (this.object.scrollable) {\n this.contentSize.width = 0;\n this.contentSize.height = 0;\n ref = this.object.controls;\n for (i = 0, len = ref.length; i < len; i++) {\n control = ref[i];\n if (control) {\n this.contentSize.width += control.margin.left + control.dstRect.width + control.margin.right;\n this.contentSize.height += control.margin.top + control.dstRect.height + control.margin.bottom;\n }\n }\n this.object.contentHeight = this.contentSize.height;\n return this.object.contentWidth = this.contentSize.width;\n }\n };\n\n\n /**\n * Updates scrolling.\n *\n * @method updateScroll\n */\n\n Component_LayoutBehavior.prototype.updateScroll = function() {\n if (this.object.scrollable) {\n this.object.scrollableHeight = Math.max(0, this.contentSize.height - this.object.dstRect.height);\n if (Input.Mouse.wheel <= -1) {\n this.object.scrollOffsetY = Math.max(this.object.scrollOffsetY - Input.Mouse.wheelSpeed * 0.1, 0);\n }\n if (Input.Mouse.wheel >= 1) {\n this.object.scrollOffsetY = Math.min(this.object.scrollOffsetY - Input.Mouse.wheelSpeed * 0.1, this.object.scrollableHeight);\n }\n return this.object.scrollOffsetY = Math.max(Math.min(this.object.scrollOffsetY, this.object.scrollableHeight), 0);\n }\n };\n\n\n /**\n * Updates the layout's content.\n *\n * @method updateContent\n */\n\n Component_LayoutBehavior.prototype.updateContent = function() {};\n\n\n /**\n * Updates the layout.\n *\n * @method update\n */\n\n Component_LayoutBehavior.prototype.update = function() {\n Component_LayoutBehavior.__super__.update.apply(this, arguments);\n this.updateContentSize();\n return this.updateScroll();\n };\n\n return Component_LayoutBehavior;\n\n})(gs.Component_Visual);\n\ngs.Component_LayoutBehavior = Component_LayoutBehavior;\n\n//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"","sourceRoot":"","sources":[""],"names":[],"mappings":"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","sourcesContent":["# ===================================================================\n#\n#   Script: Component_LayoutBehavior\n#\n#   $$COPYRIGHT$$\n#\n# ===================================================================\nclass Component_LayoutBehavior extends gs.Component_Visual\n    ###*\n    * The base class of all layout-components. A layout-component is used\n    * to layout assigned sub-objects in a specific way depending on the layout-type.\n    * For example: A grid-layout layouts its sub-objects like a grid using rows\n    * and columns. The game object needs a container-component.<br><br>\n    *\n    * A layout can also be configured as scrollable. In that case, layout's content\n    * can be larger than the layout-bounds and is automatically clipped. The content\n    * can be scrolled using mouse-wheel or touch-gesture.\n    *\n    * @module gs\n    * @class Component_LayoutBehavior\n    * @extends gs.Component\n    * @memberof gs\n    * @constructor\n    ###\n    constructor: ->\n        ###*\n        * Content size of the layout.\n        * @property contentSize\n        * @type gs.Size\n        * @readOnly\n        ###\n        @contentSize = width: 0, height: 0\n\n    ###*\n    * Disposes the layout and all its sub-objects.\n    *\n    * @method dispose\n    ###  \n    # FIXME: Is that still necessary? If the parent game object is disposed\n    # all sub-objects are disposed as well.\n    dispose: ->\n        for control in @object.controls\n            control?.dispose()\n    \n    ###*\n    * Initializes the layout.\n    *\n    * @method setup\n    ### \n    setup: ->\n     \n    ###*\n    * Sizes the layout to fit its content.\n    *\n    * @method sizeToFit\n    * @abstract\n    ### \n    sizeToFit: ->\n        \n    ###*\n    * Sort-Function to sort sub-objects by order-index.\n    *\n    * @method sort_\n    * @protected\n    * @param {gs.Object_Base} a Object A\n    * @param {gs.Object_Base} b Object B\n    ###    \n    sort_: (a, b) ->\n        if a.order > b.order\n          return -1\n        else if a.order < b.order\n          return 1\n        else\n          return 0\n    \n    ###*\n    * Updates a specified control.\n    *\n    * @method updateControl\n    * @protected\n    * @param {gs.Object_Base} control The control to update\n    ### \n    updateControl: (control) ->\n        @object.rIndex = Math.max(@object.rIndex, control.rIndex)\n        \n        if control.updateBehavior == ui.UpdateBehavior.CONTINUOUS\n            control.needsUpdate = yes\n            \n        if control.inheritProperties\n            control.ui.enabled = @object.ui.enabled\n            control.opacity = @object.opacity\n            control.zoom = @object.zoom\n            control.color = @object.color\n            control.tone = @object.tone\n            control.angle = @object.angle\n            control.anchor.x = @object.anchor.x\n            control.anchor.y = @object.anchor.y\n            \n            \n        if control.needsUpdate\n            control.needsUpdate = no\n            control.update()\n            control.parent = @object\n            \n        \n        if @object.clipRect?\n            control.clipRect = @object.clipRect\n     \n    ###*\n    * Updates the content size of the layout. Only works if scrolling is\n    * enabled.\n    *\n    * @method updateContentSize\n    * @protected\n    ### \n    updateContentSize: ->\n        if @object.scrollable\n            @contentSize.width = 0\n            @contentSize.height = 0\n            for control in @object.controls\n                if control\n                    @contentSize.width += control.margin.left + control.dstRect.width + control.margin.right\n                    @contentSize.height += control.margin.top + control.dstRect.height + control.margin.bottom\n            \n            @object.contentHeight = @contentSize.height\n            @object.contentWidth = @contentSize.width\n        \n    ###*\n    * Updates scrolling.\n    *\n    * @method updateScroll\n    ###\n    updateScroll: ->\n        if @object.scrollable\n            @object.scrollableHeight = Math.max(0, @contentSize.height - @object.dstRect.height)\n            if Input.Mouse.wheel <= -1\n                @object.scrollOffsetY = Math.max(@object.scrollOffsetY - Input.Mouse.wheelSpeed * 0.1, 0)\n               \n            if Input.Mouse.wheel >= 1\n                @object.scrollOffsetY = Math.min(@object.scrollOffsetY - Input.Mouse.wheelSpeed * 0.1, @object.scrollableHeight)\n                \n        \n            @object.scrollOffsetY = Math.max(Math.min(@object.scrollOffsetY, @object.scrollableHeight), 0)\n     \n    ###*\n    * Updates the layout's content.\n    *\n    * @method updateContent\n    ###  \n    updateContent: ->\n        \n    ###*\n    * Updates the layout.\n    *\n    * @method update\n    ###    \n    update: ->\n        super\n        \n        @updateContentSize()\n        @updateScroll()\n        \n        \n        #if @object.needsSort\n        #    @object.subObjects.sort(@sort_)\n        #    @object.needsSort = no\n    \n        \ngs.Component_LayoutBehavior = Component_LayoutBehavior"]}\n//# sourceURL=Component_LayoutBehavior_46.js"},"summary":["name","type","order"]}
|