1
0
mirror of https://github.com/zenorogue/hyperrogue.git synced 2025-01-13 02:40:33 +00:00

fixed the animation of snakelike creatures in quotient geometries

This commit is contained in:
Zeno Rogue 2018-09-10 18:46:27 +02:00
parent a95aa0a2fa
commit dbdb1ba6dc

View File

@ -1781,10 +1781,7 @@ double chainAngle(cell *c, transmatrix& V, cell *c2, double dft, const transmatr
if(!gmatrix0.count(c2)) return dft; if(!gmatrix0.count(c2)) return dft;
hyperpoint h = C0; hyperpoint h = C0;
if(animations[LAYER_BIG].count(c2)) h = animations[LAYER_BIG][c2].wherenow * h; if(animations[LAYER_BIG].count(c2)) h = animations[LAYER_BIG][c2].wherenow * h;
if(inmirrorcount) h = inverse(V) * Vwhere * calc_relative_matrix(c2, c, C0) * h;
h = inverse(V) * Vwhere * inverse(gmatrix0[c]) * gmatrix0[c2] * h;
else
h = inverse(V) * gmatrix0[c2] * h;
return atan2(h[1], h[0]); return atan2(h[1], h[0]);
} }
@ -1797,10 +1794,7 @@ bool chainAnimation(cell *c, transmatrix& V, cell *c2, int i, ld bonus, const tr
} }
hyperpoint h = C0; hyperpoint h = C0;
if(animations[LAYER_BIG].count(c2)) h = animations[LAYER_BIG][c2].wherenow * h; if(animations[LAYER_BIG].count(c2)) h = animations[LAYER_BIG][c2].wherenow * h;
if(inmirrorcount) h = inverse(V) * Vwhere * calc_relative_matrix(c2, c, C0) * h;
h = inverse(V) * Vwhere * inverse(gmatrix0[c]) * gmatrix0[c2] * h;
else
h = inverse(V) * gmatrix0[c2] * h;
length = hdist0(h); length = hdist0(h);
V = V * rspintox(h); V = V * rspintox(h);
return true; return true;