mirror of
https://github.com/zenorogue/hyperrogue.git
synced 2025-01-04 06:20:34 +00:00
improved adj_minefield_cells to avoid relative_matrix
This commit is contained in:
parent
c4e85c16d3
commit
dd5035184b
11
cell.cpp
11
cell.cpp
@ -1293,20 +1293,25 @@ EX vector<cell*> adj_minefield_cells(cell *c) {
|
|||||||
const vector<hyperpoint>& vertices = ss.vertices_only_local;
|
const vector<hyperpoint>& vertices = ss.vertices_only_local;
|
||||||
manual_celllister cl;
|
manual_celllister cl;
|
||||||
cl.add(c);
|
cl.add(c);
|
||||||
|
vector<transmatrix> M = {Id};
|
||||||
for(int i=0; i<isize(cl.lst); i++) {
|
for(int i=0; i<isize(cl.lst); i++) {
|
||||||
cell *c1 = cl.lst[i];
|
cell *c1 = cl.lst[i];
|
||||||
bool shares = false;
|
bool shares = false;
|
||||||
|
transmatrix T = M[i];
|
||||||
if(c != c1) {
|
if(c != c1) {
|
||||||
transmatrix T = currentmap->relative_matrix(c1->master, c->master, C0);
|
|
||||||
auto& ss1 = currentmap->get_cellshape(c1);
|
auto& ss1 = currentmap->get_cellshape(c1);
|
||||||
auto& vertices1 = ss1.vertices_only_local;
|
auto& vertices1 = ss1.vertices_only_local;
|
||||||
for(hyperpoint h: vertices) for(hyperpoint h2: vertices1)
|
for(hyperpoint h: vertices) for(hyperpoint h2: vertices1)
|
||||||
if(hdist(h, T * h2) < 1e-6) shares = true;
|
if(hdist(h, T * h2) < 1e-6) shares = true;
|
||||||
if(shares) res.push_back(c1);
|
if(shares) res.push_back(c1);
|
||||||
}
|
}
|
||||||
if(shares || c == c1) forCellEx(c2, c1) cl.add(c2);
|
if(shares || c == c1) forCellIdEx(c2, i, c1) {
|
||||||
|
if(cl.listed(c2)) continue;
|
||||||
|
cl.add(c2);
|
||||||
|
M.push_back(T * currentmap->adj(c1, i));
|
||||||
}
|
}
|
||||||
println(hlog, "adjacent to ", c, " = ", isize(res));
|
}
|
||||||
|
// println(hlog, "adjacent to ", c, " = ", isize(res), " of ", isize(M));
|
||||||
adj_memo[c] = res;
|
adj_memo[c] = res;
|
||||||
}
|
}
|
||||||
return res;
|
return res;
|
||||||
|
Loading…
Reference in New Issue
Block a user