1
0
mirror of https://github.com/zenorogue/hyperrogue.git synced 2025-01-23 07:27:07 +00:00

walking:: walking in solv-h3

This commit is contained in:
Zeno Rogue 2022-02-26 11:06:42 +01:00
parent 94d660cc43
commit 22fc90a30e

View File

@ -613,6 +613,7 @@ EX void check_portal_movement() {
if(walking::eye_level != -1) walking::eye_level *= scale; if(walking::eye_level != -1) walking::eye_level *= scale;
walking::floor_dir = -1; walking::floor_dir = -1;
walking::on_floor_of = nullptr;
} }
} }
@ -812,14 +813,13 @@ EX ld eye_level = 0.2174492;
EX ld eye_angle = 0; EX ld eye_angle = 0;
EX ld eye_angle_scale = 1; EX ld eye_angle_scale = 1;
map<cell*, int> recorded_floor_dir;
int ticks_end, ticks_last; int ticks_end, ticks_last;
EX set<color_t> colors_of_floors; EX set<color_t> colors_of_floors;
EX bool isFloor(cell *c) { EX bool isFloor(cell *c) {
if(!isWall(c)) return false; if(!isWall(c)) return false;
if(colors_of_floors.empty()) return true;
return colors_of_floors.count(c->landparam); return colors_of_floors.count(c->landparam);
} }
@ -837,6 +837,27 @@ EX void handle() {
if(isize(choices) == 1) { if(isize(choices) == 1) {
on_floor_of = centerover; on_floor_of = centerover;
floor_dir = choices[0]; floor_dir = choices[0];
}
else if(colors_of_floors.empty() && sn::in()) {
on_floor_of = centerover;
auto z = inverse(View) * C0;
switch(geometry) {
case gSol:
floor_dir = (z[2] > 0) ? 2 : 6;
return;
case gNIH:
floor_dir = (z[2] > 0) ? 5 : 4;
return;
case gSolN:
floor_dir = (z[2] > 0) ? 4 : 6;
return;
default: throw hr_exception("not solnihv");
}
}
else if(colors_of_floors.empty() && hyperbolic && bt::in()) {
auto z = bt::minkowski_to_bt(inverse(View) * C0);
on_floor_of = centerover;
floor_dir = z[2] > 0 ? bt::updir() : 0;
println(hlog, "set floor_dir to ", floor_dir); println(hlog, "set floor_dir to ", floor_dir);
} }
else { else {
@ -858,13 +879,10 @@ EX void handle() {
auto find_nearest = [&] (const face& fac, hyperpoint at) { auto find_nearest = [&] (const face& fac, hyperpoint at) {
if(sol) { at[2] = fac.h0[2]; return at; } if(sol) { at[2] = fac.h0[2]; return at; }
else if(sphere && false) { else if(hyperbolic && bt::in()) {
hyperpoint h = auto z = bt::minkowski_to_bt(at);
project_on_triangle(csh.faces_local[floor_dir][0], csh.faces_local[floor_dir][1], csh.faces_local[floor_dir][2]); z[2] = bt::minkowski_to_bt(fac.h0)[2];
transmatrix T = rspintox(h); return bt::bt_to_minkowski(z);
T = T * MirrorX;
transmatrix M = ToOld * T * xpush(-2*hdist0(h)) * spintox(h);
return mid(at, M * at);
} }
else if(prod && bt::in()) { else if(prod && bt::in()) {
auto dec = product_decompose(at); auto dec = product_decompose(at);
@ -890,9 +908,6 @@ EX void handle() {
auto wallpt = find_nearest(f, at); auto wallpt = find_nearest(f, at);
if(on_floor_of == centerover)
recorded_floor_dir[centerover] = floor_dir;
ld view_eps = 1e-5; ld view_eps = 1e-5;
if(eye_angle) rotate_view(cspin(1, 2, -eye_angle * degree)); if(eye_angle) rotate_view(cspin(1, 2, -eye_angle * degree));
@ -972,7 +987,7 @@ auto a = addHook(hooks_configfile, 100, [] {
"1 = the angle can be changed with keyboard or mouse movements, 0 = the angle is fixed", "1 = the angle can be changed with keyboard or mouse movements, 0 = the angle is fixed",
'k'); 'k');
}) })
+ addHook(hooks_clearmemory, 40, [] { recorded_floor_dir.clear(); on_floor_of = nullptr; floor_dir = -1; }); + addHook(hooks_clearmemory, 40, [] { on_floor_of = nullptr; floor_dir = -1; });
EX } EX }
} }