'use strict'; exports.__esModule = true; var _math = require('../math'); function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } /** * Generic class to deal with traditional 2D matrix transforms * * @class * @memberof PIXI */ var TransformBase = function () { /** * */ function TransformBase() { _classCallCheck(this, TransformBase); /** * The global matrix transform. It can be swapped temporarily by some functions like getLocalBounds() * * @member {PIXI.Matrix} */ this.worldTransform = new _math.Matrix(); /** * The local matrix transform * * @member {PIXI.Matrix} */ this.localTransform = new _math.Matrix(); this._worldID = 0; this._parentID = 0; } /** * TransformBase does not have decomposition, so this function wont do anything */ TransformBase.prototype.updateLocalTransform = function updateLocalTransform() {} // empty /** * Updates the values of the object and applies the parent's transform. * * @param {PIXI.TransformBase} parentTransform - The transform of the parent of this object */ ; TransformBase.prototype.updateTransform = function updateTransform(parentTransform) { var pt = parentTransform.worldTransform; var wt = this.worldTransform; var lt = this.localTransform; // concat the parent matrix with the objects transform. wt.a = lt.a * pt.a + lt.b * pt.c; wt.b = lt.a * pt.b + lt.b * pt.d; wt.c = lt.c * pt.a + lt.d * pt.c; wt.d = lt.c * pt.b + lt.d * pt.d; wt.tx = lt.tx * pt.a + lt.ty * pt.c + pt.tx; wt.ty = lt.tx * pt.b + lt.ty * pt.d + pt.ty; this._worldID++; }; return TransformBase; }(); /** * Updates the values of the object and applies the parent's transform. * @param parentTransform {PIXI.Transform} The transform of the parent of this object * */ exports.default = TransformBase; TransformBase.prototype.updateWorldTransform = TransformBase.prototype.updateTransform; TransformBase.IDENTITY = new TransformBase(); //# sourceMappingURL=TransformBase.js.map