UNPKG

ngx-spine

Version:

[![Build Status](https://travis-ci.org/PoiScript/ngx-spine.svg?branch=master)](https://travis-ci.org/PoiScript/ngx-spine)

448 lines 48.6 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ /****************************************************************************** * Spine Runtimes License Agreement * Last updated May 1, 2019. Replaces all prior versions. * * Copyright (c) 2013-2019, Esoteric Software LLC * * Integration of the Spine Runtimes into software or otherwise creating * derivative works of the Spine Runtimes is permitted under the terms and * conditions of Section 2 of the Spine Editor License Agreement: * http://esotericsoftware.com/spine-editor-license * * Otherwise, it is permitted to integrate the Spine Runtimes into software * or otherwise create derivative works of the Spine Runtimes (collectively, * "Products"), provided that each user of the Products must obtain their own * Spine Editor license and redistribution of the Products in any form must * include this license and copyright notice. * * THIS SOFTWARE IS PROVIDED BY ESOTERIC SOFTWARE LLC "AS IS" AND ANY EXPRESS * OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN * NO EVENT SHALL ESOTERIC SOFTWARE LLC BE LIABLE FOR ANY DIRECT, INDIRECT, * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES, BUSINESS * INTERRUPTION, OR LOSS OF USE, DATA, OR PROFITS) HOWEVER CAUSED AND ON ANY * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, * EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. *****************************************************************************/ import { Vector2, MathUtils } from "./Utils"; export class TransformConstraint { /** * @param {?} data * @param {?} skeleton */ constructor(data, skeleton) { this.rotateMix = 0; this.translateMix = 0; this.scaleMix = 0; this.shearMix = 0; this.temp = new Vector2(); this.active = false; if (data == null) throw new Error("data cannot be null."); if (skeleton == null) throw new Error("skeleton cannot be null."); this.data = data; this.rotateMix = data.rotateMix; this.translateMix = data.translateMix; this.scaleMix = data.scaleMix; this.shearMix = data.shearMix; this.bones = new Array(); for (let i = 0; i < data.bones.length; i++) this.bones.push(skeleton.findBone(data.bones[i].name)); this.target = skeleton.findBone(data.target.name); } /** * @return {?} */ isActive() { return this.active; } /** * @return {?} */ apply() { this.update(); } /** * @return {?} */ update() { if (this.data.local) { if (this.data.relative) this.applyRelativeLocal(); else this.applyAbsoluteLocal(); } else { if (this.data.relative) this.applyRelativeWorld(); else this.applyAbsoluteWorld(); } } /** * @return {?} */ applyAbsoluteWorld() { /** @type {?} */ let rotateMix = this.rotateMix; /** @type {?} */ let translateMix = this.translateMix; /** @type {?} */ let scaleMix = this.scaleMix; /** @type {?} */ let shearMix = this.shearMix; /** @type {?} */ let target = this.target; /** @type {?} */ let ta = target.a; /** @type {?} */ let tb = target.b; /** @type {?} */ let tc = target.c; /** @type {?} */ let td = target.d; /** @type {?} */ let degRadReflect = ta * td - tb * tc > 0 ? MathUtils.degRad : -MathUtils.degRad; /** @type {?} */ let offsetRotation = this.data.offsetRotation * degRadReflect; /** @type {?} */ let offsetShearY = this.data.offsetShearY * degRadReflect; /** @type {?} */ let bones = this.bones; for (let i = 0, n = bones.length; i < n; i++) { /** @type {?} */ let bone = bones[i]; /** @type {?} */ let modified = false; if (rotateMix != 0) { /** @type {?} */ let a = bone.a; /** @type {?} */ let b = bone.b; /** @type {?} */ let c = bone.c; /** @type {?} */ let d = bone.d; /** @type {?} */ let r = Math.atan2(tc, ta) - Math.atan2(c, a) + offsetRotation; if (r > MathUtils.PI) r -= MathUtils.PI2; else if (r < -MathUtils.PI) r += MathUtils.PI2; r *= rotateMix; /** @type {?} */ let cos = Math.cos(r); /** @type {?} */ let sin = Math.sin(r); bone.a = cos * a - sin * c; bone.b = cos * b - sin * d; bone.c = sin * a + cos * c; bone.d = sin * b + cos * d; modified = true; } if (translateMix != 0) { /** @type {?} */ let temp = this.temp; target.localToWorld(temp.set(this.data.offsetX, this.data.offsetY)); bone.worldX += (temp.x - bone.worldX) * translateMix; bone.worldY += (temp.y - bone.worldY) * translateMix; modified = true; } if (scaleMix > 0) { /** @type {?} */ let s = Math.sqrt(bone.a * bone.a + bone.c * bone.c); /** @type {?} */ let ts = Math.sqrt(ta * ta + tc * tc); if (s > 0.00001) s = (s + (ts - s + this.data.offsetScaleX) * scaleMix) / s; bone.a *= s; bone.c *= s; s = Math.sqrt(bone.b * bone.b + bone.d * bone.d); ts = Math.sqrt(tb * tb + td * td); if (s > 0.00001) s = (s + (ts - s + this.data.offsetScaleY) * scaleMix) / s; bone.b *= s; bone.d *= s; modified = true; } if (shearMix > 0) { /** @type {?} */ let b = bone.b; /** @type {?} */ let d = bone.d; /** @type {?} */ let by = Math.atan2(d, b); /** @type {?} */ let r = Math.atan2(td, tb) - Math.atan2(tc, ta) - (by - Math.atan2(bone.c, bone.a)); if (r > MathUtils.PI) r -= MathUtils.PI2; else if (r < -MathUtils.PI) r += MathUtils.PI2; r = by + (r + offsetShearY) * shearMix; /** @type {?} */ let s = Math.sqrt(b * b + d * d); bone.b = Math.cos(r) * s; bone.d = Math.sin(r) * s; modified = true; } if (modified) bone.appliedValid = false; } } /** * @return {?} */ applyRelativeWorld() { /** @type {?} */ let rotateMix = this.rotateMix; /** @type {?} */ let translateMix = this.translateMix; /** @type {?} */ let scaleMix = this.scaleMix; /** @type {?} */ let shearMix = this.shearMix; /** @type {?} */ let target = this.target; /** @type {?} */ let ta = target.a; /** @type {?} */ let tb = target.b; /** @type {?} */ let tc = target.c; /** @type {?} */ let td = target.d; /** @type {?} */ let degRadReflect = ta * td - tb * tc > 0 ? MathUtils.degRad : -MathUtils.degRad; /** @type {?} */ let offsetRotation = this.data.offsetRotation * degRadReflect; /** @type {?} */ let offsetShearY = this.data.offsetShearY * degRadReflect; /** @type {?} */ let bones = this.bones; for (let i = 0, n = bones.length; i < n; i++) { /** @type {?} */ let bone = bones[i]; /** @type {?} */ let modified = false; if (rotateMix != 0) { /** @type {?} */ let a = bone.a; /** @type {?} */ let b = bone.b; /** @type {?} */ let c = bone.c; /** @type {?} */ let d = bone.d; /** @type {?} */ let r = Math.atan2(tc, ta) + offsetRotation; if (r > MathUtils.PI) r -= MathUtils.PI2; else if (r < -MathUtils.PI) r += MathUtils.PI2; r *= rotateMix; /** @type {?} */ let cos = Math.cos(r); /** @type {?} */ let sin = Math.sin(r); bone.a = cos * a - sin * c; bone.b = cos * b - sin * d; bone.c = sin * a + cos * c; bone.d = sin * b + cos * d; modified = true; } if (translateMix != 0) { /** @type {?} */ let temp = this.temp; target.localToWorld(temp.set(this.data.offsetX, this.data.offsetY)); bone.worldX += temp.x * translateMix; bone.worldY += temp.y * translateMix; modified = true; } if (scaleMix > 0) { /** @type {?} */ let s = (Math.sqrt(ta * ta + tc * tc) - 1 + this.data.offsetScaleX) * scaleMix + 1; bone.a *= s; bone.c *= s; s = (Math.sqrt(tb * tb + td * td) - 1 + this.data.offsetScaleY) * scaleMix + 1; bone.b *= s; bone.d *= s; modified = true; } if (shearMix > 0) { /** @type {?} */ let r = Math.atan2(td, tb) - Math.atan2(tc, ta); if (r > MathUtils.PI) r -= MathUtils.PI2; else if (r < -MathUtils.PI) r += MathUtils.PI2; /** @type {?} */ let b = bone.b; /** @type {?} */ let d = bone.d; r = Math.atan2(d, b) + (r - MathUtils.PI / 2 + offsetShearY) * shearMix; /** @type {?} */ let s = Math.sqrt(b * b + d * d); bone.b = Math.cos(r) * s; bone.d = Math.sin(r) * s; modified = true; } if (modified) bone.appliedValid = false; } } /** * @return {?} */ applyAbsoluteLocal() { /** @type {?} */ let rotateMix = this.rotateMix; /** @type {?} */ let translateMix = this.translateMix; /** @type {?} */ let scaleMix = this.scaleMix; /** @type {?} */ let shearMix = this.shearMix; /** @type {?} */ let target = this.target; if (!target.appliedValid) target.updateAppliedTransform(); /** @type {?} */ let bones = this.bones; for (let i = 0, n = bones.length; i < n; i++) { /** @type {?} */ let bone = bones[i]; if (!bone.appliedValid) bone.updateAppliedTransform(); /** @type {?} */ let rotation = bone.arotation; if (rotateMix != 0) { /** @type {?} */ let r = target.arotation - rotation + this.data.offsetRotation; r -= (16384 - ((16384.499999999996 - r / 360) | 0)) * 360; rotation += r * rotateMix; } /** @type {?} */ let x = bone.ax; /** @type {?} */ let y = bone.ay; if (translateMix != 0) { x += (target.ax - x + this.data.offsetX) * translateMix; y += (target.ay - y + this.data.offsetY) * translateMix; } /** @type {?} */ let scaleX = bone.ascaleX; /** @type {?} */ let scaleY = bone.ascaleY; if (scaleMix != 0) { if (scaleX > 0.00001) scaleX = (scaleX + (target.ascaleX - scaleX + this.data.offsetScaleX) * scaleMix) / scaleX; if (scaleY > 0.00001) scaleY = (scaleY + (target.ascaleY - scaleY + this.data.offsetScaleY) * scaleMix) / scaleY; } /** @type {?} */ let shearY = bone.ashearY; if (shearMix != 0) { /** @type {?} */ let r = target.ashearY - shearY + this.data.offsetShearY; r -= (16384 - ((16384.499999999996 - r / 360) | 0)) * 360; bone.shearY += r * shearMix; } bone.updateWorldTransformWith(x, y, rotation, scaleX, scaleY, bone.ashearX, shearY); } } /** * @return {?} */ applyRelativeLocal() { /** @type {?} */ let rotateMix = this.rotateMix; /** @type {?} */ let translateMix = this.translateMix; /** @type {?} */ let scaleMix = this.scaleMix; /** @type {?} */ let shearMix = this.shearMix; /** @type {?} */ let target = this.target; if (!target.appliedValid) target.updateAppliedTransform(); /** @type {?} */ let bones = this.bones; for (let i = 0, n = bones.length; i < n; i++) { /** @type {?} */ let bone = bones[i]; if (!bone.appliedValid) bone.updateAppliedTransform(); /** @type {?} */ let rotation = bone.arotation; if (rotateMix != 0) rotation += (target.arotation + this.data.offsetRotation) * rotateMix; /** @type {?} */ let x = bone.ax; /** @type {?} */ let y = bone.ay; if (translateMix != 0) { x += (target.ax + this.data.offsetX) * translateMix; y += (target.ay + this.data.offsetY) * translateMix; } /** @type {?} */ let scaleX = bone.ascaleX; /** @type {?} */ let scaleY = bone.ascaleY; if (scaleMix != 0) { if (scaleX > 0.00001) scaleX *= (target.ascaleX - 1 + this.data.offsetScaleX) * scaleMix + 1; if (scaleY > 0.00001) scaleY *= (target.ascaleY - 1 + this.data.offsetScaleY) * scaleMix + 1; } /** @type {?} */ let shearY = bone.ashearY; if (shearMix != 0) shearY += (target.ashearY + this.data.offsetShearY) * shearMix; bone.updateWorldTransformWith(x, y, rotation, scaleX, scaleY, bone.ashearX, shearY); } } } if (false) { /** @type {?} */ TransformConstraint.prototype.data; /** @type {?} */ TransformConstraint.prototype.bones; /** @type {?} */ TransformConstraint.prototype.target; /** @type {?} */ TransformConstraint.prototype.rotateMix; /** @type {?} */ TransformConstraint.prototype.translateMix; /** @type {?} */ TransformConstraint.prototype.scaleMix; /** @type {?} */ TransformConstraint.prototype.shearMix; /** @type {?} */ TransformConstraint.prototype.temp; /** @type {?} */ TransformConstraint.prototype.active; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"TransformConstraint.js","sourceRoot":"ng://ngx-spine/","sources":["lib/spine-ts/core/TransformConstraint.ts"],"names":[],"mappings":"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","sourcesContent":["/******************************************************************************\r\n * Spine Runtimes License Agreement\r\n * Last updated May 1, 2019. Replaces all prior versions.\r\n *\r\n * Copyright (c) 2013-2019, Esoteric Software LLC\r\n *\r\n * Integration of the Spine Runtimes into software or otherwise creating\r\n * derivative works of the Spine Runtimes is permitted under the terms and\r\n * conditions of Section 2 of the Spine Editor License Agreement:\r\n * http://esotericsoftware.com/spine-editor-license\r\n *\r\n * Otherwise, it is permitted to integrate the Spine Runtimes into software\r\n * or otherwise create derivative works of the Spine Runtimes (collectively,\r\n * \"Products\"), provided that each user of the Products must obtain their own\r\n * Spine Editor license and redistribution of the Products in any form must\r\n * include this license and copyright notice.\r\n *\r\n * THIS SOFTWARE IS PROVIDED BY ESOTERIC SOFTWARE LLC \"AS IS\" AND ANY EXPRESS\r\n * OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES\r\n * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN\r\n * NO EVENT SHALL ESOTERIC SOFTWARE LLC BE LIABLE FOR ANY DIRECT, INDIRECT,\r\n * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,\r\n * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES, BUSINESS\r\n * INTERRUPTION, OR LOSS OF USE, DATA, OR PROFITS) HOWEVER CAUSED AND ON ANY\r\n * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING\r\n * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,\r\n * EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\r\n *****************************************************************************/\r\n\r\nimport { Updatable } from \"./Updatable\";\r\nimport { TransformConstraintData } from \"./TransformConstraintData\";\r\nimport { Bone } from \"./Bone\";\r\nimport { Vector2, MathUtils } from \"./Utils\";\r\nimport { Skeleton } from \"./Skeleton\";\r\n\r\nexport class TransformConstraint implements Updatable {\r\n  data: TransformConstraintData;\r\n  bones: Array<Bone>;\r\n  target: Bone;\r\n  rotateMix = 0;\r\n  translateMix = 0;\r\n  scaleMix = 0;\r\n  shearMix = 0;\r\n  temp = new Vector2();\r\n  active = false;\r\n  constructor(data: TransformConstraintData, skeleton: Skeleton) {\r\n    if (data == null) throw new Error(\"data cannot be null.\");\r\n    if (skeleton == null) throw new Error(\"skeleton cannot be null.\");\r\n    this.data = data;\r\n    this.rotateMix = data.rotateMix;\r\n    this.translateMix = data.translateMix;\r\n    this.scaleMix = data.scaleMix;\r\n    this.shearMix = data.shearMix;\r\n    this.bones = new Array<Bone>();\r\n    for (let i = 0; i < data.bones.length; i++)\r\n      this.bones.push(skeleton.findBone(data.bones[i].name));\r\n    this.target = skeleton.findBone(data.target.name);\r\n  }\r\n  isActive() {\r\n    return this.active;\r\n  }\r\n  apply() {\r\n    this.update();\r\n  }\r\n  update() {\r\n    if (this.data.local) {\r\n      if (this.data.relative) this.applyRelativeLocal();\r\n      else this.applyAbsoluteLocal();\r\n    } else {\r\n      if (this.data.relative) this.applyRelativeWorld();\r\n      else this.applyAbsoluteWorld();\r\n    }\r\n  }\r\n  applyAbsoluteWorld() {\r\n    let rotateMix = this.rotateMix,\r\n      translateMix = this.translateMix,\r\n      scaleMix = this.scaleMix,\r\n      shearMix = this.shearMix;\r\n    let target = this.target;\r\n    let ta = target.a,\r\n      tb = target.b,\r\n      tc = target.c,\r\n      td = target.d;\r\n    let degRadReflect =\r\n      ta * td - tb * tc > 0 ? MathUtils.degRad : -MathUtils.degRad;\r\n    let offsetRotation = this.data.offsetRotation * degRadReflect;\r\n    let offsetShearY = this.data.offsetShearY * degRadReflect;\r\n    let bones = this.bones;\r\n    for (let i = 0, n = bones.length; i < n; i++) {\r\n      let bone = bones[i];\r\n      let modified = false;\r\n      if (rotateMix != 0) {\r\n        let a = bone.a,\r\n          b = bone.b,\r\n          c = bone.c,\r\n          d = bone.d;\r\n        let r = Math.atan2(tc, ta) - Math.atan2(c, a) + offsetRotation;\r\n        if (r > MathUtils.PI) r -= MathUtils.PI2;\r\n        else if (r < -MathUtils.PI) r += MathUtils.PI2;\r\n        r *= rotateMix;\r\n        let cos = Math.cos(r),\r\n          sin = Math.sin(r);\r\n        bone.a = cos * a - sin * c;\r\n        bone.b = cos * b - sin * d;\r\n        bone.c = sin * a + cos * c;\r\n        bone.d = sin * b + cos * d;\r\n        modified = true;\r\n      }\r\n      if (translateMix != 0) {\r\n        let temp = this.temp;\r\n        target.localToWorld(temp.set(this.data.offsetX, this.data.offsetY));\r\n        bone.worldX += (temp.x - bone.worldX) * translateMix;\r\n        bone.worldY += (temp.y - bone.worldY) * translateMix;\r\n        modified = true;\r\n      }\r\n      if (scaleMix > 0) {\r\n        let s = Math.sqrt(bone.a * bone.a + bone.c * bone.c);\r\n        let ts = Math.sqrt(ta * ta + tc * tc);\r\n        if (s > 0.00001)\r\n          s = (s + (ts - s + this.data.offsetScaleX) * scaleMix) / s;\r\n        bone.a *= s;\r\n        bone.c *= s;\r\n        s = Math.sqrt(bone.b * bone.b + bone.d * bone.d);\r\n        ts = Math.sqrt(tb * tb + td * td);\r\n        if (s > 0.00001)\r\n          s = (s + (ts - s + this.data.offsetScaleY) * scaleMix) / s;\r\n        bone.b *= s;\r\n        bone.d *= s;\r\n        modified = true;\r\n      }\r\n      if (shearMix > 0) {\r\n        let b = bone.b,\r\n          d = bone.d;\r\n        let by = Math.atan2(d, b);\r\n        let r =\r\n          Math.atan2(td, tb) -\r\n          Math.atan2(tc, ta) -\r\n          (by - Math.atan2(bone.c, bone.a));\r\n        if (r > MathUtils.PI) r -= MathUtils.PI2;\r\n        else if (r < -MathUtils.PI) r += MathUtils.PI2;\r\n        r = by + (r + offsetShearY) * shearMix;\r\n        let s = Math.sqrt(b * b + d * d);\r\n        bone.b = Math.cos(r) * s;\r\n        bone.d = Math.sin(r) * s;\r\n        modified = true;\r\n      }\r\n      if (modified) bone.appliedValid = false;\r\n    }\r\n  }\r\n  applyRelativeWorld() {\r\n    let rotateMix = this.rotateMix,\r\n      translateMix = this.translateMix,\r\n      scaleMix = this.scaleMix,\r\n      shearMix = this.shearMix;\r\n    let target = this.target;\r\n    let ta = target.a,\r\n      tb = target.b,\r\n      tc = target.c,\r\n      td = target.d;\r\n    let degRadReflect =\r\n      ta * td - tb * tc > 0 ? MathUtils.degRad : -MathUtils.degRad;\r\n    let offsetRotation = this.data.offsetRotation * degRadReflect,\r\n      offsetShearY = this.data.offsetShearY * degRadReflect;\r\n    let bones = this.bones;\r\n    for (let i = 0, n = bones.length; i < n; i++) {\r\n      let bone = bones[i];\r\n      let modified = false;\r\n      if (rotateMix != 0) {\r\n        let a = bone.a,\r\n          b = bone.b,\r\n          c = bone.c,\r\n          d = bone.d;\r\n        let r = Math.atan2(tc, ta) + offsetRotation;\r\n        if (r > MathUtils.PI) r -= MathUtils.PI2;\r\n        else if (r < -MathUtils.PI) r += MathUtils.PI2;\r\n        r *= rotateMix;\r\n        let cos = Math.cos(r),\r\n          sin = Math.sin(r);\r\n        bone.a = cos * a - sin * c;\r\n        bone.b = cos * b - sin * d;\r\n        bone.c = sin * a + cos * c;\r\n        bone.d = sin * b + cos * d;\r\n        modified = true;\r\n      }\r\n      if (translateMix != 0) {\r\n        let temp = this.temp;\r\n        target.localToWorld(temp.set(this.data.offsetX, this.data.offsetY));\r\n        bone.worldX += temp.x * translateMix;\r\n        bone.worldY += temp.y * translateMix;\r\n        modified = true;\r\n      }\r\n      if (scaleMix > 0) {\r\n        let s =\r\n          (Math.sqrt(ta * ta + tc * tc) - 1 + this.data.offsetScaleX) *\r\n            scaleMix +\r\n          1;\r\n        bone.a *= s;\r\n        bone.c *= s;\r\n        s =\r\n          (Math.sqrt(tb * tb + td * td) - 1 + this.data.offsetScaleY) *\r\n            scaleMix +\r\n          1;\r\n        bone.b *= s;\r\n        bone.d *= s;\r\n        modified = true;\r\n      }\r\n      if (shearMix > 0) {\r\n        let r = Math.atan2(td, tb) - Math.atan2(tc, ta);\r\n        if (r > MathUtils.PI) r -= MathUtils.PI2;\r\n        else if (r < -MathUtils.PI) r += MathUtils.PI2;\r\n        let b = bone.b,\r\n          d = bone.d;\r\n        r = Math.atan2(d, b) + (r - MathUtils.PI / 2 + offsetShearY) * shearMix;\r\n        let s = Math.sqrt(b * b + d * d);\r\n        bone.b = Math.cos(r) * s;\r\n        bone.d = Math.sin(r) * s;\r\n        modified = true;\r\n      }\r\n      if (modified) bone.appliedValid = false;\r\n    }\r\n  }\r\n  applyAbsoluteLocal() {\r\n    let rotateMix = this.rotateMix,\r\n      translateMix = this.translateMix,\r\n      scaleMix = this.scaleMix,\r\n      shearMix = this.shearMix;\r\n    let target = this.target;\r\n    if (!target.appliedValid) target.updateAppliedTransform();\r\n    let bones = this.bones;\r\n    for (let i = 0, n = bones.length; i < n; i++) {\r\n      let bone = bones[i];\r\n      if (!bone.appliedValid) bone.updateAppliedTransform();\r\n      let rotation = bone.arotation;\r\n      if (rotateMix != 0) {\r\n        let r = target.arotation - rotation + this.data.offsetRotation;\r\n        r -= (16384 - ((16384.499999999996 - r / 360) | 0)) * 360;\r\n        rotation += r * rotateMix;\r\n      }\r\n      let x = bone.ax,\r\n        y = bone.ay;\r\n      if (translateMix != 0) {\r\n        x += (target.ax - x + this.data.offsetX) * translateMix;\r\n        y += (target.ay - y + this.data.offsetY) * translateMix;\r\n      }\r\n      let scaleX = bone.ascaleX,\r\n        scaleY = bone.ascaleY;\r\n      if (scaleMix != 0) {\r\n        if (scaleX > 0.00001)\r\n          scaleX =\r\n            (scaleX +\r\n              (target.ascaleX - scaleX + this.data.offsetScaleX) * scaleMix) /\r\n            scaleX;\r\n        if (scaleY > 0.00001)\r\n          scaleY =\r\n            (scaleY +\r\n              (target.ascaleY - scaleY + this.data.offsetScaleY) * scaleMix) /\r\n            scaleY;\r\n      }\r\n      let shearY = bone.ashearY;\r\n      if (shearMix != 0) {\r\n        let r = target.ashearY - shearY + this.data.offsetShearY;\r\n        r -= (16384 - ((16384.499999999996 - r / 360) | 0)) * 360;\r\n        bone.shearY += r * shearMix;\r\n      }\r\n      bone.updateWorldTransformWith(\r\n        x,\r\n        y,\r\n        rotation,\r\n        scaleX,\r\n        scaleY,\r\n        bone.ashearX,\r\n        shearY\r\n      );\r\n    }\r\n  }\r\n  applyRelativeLocal() {\r\n    let rotateMix = this.rotateMix,\r\n      translateMix = this.translateMix,\r\n      scaleMix = this.scaleMix,\r\n      shearMix = this.shearMix;\r\n    let target = this.target;\r\n    if (!target.appliedValid) target.updateAppliedTransform();\r\n    let bones = this.bones;\r\n    for (let i = 0, n = bones.length; i < n; i++) {\r\n      let bone = bones[i];\r\n      if (!bone.appliedValid) bone.updateAppliedTransform();\r\n      let rotation = bone.arotation;\r\n      if (rotateMix != 0)\r\n        rotation += (target.arotation + this.data.offsetRotation) * rotateMix;\r\n      let x = bone.ax,\r\n        y = bone.ay;\r\n      if (translateMix != 0) {\r\n        x += (target.ax + this.data.offsetX) * translateMix;\r\n        y += (target.ay + this.data.offsetY) * translateMix;\r\n      }\r\n      let scaleX = bone.ascaleX,\r\n        scaleY = bone.ascaleY;\r\n      if (scaleMix != 0) {\r\n        if (scaleX > 0.00001)\r\n          scaleX *=\r\n            (target.ascaleX - 1 + this.data.offsetScaleX) * scaleMix + 1;\r\n        if (scaleY > 0.00001)\r\n          scaleY *=\r\n            (target.ascaleY - 1 + this.data.offsetScaleY) * scaleMix + 1;\r\n      }\r\n      let shearY = bone.ashearY;\r\n      if (shearMix != 0)\r\n        shearY += (target.ashearY + this.data.offsetShearY) * shearMix;\r\n      bone.updateWorldTransformWith(\r\n        x,\r\n        y,\r\n        rotation,\r\n        scaleX,\r\n        scaleY,\r\n        bone.ashearX,\r\n        shearY\r\n      );\r\n    }\r\n  }\r\n}\r\n"]}