1
0
mirror of https://github.com/zenorogue/hyperrogue.git synced 2025-10-25 10:57:59 +00:00

standard draw algorithm no longer recursive; prettier gp::drawrec

This commit is contained in:
Zeno Rogue
2018-11-23 23:45:16 +01:00
parent 62a5c0abac
commit b4671e4d50
3 changed files with 62 additions and 53 deletions

View File

@@ -61,7 +61,7 @@ transmatrix calc_relative_matrix(cell *c2, cell *c1, const hyperpoint& point_hin
auto bak = gp::draw_li; auto bak = gp::draw_li;
swap(gmatrix, gmatrix0); swap(gmatrix, gmatrix0);
just_gmatrix = true; just_gmatrix = true;
drawrec(viewctr, hsOrigin, Id); drawStandard();
just_gmatrix = false; just_gmatrix = false;
swap(gmatrix, gmatrix0); swap(gmatrix, gmatrix0);
gp::draw_li = bak; gp::draw_li = bak;

View File

@@ -3858,7 +3858,7 @@ void queuestr(const hyperpoint& h, int size, const string& chr, color_t col, int
void queuechr(const transmatrix& V, double size, char chr, color_t col, int frame = 0); void queuechr(const transmatrix& V, double size, char chr, color_t col, int frame = 0);
extern bool just_gmatrix; extern bool just_gmatrix;
void drawrec(const heptspin& hs, hstate s, const transmatrix& V, int reclev = 0); void drawStandard();
bool haveLeaderboard(int id); bool haveLeaderboard(int id);
int get_currentscore(int id); int get_currentscore(int id);

View File

@@ -735,14 +735,14 @@ void drawrec(cell *c, const transmatrix& V) {
bool drawrec(cell *c, const transmatrix& V, gp::loc at, int dir, int maindir) { bool drawrec(cell *c, const transmatrix& V, gp::loc at, int dir, int maindir) {
bool res = false; bool res = false;
if(do_draw(c, V)) { transmatrix V1 = V * Tf[draw_li.last_dir][at.first&31][at.second&31][fixg6(dir)];
if(do_draw(c, V1)) {
/* auto li = get_local_info(c); /* auto li = get_local_info(c);
if(fix6(dir) != fix6(li.total_dir)) printf("totaldir %d/%d\n", dir, li.total_dir); if(fix6(dir) != fix6(li.total_dir)) printf("totaldir %d/%d\n", dir, li.total_dir);
if(at != li.relative) printf("at %s/%s\n", disp(at), disp(li.relative)); if(at != li.relative) printf("at %s/%s\n", disp(at), disp(li.relative));
if(maindir != li.last_dir) printf("ld %d/%d\n", maindir, li.last_dir); */ if(maindir != li.last_dir) printf("ld %d/%d\n", maindir, li.last_dir); */
draw_li.relative = at; draw_li.relative = at;
draw_li.total_dir = fixg6(dir); draw_li.total_dir = fixg6(dir);
transmatrix V1 = V * Tf[draw_li.last_dir][at.first&31][at.second&31][fixg6(dir)];
drawcell(c, V1, 0, false); drawcell(c, V1, 0, false);
res = true; res = true;
} }
@@ -775,9 +775,18 @@ void drawrec(cell *c, const transmatrix& V) {
} }
} }
void drawrec(const heptspin& hs, hstate s, const transmatrix& V, int reclev) { vector<tuple<heptspin, hstate, transmatrix, ld> > drawn_cells;
void drawStandard() {
drawn_cells.clear();
drawn_cells.emplace_back(viewctr, hsOrigin, cview(), band_shift);
for(int i=0; i<isize(drawn_cells); i++) {
const auto& dc = drawn_cells[i];
auto& hs = get<0>(dc);
auto& s = get<1>(dc);
auto& V = get<2>(dc);
dynamicval<ld> bs(band_shift, get<3>(dc));
// calc_relative_matrix(cwt.c, hs.at);
cell *c = hs.at->c7; cell *c = hs.at->c7;
transmatrix V10; transmatrix V10;
@@ -827,9 +836,9 @@ void drawrec(const heptspin& hs, hstate s, const transmatrix& V, int reclev) {
heptspin hs2 = hs + d + wstep; heptspin hs2 = hs + d + wstep;
transmatrix Vd = V * heptmove[d]; transmatrix Vd = V * heptmove[d];
bandfixer bf(Vd); bandfixer bf(Vd);
drawrec(hs2, s2, Vd, reclev+1); drawn_cells.emplace_back(hs2, s2, Vd, band_shift);
}
} }
} }
int mindx=-7, mindy=-7, maxdx=7, maxdy=7; int mindx=-7, mindy=-7, maxdx=7, maxdy=7;