1
0
mirror of https://github.com/zenorogue/hyperrogue.git synced 2025-10-24 18:37:39 +00:00

in_qrange now based on smartrange

This commit is contained in:
Zeno Rogue
2018-11-10 10:32:00 +01:00
parent ab58d82713
commit ec0dae48c1

View File

@@ -718,7 +718,8 @@ bool in_smart_range(const transmatrix& T) {
// in hyperbolic quotient geometries, relying on pathdist is not sufficient // in hyperbolic quotient geometries, relying on pathdist is not sufficient
bool in_qrange(const transmatrix& V) { bool in_qrange(const transmatrix& V) {
if(!quotient || !hyperbolic || vid.use_smart_range) return true; if(!quotient || !hyperbolic || vid.use_smart_range) return true;
return V[2][2] < cosh(crossf * get_sightrange_ambush()); return in_smart_range(V);
// return V[2][2] < cosh(crossf * get_sightrange_ambush());
} }
namespace gp { namespace gp {
@@ -813,7 +814,9 @@ void drawrec(const heptspin& hs, hstate s, const transmatrix& V, int reclev) {
else { else {
if(dodrawcell(c)) { if(dodrawcell(c)) {
transmatrix V2 = actualV(hs, V1); transmatrix V2 = actualV(hs, V1);
if(in_qrange(V2))
drawcell(c, V2, 0, hs.mirrored); drawcell(c, V2, 0, hs.mirrored);
else draw = false;
} }
if(BITRUNCATED) for(int d=0; d<S7; d++) { if(BITRUNCATED) for(int d=0; d<S7; d++) {
@@ -827,7 +830,7 @@ void drawrec(const heptspin& hs, hstate s, const transmatrix& V, int reclev) {
} }
} }
if(draw && in_qrange(V)) for(int d=0; d<S7; d++) { if(draw) for(int d=0; d<S7; d++) {
hstate s2 = transition(s, d); hstate s2 = transition(s, d);
if(s2 == hsError) continue; if(s2 == hsError) continue;
heptspin hs2 = hs + d + wstep; heptspin hs2 = hs + d + wstep;