Nextrek
@ 1348
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 |
var Component_ThreePartImage, 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; }, hasProp = {}.hasOwnProperty; Component_ThreePartImage = (function(superClass) { extend(Component_ThreePartImage, superClass); /** * Called if this object instance is restored from a data-bundle. It can be used * re-assign event-handler, anonymous functions, etc. * * @method onDataBundleRestore. * @param Object data - The data-bundle * @param gs.ObjectCodecContext context - The codec-context. */ Component_ThreePartImage.prototype.onDataBundleRestore = function(data, context) { return this.setupEventHandlers(); }; /** * A three-part image component displays an object on screen using three * sub-images: start, middle and end. The start and end will be rendered * with fixed size while the middle-part will be stretched in a way like this:<br> * <br> * |Start-Part Fixed|<-----------Middle-Part Stretched----------->|End-Part Fixed<br> * <br> * A three-part image is automatically added to the graphics-system * and rendered every frame until it gets disposed. It can be horizontal or * vertical. * * @module gs * @class Component_ThreePartImage * @extends gs.Component_Visual * @memberof gs * @constructor */ function Component_ThreePartImage(viewport) { Component_ThreePartImage.__super__.constructor.call(this); /** * The native three-part image graphic object. * @property threePartImage * @type gs.ThreePartImage */ this.threePartImage = new gs.ThreePartImage(viewport != null ? viewport : Graphics.viewport); /** * The name of the image used to construct the three-part image. * @property image * @type string * @protected */ this.image = null; } /** * Disposes the three-part image. * * @method dispose */ Component_ThreePartImage.prototype.dispose = function() { Component_ThreePartImage.__super__.dispose.apply(this, arguments); return this.threePartImage.dispose(); }; /** * Adds event-handlers for mouse/touch events * * @method setupEventHandlers */ Component_ThreePartImage.prototype.setupEventHandlers = function() { return this.threePartImage.onIndexChange = (function(_this) { return function() { return _this.object.rIndex = _this.threePartImage.index; }; })(this); }; /** * Setup the three-part image component. This method is automatically called by the * system. * @method setup */ Component_ThreePartImage.prototype.setup = function() { return this.setupEventHandlers(); }; /** * Updates the three-part image properties from the game object properties. * * @method updateProperties */ Component_ThreePartImage.prototype.updateProperties = function() { this.threePartImage.x = this.object.dstRect.x - this.object.dstRect.width * (this.object.zoom.x - 1.0) * this.object.anchor.x; this.threePartImage.y = this.object.dstRect.y - this.object.dstRect.height * (this.object.zoom.y - 1.0) * this.object.anchor.y; this.threePartImage.width = this.object.dstRect.width; this.threePartImage.height = this.object.dstRect.height; this.threePartImage.firstPartSize = this.object.firstPartSize || 16; this.threePartImage.middlePartSize = this.object.middlePartSize || 1; this.threePartImage.lastPartSize = this.object.lastPartSize || 16; this.threePartImage.visible = this.object.visible; this.threePartImage.ox = -this.object.origin.x; this.threePartImage.oy = -this.object.origin.y; this.threePartImage.z = (this.object.zIndex || 0) + (!this.object.parent ? 0 : this.object.parent.zIndex || 0); this.threePartImage.angle = this.object.angle || 0; this.threePartImage.anchor.x = this.object.anchor.x; return this.threePartImage.anchor.y = this.object.anchor.y; }; /** * Updates the padding. * * @method updatePadding */ Component_ThreePartImage.prototype.updatePadding = function() { if (this.object.padding != null) { this.threePartImage.x += this.object.padding.left; this.threePartImage.y += this.object.padding.top; this.threePartImage.width -= this.object.padding.left + this.object.padding.right; return this.threePartImage.height -= this.object.padding.top + this.object.padding.bottom; } }; /** * Updates the skin-image used to construct the three-part image. * * @method updateImage */ Component_ThreePartImage.prototype.updateImage = function() { var bitmap; if ((this.object.image != null) && this.image !== this.object.image) { this.image = this.object.image; bitmap = ResourceManager.getBitmap((this.object.imageFolder || "Graphics/Pictures") + "/" + this.object.image); return this.threePartImage.skin = bitmap; } }; /** * Updates the three-part image. * * @method update */ Component_ThreePartImage.prototype.update = function() { Component_ThreePartImage.__super__.update.apply(this, arguments); this.object.rIndex = this.threePartImage.index; this.updateProperties(); this.updatePadding(); return this.updateImage(); }; return Component_ThreePartImage; })(gs.Component_Visual); gs.Component_ThreePartImage = Component_ThreePartImage; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"","sourceRoot":"","sources":[""],"names":[],"mappings":"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","sourcesContent":["# ===================================================================\n#\n#   Script: Component_ThreePartImage\n#\n#   $$COPYRIGHT$$\n#\n# ===================================================================\nclass Component_ThreePartImage 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 three-part image component displays an object on screen using three\n    * sub-images: start, middle and end. The start and end will be rendered\n    * with fixed size while the middle-part will be stretched in a way like this:<br>\n    * <br>\n    * |Start-Part Fixed|<-----------Middle-Part Stretched----------->|End-Part Fixed<br>\n    * <br>\n    * A three-part image is automatically added to the graphics-system\n    * and rendered every frame until it gets disposed. It can be horizontal or\n    * vertical.\n    *\n    * @module gs\n    * @class Component_ThreePartImage\n    * @extends gs.Component_Visual\n    * @memberof gs\n    * @constructor\n    ###\n    constructor: (viewport) ->\n        super()\n        \n        ###*\n        * The native three-part image graphic object.\n        * @property threePartImage\n        * @type gs.ThreePartImage\n        ###\n        @threePartImage = new gs.ThreePartImage(viewport ? Graphics.viewport)\n        \n        ###*\n        * The name of the image used to construct the three-part image.\n        * @property image\n        * @type string\n        * @protected\n        ###\n        @image = null\n     \n    ###*\n    * Disposes the three-part image.\n    * \n    * @method dispose\n    ###       \n    dispose: ->\n        super\n        @threePartImage.dispose()\n        \n    ###*\n    * Adds event-handlers for mouse/touch events\n    *\n    * @method setupEventHandlers\n    ### \n    setupEventHandlers: ->\n        @threePartImage.onIndexChange = =>\n            @object.rIndex = @threePartImage.index\n            \n    ###*\n    * Setup the three-part image component. This method is automatically called by the\n    * system.\n    * @method setup\n    ###\n    setup: ->\n        @setupEventHandlers()\n     \n    ###*\n    * Updates the three-part image properties from the game object properties.\n    *\n    * @method updateProperties\n    ###   \n    updateProperties: ->\n        @threePartImage.x = @object.dstRect.x - @object.dstRect.width * (@object.zoom.x - 1.0) * @object.anchor.x\n        @threePartImage.y = @object.dstRect.y - @object.dstRect.height * (@object.zoom.y - 1.0) * @object.anchor.y\n        @threePartImage.width = @object.dstRect.width\n        @threePartImage.height = @object.dstRect.height\n        @threePartImage.firstPartSize = @object.firstPartSize || 16\n        @threePartImage.middlePartSize = @object.middlePartSize || 1\n        @threePartImage.lastPartSize = @object.lastPartSize || 16\n        @threePartImage.visible = @object.visible\n        @threePartImage.ox = -@object.origin.x\n        @threePartImage.oy = -@object.origin.y\n        @threePartImage.z = (@object.zIndex || 0) + (if !@object.parent then 0 else @object.parent.zIndex || 0)\n        @threePartImage.angle = @object.angle || 0\n        @threePartImage.anchor.x = @object.anchor.x\n        @threePartImage.anchor.y = @object.anchor.y\n        \n    ###*\n    * Updates the padding.\n    * \n    * @method updatePadding\n    ### \n    updatePadding: ->\n        if @object.padding?\n            @threePartImage.x += @object.padding.left\n            @threePartImage.y += @object.padding.top\n            @threePartImage.width -= @object.padding.left+@object.padding.right\n            @threePartImage.height -= @object.padding.top+@object.padding.bottom\n     \n    ###*\n    * Updates the skin-image used to construct the three-part image.\n    *\n    * @method updateImage\n    ###       \n    updateImage: ->\n        if @object.image? and @image != @object.image\n            @image = @object.image\n            bitmap = ResourceManager.getBitmap(\"#{@object.imageFolder||\"Graphics/Pictures\"}/#{@object.image}\")\n            @threePartImage.skin = bitmap\n    \n    ###*\n    * Updates the three-part image.\n    * \n    * @method update\n    ###    \n    update: ->\n        super\n        \n        @object.rIndex = @threePartImage.index\n        @updateProperties()\n        @updatePadding()\n        @updateImage()\n        \ngs.Component_ThreePartImage = Component_ThreePartImage"]} //# sourceURL=Component_ThreePartImage_156.js |