ngx-spine
Version:
[](https://travis-ci.org/PoiScript/ngx-spine)
448 lines • 48.6 kB
JavaScript
/**
* @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":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAgCA,OAAO,EAAE,OAAO,EAAE,SAAS,EAAE,MAAM,SAAS,CAAC;AAG7C,MAAM,OAAO,mBAAmB;;;;;IAU9B,YAAY,IAA6B,EAAE,QAAkB;QAN7D,cAAS,GAAG,CAAC,CAAC;QACd,iBAAY,GAAG,CAAC,CAAC;QACjB,aAAQ,GAAG,CAAC,CAAC;QACb,aAAQ,GAAG,CAAC,CAAC;QACb,SAAI,GAAG,IAAI,OAAO,EAAE,CAAC;QACrB,WAAM,GAAG,KAAK,CAAC;QAEb,IAAI,IAAI,IAAI,IAAI;YAAE,MAAM,IAAI,KAAK,CAAC,sBAAsB,CAAC,CAAC;QAC1D,IAAI,QAAQ,IAAI,IAAI;YAAE,MAAM,IAAI,KAAK,CAAC,0BAA0B,CAAC,CAAC;QAClE,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;QACjB,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,SAAS,CAAC;QAChC,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,YAAY,CAAC;QACtC,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC;QAC9B,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC;QAC9B,IAAI,CAAC,KAAK,GAAG,IAAI,KAAK,EAAQ,CAAC;QAC/B,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,EAAE,CAAC,EAAE;YACxC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC;QACzD,IAAI,CAAC,MAAM,GAAG,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;IACpD,CAAC;;;;IACD,QAAQ;QACN,OAAO,IAAI,CAAC,MAAM,CAAC;IACrB,CAAC;;;;IACD,KAAK;QACH,IAAI,CAAC,MAAM,EAAE,CAAC;IAChB,CAAC;;;;IACD,MAAM;QACJ,IAAI,IAAI,CAAC,IAAI,CAAC,KAAK,EAAE;YACnB,IAAI,IAAI,CAAC,IAAI,CAAC,QAAQ;gBAAE,IAAI,CAAC,kBAAkB,EAAE,CAAC;;gBAC7C,IAAI,CAAC,kBAAkB,EAAE,CAAC;SAChC;aAAM;YACL,IAAI,IAAI,CAAC,IAAI,CAAC,QAAQ;gBAAE,IAAI,CAAC,kBAAkB,EAAE,CAAC;;gBAC7C,IAAI,CAAC,kBAAkB,EAAE,CAAC;SAChC;IACH,CAAC;;;;IACD,kBAAkB;;YACZ,SAAS,GAAG,IAAI,CAAC,SAAS;;YAC5B,YAAY,GAAG,IAAI,CAAC,YAAY;;YAChC,QAAQ,GAAG,IAAI,CAAC,QAAQ;;YACxB,QAAQ,GAAG,IAAI,CAAC,QAAQ;;YACtB,MAAM,GAAG,IAAI,CAAC,MAAM;;YACpB,EAAE,GAAG,MAAM,CAAC,CAAC;;YACf,EAAE,GAAG,MAAM,CAAC,CAAC;;YACb,EAAE,GAAG,MAAM,CAAC,CAAC;;YACb,EAAE,GAAG,MAAM,CAAC,CAAC;;YACX,aAAa,GACf,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,MAAM;;YAC1D,cAAc,GAAG,IAAI,CAAC,IAAI,CAAC,cAAc,GAAG,aAAa;;YACzD,YAAY,GAAG,IAAI,CAAC,IAAI,CAAC,YAAY,GAAG,aAAa;;YACrD,KAAK,GAAG,IAAI,CAAC,KAAK;QACtB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,KAAK,CAAC,MAAM,EAAE,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE,EAAE;;gBACxC,IAAI,GAAG,KAAK,CAAC,CAAC,CAAC;;gBACf,QAAQ,GAAG,KAAK;YACpB,IAAI,SAAS,IAAI,CAAC,EAAE;;oBACd,CAAC,GAAG,IAAI,CAAC,CAAC;;oBACZ,CAAC,GAAG,IAAI,CAAC,CAAC;;oBACV,CAAC,GAAG,IAAI,CAAC,CAAC;;oBACV,CAAC,GAAG,IAAI,CAAC,CAAC;;oBACR,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,EAAE,EAAE,EAAE,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,GAAG,cAAc;gBAC9D,IAAI,CAAC,GAAG,SAAS,CAAC,EAAE;oBAAE,CAAC,IAAI,SAAS,CAAC,GAAG,CAAC;qBACpC,IAAI,CAAC,GAAG,CAAC,SAAS,CAAC,EAAE;oBAAE,CAAC,IAAI,SAAS,CAAC,GAAG,CAAC;gBAC/C,CAAC,IAAI,SAAS,CAAC;;oBACX,GAAG,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC;;oBACnB,GAAG,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC;gBACnB,IAAI,CAAC,CAAC,GAAG,GAAG,GAAG,CAAC,GAAG,GAAG,GAAG,CAAC,CAAC;gBAC3B,IAAI,CAAC,CAAC,GAAG,GAAG,GAAG,CAAC,GAAG,GAAG,GAAG,CAAC,CAAC;gBAC3B,IAAI,CAAC,CAAC,GAAG,GAAG,GAAG,CAAC,GAAG,GAAG,GAAG,CAAC,CAAC;gBAC3B,IAAI,CAAC,CAAC,GAAG,GAAG,GAAG,CAAC,GAAG,GAAG,GAAG,CAAC,CAAC;gBAC3B,QAAQ,GAAG,IAAI,CAAC;aACjB;YACD,IAAI,YAAY,IAAI,CAAC,EAAE;;oBACjB,IAAI,GAAG,IAAI,CAAC,IAAI;gBACpB,MAAM,CAAC,YAAY,CAAC,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC;gBACpE,IAAI,CAAC,MAAM,IAAI,CAAC,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,MAAM,CAAC,GAAG,YAAY,CAAC;gBACrD,IAAI,CAAC,MAAM,IAAI,CAAC,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,MAAM,CAAC,GAAG,YAAY,CAAC;gBACrD,QAAQ,GAAG,IAAI,CAAC;aACjB;YACD,IAAI,QAAQ,GAAG,CAAC,EAAE;;oBACZ,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC;;oBAChD,EAAE,GAAG,IAAI,CAAC,IAAI,CAAC,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,CAAC;gBACrC,IAAI,CAAC,GAAG,OAAO;oBACb,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,EAAE,GAAG,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,GAAG,QAAQ,CAAC,GAAG,CAAC,CAAC;gBAC7D,IAAI,CAAC,CAAC,IAAI,CAAC,CAAC;gBACZ,IAAI,CAAC,CAAC,IAAI,CAAC,CAAC;gBACZ,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,CAAC;gBACjD,EAAE,GAAG,IAAI,CAAC,IAAI,CAAC,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,CAAC,CAAC;gBAClC,IAAI,CAAC,GAAG,OAAO;oBACb,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,EAAE,GAAG,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,GAAG,QAAQ,CAAC,GAAG,CAAC,CAAC;gBAC7D,IAAI,CAAC,CAAC,IAAI,CAAC,CAAC;gBACZ,IAAI,CAAC,CAAC,IAAI,CAAC,CAAC;gBACZ,QAAQ,GAAG,IAAI,CAAC;aACjB;YACD,IAAI,QAAQ,GAAG,CAAC,EAAE;;oBACZ,CAAC,GAAG,IAAI,CAAC,CAAC;;oBACZ,CAAC,GAAG,IAAI,CAAC,CAAC;;oBACR,EAAE,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC;;oBACrB,CAAC,GACH,IAAI,CAAC,KAAK,CAAC,EAAE,EAAE,EAAE,CAAC;oBAClB,IAAI,CAAC,KAAK,CAAC,EAAE,EAAE,EAAE,CAAC;oBAClB,CAAC,EAAE,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,EAAE,IAAI,CAAC,CAAC,CAAC,CAAC;gBACnC,IAAI,CAAC,GAAG,SAAS,CAAC,EAAE;oBAAE,CAAC,IAAI,SAAS,CAAC,GAAG,CAAC;qBACpC,IAAI,CAAC,GAAG,CAAC,SAAS,CAAC,EAAE;oBAAE,CAAC,IAAI,SAAS,CAAC,GAAG,CAAC;gBAC/C,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC,GAAG,YAAY,CAAC,GAAG,QAAQ,CAAC;;oBACnC,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;gBAChC,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC;gBACzB,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC;gBACzB,QAAQ,GAAG,IAAI,CAAC;aACjB;YACD,IAAI,QAAQ;gBAAE,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC;SACzC;IACH,CAAC;;;;IACD,kBAAkB;;YACZ,SAAS,GAAG,IAAI,CAAC,SAAS;;YAC5B,YAAY,GAAG,IAAI,CAAC,YAAY;;YAChC,QAAQ,GAAG,IAAI,CAAC,QAAQ;;YACxB,QAAQ,GAAG,IAAI,CAAC,QAAQ;;YACtB,MAAM,GAAG,IAAI,CAAC,MAAM;;YACpB,EAAE,GAAG,MAAM,CAAC,CAAC;;YACf,EAAE,GAAG,MAAM,CAAC,CAAC;;YACb,EAAE,GAAG,MAAM,CAAC,CAAC;;YACb,EAAE,GAAG,MAAM,CAAC,CAAC;;YACX,aAAa,GACf,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,MAAM;;YAC1D,cAAc,GAAG,IAAI,CAAC,IAAI,CAAC,cAAc,GAAG,aAAa;;YAC3D,YAAY,GAAG,IAAI,CAAC,IAAI,CAAC,YAAY,GAAG,aAAa;;YACnD,KAAK,GAAG,IAAI,CAAC,KAAK;QACtB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,KAAK,CAAC,MAAM,EAAE,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE,EAAE;;gBACxC,IAAI,GAAG,KAAK,CAAC,CAAC,CAAC;;gBACf,QAAQ,GAAG,KAAK;YACpB,IAAI,SAAS,IAAI,CAAC,EAAE;;oBACd,CAAC,GAAG,IAAI,CAAC,CAAC;;oBACZ,CAAC,GAAG,IAAI,CAAC,CAAC;;oBACV,CAAC,GAAG,IAAI,CAAC,CAAC;;oBACV,CAAC,GAAG,IAAI,CAAC,CAAC;;oBACR,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,EAAE,EAAE,EAAE,CAAC,GAAG,cAAc;gBAC3C,IAAI,CAAC,GAAG,SAAS,CAAC,EAAE;oBAAE,CAAC,IAAI,SAAS,CAAC,GAAG,CAAC;qBACpC,IAAI,CAAC,GAAG,CAAC,SAAS,CAAC,EAAE;oBAAE,CAAC,IAAI,SAAS,CAAC,GAAG,CAAC;gBAC/C,CAAC,IAAI,SAAS,CAAC;;oBACX,GAAG,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC;;oBACnB,GAAG,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC;gBACnB,IAAI,CAAC,CAAC,GAAG,GAAG,GAAG,CAAC,GAAG,GAAG,GAAG,CAAC,CAAC;gBAC3B,IAAI,CAAC,CAAC,GAAG,GAAG,GAAG,CAAC,GAAG,GAAG,GAAG,CAAC,CAAC;gBAC3B,IAAI,CAAC,CAAC,GAAG,GAAG,GAAG,CAAC,GAAG,GAAG,GAAG,CAAC,CAAC;gBAC3B,IAAI,CAAC,CAAC,GAAG,GAAG,GAAG,CAAC,GAAG,GAAG,GAAG,CAAC,CAAC;gBAC3B,QAAQ,GAAG,IAAI,CAAC;aACjB;YACD,IAAI,YAAY,IAAI,CAAC,EAAE;;oBACjB,IAAI,GAAG,IAAI,CAAC,IAAI;gBACpB,MAAM,CAAC,YAAY,CAAC,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC;gBACpE,IAAI,CAAC,MAAM,IAAI,IAAI,CAAC,CAAC,GAAG,YAAY,CAAC;gBACrC,IAAI,CAAC,MAAM,IAAI,IAAI,CAAC,CAAC,GAAG,YAAY,CAAC;gBACrC,QAAQ,GAAG,IAAI,CAAC;aACjB;YACD,IAAI,QAAQ,GAAG,CAAC,EAAE;;oBACZ,CAAC,GACH,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC;oBACzD,QAAQ;oBACV,CAAC;gBACH,IAAI,CAAC,CAAC,IAAI,CAAC,CAAC;gBACZ,IAAI,CAAC,CAAC,IAAI,CAAC,CAAC;gBACZ,CAAC;oBACC,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC;wBACzD,QAAQ;wBACV,CAAC,CAAC;gBACJ,IAAI,CAAC,CAAC,IAAI,CAAC,CAAC;gBACZ,IAAI,CAAC,CAAC,IAAI,CAAC,CAAC;gBACZ,QAAQ,GAAG,IAAI,CAAC;aACjB;YACD,IAAI,QAAQ,GAAG,CAAC,EAAE;;oBACZ,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,EAAE,EAAE,EAAE,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,EAAE,EAAE,EAAE,CAAC;gBAC/C,IAAI,CAAC,GAAG,SAAS,CAAC,EAAE;oBAAE,CAAC,IAAI,SAAS,CAAC,GAAG,CAAC;qBACpC,IAAI,CAAC,GAAG,CAAC,SAAS,CAAC,EAAE;oBAAE,CAAC,IAAI,SAAS,CAAC,GAAG,CAAC;;oBAC3C,CAAC,GAAG,IAAI,CAAC,CAAC;;oBACZ,CAAC,GAAG,IAAI,CAAC,CAAC;gBACZ,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,SAAS,CAAC,EAAE,GAAG,CAAC,GAAG,YAAY,CAAC,GAAG,QAAQ,CAAC;;oBACpE,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;gBAChC,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC;gBACzB,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC;gBACzB,QAAQ,GAAG,IAAI,CAAC;aACjB;YACD,IAAI,QAAQ;gBAAE,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC;SACzC;IACH,CAAC;;;;IACD,kBAAkB;;YACZ,SAAS,GAAG,IAAI,CAAC,SAAS;;YAC5B,YAAY,GAAG,IAAI,CAAC,YAAY;;YAChC,QAAQ,GAAG,IAAI,CAAC,QAAQ;;YACxB,QAAQ,GAAG,IAAI,CAAC,QAAQ;;YACtB,MAAM,GAAG,IAAI,CAAC,MAAM;QACxB,IAAI,CAAC,MAAM,CAAC,YAAY;YAAE,MAAM,CAAC,sBAAsB,EAAE,CAAC;;YACtD,KAAK,GAAG,IAAI,CAAC,KAAK;QACtB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,KAAK,CAAC,MAAM,EAAE,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE,EAAE;;gBACxC,IAAI,GAAG,KAAK,CAAC,CAAC,CAAC;YACnB,IAAI,CAAC,IAAI,CAAC,YAAY;gBAAE,IAAI,CAAC,sBAAsB,EAAE,CAAC;;gBAClD,QAAQ,GAAG,IAAI,CAAC,SAAS;YAC7B,IAAI,SAAS,IAAI,CAAC,EAAE;;oBACd,CAAC,GAAG,MAAM,CAAC,SAAS,GAAG,QAAQ,GAAG,IAAI,CAAC,IAAI,CAAC,cAAc;gBAC9D,CAAC,IAAI,CAAC,KAAK,GAAG,CAAC,CAAC,kBAAkB,GAAG,CAAC,GAAG,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC;gBAC1D,QAAQ,IAAI,CAAC,GAAG,SAAS,CAAC;aAC3B;;gBACG,CAAC,GAAG,IAAI,CAAC,EAAE;;gBACb,CAAC,GAAG,IAAI,CAAC,EAAE;YACb,IAAI,YAAY,IAAI,CAAC,EAAE;gBACrB,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE,GAAG,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,GAAG,YAAY,CAAC;gBACxD,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE,GAAG,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,GAAG,YAAY,CAAC;aACzD;;gBACG,MAAM,GAAG,IAAI,CAAC,OAAO;;gBACvB,MAAM,GAAG,IAAI,CAAC,OAAO;YACvB,IAAI,QAAQ,IAAI,CAAC,EAAE;gBACjB,IAAI,MAAM,GAAG,OAAO;oBAClB,MAAM;wBACJ,CAAC,MAAM;4BACL,CAAC,MAAM,CAAC,OAAO,GAAG,MAAM,GAAG,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,GAAG,QAAQ,CAAC;4BAChE,MAAM,CAAC;gBACX,IAAI,MAAM,GAAG,OAAO;oBAClB,MAAM;wBACJ,CAAC,MAAM;4BACL,CAAC,MAAM,CAAC,OAAO,GAAG,MAAM,GAAG,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,GAAG,QAAQ,CAAC;4BAChE,MAAM,CAAC;aACZ;;gBACG,MAAM,GAAG,IAAI,CAAC,OAAO;YACzB,IAAI,QAAQ,IAAI,CAAC,EAAE;;oBACb,CAAC,GAAG,MAAM,CAAC,OAAO,GAAG,MAAM,GAAG,IAAI,CAAC,IAAI,CAAC,YAAY;gBACxD,CAAC,IAAI,CAAC,KAAK,GAAG,CAAC,CAAC,kBAAkB,GAAG,CAAC,GAAG,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC;gBAC1D,IAAI,CAAC,MAAM,IAAI,CAAC,GAAG,QAAQ,CAAC;aAC7B;YACD,IAAI,CAAC,wBAAwB,CAC3B,CAAC,EACD,CAAC,EACD,QAAQ,EACR,MAAM,EACN,MAAM,EACN,IAAI,CAAC,OAAO,EACZ,MAAM,CACP,CAAC;SACH;IACH,CAAC;;;;IACD,kBAAkB;;YACZ,SAAS,GAAG,IAAI,CAAC,SAAS;;YAC5B,YAAY,GAAG,IAAI,CAAC,YAAY;;YAChC,QAAQ,GAAG,IAAI,CAAC,QAAQ;;YACxB,QAAQ,GAAG,IAAI,CAAC,QAAQ;;YACtB,MAAM,GAAG,IAAI,CAAC,MAAM;QACxB,IAAI,CAAC,MAAM,CAAC,YAAY;YAAE,MAAM,CAAC,sBAAsB,EAAE,CAAC;;YACtD,KAAK,GAAG,IAAI,CAAC,KAAK;QACtB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,KAAK,CAAC,MAAM,EAAE,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE,EAAE;;gBACxC,IAAI,GAAG,KAAK,CAAC,CAAC,CAAC;YACnB,IAAI,CAAC,IAAI,CAAC,YAAY;gBAAE,IAAI,CAAC,sBAAsB,EAAE,CAAC;;gBAClD,QAAQ,GAAG,IAAI,CAAC,SAAS;YAC7B,IAAI,SAAS,IAAI,CAAC;gBAChB,QAAQ,IAAI,CAAC,MAAM,CAAC,SAAS,GAAG,IAAI,CAAC,IAAI,CAAC,cAAc,CAAC,GAAG,SAAS,CAAC;;gBACpE,CAAC,GAAG,IAAI,CAAC,EAAE;;gBACb,CAAC,GAAG,IAAI,CAAC,EAAE;YACb,IAAI,YAAY,IAAI,CAAC,EAAE;gBACrB,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE,GAAG,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,GAAG,YAAY,CAAC;gBACpD,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE,GAAG,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,GAAG,YAAY,CAAC;aACrD;;gBACG,MAAM,GAAG,IAAI,CAAC,OAAO;;gBACvB,MAAM,GAAG,IAAI,CAAC,OAAO;YACvB,IAAI,QAAQ,IAAI,CAAC,EAAE;gBACjB,IAAI,MAAM,GAAG,OAAO;oBAClB,MAAM;wBACJ,CAAC,MAAM,CAAC,OAAO,GAAG,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,GAAG,QAAQ,GAAG,CAAC,CAAC;gBACjE,IAAI,MAAM,GAAG,OAAO;oBAClB,MAAM;wBACJ,CAAC,MAAM,CAAC,OAAO,GAAG,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,GAAG,QAAQ,GAAG,CAAC,CAAC;aAClE;;gBACG,MAAM,GAAG,IAAI,CAAC,OAAO;YACzB,IAAI,QAAQ,IAAI,CAAC;gBACf,MAAM,IAAI,CAAC,MAAM,CAAC,OAAO,GAAG,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,GAAG,QAAQ,CAAC;YACjE,IAAI,CAAC,wBAAwB,CAC3B,CAAC,EACD,CAAC,EACD,QAAQ,EACR,MAAM,EACN,MAAM,EACN,IAAI,CAAC,OAAO,EACZ,MAAM,CACP,CAAC;SACH;IACH,CAAC;CACF;;;IA3RC,mCAA8B;;IAC9B,oCAAmB;;IACnB,qCAAa;;IACb,wCAAc;;IACd,2CAAiB;;IACjB,uCAAa;;IACb,uCAAa;;IACb,mCAAqB;;IACrB,qCAAe","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"]}