mirror of
https://github.com/EsotericSoftware/spine-runtimes.git
synced 2026-02-06 23:34:53 +08:00
[ts] Fix 1-bone IK, see #1692.
This commit is contained in:
parent
85dd60bf57
commit
c64e6adbde
@ -2844,10 +2844,12 @@ var spine;
|
||||
ty = targetY - bone.worldY;
|
||||
break;
|
||||
case spine.TransformMode.NoRotationOrReflection:
|
||||
rotationIK += Math.atan2(pc, pa) * spine.MathUtils.radDeg;
|
||||
var ps = Math.abs(pa * pd - pb * pc) / (pa * pa + pc * pc);
|
||||
pb = -pc * ps;
|
||||
pd = pa * ps;
|
||||
var s = Math.abs(pa * pd - pb * pc) / (pa * pa + pc * pc);
|
||||
var sa = pa / bone.skeleton.scaleX;
|
||||
var sc = pc / bone.skeleton.scaleY;
|
||||
pb = -sc * s * bone.skeleton.scaleX;
|
||||
pd = sa * s * bone.skeleton.scaleY;
|
||||
rotationIK += Math.atan2(sc, sa) * spine.MathUtils.radDeg;
|
||||
default:
|
||||
var x = targetX - p.worldX, y = targetY - p.worldY;
|
||||
var d = pa * pd - pb * pc;
|
||||
|
||||
File diff suppressed because one or more lines are too long
@ -2844,10 +2844,12 @@ var spine;
|
||||
ty = targetY - bone.worldY;
|
||||
break;
|
||||
case spine.TransformMode.NoRotationOrReflection:
|
||||
rotationIK += Math.atan2(pc, pa) * spine.MathUtils.radDeg;
|
||||
var ps = Math.abs(pa * pd - pb * pc) / (pa * pa + pc * pc);
|
||||
pb = -pc * ps;
|
||||
pd = pa * ps;
|
||||
var s = Math.abs(pa * pd - pb * pc) / (pa * pa + pc * pc);
|
||||
var sa = pa / bone.skeleton.scaleX;
|
||||
var sc = pc / bone.skeleton.scaleY;
|
||||
pb = -sc * s * bone.skeleton.scaleX;
|
||||
pd = sa * s * bone.skeleton.scaleY;
|
||||
rotationIK += Math.atan2(sc, sa) * spine.MathUtils.radDeg;
|
||||
default:
|
||||
var x = targetX - p.worldX, y = targetY - p.worldY;
|
||||
var d = pa * pd - pb * pc;
|
||||
|
||||
File diff suppressed because one or more lines are too long
@ -2844,10 +2844,12 @@ var spine;
|
||||
ty = targetY - bone.worldY;
|
||||
break;
|
||||
case spine.TransformMode.NoRotationOrReflection:
|
||||
rotationIK += Math.atan2(pc, pa) * spine.MathUtils.radDeg;
|
||||
var ps = Math.abs(pa * pd - pb * pc) / (pa * pa + pc * pc);
|
||||
pb = -pc * ps;
|
||||
pd = pa * ps;
|
||||
var s = Math.abs(pa * pd - pb * pc) / (pa * pa + pc * pc);
|
||||
var sa = pa / bone.skeleton.scaleX;
|
||||
var sc = pc / bone.skeleton.scaleY;
|
||||
pb = -sc * s * bone.skeleton.scaleX;
|
||||
pd = sa * s * bone.skeleton.scaleY;
|
||||
rotationIK += Math.atan2(sc, sa) * spine.MathUtils.radDeg;
|
||||
default:
|
||||
var x = targetX - p.worldX, y = targetY - p.worldY;
|
||||
var d = pa * pd - pb * pc;
|
||||
|
||||
File diff suppressed because one or more lines are too long
@ -2844,10 +2844,12 @@ var spine;
|
||||
ty = targetY - bone.worldY;
|
||||
break;
|
||||
case spine.TransformMode.NoRotationOrReflection:
|
||||
rotationIK += Math.atan2(pc, pa) * spine.MathUtils.radDeg;
|
||||
var ps = Math.abs(pa * pd - pb * pc) / (pa * pa + pc * pc);
|
||||
pb = -pc * ps;
|
||||
pd = pa * ps;
|
||||
var s = Math.abs(pa * pd - pb * pc) / (pa * pa + pc * pc);
|
||||
var sa = pa / bone.skeleton.scaleX;
|
||||
var sc = pc / bone.skeleton.scaleY;
|
||||
pb = -sc * s * bone.skeleton.scaleX;
|
||||
pd = sa * s * bone.skeleton.scaleY;
|
||||
rotationIK += Math.atan2(sc, sa) * spine.MathUtils.radDeg;
|
||||
default:
|
||||
var x = targetX - p.worldX, y = targetY - p.worldY;
|
||||
var d = pa * pd - pb * pc;
|
||||
|
||||
File diff suppressed because one or more lines are too long
@ -2844,10 +2844,12 @@ var spine;
|
||||
ty = targetY - bone.worldY;
|
||||
break;
|
||||
case spine.TransformMode.NoRotationOrReflection:
|
||||
rotationIK += Math.atan2(pc, pa) * spine.MathUtils.radDeg;
|
||||
var ps = Math.abs(pa * pd - pb * pc) / (pa * pa + pc * pc);
|
||||
pb = -pc * ps;
|
||||
pd = pa * ps;
|
||||
var s = Math.abs(pa * pd - pb * pc) / (pa * pa + pc * pc);
|
||||
var sa = pa / bone.skeleton.scaleX;
|
||||
var sc = pc / bone.skeleton.scaleY;
|
||||
pb = -sc * s * bone.skeleton.scaleX;
|
||||
pd = sa * s * bone.skeleton.scaleY;
|
||||
rotationIK += Math.atan2(sc, sa) * spine.MathUtils.radDeg;
|
||||
default:
|
||||
var x = targetX - p.worldX, y = targetY - p.worldY;
|
||||
var d = pa * pd - pb * pc;
|
||||
|
||||
File diff suppressed because one or more lines are too long
@ -2844,10 +2844,12 @@ var spine;
|
||||
ty = targetY - bone.worldY;
|
||||
break;
|
||||
case spine.TransformMode.NoRotationOrReflection:
|
||||
rotationIK += Math.atan2(pc, pa) * spine.MathUtils.radDeg;
|
||||
var ps = Math.abs(pa * pd - pb * pc) / (pa * pa + pc * pc);
|
||||
pb = -pc * ps;
|
||||
pd = pa * ps;
|
||||
var s = Math.abs(pa * pd - pb * pc) / (pa * pa + pc * pc);
|
||||
var sa = pa / bone.skeleton.scaleX;
|
||||
var sc = pc / bone.skeleton.scaleY;
|
||||
pb = -sc * s * bone.skeleton.scaleX;
|
||||
pd = sa * s * bone.skeleton.scaleY;
|
||||
rotationIK += Math.atan2(sc, sa) * spine.MathUtils.radDeg;
|
||||
default:
|
||||
var x = targetX - p.worldX, y = targetY - p.worldY;
|
||||
var d = pa * pd - pb * pc;
|
||||
|
||||
File diff suppressed because one or more lines are too long
@ -112,10 +112,12 @@ module spine {
|
||||
ty = targetY - bone.worldY;
|
||||
break;
|
||||
case TransformMode.NoRotationOrReflection:
|
||||
rotationIK += Math.atan2(pc, pa) * MathUtils.radDeg;
|
||||
let ps = Math.abs(pa * pd - pb * pc) / (pa * pa + pc * pc);
|
||||
pb = -pc * ps;
|
||||
pd = pa * ps;
|
||||
let s = Math.abs(pa * pd - pb * pc) / (pa * pa + pc * pc);
|
||||
let sa = pa / bone.skeleton.scaleX;
|
||||
let sc = pc / bone.skeleton.scaleY;
|
||||
pb = -sc * s * bone.skeleton.scaleX;
|
||||
pd = sa * s * bone.skeleton.scaleY;
|
||||
rotationIK += Math.atan2(sc, sa) * MathUtils.radDeg;
|
||||
// Fall through
|
||||
default:
|
||||
let x = targetX - p.worldX, y = targetY - p.worldY;
|
||||
|
||||
Loading…
x
Reference in New Issue
Block a user