mirror of
https://github.com/zenorogue/hyperrogue.git
synced 2025-01-11 18:00:34 +00:00
torus3 improvements
This commit is contained in:
parent
e8de4d088c
commit
377fd3f8bd
2
cell.cpp
2
cell.cpp
@ -435,7 +435,7 @@ EX int celldist(cell *c) {
|
|||||||
if(fulltorus && WDIM == 2)
|
if(fulltorus && WDIM == 2)
|
||||||
return get_torus_dist(decodeId(c->master));
|
return get_torus_dist(decodeId(c->master));
|
||||||
if(nil) return DISTANCE_UNKNOWN;
|
if(nil) return DISTANCE_UNKNOWN;
|
||||||
if(euwrap)
|
if(euwrap && WDIM == 2)
|
||||||
return torusconfig::cyldist(decodeId(c->master), 0);
|
return torusconfig::cyldist(decodeId(c->master), 0);
|
||||||
if(masterless)
|
if(masterless)
|
||||||
return eudist(decodeId(c->master));
|
return eudist(decodeId(c->master));
|
||||||
|
11
euclid.cpp
11
euclid.cpp
@ -846,7 +846,7 @@ EX namespace euclid3 {
|
|||||||
|
|
||||||
EX int celldistance(cell *c1, cell *c2) {
|
EX int celldistance(cell *c1, cell *c2) {
|
||||||
auto cm = cubemap();
|
auto cm = cubemap();
|
||||||
return celldistance(cm->ispacemap[c1->master] - cm->ispacemap[c2->master]);
|
return celldistance(canonicalize(cm->ispacemap[c1->master] - cm->ispacemap[c2->master]));
|
||||||
}
|
}
|
||||||
|
|
||||||
EX void set_land(cell *c) {
|
EX void set_land(cell *c) {
|
||||||
@ -913,15 +913,16 @@ EX namespace euclid3 {
|
|||||||
int coords;
|
int coords;
|
||||||
int twisted0, twisted_edit;
|
int twisted0, twisted_edit;
|
||||||
|
|
||||||
EX void clear_torus3() {
|
|
||||||
for(int i=0; i<3; i++) user_axes[i] = 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
EX void set_torus3(int x, int y, int z) {
|
EX void set_torus3(int x, int y, int z) {
|
||||||
for(int i=0; i<3; i++) for(int j=0; j<3; j++) T0[i][j] = 0;
|
for(int i=0; i<3; i++) for(int j=0; j<3; j++) T0[i][j] = 0;
|
||||||
tie(T0[0][0], T0[1][1], T0[2][2]) = make_tuple(x, y, z);
|
tie(T0[0][0], T0[1][1], T0[2][2]) = make_tuple(x, y, z);
|
||||||
|
twisted = 0;
|
||||||
build_torus3();
|
build_torus3();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
EX void clear_torus3() {
|
||||||
|
set_torus3(0, 0, 0);
|
||||||
|
}
|
||||||
|
|
||||||
unordered_map<coord, int> canonical_hash;
|
unordered_map<coord, int> canonical_hash;
|
||||||
vector<coord> canonical_seq;
|
vector<coord> canonical_seq;
|
||||||
|
Loading…
Reference in New Issue
Block a user