1
0
mirror of https://github.com/zenorogue/hyperrogue.git synced 2025-01-13 10:50:35 +00:00

yet another fix to adjust_eye in nonisotropic space

This commit is contained in:
Zeno Rogue 2022-12-17 19:03:36 +01:00
parent 805cb4dc0c
commit be747b7a44

View File

@ -2066,7 +2066,17 @@ EX void centerpc(ld aspd) {
auto& pc = shmup::pc[id]; auto& pc = shmup::pc[id];
centerover = pc->base; centerover = pc->base;
transmatrix T = pc->at; transmatrix T = pc->at;
adjust_eye(T, pc->base, +1);
if(nonisotropic) {
transmatrix rot = inverse(rgpushxto0(T * C0)) * T;
T = T * inverse(rot);
adjust_eye(T, pc->base, +1);
T = T * rot;
}
else {
adjust_eye(T, pc->base, +1);
}
View = iview_inverse(T); View = iview_inverse(T);
if(gproduct) NLP = ortho_inverse(pc->ori); if(gproduct) NLP = ortho_inverse(pc->ori);
if(WDIM == 2) { if(WDIM == 2) {
@ -2231,11 +2241,11 @@ EX void resetview() {
View = Id; View = Id;
} }
adjust_eye(View, cwt.at, -1);
if(WDIM == 2) View = spin(M_PI + vid.fixed_facing_dir * degree) * View; if(WDIM == 2) View = spin(M_PI + vid.fixed_facing_dir * degree) * View;
if(WDIM == 3 && !gproduct) View = cspin90(0, 2) * View; if(WDIM == 3 && !gproduct) View = cspin90(0, 2) * View;
if(gproduct) NLP = cspin90(0, 2); if(gproduct) NLP = cspin90(0, 2);
adjust_eye(View, cwt.at, -1);
View = inverse(logical_to_actual()) * View; View = inverse(logical_to_actual()) * View;
if(embedded_plane) View = cspin90(1, 2) * View; if(embedded_plane) View = cspin90(1, 2) * View;
if(embedded_plane && vid.wall_height < 0) View = cspin180(0, 1) * View; if(embedded_plane && vid.wall_height < 0) View = cspin180(0, 1) * View;