1
0
mirror of https://github.com/zenorogue/hyperrogue.git synced 2025-01-19 21:53:04 +00:00

arb:: 'nonorientable' tiles

This commit is contained in:
Zeno Rogue 2020-01-02 18:53:57 +01:00
parent 61261a5acc
commit 6496b3f8b6

View File

@ -321,7 +321,10 @@ struct hrmap_arbi : hrmap {
auto& co = sh.connections[dl]; auto& co = sh.connections[dl];
int xt = get<0>(co); int xt = get<0>(co);
int xdl = get<1>(co); int xdl = get<1>(co);
// int m = get<2>(co); int m = get<2>(co);
if(h->c.move(dl)) xdl = h->c.spin(dl);
auto& xsh = c.shapes[xt]; auto& xsh = c.shapes[xt];
int xdr = gmod(xdl+1, xsh.size()); int xdr = gmod(xdl+1, xsh.size());
@ -364,6 +367,7 @@ struct hrmap_arbi : hrmap {
int xt = get<0>(co); int xt = get<0>(co);
int e = get<1>(co); int e = get<1>(co);
int m = get<2>(co); int m = get<2>(co);
auto& xsh = current.shapes[xt];
transmatrix T = p.second * adj(h, d); transmatrix T = p.second * adj(h, d);
@ -381,10 +385,13 @@ struct hrmap_arbi : hrmap {
alt = (heptagon*) s; alt = (heptagon*) s;
} }
for(auto& p2: altmap[alt]) if(eqmatrix(p2.second, T)) { for(auto& p2: altmap[alt]) if(id_of(p2.first) == xt && hdist(tC0(p2.second), tC0(T)) < 1e-2) {
h->c.connect(d, p2.first, e, m); for(int oth=0; oth < p2.first->type; oth++)
if(hdist(p2.second * xsh.vertices[oth], T * xsh.vertices[e]) < 1e-2) {
h->c.connect(d, p2.first, oth%p2.first->type, m);
return p2.first; return p2.first;
} }
}
auto h1 = tailored_alloc<heptagon> (current.shapes[xt].size()); auto h1 = tailored_alloc<heptagon> (current.shapes[xt].size());
h1->distance = h->distance + 1; h1->distance = h->distance + 1;