mirror of
https://github.com/zenorogue/hyperrogue.git
synced 2025-01-26 17:06:59 +00:00
changed chamfered to bitruncated
This commit is contained in:
parent
1427147fbc
commit
5bf6d54c7d
@ -84,7 +84,7 @@ vector<string> achievementsReceived;
|
|||||||
bool wrongMode(char flags) {
|
bool wrongMode(char flags) {
|
||||||
if(cheater) return true;
|
if(cheater) return true;
|
||||||
if(flags == 'x') return false;
|
if(flags == 'x') return false;
|
||||||
if(nonchamfered != (flags == '7')) return true;
|
if(nonbitrunc != (flags == '7')) return true;
|
||||||
if(euclid != (flags == 'e')) return true;
|
if(euclid != (flags == 'e')) return true;
|
||||||
if(flags == 'E' && S7 < 5) return false;
|
if(flags == 'E' && S7 < 5) return false;
|
||||||
if(sphere != (flags == 'E')) return true;
|
if(sphere != (flags == 'E')) return true;
|
||||||
@ -496,7 +496,7 @@ void achievement_score(int cat, int number) {
|
|||||||
if(sphere && cat != LB_HALLOWEEN) return;
|
if(sphere && cat != LB_HALLOWEEN) return;
|
||||||
if(quotient) return;
|
if(quotient) return;
|
||||||
if(elliptic && cat != LB_HALLOWEEN) return;
|
if(elliptic && cat != LB_HALLOWEEN) return;
|
||||||
if(nonchamfered) return;
|
if(nonbitrunc) return;
|
||||||
if(randomPatternsMode) return;
|
if(randomPatternsMode) return;
|
||||||
if(shmup::on && cat != LB_PURE_TACTICS_SHMUP && cat != LB_PURE_TACTICS_COOP) return;
|
if(shmup::on && cat != LB_PURE_TACTICS_SHMUP && cat != LB_PURE_TACTICS_COOP) return;
|
||||||
if(yendor::on && cat != LB_YENDOR_CHALLENGE) return;
|
if(yendor::on && cat != LB_YENDOR_CHALLENGE) return;
|
||||||
@ -584,7 +584,7 @@ void achievement_final(bool really_final) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
if(sphere && specialland == laHalloween) {
|
if(sphere && specialland == laHalloween) {
|
||||||
if(shmup::on || chaosmode || nonchamfered || numplayers() > 1 || tactic::on || randomPatternsMode)
|
if(shmup::on || chaosmode || nonbitrunc || numplayers() > 1 || tactic::on || randomPatternsMode)
|
||||||
return;
|
return;
|
||||||
achievement_score(LB_HALLOWEEN, items[itTreat]);
|
achievement_score(LB_HALLOWEEN, items[itTreat]);
|
||||||
}
|
}
|
||||||
@ -598,21 +598,21 @@ void achievement_final(bool really_final) {
|
|||||||
int specials = 0;
|
int specials = 0;
|
||||||
if(shmup::on) specials++;
|
if(shmup::on) specials++;
|
||||||
if(chaosmode) specials++;
|
if(chaosmode) specials++;
|
||||||
if(nonchamfered) specials++;
|
if(nonbitrunc) specials++;
|
||||||
if(inv::on) specials++;
|
if(inv::on) specials++;
|
||||||
if(specials > 1) return;
|
if(specials > 1) return;
|
||||||
|
|
||||||
if(numplayers() > 1 && chaosmode) return;
|
if(numplayers() > 1 && chaosmode) return;
|
||||||
if(numplayers() > 1 && nonchamfered) return;
|
if(numplayers() > 1 && nonbitrunc) return;
|
||||||
if(numplayers() > 1 && inv::on) return;
|
if(numplayers() > 1 && inv::on) return;
|
||||||
|
|
||||||
int total_improved = 0;
|
int total_improved = 0;
|
||||||
specific_improved = 0;
|
specific_improved = 0;
|
||||||
specific_what = 0;
|
specific_what = 0;
|
||||||
|
|
||||||
if(!shmup::on && !chaosmode && !nonchamfered && numplayers() == 1 && !inv::on) improveItemScores();
|
if(!shmup::on && !chaosmode && !nonbitrunc && numplayers() == 1 && !inv::on) improveItemScores();
|
||||||
|
|
||||||
int sid = nonchamfered ? 57 : chaosmode ? 53 : shmup::on ? (numplayers() > 1 ? 44 : 28) :
|
int sid = nonbitrunc ? 57 : chaosmode ? 53 : shmup::on ? (numplayers() > 1 ? 44 : 28) :
|
||||||
inv::on ? 69 :
|
inv::on ? 69 :
|
||||||
(numplayers() > 1 ? 61 : 0);
|
(numplayers() > 1 ? 61 : 0);
|
||||||
|
|
||||||
@ -671,7 +671,7 @@ void achievement_victory(bool hyper) {
|
|||||||
if(euclid) return;
|
if(euclid) return;
|
||||||
if(sphere) return;
|
if(sphere) return;
|
||||||
if(quotient) return;
|
if(quotient) return;
|
||||||
if(nonchamfered) return;
|
if(nonbitrunc) return;
|
||||||
if(randomPatternsMode) return;
|
if(randomPatternsMode) return;
|
||||||
if(hyper && shmup::on) return;
|
if(hyper && shmup::on) return;
|
||||||
if(yendor::on) return;
|
if(yendor::on) return;
|
||||||
|
86
barriers.cpp
86
barriers.cpp
@ -8,20 +8,20 @@ bool checkBarriersFront(cellwalker bb, int q, bool cross) {
|
|||||||
if(bb.c->mpdist < BARLEV) return false;
|
if(bb.c->mpdist < BARLEV) return false;
|
||||||
if(bb.c->mpdist == BUGLEV) return false;
|
if(bb.c->mpdist == BUGLEV) return false;
|
||||||
if(bb.c->bardir != NODIR) return false;
|
if(bb.c->bardir != NODIR) return false;
|
||||||
if(bb.spin == (nonchamfered ? 3 : 0)) {q--; if(!q) return true; }
|
if(bb.spin == (nonbitrunc ? 3 : 0)) {q--; if(!q) return true; }
|
||||||
|
|
||||||
if(!cross) for(int i=0; i<7; i++) {
|
if(!cross) for(int i=0; i<7; i++) {
|
||||||
cellwalker bb2 = bb;
|
cellwalker bb2 = bb;
|
||||||
cwspin(bb2, i); cwstep(bb2);
|
cwspin(bb2, i); cwstep(bb2);
|
||||||
if(bb2.c->bardir != NODIR) return false;
|
if(bb2.c->bardir != NODIR) return false;
|
||||||
if(!nonchamfered) {
|
if(!nonbitrunc) {
|
||||||
cwspin(bb2, 4); cwstep(bb2);
|
cwspin(bb2, 4); cwstep(bb2);
|
||||||
if(bb2.c->bardir != NODIR) return false;
|
if(bb2.c->bardir != NODIR) return false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
cwstep(bb);
|
cwstep(bb);
|
||||||
if(!nonchamfered) { cwspin(bb, 3); cwstep(bb); cwspin(bb, 3); cwstep(bb); }
|
if(!nonbitrunc) { cwspin(bb, 3); cwstep(bb); cwspin(bb, 3); cwstep(bb); }
|
||||||
return checkBarriersBack(bb, q);
|
return checkBarriersBack(bb, q);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -48,13 +48,13 @@ bool checkBarriersBack(cellwalker bb, int q, bool cross) {
|
|||||||
cellwalker bb2 = bb;
|
cellwalker bb2 = bb;
|
||||||
cwspin(bb2, i); cwstep(bb2);
|
cwspin(bb2, i); cwstep(bb2);
|
||||||
if(bb2.c->bardir != NODIR) return false;
|
if(bb2.c->bardir != NODIR) return false;
|
||||||
if(!nonchamfered) {
|
if(!nonbitrunc) {
|
||||||
cwspin(bb2, 4); cwstep(bb2);
|
cwspin(bb2, 4); cwstep(bb2);
|
||||||
if(bb2.c->bardir != NODIR) return false;
|
if(bb2.c->bardir != NODIR) return false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
cwspin(bb, 3); cwstep(bb); cwspin(bb, nonchamfered ? 5 : 4);
|
cwspin(bb, 3); cwstep(bb); cwspin(bb, nonbitrunc ? 5 : 4);
|
||||||
// bool create = cwstepcreates(bb);
|
// bool create = cwstepcreates(bb);
|
||||||
cwstep(bb); cwspin(bb, 3);
|
cwstep(bb); cwspin(bb, 3);
|
||||||
// if(create && bb.spin == 0) return true;
|
// if(create && bb.spin == 0) return true;
|
||||||
@ -87,12 +87,12 @@ bool checkBarriersNowall(cellwalker bb, int q, int dir, eLand l1=laNone, eLand l
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if(nonchamfered && S3==4) {
|
if(nonbitrunc && S3==4) {
|
||||||
cwspin(bb, dir);
|
cwspin(bb, dir);
|
||||||
cwstep(bb);
|
cwstep(bb);
|
||||||
cwspin(bb, dir);
|
cwspin(bb, dir);
|
||||||
}
|
}
|
||||||
else if(nonchamfered) {
|
else if(nonbitrunc) {
|
||||||
cwspin(bb, 3*dir);
|
cwspin(bb, 3*dir);
|
||||||
cwstep(bb);
|
cwstep(bb);
|
||||||
cwspin(bb, -3*dir);
|
cwspin(bb, -3*dir);
|
||||||
@ -158,7 +158,7 @@ void setland(cell *c, eLand l) {
|
|||||||
|
|
||||||
void extendcheck(cell *c) {
|
void extendcheck(cell *c) {
|
||||||
return;
|
return;
|
||||||
if(!nonchamfered && c->landparam == 0 && c->barleft != NOWALLSEP) {
|
if(!nonbitrunc && c->landparam == 0 && c->barleft != NOWALLSEP) {
|
||||||
raiseBuggyGeneration(c, "extend error");
|
raiseBuggyGeneration(c, "extend error");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -176,7 +176,7 @@ void extendBarrierFront(cell *c) {
|
|||||||
cellwalker bb(c, c->bardir); setbarrier(bb.c);
|
cellwalker bb(c, c->bardir); setbarrier(bb.c);
|
||||||
cwstep(bb);
|
cwstep(bb);
|
||||||
|
|
||||||
if(!nonchamfered) {
|
if(!nonbitrunc) {
|
||||||
bb.c->barleft = c->barleft;
|
bb.c->barleft = c->barleft;
|
||||||
bb.c->barright = c->barright;
|
bb.c->barright = c->barright;
|
||||||
setbarrier(bb.c);
|
setbarrier(bb.c);
|
||||||
@ -212,7 +212,7 @@ void extendBarrierFront(cell *c) {
|
|||||||
extendBarrier(bb.c);
|
extendBarrier(bb.c);
|
||||||
|
|
||||||
for(int a=-3; a<=3; a++) if(a) {
|
for(int a=-3; a<=3; a++) if(a) {
|
||||||
bb.c = c; bb.spin = c->bardir; cwspin(bb, nonchamfered?-a:a); cwstep(bb);
|
bb.c = c; bb.spin = c->bardir; cwspin(bb, nonbitrunc?-a:a); cwstep(bb);
|
||||||
setland(bb.c, a > 0 ? c->barright : c->barleft);
|
setland(bb.c, a > 0 ? c->barright : c->barleft);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -224,8 +224,8 @@ void extendBarrierBack(cell *c) {
|
|||||||
extendcheck(c);
|
extendcheck(c);
|
||||||
|
|
||||||
cellwalker bb(c, c->bardir); setbarrier(bb.c);
|
cellwalker bb(c, c->bardir); setbarrier(bb.c);
|
||||||
cwspin(bb, 3); cwstep(bb); cwspin(bb, nonchamfered?5:4);
|
cwspin(bb, 3); cwstep(bb); cwspin(bb, nonbitrunc?5:4);
|
||||||
setland(bb.c, nonchamfered ? c->barleft : c->barright);
|
setland(bb.c, nonbitrunc ? c->barleft : c->barright);
|
||||||
cwstep(bb); cwspin(bb, 3);
|
cwstep(bb); cwspin(bb, 3);
|
||||||
bb.c->bardir = bb.spin;
|
bb.c->bardir = bb.spin;
|
||||||
bb.c->barleft = c->barright;
|
bb.c->barleft = c->barright;
|
||||||
@ -236,7 +236,7 @@ void extendBarrierBack(cell *c) {
|
|||||||
//printf("[D heat %d]\n", (ht^11));
|
//printf("[D heat %d]\n", (ht^11));
|
||||||
|
|
||||||
// needed for CR2 to work
|
// needed for CR2 to work
|
||||||
if(!nonchamfered) {
|
if(!nonbitrunc) {
|
||||||
cwstep(bb);
|
cwstep(bb);
|
||||||
bb.c->barleft = c->barright;
|
bb.c->barleft = c->barright;
|
||||||
bb.c->barright = c->barleft;
|
bb.c->barright = c->barleft;
|
||||||
@ -255,12 +255,12 @@ void extendNowall(cell *c) {
|
|||||||
c->barleft = NOWALLSEP_USED;
|
c->barleft = NOWALLSEP_USED;
|
||||||
cellwalker cw(c, c->bardir);
|
cellwalker cw(c, c->bardir);
|
||||||
|
|
||||||
if(!nonchamfered) {
|
if(!nonbitrunc) {
|
||||||
cwstep(cw);
|
cwstep(cw);
|
||||||
setland(cw.c, c->barright);
|
setland(cw.c, c->barright);
|
||||||
}
|
}
|
||||||
|
|
||||||
if(nonchamfered && S3 == 4) {
|
if(nonbitrunc && S3 == 4) {
|
||||||
cwstep(cw);
|
cwstep(cw);
|
||||||
setland(cw.c, c->barright);
|
setland(cw.c, c->barright);
|
||||||
cw.c->barleft = NOWALLSEP_USED;
|
cw.c->barleft = NOWALLSEP_USED;
|
||||||
@ -270,12 +270,12 @@ void extendNowall(cell *c) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
for(int i=-1; i<2; i+=2) {
|
for(int i=-1; i<2; i+=2) {
|
||||||
if(nonchamfered && S3==4) {
|
if(nonbitrunc && S3==4) {
|
||||||
cwspin(cw, i);
|
cwspin(cw, i);
|
||||||
cwstep(cw);
|
cwstep(cw);
|
||||||
cwspin(cw, i);
|
cwspin(cw, i);
|
||||||
}
|
}
|
||||||
else if(nonchamfered) {
|
else if(nonbitrunc) {
|
||||||
cwspin(cw, 3*i);
|
cwspin(cw, 3*i);
|
||||||
cwstep(cw);
|
cwstep(cw);
|
||||||
cwspin(cw, -3*i);
|
cwspin(cw, -3*i);
|
||||||
@ -286,7 +286,7 @@ void extendNowall(cell *c) {
|
|||||||
}
|
}
|
||||||
if(cw.c->barleft != NOWALLSEP_USED) {
|
if(cw.c->barleft != NOWALLSEP_USED) {
|
||||||
cw.c->barleft = NOWALLSEP;
|
cw.c->barleft = NOWALLSEP;
|
||||||
if(S3 == 4 && nonchamfered) {
|
if(S3 == 4 && nonbitrunc) {
|
||||||
cw.c->barright = c->barright;
|
cw.c->barright = c->barright;
|
||||||
cw.c->bardir = cw.spin;
|
cw.c->bardir = cw.spin;
|
||||||
setland(cw.c, c->land);
|
setland(cw.c, c->land);
|
||||||
@ -298,19 +298,19 @@ void extendNowall(cell *c) {
|
|||||||
printf("barright\n");
|
printf("barright\n");
|
||||||
}// NONEDEBUG
|
}// NONEDEBUG
|
||||||
setland(cw.c, c->barright);
|
setland(cw.c, c->barright);
|
||||||
if(!nonchamfered) cwspin(cw, i);
|
if(!nonbitrunc) cwspin(cw, i);
|
||||||
cw.c->bardir = cw.spin;
|
cw.c->bardir = cw.spin;
|
||||||
if(!nonchamfered) cwspin(cw, -i);
|
if(!nonbitrunc) cwspin(cw, -i);
|
||||||
}
|
}
|
||||||
extendcheck(cw.c);
|
extendcheck(cw.c);
|
||||||
extendBarrier(cw.c);
|
extendBarrier(cw.c);
|
||||||
}
|
}
|
||||||
if(nonchamfered && S3==4) {
|
if(nonbitrunc && S3==4) {
|
||||||
cwspin(cw, -i);
|
cwspin(cw, -i);
|
||||||
cwstep(cw);
|
cwstep(cw);
|
||||||
cwspin(cw, -i);
|
cwspin(cw, -i);
|
||||||
}
|
}
|
||||||
else if(nonchamfered) {
|
else if(nonbitrunc) {
|
||||||
cwspin(cw, 3*i);
|
cwspin(cw, 3*i);
|
||||||
cwstep(cw);
|
cwstep(cw);
|
||||||
cwspin(cw, -3*i);
|
cwspin(cw, -3*i);
|
||||||
@ -325,7 +325,7 @@ void extendNowall(cell *c) {
|
|||||||
bool gotit = false;
|
bool gotit = false;
|
||||||
|
|
||||||
void extendCR5(cell *c) {
|
void extendCR5(cell *c) {
|
||||||
if(nonchamfered) return;
|
if(nonbitrunc) return;
|
||||||
// if(c->barright == laCrossroads5) extendCR5(c);
|
// if(c->barright == laCrossroads5) extendCR5(c);
|
||||||
eLand forbidden = c->barleft;
|
eLand forbidden = c->barleft;
|
||||||
eLand forbidden2 = laNone;
|
eLand forbidden2 = laNone;
|
||||||
@ -391,14 +391,14 @@ void extendBarrier(cell *c) {
|
|||||||
|
|
||||||
if(firstmirror && c->barleft == laMirror && hrand(100) < 60) {
|
if(firstmirror && c->barleft == laMirror && hrand(100) < 60) {
|
||||||
cellwalker cw(c, c->bardir);
|
cellwalker cw(c, c->bardir);
|
||||||
if(!nonchamfered) cwstep(cw);
|
if(!nonbitrunc) cwstep(cw);
|
||||||
if(cw.c->land != laMirrorWall)
|
if(cw.c->land != laMirrorWall)
|
||||||
if(buildBarrier6(cw, 1)) return;
|
if(buildBarrier6(cw, 1)) return;
|
||||||
}
|
}
|
||||||
|
|
||||||
if(firstmirror && (nonchamfered?c->barleft == laMirror : c->barright == laMirror) && hrand(100) < 60) {
|
if(firstmirror && (nonbitrunc?c->barleft == laMirror : c->barright == laMirror) && hrand(100) < 60) {
|
||||||
cellwalker cw(c, c->bardir);
|
cellwalker cw(c, c->bardir);
|
||||||
if(nonchamfered) {
|
if(nonbitrunc) {
|
||||||
cwspin(cw, -3); cwstep(cw); cwspin(cw, -3);
|
cwspin(cw, -3); cwstep(cw); cwspin(cw, -3);
|
||||||
// cwspin(cw, 3); cwstep(cw); cwspin(cw, -2); cwstep(cw); cwspin(cw, 3);
|
// cwspin(cw, 3); cwstep(cw); cwspin(cw, -2); cwstep(cw); cwspin(cw, 3);
|
||||||
}
|
}
|
||||||
@ -414,7 +414,7 @@ void extendBarrier(cell *c) {
|
|||||||
) {
|
) {
|
||||||
|
|
||||||
cellwalker cw(c, c->bardir);
|
cellwalker cw(c, c->bardir);
|
||||||
if(nonchamfered) {
|
if(nonbitrunc) {
|
||||||
cwstep(cw);
|
cwstep(cw);
|
||||||
if(isbar4(cw.c)) {
|
if(isbar4(cw.c)) {
|
||||||
cwstep(cw); cwspin(cw, 3); cwstep(cw); cwspin(cw, -1); cwstep(cw);
|
cwstep(cw); cwspin(cw, 3); cwstep(cw); cwspin(cw, -1); cwstep(cw);
|
||||||
@ -478,7 +478,7 @@ bool buildBarrier6(cellwalker cw, int type) {
|
|||||||
|
|
||||||
if(buggyGeneration) return true;
|
if(buggyGeneration) return true;
|
||||||
|
|
||||||
if(!nonchamfered) {
|
if(!nonbitrunc) {
|
||||||
cwstep(b[0]);
|
cwstep(b[0]);
|
||||||
cwspin(b[1], 1); cwstep(b[1]); cwspin(b[1], 3); cwstep(b[1]);
|
cwspin(b[1], 1); cwstep(b[1]); cwspin(b[1], 3); cwstep(b[1]);
|
||||||
cwspin(b[2], 4); cwstep(b[2]);
|
cwspin(b[2], 4); cwstep(b[2]);
|
||||||
@ -506,18 +506,18 @@ bool buildBarrier6(cellwalker cw, int type) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
if(type == 1) {
|
if(type == 1) {
|
||||||
if(!(nonchamfered?checkBarriersFront:checkBarriersBack)(b[1], 6, true)) return false;
|
if(!(nonbitrunc?checkBarriersFront:checkBarriersBack)(b[1], 6, true)) return false;
|
||||||
if(!(nonchamfered?checkBarriersFront:checkBarriersBack)(b[2], 6, true)) return false;
|
if(!(nonbitrunc?checkBarriersFront:checkBarriersBack)(b[2], 6, true)) return false;
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
if(!(nonchamfered?checkBarriersFront:checkBarriersBack)(b[0], 6, true)) return false;
|
if(!(nonbitrunc?checkBarriersFront:checkBarriersBack)(b[0], 6, true)) return false;
|
||||||
if(!(nonchamfered?checkBarriersFront:checkBarriersBack)(b[3], 6, true)) return false;
|
if(!(nonbitrunc?checkBarriersFront:checkBarriersBack)(b[3], 6, true)) return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
for(int d=0; d<4; d++) {
|
for(int d=0; d<4; d++) {
|
||||||
b[d].c->bardir = b[d].spin;
|
b[d].c->bardir = b[d].spin;
|
||||||
|
|
||||||
if(nonchamfered) {
|
if(nonbitrunc) {
|
||||||
b[0].c->barleft = laMirrored, b[0].c->barright = laMirrored2;
|
b[0].c->barleft = laMirrored, b[0].c->barright = laMirrored2;
|
||||||
b[1].c->barleft = laMirror, b[1].c->barright = laMirrored;
|
b[1].c->barleft = laMirror, b[1].c->barright = laMirrored;
|
||||||
b[2].c->barleft = laMirrored2, b[2].c->barright = laMirrored;
|
b[2].c->barleft = laMirrored2, b[2].c->barright = laMirrored;
|
||||||
@ -530,17 +530,17 @@ bool buildBarrier6(cellwalker cw, int type) {
|
|||||||
b[3].c->barleft = laMirrored2, b[3].c->barright = laMirrored;
|
b[3].c->barleft = laMirrored2, b[3].c->barright = laMirrored;
|
||||||
}
|
}
|
||||||
|
|
||||||
(nonchamfered?extendBarrierFront:extendBarrierBack)(b[d].c);
|
(nonbitrunc?extendBarrierFront:extendBarrierBack)(b[d].c);
|
||||||
}
|
}
|
||||||
|
|
||||||
if(nonchamfered && false) {
|
if(nonbitrunc && false) {
|
||||||
for(int z=0; z<4; z++)
|
for(int z=0; z<4; z++)
|
||||||
b[z].c->item = eItem(1+z+4*type);
|
b[z].c->item = eItem(1+z+4*type);
|
||||||
for(int a=0; a<4; a++)
|
for(int a=0; a<4; a++)
|
||||||
extendBarrierBack(cwpeek(b[a],0));
|
extendBarrierBack(cwpeek(b[a],0));
|
||||||
}
|
}
|
||||||
|
|
||||||
if(!nonchamfered) {
|
if(!nonbitrunc) {
|
||||||
setland(cwpeek(cw, 1), laMirrorWall);
|
setland(cwpeek(cw, 1), laMirrorWall);
|
||||||
setland(cwpeek(cw, 2), laMirrored);
|
setland(cwpeek(cw, 2), laMirrored);
|
||||||
setland(cwpeek(cw, 3), laMirrorWall2);
|
setland(cwpeek(cw, 3), laMirrorWall2);
|
||||||
@ -594,11 +594,11 @@ bool buildBarrier4(cell *c, int d, int mode, eLand ll, eLand lr) {
|
|||||||
cellwalker b1(c, d);
|
cellwalker b1(c, d);
|
||||||
|
|
||||||
cellwalker b2(c, d);
|
cellwalker b2(c, d);
|
||||||
if(nonchamfered) cwstep(b2);
|
if(nonbitrunc) cwstep(b2);
|
||||||
else { cwstep(b2); cwspin(b2, 3); cwstep(b2); cwspin(b2, 3); cwstep(b2); }
|
else { cwstep(b2); cwspin(b2, 3); cwstep(b2); cwspin(b2, 3); cwstep(b2); }
|
||||||
|
|
||||||
cellwalker b3(c, d);
|
cellwalker b3(c, d);
|
||||||
if(nonchamfered) {
|
if(nonbitrunc) {
|
||||||
cwspin(b3, -1); cwstep(b3); cwspin(b3, 3);
|
cwspin(b3, -1); cwstep(b3); cwspin(b3, 3);
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
@ -606,7 +606,7 @@ bool buildBarrier4(cell *c, int d, int mode, eLand ll, eLand lr) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
cellwalker b4(c, d);
|
cellwalker b4(c, d);
|
||||||
if(nonchamfered) {
|
if(nonbitrunc) {
|
||||||
cwspin(b4, 1); cwstep(b4); cwspin(b4, -3);
|
cwspin(b4, 1); cwstep(b4); cwspin(b4, -3);
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
@ -642,16 +642,16 @@ bool buildBarrier4(cell *c, int d, int mode, eLand ll, eLand lr) {
|
|||||||
c= b4.c; d=b4.spin;
|
c= b4.c; d=b4.spin;
|
||||||
c->bardir = d, c->barleft = ll, c->barright = xr; extendBarrierFront(c);
|
c->bardir = d, c->barleft = ll, c->barright = xr; extendBarrierFront(c);
|
||||||
|
|
||||||
if(!nonchamfered) for(int a=-3; a<=3; a++) if(a) {
|
if(!nonbitrunc) for(int a=-3; a<=3; a++) if(a) {
|
||||||
setland(cwpeek(b1, a), a > 0 ? lr : ll);
|
setland(cwpeek(b1, a), a > 0 ? lr : ll);
|
||||||
setland(cwpeek(b2, a), a > 0 ? xr : xl);
|
setland(cwpeek(b2, a), a > 0 ? xr : xl);
|
||||||
setland(cwpeek(b3, a), a > 0 ? lr : xl);
|
setland(cwpeek(b3, a), a > 0 ? lr : xl);
|
||||||
setland(cwpeek(b4, a), a > 0 ? xr : ll);
|
setland(cwpeek(b4, a), a > 0 ? xr : ll);
|
||||||
}
|
}
|
||||||
|
|
||||||
if(nonchamfered) setbarrier(b1.c), setbarrier(b2.c), setbarrier(b3.c), setbarrier(b4.c);
|
if(nonbitrunc) setbarrier(b1.c), setbarrier(b2.c), setbarrier(b3.c), setbarrier(b4.c);
|
||||||
|
|
||||||
if(!nonchamfered) {
|
if(!nonbitrunc) {
|
||||||
cell *cp;
|
cell *cp;
|
||||||
cp = cwpeek(b1, 0);
|
cp = cwpeek(b1, 0);
|
||||||
cp->barleft = ll; cp->barright = lr; setbarrier(cp);
|
cp->barleft = ll; cp->barright = lr; setbarrier(cp);
|
||||||
@ -782,7 +782,7 @@ bool buildBarrierNowall(cell *c, eLand l2, bool force) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
for(int i=0; i<3; i++) {
|
for(int i=0; i<3; i++) {
|
||||||
int d = (S3>3 && nonchamfered) ? (2+(i&1)) : dtab[i];
|
int d = (S3>3 && nonbitrunc) ? (2+(i&1)) : dtab[i];
|
||||||
if(force) d=1;
|
if(force) d=1;
|
||||||
cellwalker cw(c, d);
|
cellwalker cw(c, d);
|
||||||
|
|
||||||
|
18
bigstuff.cpp
18
bigstuff.cpp
@ -44,7 +44,7 @@ int euclidAlt(short x, short y) {
|
|||||||
if(specialland == laTemple || specialland == laClearing) {
|
if(specialland == laTemple || specialland == laClearing) {
|
||||||
if(euclid6)
|
if(euclid6)
|
||||||
return max(int(x), x+y);
|
return max(int(x), x+y);
|
||||||
else if(nonchamfered)
|
else if(nonbitrunc)
|
||||||
return x + abs(y);
|
return x + abs(y);
|
||||||
else
|
else
|
||||||
return max(x, y);
|
return max(x, y);
|
||||||
@ -57,7 +57,7 @@ int euclidAlt(short x, short y) {
|
|||||||
max(int(x+y), int(y)) + 3),
|
max(int(x+y), int(y)) + 3),
|
||||||
max(int(x), int(-y)) + 3
|
max(int(x), int(-y)) + 3
|
||||||
);
|
);
|
||||||
else if(nonchamfered)
|
else if(nonbitrunc)
|
||||||
return 3 - min(abs(x-y), abs(x+y));
|
return 3 - min(abs(x-y), abs(x+y));
|
||||||
else
|
else
|
||||||
return 3 - min(abs(x), abs(y));
|
return 3 - min(abs(x), abs(y));
|
||||||
@ -594,7 +594,7 @@ void buildEquidistant(cell *c) {
|
|||||||
if(c->landparam > 30 && b == laOcean && !generatingEquidistant && hrand(10) < 5)
|
if(c->landparam > 30 && b == laOcean && !generatingEquidistant && hrand(10) < 5)
|
||||||
buildAnotherEquidistant(c);
|
buildAnotherEquidistant(c);
|
||||||
|
|
||||||
if(c->landparam > HAUNTED_RADIUS+5 && b == laGraveyard && !generatingEquidistant && hrand(100) < (nonchamfered?25:5) && items[itBone] >= 10)
|
if(c->landparam > HAUNTED_RADIUS+5 && b == laGraveyard && !generatingEquidistant && hrand(100) < (nonbitrunc?25:5) && items[itBone] >= 10)
|
||||||
buildAnotherEquidistant(c);
|
buildAnotherEquidistant(c);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -971,7 +971,7 @@ void buildBigStuff(cell *c, cell *from) {
|
|||||||
|
|
||||||
else if(weirdhyperbolic) ; // non-Nowall barriers not implemented yet in weird hyperbolic
|
else if(weirdhyperbolic) ; // non-Nowall barriers not implemented yet in weird hyperbolic
|
||||||
|
|
||||||
else if(c->land == laCrossroads2 && !nonchamfered)
|
else if(c->land == laCrossroads2 && !nonbitrunc)
|
||||||
buildCrossroads2(c);
|
buildCrossroads2(c);
|
||||||
|
|
||||||
else if(c->land == laPrairie && c->LHU.fi.walldist == 0) {
|
else if(c->land == laPrairie && c->LHU.fi.walldist == 0) {
|
||||||
@ -1010,7 +1010,7 @@ void buildBigStuff(cell *c, cell *from) {
|
|||||||
c->land == laHaunted ? 0 :
|
c->land == laHaunted ? 0 :
|
||||||
(c->land == laGraveyard && !deepOcean) ? 0 :
|
(c->land == laGraveyard && !deepOcean) ? 0 :
|
||||||
(c->land == laGraveyard && items[itBone] >= 10) ? 120 :
|
(c->land == laGraveyard && items[itBone] >= 10) ? 120 :
|
||||||
c->land == laOcean ? (deepOcean ? (nonchamfered ? 250 : 2000) : 0) :
|
c->land == laOcean ? (deepOcean ? (nonbitrunc ? 250 : 2000) : 0) :
|
||||||
c->land == laDragon ? 120 :
|
c->land == laDragon ? 120 :
|
||||||
50))
|
50))
|
||||||
{
|
{
|
||||||
@ -1065,7 +1065,7 @@ void buildBigStuff(cell *c, cell *from) {
|
|||||||
|
|
||||||
if(c->land == laOcean && ctof(c) && deepOcean && !generatingEquidistant && !peace::on &&
|
if(c->land == laOcean && ctof(c) && deepOcean && !generatingEquidistant && !peace::on &&
|
||||||
(quickfind(laWhirlpool) || (
|
(quickfind(laWhirlpool) || (
|
||||||
hrand(2000) < (nonchamfered ? 500 : 1000) && !tactic::on && !yendor::on)))
|
hrand(2000) < (nonbitrunc ? 500 : 1000) && !tactic::on && !yendor::on)))
|
||||||
createAlternateMap(c, 2, hsA);
|
createAlternateMap(c, 2, hsA);
|
||||||
|
|
||||||
if(c->land == laCaribbean && ctof(c))
|
if(c->land == laCaribbean && ctof(c))
|
||||||
@ -1178,7 +1178,7 @@ void moreBigStuff(cell *c) {
|
|||||||
}
|
}
|
||||||
if(q == 1) buildCamelotWall(c);
|
if(q == 1) buildCamelotWall(c);
|
||||||
// towers of Camelot
|
// towers of Camelot
|
||||||
if(q == 0 && !nonchamfered) {
|
if(q == 0 && !nonbitrunc) {
|
||||||
c->monst = moKnight;
|
c->monst = moKnight;
|
||||||
c->wall = waTower;
|
c->wall = waTower;
|
||||||
forCellEx(c2, c) {
|
forCellEx(c2, c) {
|
||||||
@ -1203,7 +1203,7 @@ void moreBigStuff(cell *c) {
|
|||||||
}
|
}
|
||||||
if(d == 1) {
|
if(d == 1) {
|
||||||
// roughly as many knights as table cells
|
// roughly as many knights as table cells
|
||||||
if(hrand(nonchamfered ? 2618 : 1720) < 1000)
|
if(hrand(nonbitrunc ? 2618 : 1720) < 1000)
|
||||||
c->monst = moKnight;
|
c->monst = moKnight;
|
||||||
if(!euclid) for(int i=0; i<S7; i++) generateAlts(c->master->move[i]);
|
if(!euclid) for(int i=0; i<S7; i++) generateAlts(c->master->move[i]);
|
||||||
for(int i=0; i<c->type; i++)
|
for(int i=0; i<c->type; i++)
|
||||||
@ -1237,7 +1237,7 @@ void moreBigStuff(cell *c) {
|
|||||||
c->land = laTemple, c->wall = waNone, c->monst = moNone, c->item = itNone;
|
c->land = laTemple, c->wall = waNone, c->monst = moNone, c->item = itNone;
|
||||||
}
|
}
|
||||||
if(d % TEMPLE_EACH==0) {
|
if(d % TEMPLE_EACH==0) {
|
||||||
if((weirdhyperbolic && nonchamfered) ? hrand(100) < 50 : pseudohept(c))
|
if((weirdhyperbolic && nonbitrunc) ? hrand(100) < 50 : pseudohept(c))
|
||||||
c->wall = waColumn;
|
c->wall = waColumn;
|
||||||
else {
|
else {
|
||||||
if(!euclid) for(int i=0; i<S7; i++) generateAlts(c->master->move[i]);
|
if(!euclid) for(int i=0; i<S7; i++) generateAlts(c->master->move[i]);
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
double randd() { return (rand() % 1000000) / 1000000. + .0000005; }
|
double randd() { return (rand() % 1000000) / 1000000. + .0000005; }
|
||||||
|
|
||||||
double cellgfxdist(cell *c, int i) {
|
double cellgfxdist(cell *c, int i) {
|
||||||
return nonchamfered ? tessf : (c->type == 6 && (i&1)) ? hexhexdist : crossf;
|
return nonbitrunc ? tessf : (c->type == 6 && (i&1)) ? hexhexdist : crossf;
|
||||||
}
|
}
|
||||||
|
|
||||||
transmatrix cellrelmatrix(cell *c, int i) {
|
transmatrix cellrelmatrix(cell *c, int i) {
|
||||||
@ -13,7 +13,7 @@ hyperpoint randomPointIn(int t) {
|
|||||||
while(true) {
|
while(true) {
|
||||||
hyperpoint h = spin(2*M_PI*(randd()-.5)/t) * tC0(xpush(asinh(randd())));
|
hyperpoint h = spin(2*M_PI*(randd()-.5)/t) * tC0(xpush(asinh(randd())));
|
||||||
double d =
|
double d =
|
||||||
nonchamfered ? tessf : t == 6 ? hexhexdist : crossf;
|
nonbitrunc ? tessf : t == 6 ? hexhexdist : crossf;
|
||||||
if(hdist0(h) < hdist0(xpush(-d) * h))
|
if(hdist0(h) < hdist0(xpush(-d) * h))
|
||||||
return spin(2*M_PI/t * (rand() % t)) * h;
|
return spin(2*M_PI/t * (rand() % t)) * h;
|
||||||
}
|
}
|
||||||
|
20
cell.cpp
20
cell.cpp
@ -70,7 +70,7 @@ hrmap_hyperbolic::hrmap_hyperbolic() {
|
|||||||
h.spintable = 0;
|
h.spintable = 0;
|
||||||
h.alt = NULL;
|
h.alt = NULL;
|
||||||
h.distance = 0;
|
h.distance = 0;
|
||||||
isnonchamfered = nonchamfered;
|
isnonbitrunc = nonbitrunc;
|
||||||
h.c7 = newCell(S7, origin);
|
h.c7 = newCell(S7, origin);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -89,10 +89,10 @@ vector<int> siblings;
|
|||||||
|
|
||||||
struct hrmap_spherical : hrmap {
|
struct hrmap_spherical : hrmap {
|
||||||
heptagon *dodecahedron[12];
|
heptagon *dodecahedron[12];
|
||||||
bool isnonchamfered;
|
bool isnonbitrunc;
|
||||||
|
|
||||||
hrmap_spherical() {
|
hrmap_spherical() {
|
||||||
isnonchamfered = nonchamfered;
|
isnonbitrunc = nonbitrunc;
|
||||||
for(int i=0; i<spherecells(); i++) {
|
for(int i=0; i<spherecells(); i++) {
|
||||||
heptagon& h = *(dodecahedron[i] = new heptagon);
|
heptagon& h = *(dodecahedron[i] = new heptagon);
|
||||||
h.s = hsOrigin;
|
h.s = hsOrigin;
|
||||||
@ -162,7 +162,7 @@ struct hrmap_spherical : hrmap {
|
|||||||
heptagon *getOrigin() { return dodecahedron[0]; }
|
heptagon *getOrigin() { return dodecahedron[0]; }
|
||||||
|
|
||||||
~hrmap_spherical() {
|
~hrmap_spherical() {
|
||||||
dynamicval<bool> ph(nonchamfered, isnonchamfered);
|
dynamicval<bool> ph(nonbitrunc, isnonbitrunc);
|
||||||
for(int i=0; i<spherecells(); i++) clearHexes(dodecahedron[i]);
|
for(int i=0; i<spherecells(); i++) clearHexes(dodecahedron[i]);
|
||||||
for(int i=0; i<spherecells(); i++) delete dodecahedron[i];
|
for(int i=0; i<spherecells(); i++) delete dodecahedron[i];
|
||||||
}
|
}
|
||||||
@ -365,10 +365,10 @@ int euclid_getvec(int dx, int dy) {
|
|||||||
template<class T> void build_euclidean_moves(cell *c, int vec, const T& builder) {
|
template<class T> void build_euclidean_moves(cell *c, int vec, const T& builder) {
|
||||||
int x, y;
|
int x, y;
|
||||||
tie(x,y) = vec_to_pair(vec);
|
tie(x,y) = vec_to_pair(vec);
|
||||||
c->type = a4 ? (nonchamfered || ((x^y^1) & 1) ? 4 : 8) : 6;
|
c->type = a4 ? (nonbitrunc || ((x^y^1) & 1) ? 4 : 8) : 6;
|
||||||
|
|
||||||
if(c->type == 4) {
|
if(c->type == 4) {
|
||||||
int m = nonchamfered ? 1 : 2;
|
int m = nonbitrunc ? 1 : 2;
|
||||||
builder(euclid_getvec(+1,+0), 0, 2 * m);
|
builder(euclid_getvec(+1,+0), 0, 2 * m);
|
||||||
builder(euclid_getvec(+0,+1), 1, 3 * m);
|
builder(euclid_getvec(+0,+1), 1, 3 * m);
|
||||||
builder(euclid_getvec(-1,+0), 2, 0 * m);
|
builder(euclid_getvec(-1,+0), 2, 0 * m);
|
||||||
@ -726,7 +726,7 @@ cell *createMov(cell *c, int d) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
if(c->mov[d]) return c->mov[d];
|
if(c->mov[d]) return c->mov[d];
|
||||||
else if(nonchamfered) {
|
else if(nonbitrunc) {
|
||||||
heptagon *h2 = createStep(c->master, d);
|
heptagon *h2 = createStep(c->master, d);
|
||||||
merge(c,d,h2->c7,c->master->spin(d),false);
|
merge(c,d,h2->c7,c->master->spin(d),false);
|
||||||
}
|
}
|
||||||
@ -840,7 +840,7 @@ heptagon deletion_marker;
|
|||||||
|
|
||||||
void clearHexes(heptagon *at) {
|
void clearHexes(heptagon *at) {
|
||||||
if(at->c7) {
|
if(at->c7) {
|
||||||
if(!nonchamfered) for(int i=0; i<7; i++)
|
if(!nonbitrunc) for(int i=0; i<7; i++)
|
||||||
clearcell(at->c7->mov[i]);
|
clearcell(at->c7->mov[i]);
|
||||||
clearcell(at->c7);
|
clearcell(at->c7);
|
||||||
}
|
}
|
||||||
@ -880,7 +880,7 @@ void verifycell(cell *c) {
|
|||||||
for(int i=0; i<t; i++) {
|
for(int i=0; i<t; i++) {
|
||||||
cell *c2 = c->mov[i];
|
cell *c2 = c->mov[i];
|
||||||
if(c2) {
|
if(c2) {
|
||||||
if(!euclid && !nonchamfered && c == c->master->c7) verifycell(c2);
|
if(!euclid && !nonbitrunc && c == c->master->c7) verifycell(c2);
|
||||||
if(c2->mov[c->spn(i)] && c2->mov[c->spn(i)] != c) {
|
if(c2->mov[c->spn(i)] && c2->mov[c->spn(i)] != c) {
|
||||||
printf("cell error %p:%d [%d] %p:%d [%d]\n", c, i, c->type, c2, c->spn(i), c2->type);
|
printf("cell error %p:%d [%d] %p:%d [%d]\n", c, i, c->type, c2, c->spn(i), c2->type);
|
||||||
exit(1);
|
exit(1);
|
||||||
@ -1341,7 +1341,7 @@ int celldistance(cell *c1, cell *c2) {
|
|||||||
if(ac == xtgt) return d;
|
if(ac == xtgt) return d;
|
||||||
ac = chosenDown(ac, 1, 1, celldist);
|
ac = chosenDown(ac, 1, 1, celldist);
|
||||||
if(ac == tgt) return d+2;
|
if(ac == tgt) return d+2;
|
||||||
if(!nonchamfered) {
|
if(!nonbitrunc) {
|
||||||
ac = chosenDown(ac, 1, 1, celldist);
|
ac = chosenDown(ac, 1, 1, celldist);
|
||||||
if(ac == tgt) {
|
if(ac == tgt) {
|
||||||
if(chosenDown(ac0, 1, 0, celldist) ==
|
if(chosenDown(ac0, 1, 0, celldist) ==
|
||||||
|
@ -205,8 +205,8 @@ struct geometryinfo {
|
|||||||
int vertex;
|
int vertex;
|
||||||
int quotientstyle;
|
int quotientstyle;
|
||||||
eGeometryClass cclass;
|
eGeometryClass cclass;
|
||||||
array<int,2> distlimit; // chamfered, non-chamfered
|
|
||||||
int xcode;
|
int xcode;
|
||||||
|
array<int,2> distlimit; // bitrunc, non-bitrunc
|
||||||
};
|
};
|
||||||
|
|
||||||
static const int qZEBRA = 1;
|
static const int qZEBRA = 1;
|
||||||
|
@ -182,7 +182,7 @@ else if(args()[0] == '-' && args()[1] == x && args()[2] == '0') { showstartmenu
|
|||||||
|
|
||||||
TOGGLE('o', vid.usingGL, switchGL())
|
TOGGLE('o', vid.usingGL, switchGL())
|
||||||
TOGGLE('C', chaosmode, restartGame('C'))
|
TOGGLE('C', chaosmode, restartGame('C'))
|
||||||
TOGGLE('7', nonchamfered, restartGame('7'))
|
TOGGLE('7', nonbitrunc, restartGame('7'))
|
||||||
TOGGLE('f', vid.full, switchFullscreen())
|
TOGGLE('f', vid.full, switchFullscreen())
|
||||||
TOGGLE('T', tactic::on, restartGame('t'))
|
TOGGLE('T', tactic::on, restartGame('t'))
|
||||||
TOGGLE('S', shmup::on, restartGame('s'))
|
TOGGLE('S', shmup::on, restartGame('s'))
|
||||||
|
24
complex.cpp
24
complex.cpp
@ -747,7 +747,7 @@ namespace clearing {
|
|||||||
}
|
}
|
||||||
int d = celldistAlt(c);
|
int d = celldistAlt(c);
|
||||||
|
|
||||||
if(nonchamfered) {
|
if(nonbitrunc) {
|
||||||
for(int i=0; i<S7; i++) {
|
for(int i=0; i<S7; i++) {
|
||||||
cell *c2 = createMov(c, i);
|
cell *c2 = createMov(c, i);
|
||||||
if(!pseudohept(c2) && celldistAlt(c2) == d-1)
|
if(!pseudohept(c2) && celldistAlt(c2) == d-1)
|
||||||
@ -1111,7 +1111,7 @@ namespace mirror {
|
|||||||
}
|
}
|
||||||
|
|
||||||
void createMirages(cellwalker cw, int cpid) {
|
void createMirages(cellwalker cw, int cpid) {
|
||||||
if(nonchamfered) {
|
if(nonbitrunc) {
|
||||||
for(int i=0; i<cw.c->type; i++) {
|
for(int i=0; i<cw.c->type; i++) {
|
||||||
cellwalker C2 = cw;
|
cellwalker C2 = cw;
|
||||||
cwstep(C2);
|
cwstep(C2);
|
||||||
@ -1321,9 +1321,9 @@ namespace mirror {
|
|||||||
v.push_back(1);
|
v.push_back(1);
|
||||||
stepcount++; if(stepcount > 10000) { printf("failhep\n"); return cw; }
|
stepcount++; if(stepcount > 10000) { printf("failhep\n"); return cw; }
|
||||||
}
|
}
|
||||||
if(nonchamfered && cwpeek(cw,0) == cwcopy.c)
|
if(nonbitrunc && cwpeek(cw,0) == cwcopy.c)
|
||||||
v.pop_back();
|
v.pop_back();
|
||||||
if(nonchamfered && cwpeek(cw,3)->land == laMirrored && cwpeek(cw,2)->land == laMirrorWall) {
|
if(nonbitrunc && cwpeek(cw,3)->land == laMirrored && cwpeek(cw,2)->land == laMirrorWall) {
|
||||||
cw.mirrored = !cw.mirrored;
|
cw.mirrored = !cw.mirrored;
|
||||||
auto p = traceback(v, cw);
|
auto p = traceback(v, cw);
|
||||||
if(p.first) return p.second;
|
if(p.first) return p.second;
|
||||||
@ -1828,7 +1828,7 @@ namespace heat {
|
|||||||
cell *c = playerpos(i);
|
cell *c = playerpos(i);
|
||||||
if(!c) continue;
|
if(!c) continue;
|
||||||
double xrate = (c->land == laCocytus && shmup::on) ? rate/3 : rate;
|
double xrate = (c->land == laCocytus && shmup::on) ? rate/3 : rate;
|
||||||
if(nonchamfered) xrate *= 1.7;
|
if(nonbitrunc) xrate *= 1.7;
|
||||||
if(!shmup::on) xrate /= FIX94;
|
if(!shmup::on) xrate /= FIX94;
|
||||||
if(isIcyLand(c))
|
if(isIcyLand(c))
|
||||||
HEAT(c) += (markOrb(itOrbWinter) ? -1.2 : 1.2) * xrate;
|
HEAT(c) += (markOrb(itOrbWinter) ? -1.2 : 1.2) * xrate;
|
||||||
@ -1843,7 +1843,7 @@ namespace heat {
|
|||||||
for(int i=0; i<dcs; i++) {
|
for(int i=0; i<dcs; i++) {
|
||||||
cell *c = allcells[i];
|
cell *c = allcells[i];
|
||||||
double xrate = (c->land == laCocytus && shmup::on) ? 1/3. : 1;
|
double xrate = (c->land == laCocytus && shmup::on) ? 1/3. : 1;
|
||||||
if(nonchamfered) xrate *= 1.7;
|
if(nonbitrunc) xrate *= 1.7;
|
||||||
if(!shmup::on) xrate /= FIX94;
|
if(!shmup::on) xrate /= FIX94;
|
||||||
if(c->cpdist > 7 && !doall) break;
|
if(c->cpdist > 7 && !doall) break;
|
||||||
|
|
||||||
@ -2524,7 +2524,7 @@ namespace sword {
|
|||||||
}
|
}
|
||||||
|
|
||||||
void shuffle(int i) {
|
void shuffle(int i) {
|
||||||
sword::angle[i] = euclid ? S7*hrand(6) : nonchamfered ? 3*hrand(S14)+1 : hrand(S42);
|
sword::angle[i] = euclid ? S7*hrand(6) : nonbitrunc ? 3*hrand(S14)+1 : hrand(S42);
|
||||||
}
|
}
|
||||||
|
|
||||||
void reset() {
|
void reset() {
|
||||||
@ -2709,7 +2709,7 @@ namespace prairie {
|
|||||||
c->LHU.fi.rval = (y&15);
|
c->LHU.fi.rval = (y&15);
|
||||||
}
|
}
|
||||||
else if(sphere) {
|
else if(sphere) {
|
||||||
c->LHU.fi.rval = celldistance(c, cwt.c) + 8 - (nonchamfered ? 2 : 3);
|
c->LHU.fi.rval = celldistance(c, cwt.c) + 8 - (nonbitrunc ? 2 : 3);
|
||||||
}
|
}
|
||||||
else if(weirdhyperbolic) {
|
else if(weirdhyperbolic) {
|
||||||
c->LHU.fi.rval = max(celldist(c), 15);
|
c->LHU.fi.rval = max(celldist(c), 15);
|
||||||
@ -2771,8 +2771,8 @@ namespace prairie {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#define RLOW (sphere?(nonchamfered?7:6):nonchamfered?4:2)
|
#define RLOW (sphere?(nonbitrunc?7:6):nonbitrunc?4:2)
|
||||||
#define RHIGH (sphere?(nonchamfered?8:9):nonchamfered?11:13)
|
#define RHIGH (sphere?(nonbitrunc?8:9):nonbitrunc?11:13)
|
||||||
|
|
||||||
bool isriver(cell *c) {
|
bool isriver(cell *c) {
|
||||||
return c->land == laPrairie && c->LHU.fi.rval <= RHIGH && c->LHU.fi.rval >= RLOW;
|
return c->land == laPrairie && c->LHU.fi.rval <= RHIGH && c->LHU.fi.rval >= RLOW;
|
||||||
@ -2934,7 +2934,7 @@ namespace prairie {
|
|||||||
else if(!enter && isriver(cwt.c)) enter = cwt.c;
|
else if(!enter && isriver(cwt.c)) enter = cwt.c;
|
||||||
if(size(tchoices)) {
|
if(size(tchoices)) {
|
||||||
if(lasttreasure && lasttreasure->item == itGreenGrass) {
|
if(lasttreasure && lasttreasure->item == itGreenGrass) {
|
||||||
if(celldistance(lasttreasure, cwt.c) >= (nonchamfered ? 7 : 10)) {
|
if(celldistance(lasttreasure, cwt.c) >= (nonbitrunc ? 7 : 10)) {
|
||||||
lasttreasure->item = itNone;
|
lasttreasure->item = itNone;
|
||||||
forCellEx(c2, lasttreasure) if(c2->item == itGreenGrass) c2->item = itNone;
|
forCellEx(c2, lasttreasure) if(c2->item == itGreenGrass) c2->item = itNone;
|
||||||
}
|
}
|
||||||
@ -3310,7 +3310,7 @@ namespace halloween {
|
|||||||
else if(CHANCE(5) && itr >= 60) {
|
else if(CHANCE(5) && itr >= 60) {
|
||||||
dragoncount++;
|
dragoncount++;
|
||||||
}
|
}
|
||||||
else if(dragoncount && !nonchamfered && !mcount) {
|
else if(dragoncount && !nonbitrunc && !mcount) {
|
||||||
bool fill = false;
|
bool fill = false;
|
||||||
for(int i=0; i<4; i++)
|
for(int i=0; i<4; i++)
|
||||||
if(!dragoncells[i] || dragoncells[i]->monst)
|
if(!dragoncells[i] || dragoncells[i]->monst)
|
||||||
|
10
config.cpp
10
config.cpp
@ -321,7 +321,7 @@ void initConfig() {
|
|||||||
addsaver(hardcore, "mode-hardcore", false);
|
addsaver(hardcore, "mode-hardcore", false);
|
||||||
addsaver(chaosmode, "mode-chaos");
|
addsaver(chaosmode, "mode-chaos");
|
||||||
addsaver(inv::on, "mode-Orb Strategy");
|
addsaver(inv::on, "mode-Orb Strategy");
|
||||||
addsaver(nonchamfered, "mode-heptagonal", false);
|
addsaver(nonbitrunc, "mode-heptagonal", false);
|
||||||
addsaver(peace::on, "mode-peace");
|
addsaver(peace::on, "mode-peace");
|
||||||
addsaver(peace::otherpuzzles, "mode-peace-submode");
|
addsaver(peace::otherpuzzles, "mode-peace-submode");
|
||||||
addsaverenum(specialland, "land for special modes");
|
addsaverenum(specialland, "land for special modes");
|
||||||
@ -337,7 +337,7 @@ void initConfig() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
bool inSpecialMode() {
|
bool inSpecialMode() {
|
||||||
return chaosmode || nonchamfered || peace::on || tour::on ||
|
return chaosmode || nonbitrunc || peace::on || tour::on ||
|
||||||
yendor::on || tactic::on || randomPatternsMode ||
|
yendor::on || tactic::on || randomPatternsMode ||
|
||||||
geometry != gNormal || pmodel != mdDisk || vid.alpha != 1 || vid.scale != 1 ||
|
geometry != gNormal || pmodel != mdDisk || vid.alpha != 1 || vid.scale != 1 ||
|
||||||
rug::rugged || vid.monmode != DEFAULT_MONMODE ||
|
rug::rugged || vid.monmode != DEFAULT_MONMODE ||
|
||||||
@ -350,7 +350,7 @@ void resetModes(char leave = 'c') {
|
|||||||
if(shmup::on != (leave == 's')) restartGame('s');
|
if(shmup::on != (leave == 's')) restartGame('s');
|
||||||
if(inv::on != (leave == 'i')) restartGame('i');
|
if(inv::on != (leave == 'i')) restartGame('i');
|
||||||
if(chaosmode != (leave == 'C')) restartGame('C');
|
if(chaosmode != (leave == 'C')) restartGame('C');
|
||||||
if(nonchamfered != (leave == '7')) restartGame('7');
|
if(nonbitrunc != (leave == '7')) restartGame('7');
|
||||||
if(peace::on != (leave == 'P')) restartGame('P');
|
if(peace::on != (leave == 'P')) restartGame('P');
|
||||||
#if CAP_TOUR
|
#if CAP_TOUR
|
||||||
if(tour::on != (leave == 'T')) restartGame('T');
|
if(tour::on != (leave == 'T')) restartGame('T');
|
||||||
@ -454,11 +454,11 @@ void loadOldConfig(FILE *f) {
|
|||||||
|
|
||||||
shmup::loadConfig(f);
|
shmup::loadConfig(f);
|
||||||
|
|
||||||
aa = rug::renderonce; bb = rug::rendernogl; cc = nonchamfered; dd = chaosmode;
|
aa = rug::renderonce; bb = rug::rendernogl; cc = nonbitrunc; dd = chaosmode;
|
||||||
int ee = vid.steamscore;
|
int ee = vid.steamscore;
|
||||||
double rs = 2/rug::model_distance;
|
double rs = 2/rug::model_distance;
|
||||||
err=fscanf(f, "%d%d%d%d%lf%d%d", &aa, &bb, &rug::texturesize, &cc, &rs, &ee, &dd);
|
err=fscanf(f, "%d%d%d%d%lf%d%d", &aa, &bb, &rug::texturesize, &cc, &rs, &ee, &dd);
|
||||||
rug::renderonce = aa; rug::rendernogl = bb; nonchamfered = cc; chaosmode = dd; vid.steamscore = ee;
|
rug::renderonce = aa; rug::rendernogl = bb; nonbitrunc = cc; chaosmode = dd; vid.steamscore = ee;
|
||||||
rug::model_distance = 2/rs;
|
rug::model_distance = 2/rs;
|
||||||
|
|
||||||
aa=conformal::autobandhistory;
|
aa=conformal::autobandhistory;
|
||||||
|
@ -383,7 +383,7 @@ struct fpattern {
|
|||||||
dists[at] = i;
|
dists[at] = i;
|
||||||
for(int q=0; q<S7; q++) {
|
for(int q=0; q<S7; q++) {
|
||||||
dists[at] = i;
|
dists[at] = i;
|
||||||
if(nonchamfered)
|
if(nonbitrunc)
|
||||||
indist[i+1].push_back(connections[at]);
|
indist[i+1].push_back(connections[at]);
|
||||||
else {
|
else {
|
||||||
indist[i+2].push_back(connections[at]);
|
indist[i+2].push_back(connections[at]);
|
||||||
@ -397,7 +397,7 @@ struct fpattern {
|
|||||||
|
|
||||||
void analyze() {
|
void analyze() {
|
||||||
|
|
||||||
DEBB(DF_FIELD, (debugfile, "nonchamfered = %d\n", nonchamfered));
|
DEBB(DF_FIELD, (debugfile, "nonbitrunc = %d\n", nonbitrunc));
|
||||||
int N = connections.size();
|
int N = connections.size();
|
||||||
|
|
||||||
markers.resize(N);
|
markers.resize(N);
|
||||||
@ -512,7 +512,7 @@ struct fpattern {
|
|||||||
W = mmul(Wall, W);
|
W = mmul(Wall, W);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
dijkstra(nonchamfered ? distriver : distflower, indist);
|
dijkstra(nonbitrunc ? distriver : distflower, indist);
|
||||||
|
|
||||||
W = matrices[riverid];
|
W = matrices[riverid];
|
||||||
for(int i=0; i<wallorder; i++) {
|
for(int i=0; i<wallorder; i++) {
|
||||||
@ -534,7 +534,7 @@ struct fpattern {
|
|||||||
SETDIST(W, 1, itGold)
|
SETDIST(W, 1, itGold)
|
||||||
W = mmul(W, Wall);
|
W = mmul(W, Wall);
|
||||||
}
|
}
|
||||||
int riverdist = dijkstra(nonchamfered ? distflower : distriver, indist);
|
int riverdist = dijkstra(nonbitrunc ? distflower : distriver, indist);
|
||||||
DEBB(DF_FIELD, (debugfile, "river dist = %d\n", riverdist));
|
DEBB(DF_FIELD, (debugfile, "river dist = %d\n", riverdist));
|
||||||
|
|
||||||
for(int i=0; i<size(currfp.matrices); i++)
|
for(int i=0; i<size(currfp.matrices); i++)
|
||||||
@ -543,7 +543,7 @@ struct fpattern {
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
if(!nonchamfered) {
|
if(!nonbitrunc) {
|
||||||
W = matrices[riverid];
|
W = matrices[riverid];
|
||||||
for(int i=0; i<wallorder; i++) {
|
for(int i=0; i<wallorder; i++) {
|
||||||
SETDIST(W, 0, itStatue)
|
SETDIST(W, 0, itStatue)
|
||||||
|
12
game.cpp
12
game.cpp
@ -2136,7 +2136,7 @@ void killMonster(cell *c, eMonster who, flagtype deathflags) {
|
|||||||
for(int i=0; i<c->type; i++) {
|
for(int i=0; i<c->type; i++) {
|
||||||
cell *c2 = c->mov[i];
|
cell *c2 = c->mov[i];
|
||||||
if(c2 && c2->item == itCompass) toomany = true;
|
if(c2 && c2->item == itCompass) toomany = true;
|
||||||
if(c2 && !nonchamfered) for(int j=0; j<c2->type; j++)
|
if(c2 && !nonbitrunc) for(int j=0; j<c2->type; j++)
|
||||||
if(c2->mov[j] && c2->mov[j]->item == itCompass)
|
if(c2->mov[j] && c2->mov[j]->item == itCompass)
|
||||||
toomany = true;
|
toomany = true;
|
||||||
}
|
}
|
||||||
@ -2684,7 +2684,7 @@ void buildRosemap() {
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
int getDistLimit() { return ginf[geometry].distlimit[nonchamfered]; }
|
int getDistLimit() { return ginf[geometry].distlimit[nonbitrunc]; }
|
||||||
|
|
||||||
bool nogoSlow(cell *to, cell *from) {
|
bool nogoSlow(cell *to, cell *from) {
|
||||||
if(cellEdgeUnstable(to) && gravityLevel(to) >= gravityLevel(from)) return true;
|
if(cellEdgeUnstable(to) && gravityLevel(to) >= gravityLevel(from)) return true;
|
||||||
@ -3084,7 +3084,7 @@ void toggleGates(cell *ct, eWall type, int rad) {
|
|||||||
void toggleGates(cell *ct, eWall type) {
|
void toggleGates(cell *ct, eWall type) {
|
||||||
playSound(ct, "click");
|
playSound(ct, "click");
|
||||||
numgates = 0;
|
numgates = 0;
|
||||||
if(type == waClosePlate && nonchamfered)
|
if(type == waClosePlate && nonbitrunc)
|
||||||
toggleGates(ct, type, 2);
|
toggleGates(ct, type, 2);
|
||||||
else
|
else
|
||||||
toggleGates(ct, type, 3);
|
toggleGates(ct, type, 3);
|
||||||
@ -6786,11 +6786,11 @@ ld circlesizeD[10000];
|
|||||||
int lastsize;
|
int lastsize;
|
||||||
|
|
||||||
void computeSizes() {
|
void computeSizes() {
|
||||||
lastsize = nonchamfered ? 44 : 76;
|
lastsize = nonbitrunc ? 44 : 76;
|
||||||
|
|
||||||
circlesize[0] = 1;
|
circlesize[0] = 1;
|
||||||
|
|
||||||
if(!nonchamfered) {
|
if(!nonbitrunc) {
|
||||||
circlesize[1] = 1*7;
|
circlesize[1] = 1*7;
|
||||||
circlesize[2] = 2*7;
|
circlesize[2] = 2*7;
|
||||||
circlesize[3] = 4*7;
|
circlesize[3] = 4*7;
|
||||||
@ -7542,7 +7542,7 @@ bool movepcto(int d, int subdir, bool checkonly) {
|
|||||||
if(checkonly) return false;
|
if(checkonly) return false;
|
||||||
if(nonAdjacent(cwt.c,c2))
|
if(nonAdjacent(cwt.c,c2))
|
||||||
addMessage(XLAT(
|
addMessage(XLAT(
|
||||||
nonchamfered ?
|
nonbitrunc ?
|
||||||
"You cannot move between the cells without dots here!" :
|
"You cannot move between the cells without dots here!" :
|
||||||
"You cannot move between the triangular cells here!"
|
"You cannot move between the triangular cells here!"
|
||||||
));
|
));
|
||||||
|
38
geom-exp.cpp
38
geom-exp.cpp
@ -10,7 +10,7 @@ string euchelp =
|
|||||||
"You can try many different geometries here. We start by gluing "
|
"You can try many different geometries here. We start by gluing "
|
||||||
"n-gons in such a way that k of them meet in every vertex. "
|
"n-gons in such a way that k of them meet in every vertex. "
|
||||||
"Depending on n and k, this either folds into a sphere, unfolds into a plane, "
|
"Depending on n and k, this either folds into a sphere, unfolds into a plane, "
|
||||||
"or requires a hyperbolic space. The result may be then 'chamfered' by "
|
"or requires a hyperbolic space. The result may be then 'bitrunc' by "
|
||||||
"replacing each vertex by a 2k-gon. Furthermore, you can play "
|
"replacing each vertex by a 2k-gon. Furthermore, you can play "
|
||||||
"with quotient geometries. For example, the elliptic geometry is "
|
"with quotient geometries. For example, the elliptic geometry is "
|
||||||
"obtained from the sphere by making the antipodes be the same point, "
|
"obtained from the sphere by making the antipodes be the same point, "
|
||||||
@ -18,7 +18,7 @@ string euchelp =
|
|||||||
"Have fun experimenting! "
|
"Have fun experimenting! "
|
||||||
"Achievements and leaderboards do not work in geometry experiments, "
|
"Achievements and leaderboards do not work in geometry experiments, "
|
||||||
"except some specific ones.\n\n"
|
"except some specific ones.\n\n"
|
||||||
"In standard geometry (chamfered or not), you can play the full game, but in other geometries "
|
"In standard geometry (bitrunc or not), you can play the full game, but in other geometries "
|
||||||
"you select a particular land. Lands are unlocked by visiting them in this "
|
"you select a particular land. Lands are unlocked by visiting them in this "
|
||||||
"session, or permanently by collecting 25 treasure. Try Crossroads in Euclidean "
|
"session, or permanently by collecting 25 treasure. Try Crossroads in Euclidean "
|
||||||
"or chaos mode in non-standard non-quotient hyperbolic to visit many lands. "
|
"or chaos mode in non-standard non-quotient hyperbolic to visit many lands. "
|
||||||
@ -41,7 +41,7 @@ void showQuotientConfig() {
|
|||||||
nextPrimes(gxcur);
|
nextPrimes(gxcur);
|
||||||
for(int i=0; i<size(gxcur.primes); i++) {
|
for(int i=0; i<size(gxcur.primes); i++) {
|
||||||
auto& p = gxcur.primes[i];
|
auto& p = gxcur.primes[i];
|
||||||
dialog::addBoolItem(XLAT("order %1%2 (non-chamfered cells: %3)", its(p.p), p.squared ? "²" : "", its(p.cells)), i == gxcur.current_prime_id, 'A'+i);
|
dialog::addBoolItem(XLAT("order %1%2 (non-bitrunc cells: %3)", its(p.p), p.squared ? "²" : "", its(p.cells)), i == gxcur.current_prime_id, 'A'+i);
|
||||||
}
|
}
|
||||||
|
|
||||||
if(size(gxcur.primes) < 6) {
|
if(size(gxcur.primes) < 6) {
|
||||||
@ -84,7 +84,7 @@ void showQuotientConfig() {
|
|||||||
dialog::display();
|
dialog::display();
|
||||||
}
|
}
|
||||||
|
|
||||||
bool torus_chamfer;
|
bool torus_bitrunc;
|
||||||
|
|
||||||
void showTorusConfig() {
|
void showTorusConfig() {
|
||||||
cmode = sm::SIDE | sm::TORUSCONFIG;
|
cmode = sm::SIDE | sm::TORUSCONFIG;
|
||||||
@ -114,7 +114,7 @@ void showTorusConfig() {
|
|||||||
dialog::addSelItem(XLAT("height (y)"), its(torusconfig::newsdy), 'y');
|
dialog::addSelItem(XLAT("height (y)"), its(torusconfig::newsdy), 'y');
|
||||||
}
|
}
|
||||||
|
|
||||||
if(square) dialog::addBoolItem(XLAT("chamfering"), !torus_chamfer, 't');
|
if(square) dialog::addBoolItem(XLAT("bitruncated"), !torus_bitrunc, 't');
|
||||||
else dialog::addInfo("", 100);
|
else dialog::addInfo("", 100);
|
||||||
|
|
||||||
int valid = 2;
|
int valid = 2;
|
||||||
@ -122,8 +122,8 @@ void showTorusConfig() {
|
|||||||
if(single) {
|
if(single) {
|
||||||
if(square) {
|
if(square) {
|
||||||
dialog::addInfo("this mode has bad patterns", 0x808080), valid = 1;
|
dialog::addInfo("this mode has bad patterns", 0x808080), valid = 1;
|
||||||
if(!torus_chamfer && valid == 1)
|
if(!torus_bitrunc && valid == 1)
|
||||||
dialog::addInfo("incompatible with chamfering", 0x808080), valid = 0;
|
dialog::addInfo("incompatible with bitruncating", 0x808080), valid = 0;
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
if(torusconfig::newqty % 3)
|
if(torusconfig::newqty % 3)
|
||||||
@ -138,8 +138,8 @@ void showTorusConfig() {
|
|||||||
dialog::addInfo(XLAT("best if %1 is divisible by %2", "x", "2"), 0x808080), valid = 1;
|
dialog::addInfo(XLAT("best if %1 is divisible by %2", "x", "2"), 0x808080), valid = 1;
|
||||||
if(torusconfig::newsdy & 1)
|
if(torusconfig::newsdy & 1)
|
||||||
dialog::addInfo(XLAT("best if %1 is divisible by %2", "y", "2"), 0x808080), valid = 1;
|
dialog::addInfo(XLAT("best if %1 is divisible by %2", "y", "2"), 0x808080), valid = 1;
|
||||||
if(!torus_chamfer && valid == 1)
|
if(!torus_bitrunc && valid == 1)
|
||||||
dialog::addInfo("incompatible with chamfering", 0x808080), valid = 0;
|
dialog::addInfo("incompatible with bitruncating", 0x808080), valid = 0;
|
||||||
}
|
}
|
||||||
else if(simple) {
|
else if(simple) {
|
||||||
if(torusconfig::newsdx & 1)
|
if(torusconfig::newsdx & 1)
|
||||||
@ -179,7 +179,7 @@ void showTorusConfig() {
|
|||||||
else if(uni == 'y' && !single)
|
else if(uni == 'y' && !single)
|
||||||
dialog::editNumber(torusconfig::newsdy, 0, 1000, square ? 2 : simple ? 3 : 2, 12, XLAT("height (y)"), "");
|
dialog::editNumber(torusconfig::newsdy, 0, 1000, square ? 2 : simple ? 3 : 2, 12, XLAT("height (y)"), "");
|
||||||
else if(uni == 't')
|
else if(uni == 't')
|
||||||
torus_chamfer = !torus_chamfer;
|
torus_bitrunc = !torus_bitrunc;
|
||||||
else if((uni == 'a' || uni == '\n') && torusconfig::newqty >= 3 && valid) {
|
else if((uni == 'a' || uni == '\n') && torusconfig::newqty >= 3 && valid) {
|
||||||
targetgeometry = gNormal; restartGame('g', false, true);
|
targetgeometry = gNormal; restartGame('g', false, true);
|
||||||
torusconfig::torus_mode = torusconfig::newmode;
|
torusconfig::torus_mode = torusconfig::newmode;
|
||||||
@ -188,7 +188,7 @@ void showTorusConfig() {
|
|||||||
torusconfig::sdx = torusconfig::newsdx;
|
torusconfig::sdx = torusconfig::newsdx;
|
||||||
torusconfig::sdy = torusconfig::newsdy;
|
torusconfig::sdy = torusconfig::newsdy;
|
||||||
torusconfig::activate();
|
torusconfig::activate();
|
||||||
if((square && torus_chamfer) != nonchamfered) restartGame('7', false, true);
|
if((square && torus_bitrunc) != nonbitrunc) restartGame('7', false, true);
|
||||||
targetgeometry = gTorus; restartGame('g', false, true);
|
targetgeometry = gTorus; restartGame('g', false, true);
|
||||||
}
|
}
|
||||||
else if(uni == 'c') {
|
else if(uni == 'c') {
|
||||||
@ -209,7 +209,7 @@ void showTorusConfig() {
|
|||||||
dialog::display();
|
dialog::display();
|
||||||
}
|
}
|
||||||
|
|
||||||
string chamfernames[2] = {" (c)", " (n)"};
|
string bitruncnames[2] = {" (b)", " (n)"};
|
||||||
|
|
||||||
void showEuclideanMenu() {
|
void showEuclideanMenu() {
|
||||||
cmode = sm::SIDE;
|
cmode = sm::SIDE;
|
||||||
@ -237,7 +237,7 @@ void showEuclideanMenu() {
|
|||||||
int ts = ginf[geometry].sides;
|
int ts = ginf[geometry].sides;
|
||||||
int tv = ginf[geometry].vertex;
|
int tv = ginf[geometry].vertex;
|
||||||
int tq = ginf[geometry].quotientstyle;
|
int tq = ginf[geometry].quotientstyle;
|
||||||
int nom = (nonchamfered ? tv : tv+ts) * ((tq & qELLIP) ? 2 : 4);
|
int nom = (nonbitrunc ? tv : tv+ts) * ((tq & qELLIP) ? 2 : 4);
|
||||||
int denom = (2*ts + 2*tv - ts * tv);
|
int denom = (2*ts + 2*tv - ts * tv);
|
||||||
|
|
||||||
dialog::addSelItem(XLAT("land"), XLAT1(linf[specialland].name), '5');
|
dialog::addSelItem(XLAT("land"), XLAT1(linf[specialland].name), '5');
|
||||||
@ -249,18 +249,18 @@ void showEuclideanMenu() {
|
|||||||
dialog::addBreak(50);
|
dialog::addBreak(50);
|
||||||
|
|
||||||
if(ts == 6 && tv == 3)
|
if(ts == 6 && tv == 3)
|
||||||
dialog::addSelItem(XLAT("chamfered"), XLAT("does not matter"), 't');
|
dialog::addSelItem(XLAT("bitrunc"), XLAT("does not matter"), 't');
|
||||||
else
|
else
|
||||||
dialog::addBoolItem(XLAT("chamfered"), !nonchamfered, 't');
|
dialog::addBoolItem(XLAT("bitrunc"), !nonbitrunc, 't');
|
||||||
|
|
||||||
dialog::addBreak(50);
|
dialog::addBreak(50);
|
||||||
|
|
||||||
int worldsize = denom ? nom/denom : 0;
|
int worldsize = denom ? nom/denom : 0;
|
||||||
if(tq & qTORUS) worldsize = torusconfig::qty;
|
if(tq & qTORUS) worldsize = torusconfig::qty;
|
||||||
if(tq & qZEBRA) worldsize = nonchamfered ? 12 : 40;
|
if(tq & qZEBRA) worldsize = nonbitrunc ? 12 : 40;
|
||||||
if(tq & qFIELD) {
|
if(tq & qFIELD) {
|
||||||
worldsize = size(currfp.matrices) / ts;
|
worldsize = size(currfp.matrices) / ts;
|
||||||
if(!nonchamfered) worldsize = ((ts+tv)*worldsize) / tv;
|
if(!nonbitrunc) worldsize = ((ts+tv)*worldsize) / tv;
|
||||||
}
|
}
|
||||||
|
|
||||||
dialog::addSelItem(XLAT("sides per face"), its(ts), 0);
|
dialog::addSelItem(XLAT("sides per face"), its(ts), 0);
|
||||||
@ -341,7 +341,7 @@ void showEuclideanMenu() {
|
|||||||
torusconfig::newsdx = torusconfig::sdx,
|
torusconfig::newsdx = torusconfig::sdx,
|
||||||
torusconfig::newsdy = torusconfig::sdy,
|
torusconfig::newsdy = torusconfig::sdy,
|
||||||
torusconfig::newmode = torusconfig::torus_mode,
|
torusconfig::newmode = torusconfig::torus_mode,
|
||||||
torus_chamfer = nonchamfered,
|
torus_bitrunc = nonbitrunc,
|
||||||
pushScreen(showTorusConfig);
|
pushScreen(showTorusConfig);
|
||||||
if(quotient==2) pushScreen(showQuotientConfig);
|
if(quotient==2) pushScreen(showQuotientConfig);
|
||||||
}
|
}
|
||||||
@ -352,7 +352,7 @@ void showEuclideanMenu() {
|
|||||||
else {
|
else {
|
||||||
dialog::init(XLAT("experiment with geometry"));
|
dialog::init(XLAT("experiment with geometry"));
|
||||||
|
|
||||||
dialog::addSelItem(XLAT("geometry"), XLAT(ginf[geometry].name) + XLAT(chamfernames[nonchamfered]), '5');
|
dialog::addSelItem(XLAT("geometry"), XLAT(ginf[geometry].name) + XLAT(bitruncnames[nonbitrunc]), '5');
|
||||||
dialog::addBreak(50);
|
dialog::addBreak(50);
|
||||||
|
|
||||||
generateLandList(isLandValid);
|
generateLandList(isLandValid);
|
||||||
|
@ -53,7 +53,7 @@ void precalc() {
|
|||||||
// dynamicval<eGeometry> g(geometry, gNormal);
|
// dynamicval<eGeometry> g(geometry, gNormal);
|
||||||
// precalc(); }
|
// precalc(); }
|
||||||
// for(int i=0; i<S84; i++) spinmatrix[i] = spin(i * M_PI / S42);
|
// for(int i=0; i<S84; i++) spinmatrix[i] = spin(i * M_PI / S42);
|
||||||
if(a4 && nonchamfered) {
|
if(a4 && nonbitrunc) {
|
||||||
crossf = .5;
|
crossf = .5;
|
||||||
hexf = .5;
|
hexf = .5;
|
||||||
hcrossf = crossf * sqrt(2) / 2;
|
hcrossf = crossf * sqrt(2) / 2;
|
||||||
@ -119,7 +119,7 @@ void precalc() {
|
|||||||
else {
|
else {
|
||||||
hcrossf = hdist(xpush(tessf) * C0, spin(2*M_PI/S7) * xpush(tessf) * C0) / 2;
|
hcrossf = hdist(xpush(tessf) * C0, spin(2*M_PI/S7) * xpush(tessf) * C0) / 2;
|
||||||
}
|
}
|
||||||
crossf = nonchamfered ? tessf : hcrossf;
|
crossf = nonbitrunc ? tessf : hcrossf;
|
||||||
|
|
||||||
fmin = 0, fmax = tessf;
|
fmin = 0, fmax = tessf;
|
||||||
for(int p=0; p<100; p++) {
|
for(int p=0; p<100; p++) {
|
||||||
@ -132,9 +132,9 @@ void precalc() {
|
|||||||
}
|
}
|
||||||
hexf = fmin;
|
hexf = fmin;
|
||||||
|
|
||||||
rhexf = nonchamfered ? hcrossf : hexf;
|
rhexf = nonbitrunc ? hcrossf : hexf;
|
||||||
|
|
||||||
if(!euclid && !nonchamfered && !(S7&1))
|
if(!euclid && !nonbitrunc && !(S7&1))
|
||||||
hexshift = ALPHA/2 + ALPHA * ((S7-1)/2) + M_PI;
|
hexshift = ALPHA/2 + ALPHA * ((S7-1)/2) + M_PI;
|
||||||
|
|
||||||
finish:
|
finish:
|
||||||
|
56
graph.cpp
56
graph.cpp
@ -157,7 +157,7 @@ void drawSpeed(const transmatrix& V) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
int ctof(cell *c) {
|
int ctof(cell *c) {
|
||||||
if(nonchamfered) return 1;
|
if(nonbitrunc) return 1;
|
||||||
// if(euclid) return 0;
|
// if(euclid) return 0;
|
||||||
return ishept(c) ? 1 : 0;
|
return ishept(c) ? 1 : 0;
|
||||||
// c->type == 6 ? 0 : 1;
|
// c->type == 6 ? 0 : 1;
|
||||||
@ -238,8 +238,8 @@ int displaydir(cell *c, int d) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
double hexshiftat(cell *c) {
|
double hexshiftat(cell *c) {
|
||||||
if(ctof(c) && S7==6 && S3 == 4 && !nonchamfered) return hexshift + 2*M_PI/S7;
|
if(ctof(c) && S7==6 && S3 == 4 && !nonbitrunc) return hexshift + 2*M_PI/S7;
|
||||||
if(ctof(c) && (S7==8 || S7 == 4) && S3 == 3 && !nonchamfered) return hexshift + 2*M_PI/S7;
|
if(ctof(c) && (S7==8 || S7 == 4) && S3 == 3 && !nonbitrunc) return hexshift + 2*M_PI/S7;
|
||||||
if(hexshift && ctof(c)) return hexshift;
|
if(hexshift && ctof(c)) return hexshift;
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
@ -291,11 +291,11 @@ void drawPlayerEffects(const transmatrix& V, cell *c, bool onplayer) {
|
|||||||
if(!euclid) for(int a=0; a<S42; a++) {
|
if(!euclid) for(int a=0; a<S42; a++) {
|
||||||
int dda = S42 + (-1-2*a);
|
int dda = S42 + (-1-2*a);
|
||||||
if(a == ang && items[itOrbSword]) continue;
|
if(a == ang && items[itOrbSword]) continue;
|
||||||
if(nonchamfered && a%3 != ang%3) continue;
|
if(nonbitrunc && a%3 != ang%3) continue;
|
||||||
if((a+S21)%S42 == ang && items[itOrbSword2]) continue;
|
if((a+S21)%S42 == ang && items[itOrbSword2]) continue;
|
||||||
bool longer = sword::pos(cwt.c, a-1) != sword::pos(cwt.c, a+1);
|
bool longer = sword::pos(cwt.c, a-1) != sword::pos(cwt.c, a+1);
|
||||||
int col = darkena(0xC0C0C0, 0, 0xFF);
|
int col = darkena(0xC0C0C0, 0, 0xFF);
|
||||||
queueline(Vnow*ddi0(dda, nonchamfered ? 0.6 : longer ? 0.36 : 0.4), Vnow*ddi0(dda, nonchamfered ? 0.7 : longer ? 0.44 : 0.42), col, 1);
|
queueline(Vnow*ddi0(dda, nonbitrunc ? 0.6 : longer ? 0.36 : 0.4), Vnow*ddi0(dda, nonbitrunc ? 0.7 : longer ? 0.44 : 0.42), col, 1);
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -2289,7 +2289,7 @@ void drawTowerFloor(const transmatrix& V, cell *c, int col, cellfunction *cf = c
|
|||||||
if(i == 9) j = 4;
|
if(i == 9) j = 4;
|
||||||
if(i == 10) j = 5;
|
if(i == 10) j = 5;
|
||||||
if(i == 13) j = 6;
|
if(i == 13) j = 6;
|
||||||
if(nonchamfered) {
|
if(nonbitrunc) {
|
||||||
if(i == 7) j = 7;
|
if(i == 7) j = 7;
|
||||||
if(i == 11) j = 8;
|
if(i == 11) j = 8;
|
||||||
if(i == 15) j = 9;
|
if(i == 15) j = 9;
|
||||||
@ -2313,7 +2313,7 @@ void drawZebraFloor(const transmatrix& V, cell *c, int col) {
|
|||||||
auto si = patterns::getpatterninfo(c, 'z', patterns::SPF_SYM0123);
|
auto si = patterns::getpatterninfo(c, 'z', patterns::SPF_SYM0123);
|
||||||
|
|
||||||
int j;
|
int j;
|
||||||
if(nonchamfered) j = 4;
|
if(nonbitrunc) j = 4;
|
||||||
else if(si.id >=4 && si.id < 16) j = 2;
|
else if(si.id >=4 && si.id < 16) j = 2;
|
||||||
else if(si.id >= 16 && si.id < 28) j = 1;
|
else if(si.id >= 16 && si.id < 28) j = 1;
|
||||||
else if(si.id >= 28 && si.id < 40) j = 3;
|
else if(si.id >= 28 && si.id < 40) j = 3;
|
||||||
@ -2335,7 +2335,7 @@ void drawReptileFloor(const transmatrix& V, cell *c, int col, bool usefloor) {
|
|||||||
int j;
|
int j;
|
||||||
|
|
||||||
if(!wmescher) j = 4;
|
if(!wmescher) j = 4;
|
||||||
else if(nonchamfered) j = 0;
|
else if(nonbitrunc) j = 0;
|
||||||
else if(si.id < 4) j = 0;
|
else if(si.id < 4) j = 0;
|
||||||
else if(si.id >=4 && si.id < 16) j = 1;
|
else if(si.id >=4 && si.id < 16) j = 1;
|
||||||
else if(si.id >= 16 && si.id < 28) j = 2;
|
else if(si.id >= 16 && si.id < 28) j = 2;
|
||||||
@ -2393,7 +2393,7 @@ void drawReptileFloor(const transmatrix& V, cell *c, int col, bool usefloor) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
void drawEmeraldFloor(const transmatrix& V, cell *c, int col) {
|
void drawEmeraldFloor(const transmatrix& V, cell *c, int col) {
|
||||||
if(!euclid && !nonchamfered) {
|
if(!euclid && !nonbitrunc) {
|
||||||
auto si = patterns::getpatterninfo(c, 'f', patterns::SPF_SYM0123);
|
auto si = patterns::getpatterninfo(c, 'f', patterns::SPF_SYM0123);
|
||||||
|
|
||||||
int j = -1;
|
int j = -1;
|
||||||
@ -2933,7 +2933,7 @@ bool noAdjacentChasms(cell *c) {
|
|||||||
void floorShadow(cell *c, const transmatrix& V, int col, bool warp) {
|
void floorShadow(cell *c, const transmatrix& V, int col, bool warp) {
|
||||||
if(pmodel == mdHyperboloid || pmodel == mdBall)
|
if(pmodel == mdHyperboloid || pmodel == mdBall)
|
||||||
return; // shadows break the depth testing
|
return; // shadows break the depth testing
|
||||||
if(shmup::on || nonchamfered) warp = false;
|
if(shmup::on || nonbitrunc) warp = false;
|
||||||
dynamicval<int> p(poly_outline, OUTLINE_TRANS);
|
dynamicval<int> p(poly_outline, OUTLINE_TRANS);
|
||||||
if(wmescher && qfi.special) {
|
if(wmescher && qfi.special) {
|
||||||
queuepolyat(V * qfi.spin * shadowmulmatrix, *qfi.shape, col, PPR_WALLSHADOW);
|
queuepolyat(V * qfi.spin * shadowmulmatrix, *qfi.shape, col, PPR_WALLSHADOW);
|
||||||
@ -2950,7 +2950,7 @@ void floorShadow(cell *c, const transmatrix& V, int col, bool warp) {
|
|||||||
queuepolyat(V * applyPatterndir(c, si), shTriheptaFloorShadow[ctof(c)], col, PPR_WALLSHADOW);
|
queuepolyat(V * applyPatterndir(c, si), shTriheptaFloorShadow[ctof(c)], col, PPR_WALLSHADOW);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else if(c->land == laDual && !nonchamfered) {
|
else if(c->land == laDual && !nonbitrunc) {
|
||||||
if(euclid && !a4 && ishex1(c))
|
if(euclid && !a4 && ishex1(c))
|
||||||
queuepolyat(V * pispin, shBigTriShadow, col, PPR_WALLSHADOW);
|
queuepolyat(V * pispin, shBigTriShadow, col, PPR_WALLSHADOW);
|
||||||
else
|
else
|
||||||
@ -2974,7 +2974,7 @@ void plainfloor(cell *c, bool warp, const transmatrix &V, int col, int prio) {
|
|||||||
queuepolyat(V * applyPatterndir(c, si), shTriheptaFloor[sphere ? ctof(c) : si.id], col, prio);
|
queuepolyat(V * applyPatterndir(c, si), shTriheptaFloor[sphere ? ctof(c) : si.id], col, prio);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else if(c->land == laDual && !nonchamfered) {
|
else if(c->land == laDual && !nonbitrunc) {
|
||||||
if(euclid && !a4 && ishex1(c))
|
if(euclid && !a4 && ishex1(c))
|
||||||
queuepolyat(V * pispin, shBigTriangle, col, prio);
|
queuepolyat(V * pispin, shBigTriangle, col, prio);
|
||||||
else
|
else
|
||||||
@ -2992,7 +2992,7 @@ void qplainfloor(cell *c, bool warp, const transmatrix &V, int col) {
|
|||||||
auto si = patterns::getpatterninfo(c, 0, 0);
|
auto si = patterns::getpatterninfo(c, 0, 0);
|
||||||
qfloor(c, V, applyPatterndir(c, si), shTriheptaFloor[si.id], col);
|
qfloor(c, V, applyPatterndir(c, si), shTriheptaFloor[si.id], col);
|
||||||
}
|
}
|
||||||
else if(c->land == laDual && !nonchamfered)
|
else if(c->land == laDual && !nonbitrunc)
|
||||||
qfloor_eswap(c, V, shBigTriangle, col);
|
qfloor_eswap(c, V, shBigTriangle, col);
|
||||||
else {
|
else {
|
||||||
qfloor(c, V, shFloor[ctof(c)], col);
|
qfloor(c, V, shFloor[ctof(c)], col);
|
||||||
@ -3002,7 +3002,7 @@ void qplainfloor(cell *c, bool warp, const transmatrix &V, int col) {
|
|||||||
int wavephase;
|
int wavephase;
|
||||||
|
|
||||||
void warpfloor(cell *c, const transmatrix& V, int col, int prio, bool warp) {
|
void warpfloor(cell *c, const transmatrix& V, int col, int prio, bool warp) {
|
||||||
if(shmup::on || nonchamfered) warp = false;
|
if(shmup::on || nonbitrunc) warp = false;
|
||||||
#if CAP_TEXTURE
|
#if CAP_TEXTURE
|
||||||
if(qfi.tinf) {
|
if(qfi.tinf) {
|
||||||
queuetable(V*qfi.spin, &qfi.tinf->vertices[0], size(qfi.tinf->vertices) / 3, 0, texture::recolor(col), prio);
|
queuetable(V*qfi.spin, &qfi.tinf->vertices[0], size(qfi.tinf->vertices) / 3, 0, texture::recolor(col), prio);
|
||||||
@ -3054,9 +3054,9 @@ void escherSidewall(cell *c, int sidepar, const transmatrix& V, int col) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
void placeSidewall(cell *c, int i, int sidepar, const transmatrix& V, bool warp, bool mirr, int col) {
|
void placeSidewall(cell *c, int i, int sidepar, const transmatrix& V, bool warp, bool mirr, int col) {
|
||||||
if(shmup::on || nonchamfered) warp = false;
|
if(shmup::on || nonbitrunc) warp = false;
|
||||||
if(warp && !ishept(c) && (!c->mov[i] || !ishept(c->mov[i]))) return;
|
if(warp && !ishept(c) && (!c->mov[i] || !ishept(c->mov[i]))) return;
|
||||||
if(c->land == laDual && !nonchamfered) {
|
if(c->land == laDual && !nonbitrunc) {
|
||||||
if(ctof(c)) return;
|
if(ctof(c)) return;
|
||||||
if((euclid && !a4) ? (ishex1(c) ? !(i&1) : (i&1)) : !(i&1)) return;
|
if((euclid && !a4) ? (ishex1(c) ? !(i&1) : (i&1)) : !(i&1)) return;
|
||||||
}
|
}
|
||||||
@ -3081,7 +3081,7 @@ void placeSidewall(cell *c, int i, int sidepar, const transmatrix& V, bool warp,
|
|||||||
// prio += c->cpdist - c->mov[i]->cpdist;
|
// prio += c->cpdist - c->mov[i]->cpdist;
|
||||||
|
|
||||||
queuepolyat(V2,
|
queuepolyat(V2,
|
||||||
(qfi.tinf?shFullFloorSide:mirr?shMFloorSide:warp?shTriheptaSide:(c->land == laDual&&!nonchamfered)?shBigTriSide:shFloorSide)[sidepar][ctof(c)], col, prio);
|
(qfi.tinf?shFullFloorSide:mirr?shMFloorSide:warp?shTriheptaSide:(c->land == laDual&&!nonbitrunc)?shBigTriSide:shFloorSide)[sidepar][ctof(c)], col, prio);
|
||||||
}
|
}
|
||||||
|
|
||||||
bool openorsafe(cell *c) {
|
bool openorsafe(cell *c) {
|
||||||
@ -3609,7 +3609,7 @@ void drawcell(cell *c, transmatrix V, int spinv, bool mirrored) {
|
|||||||
auto si = patterns::getpatterninfo0(c);
|
auto si = patterns::getpatterninfo0(c);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
bool eoh = euclid || nonchamfered;
|
bool eoh = euclid || nonbitrunc;
|
||||||
|
|
||||||
if(c->wall == waChasm) {
|
if(c->wall == waChasm) {
|
||||||
if(c->land == laZebra) fd++;
|
if(c->land == laZebra) fd++;
|
||||||
@ -3655,7 +3655,7 @@ void drawcell(cell *c, transmatrix V, int spinv, bool mirrored) {
|
|||||||
onleft = !onleft;
|
onleft = !onleft;
|
||||||
if(c->type == 6 && c->mov[d]->barleft == laMirror)
|
if(c->type == 6 && c->mov[d]->barleft == laMirror)
|
||||||
onleft = !onleft;
|
onleft = !onleft;
|
||||||
if(nonchamfered) onleft = !onleft;
|
if(nonbitrunc) onleft = !onleft;
|
||||||
|
|
||||||
if(d == -1) {
|
if(d == -1) {
|
||||||
for(d=0; d<6; d++)
|
for(d=0; d<6; d++)
|
||||||
@ -3775,11 +3775,11 @@ void drawcell(cell *c, transmatrix V, int spinv, bool mirrored) {
|
|||||||
else if(isWarped(c) && euclid)
|
else if(isWarped(c) && euclid)
|
||||||
qfloor_eswap(c, Vf, shTriheptaFloor[ctof(c)], darkena(fcol, fd, 0xFF));
|
qfloor_eswap(c, Vf, shTriheptaFloor[ctof(c)], darkena(fcol, fd, 0xFF));
|
||||||
|
|
||||||
else if(c->land == laDual && !nonchamfered && !ctof(c)) {
|
else if(c->land == laDual && !nonbitrunc && !ctof(c)) {
|
||||||
qfloor_eswap(c, Vf, shBigTriangle, darkena(fcol, fd, 0xFF));
|
qfloor_eswap(c, Vf, shBigTriangle, darkena(fcol, fd, 0xFF));
|
||||||
}
|
}
|
||||||
|
|
||||||
else if(isWarped(c) && !nonchamfered && !shmup::on) {
|
else if(isWarped(c) && !nonbitrunc && !shmup::on) {
|
||||||
auto si = patterns::getpatterninfo(c, 0, 0);
|
auto si = patterns::getpatterninfo(c, 0, 0);
|
||||||
if(si.id < 13)
|
if(si.id < 13)
|
||||||
qfloor(c, Vf, applyPatterndir(c, si), shTriheptaFloor[si.id], darkena(fcol, fd, 0xFF));
|
qfloor(c, Vf, applyPatterndir(c, si), shTriheptaFloor[si.id], darkena(fcol, fd, 0xFF));
|
||||||
@ -3874,7 +3874,7 @@ void drawcell(cell *c, transmatrix V, int spinv, bool mirrored) {
|
|||||||
else if(c->land == laTortoise)
|
else if(c->land == laTortoise)
|
||||||
qfloor_eswap(c, Vf, TURTLEFLOOR, darkena(fcol, fd, 0xFF));
|
qfloor_eswap(c, Vf, TURTLEFLOOR, darkena(fcol, fd, 0xFF));
|
||||||
|
|
||||||
else if(c->land == laDragon && !nonchamfered) {
|
else if(c->land == laDragon && !nonbitrunc) {
|
||||||
/* if(!wmspatial || noAdjacentChasms(c)) */
|
/* if(!wmspatial || noAdjacentChasms(c)) */
|
||||||
qfloor(c, Vf, DRAGONFLOOR, darkena(fcol, fd, 0xFF));
|
qfloor(c, Vf, DRAGONFLOOR, darkena(fcol, fd, 0xFF));
|
||||||
/* if(wmspatial)
|
/* if(wmspatial)
|
||||||
@ -4063,7 +4063,7 @@ void drawcell(cell *c, transmatrix V, int spinv, bool mirrored) {
|
|||||||
if(pseudohept(c) && (
|
if(pseudohept(c) && (
|
||||||
c->land == laRedRock ||
|
c->land == laRedRock ||
|
||||||
vid.darkhepta ||
|
vid.darkhepta ||
|
||||||
(c->land == laClearing && nonchamfered))) {
|
(c->land == laClearing && nonbitrunc))) {
|
||||||
queuepoly((*Vdp), shHeptaMarker, wmblack ? 0x80808080 : 0x00000080);
|
queuepoly((*Vdp), shHeptaMarker, wmblack ? 0x80808080 : 0x00000080);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -4548,7 +4548,7 @@ void drawcell(cell *c, transmatrix V, int spinv, bool mirrored) {
|
|||||||
calcAirdir(c2); // printf("airdir = %d\n", airdir);
|
calcAirdir(c2); // printf("airdir = %d\n", airdir);
|
||||||
transmatrix V0 = ddspin(c, i, S42);
|
transmatrix V0 = ddspin(c, i, S42);
|
||||||
|
|
||||||
double ph = ticks / (nonchamfered?150:75.0) + airdir * M_PI / (S21+.0);
|
double ph = ticks / (nonbitrunc?150:75.0) + airdir * M_PI / (S21+.0);
|
||||||
|
|
||||||
int aircol = 0x8080FF00 | int(32 + 32 * -cos(ph));
|
int aircol = 0x8080FF00 | int(32 + 32 * -cos(ph));
|
||||||
|
|
||||||
@ -4593,7 +4593,7 @@ void drawcell(cell *c, transmatrix V, int spinv, bool mirrored) {
|
|||||||
|
|
||||||
transmatrix V0 = spin((hdir) * M_PI / S42);
|
transmatrix V0 = spin((hdir) * M_PI / S42);
|
||||||
|
|
||||||
double ldist = nonchamfered ? crossf : c->type == 6 ? .2840 : 0.3399;
|
double ldist = nonbitrunc ? crossf : c->type == 6 ? .2840 : 0.3399;
|
||||||
|
|
||||||
poly_outline = OUTLINE_TRANS;
|
poly_outline = OUTLINE_TRANS;
|
||||||
queuepoly((*Vdp)*V0*xpush(ldist*(2*ph1-1)), shDisk, aircol);
|
queuepoly((*Vdp)*V0*xpush(ldist*(2*ph1-1)), shDisk, aircol);
|
||||||
@ -4618,7 +4618,7 @@ void drawcell(cell *c, transmatrix V, int spinv, bool mirrored) {
|
|||||||
|
|
||||||
int prec = sphere ? 3 : 1;
|
int prec = sphere ? 3 : 1;
|
||||||
|
|
||||||
if(nonchamfered) {
|
if(nonbitrunc) {
|
||||||
double x = hcrossf;
|
double x = hcrossf;
|
||||||
for(int t=0; t<S7; t++)
|
for(int t=0; t<S7; t++)
|
||||||
if(c->mov[t] && c->mov[t] < c)
|
if(c->mov[t] && c->mov[t] < c)
|
||||||
@ -5017,7 +5017,7 @@ void drawthemap() {
|
|||||||
mmspatial = vid.monmode == 4 || vid.monmode == 5;
|
mmspatial = vid.monmode == 4 || vid.monmode == 5;
|
||||||
|
|
||||||
DEBB(DF_GRAPH, (debugfile,"draw the map\n"));
|
DEBB(DF_GRAPH, (debugfile,"draw the map\n"));
|
||||||
fanframe = ticks / (nonchamfered ? 300 : 150.0) / M_PI;
|
fanframe = ticks / (nonbitrunc ? 300 : 150.0) / M_PI;
|
||||||
|
|
||||||
for(int m=0; m<motypes; m++) if(isPrincess(eMonster(m)))
|
for(int m=0; m<motypes; m++) if(isPrincess(eMonster(m)))
|
||||||
minf[m].name = princessgender() ? "Princess" : "Prince";
|
minf[m].name = princessgender() ? "Princess" : "Prince";
|
||||||
@ -5624,6 +5624,6 @@ cell *viewcenter() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
bool inscreenrange(cell *c) {
|
bool inscreenrange(cell *c) {
|
||||||
return celldistance(viewcenter(), c) <= (euclid ? sightrange : nonchamfered ? 9 : 13);
|
return celldistance(viewcenter(), c) <= (euclid ? sightrange : nonbitrunc ? 9 : 13);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
2
help.cpp
2
help.cpp
@ -347,7 +347,7 @@ string generateHelpForWall(eWall w) {
|
|||||||
if(w == waMineMine || w == waMineUnknown || w == waMineOpen)
|
if(w == waMineMine || w == waMineUnknown || w == waMineOpen)
|
||||||
addMinefieldExplanation(s);
|
addMinefieldExplanation(s);
|
||||||
if(isThumper(w)) s += pushtext(w);
|
if(isThumper(w)) s += pushtext(w);
|
||||||
if((w == waClosePlate || w == waOpenPlate) && nonchamfered)
|
if((w == waClosePlate || w == waOpenPlate) && nonbitrunc)
|
||||||
s += "\n\n(For the heptagonal mode, the radius has been reduced to 2 for closing plates.)";
|
s += "\n\n(For the heptagonal mode, the radius has been reduced to 2 for closing plates.)";
|
||||||
return s;
|
return s;
|
||||||
}
|
}
|
||||||
|
@ -95,7 +95,7 @@ heptagon *buildHeptagon(heptagon *parent, int d, hstate s, int pard = 0, int fix
|
|||||||
if(pard == 0) {
|
if(pard == 0) {
|
||||||
h->dm4 = parent->dm4+1;
|
h->dm4 = parent->dm4+1;
|
||||||
if(fixdistance != COMPUTE) h->distance = fixdistance;
|
if(fixdistance != COMPUTE) h->distance = fixdistance;
|
||||||
else if(nonchamfered) h->distance = parent->distance + 1;
|
else if(nonbitrunc) h->distance = parent->distance + 1;
|
||||||
else if(parent->s == hsOrigin) h->distance = parent->distance + 2;
|
else if(parent->s == hsOrigin) h->distance = parent->distance + 2;
|
||||||
else if(S3 == 4) {
|
else if(S3 == 4) {
|
||||||
h->distance = parent->distance + 2;
|
h->distance = parent->distance + 2;
|
||||||
@ -127,7 +127,7 @@ heptagon *buildHeptagon(heptagon *parent, int d, hstate s, int pard = 0, int fix
|
|||||||
else h->distance = parent->distance + 2;
|
else h->distance = parent->distance + 2;
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
h->distance = parent->distance - (nonchamfered?1:2);
|
h->distance = parent->distance - (nonbitrunc?1:2);
|
||||||
if(S3 == 4 && S7 == 5) {
|
if(S3 == 4 && S7 == 5) {
|
||||||
if(h->s == hsOrigin) {
|
if(h->s == hsOrigin) {
|
||||||
printf("had to cheat!\n");
|
printf("had to cheat!\n");
|
||||||
|
8
hud.cpp
8
hud.cpp
@ -343,21 +343,21 @@ void drawStats() {
|
|||||||
if(d >= 0 && d < 64) qty[d]++;
|
if(d >= 0 && d < 64) qty[d]++;
|
||||||
}
|
}
|
||||||
if(geometry == gNormal)
|
if(geometry == gNormal)
|
||||||
for(int i=nonchamfered?6:8; i<=15; i++)
|
for(int i=nonbitrunc?6:8; i<=15; i++)
|
||||||
qty[i] =
|
qty[i] =
|
||||||
nonchamfered ?
|
nonbitrunc ?
|
||||||
3*qty[i-1] - qty[i-2]
|
3*qty[i-1] - qty[i-2]
|
||||||
: qty[i-1] + qty[i-2] + qty[i-3] - qty[i-4];
|
: qty[i-1] + qty[i-2] + qty[i-3] - qty[i-4];
|
||||||
if(geometry == gEuclid)
|
if(geometry == gEuclid)
|
||||||
for(int i=8; i<=15; i++) qty[i] = 6*i;
|
for(int i=8; i<=15; i++) qty[i] = 6*i;
|
||||||
for(int i=0; i<64; i++) if(qty[i])
|
for(int i=0; i<64; i++) if(qty[i])
|
||||||
dialog::addInfo(its(qty[i]), distcolors[i&7]);
|
dialog::addInfo(its(qty[i]), distcolors[i&7]);
|
||||||
if(geometry == gNormal && !nonchamfered) {
|
if(geometry == gNormal && !nonbitrunc) {
|
||||||
dialog::addBreak(200);
|
dialog::addBreak(200);
|
||||||
dialog::addHelp("a(d+4) = a(d+3) + a(d+2) + a(d+1) - a(d)");
|
dialog::addHelp("a(d+4) = a(d+3) + a(d+2) + a(d+1) - a(d)");
|
||||||
dialog::addInfo("a(d) ~ 1.72208ᵈ", forecolor);
|
dialog::addInfo("a(d) ~ 1.72208ᵈ", forecolor);
|
||||||
}
|
}
|
||||||
if(geometry == gNormal && nonchamfered) {
|
if(geometry == gNormal && nonbitrunc) {
|
||||||
dialog::addBreak(200);
|
dialog::addBreak(200);
|
||||||
dialog::addHelp("a(d+2) = 3a(d+1) - a(d+2)");
|
dialog::addHelp("a(d+2) = 3a(d+1) - a(d+2)");
|
||||||
dialog::addInfo("a(d) ~ 2.61803ᵈ", forecolor);
|
dialog::addInfo("a(d) ~ 2.61803ᵈ", forecolor);
|
||||||
|
8
hyper.h
8
hyper.h
@ -1201,7 +1201,7 @@ void checkStunKill(cell *dest);
|
|||||||
void clearMessages();
|
void clearMessages();
|
||||||
|
|
||||||
void resetGeometry();
|
void resetGeometry();
|
||||||
extern bool nonchamfered;
|
extern bool nonbitrunc;
|
||||||
|
|
||||||
namespace svg {
|
namespace svg {
|
||||||
void circle(int x, int y, int size, int col);
|
void circle(int x, int y, int size, int col);
|
||||||
@ -2191,13 +2191,13 @@ struct hrmap {
|
|||||||
|
|
||||||
struct hrmap_hyperbolic : hrmap {
|
struct hrmap_hyperbolic : hrmap {
|
||||||
heptagon *origin;
|
heptagon *origin;
|
||||||
bool isnonchamfered;
|
bool isnonbitrunc;
|
||||||
hrmap_hyperbolic();
|
hrmap_hyperbolic();
|
||||||
heptagon *getOrigin() { return origin; }
|
heptagon *getOrigin() { return origin; }
|
||||||
~hrmap_hyperbolic() {
|
~hrmap_hyperbolic() {
|
||||||
DEBMEM ( verifycells(origin); )
|
DEBMEM ( verifycells(origin); )
|
||||||
// printf("Deleting hyperbolic map: %p\n", this);
|
// printf("Deleting hyperbolic map: %p\n", this);
|
||||||
dynamicval<bool> ph(nonchamfered, isnonchamfered);
|
dynamicval<bool> ph(nonbitrunc, isnonbitrunc);
|
||||||
clearfrom(origin);
|
clearfrom(origin);
|
||||||
}
|
}
|
||||||
void verify() { verifycells(origin); }
|
void verify() { verifycells(origin); }
|
||||||
@ -2431,7 +2431,7 @@ inline hyperpoint tC0(const transmatrix &T) {
|
|||||||
transmatrix actualV(const heptspin& hs, const transmatrix& V);
|
transmatrix actualV(const heptspin& hs, const transmatrix& V);
|
||||||
transmatrix cview();
|
transmatrix cview();
|
||||||
|
|
||||||
extern string chamfernames[2];
|
extern string bitruncnames[2];
|
||||||
extern bool need_mouseh;
|
extern bool need_mouseh;
|
||||||
|
|
||||||
extern int whateveri, whateveri2;
|
extern int whateveri, whateveri2;
|
||||||
|
@ -4,7 +4,7 @@
|
|||||||
eGeometry geometry, targetgeometry;
|
eGeometry geometry, targetgeometry;
|
||||||
|
|
||||||
// for the pure heptagonal grid
|
// for the pure heptagonal grid
|
||||||
bool nonchamfered = false;
|
bool nonbitrunc = false;
|
||||||
|
|
||||||
// hyperbolic points and matrices
|
// hyperbolic points and matrices
|
||||||
|
|
||||||
|
@ -330,7 +330,7 @@ bool confusingGeometry() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
transmatrix actualV(const heptspin& hs, const transmatrix& V) {
|
transmatrix actualV(const heptspin& hs, const transmatrix& V) {
|
||||||
return (hs.spin || nonchamfered) ? V * spin(hs.spin*2*M_PI/S7 + (nonchamfered ? M_PI:0)) : V;
|
return (hs.spin || nonbitrunc) ? V * spin(hs.spin*2*M_PI/S7 + (nonbitrunc ? M_PI:0)) : V;
|
||||||
}
|
}
|
||||||
|
|
||||||
void drawrec(const heptspin& hs, int lev, hstate s, const transmatrix& V) {
|
void drawrec(const heptspin& hs, int lev, hstate s, const transmatrix& V) {
|
||||||
@ -349,7 +349,7 @@ void drawrec(const heptspin& hs, int lev, hstate s, const transmatrix& V) {
|
|||||||
|
|
||||||
if(lev <= 0) return;
|
if(lev <= 0) return;
|
||||||
|
|
||||||
if(!nonchamfered) for(int d=0; d<S7; d++) {
|
if(!nonbitrunc) for(int d=0; d<S7; d++) {
|
||||||
int ds = fixrot(hs.spin + d);
|
int ds = fixrot(hs.spin + d);
|
||||||
reclevel = maxreclevel - lev + 1;
|
reclevel = maxreclevel - lev + 1;
|
||||||
// createMov(c, ds);
|
// createMov(c, ds);
|
||||||
|
2
init.cpp
2
init.cpp
@ -378,7 +378,7 @@ void addMessage(string s, char spamtype = 0);
|
|||||||
#define stdeuc (geometry == gNormal || geometry == gEuclid || geometry == gEuclidSquare)
|
#define stdeuc (geometry == gNormal || geometry == gEuclid || geometry == gEuclidSquare)
|
||||||
#define smallsphere (S7 < 5)
|
#define smallsphere (S7 < 5)
|
||||||
#define bigsphere (S7 == 5)
|
#define bigsphere (S7 == 5)
|
||||||
#define ap4 (a4 && nonchamfered)
|
#define ap4 (a4 && nonbitrunc)
|
||||||
#define euclid4 (euclid && a4)
|
#define euclid4 (euclid && a4)
|
||||||
#define euclid6 (euclid && !a4)
|
#define euclid6 (euclid && !a4)
|
||||||
|
|
||||||
|
@ -532,7 +532,7 @@ void sominit(int initto) {
|
|||||||
targetGeometry = gQuotient1;
|
targetGeometry = gQuotient1;
|
||||||
restartGame('g');
|
restartGame('g');
|
||||||
}
|
}
|
||||||
if(!nonchamfered) restartGame('7'); */
|
if(!nonbitrunc) restartGame('7'); */
|
||||||
|
|
||||||
printf("Initializing SOM (1)\n");
|
printf("Initializing SOM (1)\n");
|
||||||
|
|
||||||
|
48
landgen.cpp
48
landgen.cpp
@ -186,7 +186,7 @@ void giantLandSwitch(cell *c, int d, cell *from) {
|
|||||||
if(gs == 1)
|
if(gs == 1)
|
||||||
c->wall = waPalace;
|
c->wall = waPalace;
|
||||||
if(gs == 3)
|
if(gs == 3)
|
||||||
c->wall = nonchamfered ? waOpenGate : waClosedGate;
|
c->wall = nonbitrunc ? waOpenGate : waClosedGate;
|
||||||
if(gs == 4 && hrand(100) < 40)
|
if(gs == 4 && hrand(100) < 40)
|
||||||
c->wall = waClosePlate;
|
c->wall = waClosePlate;
|
||||||
if(gs == 6)
|
if(gs == 6)
|
||||||
@ -203,7 +203,7 @@ void giantLandSwitch(cell *c, int d, cell *from) {
|
|||||||
bool lookingForPrincess = !euclid && c->master->alt && !princess::challenge;
|
bool lookingForPrincess = !euclid && c->master->alt && !princess::challenge;
|
||||||
|
|
||||||
bool pgate = false;
|
bool pgate = false;
|
||||||
if(nonchamfered) {
|
if(nonbitrunc) {
|
||||||
int i = fiftyval049(c);
|
int i = fiftyval049(c);
|
||||||
if(i >= 8 && i <= 14 && !polarb50(c)) pgate = true;
|
if(i >= 8 && i <= 14 && !polarb50(c)) pgate = true;
|
||||||
}
|
}
|
||||||
@ -239,9 +239,9 @@ void giantLandSwitch(cell *c, int d, cell *from) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else if((hrand(100) < (lookingForPrincess ? (nonchamfered ? 11 : 7) : 5) && cdist50(c)) ||
|
else if((hrand(100) < (lookingForPrincess ? (nonbitrunc ? 11 : 7) : 5) && cdist50(c)) ||
|
||||||
(cdist50(c) == 0 && polarb50(c) && hrand(100) < 60)) {
|
(cdist50(c) == 0 && polarb50(c) && hrand(100) < 60)) {
|
||||||
c->wall = hrand(100) < (lookingForPrincess ? (nonchamfered ? 25 : 30):50) ? waClosePlate : waOpenPlate;
|
c->wall = hrand(100) < (lookingForPrincess ? (nonbitrunc ? 25 : 30):50) ? waClosePlate : waOpenPlate;
|
||||||
}
|
}
|
||||||
else if(hrand(100) < (lookingForPrincess ? 3 : 5))
|
else if(hrand(100) < (lookingForPrincess ? 3 : 5))
|
||||||
c->wall = waTrapdoor;
|
c->wall = waTrapdoor;
|
||||||
@ -256,9 +256,9 @@ void giantLandSwitch(cell *c, int d, cell *from) {
|
|||||||
|
|
||||||
if(princess::generating) {
|
if(princess::generating) {
|
||||||
// no Opening Plates nearby
|
// no Opening Plates nearby
|
||||||
if(d <= 7 && c->wall == waOpenPlate && !nonchamfered)
|
if(d <= 7 && c->wall == waOpenPlate && !nonbitrunc)
|
||||||
c->wall = waNone;
|
c->wall = waNone;
|
||||||
if(d <= 7 && c->wall == waClosePlate && nonchamfered)
|
if(d <= 7 && c->wall == waClosePlate && nonbitrunc)
|
||||||
c->wall = waOpenPlate;
|
c->wall = waOpenPlate;
|
||||||
// no monsters nearby
|
// no monsters nearby
|
||||||
if(d>0) c->monst = moNone;
|
if(d>0) c->monst = moNone;
|
||||||
@ -357,7 +357,7 @@ void giantLandSwitch(cell *c, int d, cell *from) {
|
|||||||
c->wall = waCavewall;
|
c->wall = waCavewall;
|
||||||
else c->wall = waCavefloor;
|
else c->wall = waCavefloor;
|
||||||
}
|
}
|
||||||
else if(nonchamfered) {
|
else if(nonbitrunc) {
|
||||||
if(polarb50(c))
|
if(polarb50(c))
|
||||||
c->wall = waCavewall;
|
c->wall = waCavewall;
|
||||||
else c->wall = waCavefloor;
|
else c->wall = waCavefloor;
|
||||||
@ -378,7 +378,7 @@ void giantLandSwitch(cell *c, int d, cell *from) {
|
|||||||
c->monst = moSeep;
|
c->monst = moSeep;
|
||||||
|
|
||||||
ONEMPTY {
|
ONEMPTY {
|
||||||
if(hrand(nonchamfered?400:1000) < PT(100 + 2 * (kills[moMiner] + kills[moLancer] + kills[moFlailer]), 200) && notDippingFor(itEmerald)) {
|
if(hrand(nonbitrunc?400:1000) < PT(100 + 2 * (kills[moMiner] + kills[moLancer] + kills[moFlailer]), 200) && notDippingFor(itEmerald)) {
|
||||||
// do not destroy walls!
|
// do not destroy walls!
|
||||||
bool ok = true;
|
bool ok = true;
|
||||||
for(int i=0; i<c->type; i++) if(c->mov[i]->wall == waCavewall) ok = false;
|
for(int i=0; i<c->type; i++) if(c->mov[i]->wall == waCavewall) ok = false;
|
||||||
@ -977,7 +977,7 @@ void giantLandSwitch(cell *c, int d, cell *from) {
|
|||||||
|
|
||||||
case laHalloween:
|
case laHalloween:
|
||||||
if(d == 9) {
|
if(d == 9) {
|
||||||
if(nonchamfered) {
|
if(nonbitrunc) {
|
||||||
int fv = c->master->fiftyval;
|
int fv = c->master->fiftyval;
|
||||||
if(fv == 1 || fv == 4 || fv == 2)
|
if(fv == 1 || fv == 4 || fv == 2)
|
||||||
c->wall = waChasm;
|
c->wall = waChasm;
|
||||||
@ -1086,7 +1086,7 @@ void giantLandSwitch(cell *c, int d, cell *from) {
|
|||||||
if(ctof(c)) {
|
if(ctof(c)) {
|
||||||
int id = c->master->fiftyval;
|
int id = c->master->fiftyval;
|
||||||
if(id == 1) c->wall = waCharged;
|
if(id == 1) c->wall = waCharged;
|
||||||
if(id == (elliptic && !nonchamfered ? 3 : 9)) c->wall = waGrounded;
|
if(id == (elliptic && !nonbitrunc ? 3 : 9)) c->wall = waGrounded;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else if(S7 == 4) {
|
else if(S7 == 4) {
|
||||||
@ -1108,7 +1108,7 @@ void giantLandSwitch(cell *c, int d, cell *from) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else if(nonchamfered) {
|
else if(nonbitrunc) {
|
||||||
int i = zebra40(c);
|
int i = zebra40(c);
|
||||||
if((i == 5 || i == 8) && hrand(100) < 20) c->wall = hrand(2) ? waCharged : waGrounded;
|
if((i == 5 || i == 8) && hrand(100) < 20) c->wall = hrand(2) ? waCharged : waGrounded;
|
||||||
else if(i == 15) c->wall = waSandstone;
|
else if(i == 15) c->wall = waSandstone;
|
||||||
@ -1232,7 +1232,7 @@ void giantLandSwitch(cell *c, int d, cell *from) {
|
|||||||
|
|
||||||
case laHell:
|
case laHell:
|
||||||
if(d == 9) {
|
if(d == 9) {
|
||||||
if(hrand(1000) < (nonchamfered ? 16 : 36) && celldist(c) >= 3) {
|
if(hrand(1000) < (nonbitrunc ? 16 : 36) && celldist(c) >= 3) {
|
||||||
for(int i=0; i<c->type; i++) {
|
for(int i=0; i<c->type; i++) {
|
||||||
cell *c2 = createMov(c, i);
|
cell *c2 = createMov(c, i);
|
||||||
setdist(c2, d+1, c);
|
setdist(c2, d+1, c);
|
||||||
@ -1284,7 +1284,7 @@ void giantLandSwitch(cell *c, int d, cell *from) {
|
|||||||
|
|
||||||
case laHive:
|
case laHive:
|
||||||
if(d == 9) {
|
if(d == 9) {
|
||||||
if(hrand(2000) < (chaosmode ? 1000 : nonchamfered?200:2) && !safety)
|
if(hrand(2000) < (chaosmode ? 1000 : nonbitrunc?200:2) && !safety)
|
||||||
hive::createBugArmy(c);
|
hive::createBugArmy(c);
|
||||||
if(hrand(2000) < 100 && !c->wall && !c->item && !c->monst) {
|
if(hrand(2000) < 100 && !c->wall && !c->item && !c->monst) {
|
||||||
int nww = 0;
|
int nww = 0;
|
||||||
@ -1504,14 +1504,14 @@ void giantLandSwitch(cell *c, int d, cell *from) {
|
|||||||
if(d == 7 && c->wall == waNone)
|
if(d == 7 && c->wall == waNone)
|
||||||
buildPrizeMirror(c, 1000);
|
buildPrizeMirror(c, 1000);
|
||||||
ONEMPTY {
|
ONEMPTY {
|
||||||
if(hrand((doCross && celldist(c) <= 5) ?450:16000) < 30+items[itRedGem]+yendor::hardness() && !pseudohept(c) && !c->monst && !c->wall && !(nonchamfered && S3==4)) {
|
if(hrand((doCross && celldist(c) <= 5) ?450:16000) < 30+items[itRedGem]+yendor::hardness() && !pseudohept(c) && !c->monst && !c->wall && !(nonbitrunc && S3==4)) {
|
||||||
int i = -1;
|
int i = -1;
|
||||||
for(int t=0; t<c->type; t++) if(c->mov[t]->mpdist > c->mpdist && !pseudohept(c->mov[t]))
|
for(int t=0; t<c->type; t++) if(c->mov[t]->mpdist > c->mpdist && !pseudohept(c->mov[t]))
|
||||||
i = t;
|
i = t;
|
||||||
if(i != -1 && !peace::on)
|
if(i != -1 && !peace::on)
|
||||||
generateSnake(c, i);
|
generateSnake(c, i);
|
||||||
}
|
}
|
||||||
else if(hrand(16000) < 50+items[itRedGem]+yendor::hardness() && (nonchamfered?hrand(10)<3:!ishept(c)) && !c->monst)
|
else if(hrand(16000) < 50+items[itRedGem]+yendor::hardness() && (nonbitrunc?hrand(10)<3:!ishept(c)) && !c->monst)
|
||||||
c->monst = moRedTroll,
|
c->monst = moRedTroll,
|
||||||
c->mondir = NODIR;
|
c->mondir = NODIR;
|
||||||
}
|
}
|
||||||
@ -1541,7 +1541,7 @@ void giantLandSwitch(cell *c, int d, cell *from) {
|
|||||||
if(hrand(1000) < 150 && celldist(c) >= 3 && !pseudohept(c))
|
if(hrand(1000) < 150 && celldist(c) >= 3 && !pseudohept(c))
|
||||||
c->wall = waSmallTree;
|
c->wall = waSmallTree;
|
||||||
int q = 0;
|
int q = 0;
|
||||||
if(!nonchamfered && !chaosmode) for(int i=0; i<c->type; i++)
|
if(!nonbitrunc && !chaosmode) for(int i=0; i<c->type; i++)
|
||||||
if(c->mov[i] && !isWarped(c->mov[i]->land) && c->mov[i]->land != laCrossroads4)
|
if(c->mov[i] && !isWarped(c->mov[i]->land) && c->mov[i]->land != laCrossroads4)
|
||||||
q++;
|
q++;
|
||||||
if(q == 1) c->wall = waWarpGate;
|
if(q == 1) c->wall = waWarpGate;
|
||||||
@ -1550,7 +1550,7 @@ void giantLandSwitch(cell *c, int d, cell *from) {
|
|||||||
if(c->land == laWarpSea) {
|
if(c->land == laWarpSea) {
|
||||||
c->wall = waSea;
|
c->wall = waSea;
|
||||||
int q = 0;
|
int q = 0;
|
||||||
if(!nonchamfered && !chaosmode) for(int i=0; i<c->type; i++)
|
if(!nonbitrunc && !chaosmode) for(int i=0; i<c->type; i++)
|
||||||
if(c->mov[i] && !isWarped(c->mov[i]->land)) q++;
|
if(c->mov[i] && !isWarped(c->mov[i]->land)) q++;
|
||||||
if(q == 1) c->wall = waWarpGate;
|
if(q == 1) c->wall = waWarpGate;
|
||||||
}
|
}
|
||||||
@ -1671,7 +1671,7 @@ void giantLandSwitch(cell *c, int d, cell *from) {
|
|||||||
}
|
}
|
||||||
else if(items[itHunting] < 10) {
|
else if(items[itHunting] < 10) {
|
||||||
vector<cell*> next;
|
vector<cell*> next;
|
||||||
forCellEx(c2, c) if(c2->mpdist > 7 && (nonchamfered || !ctof(c2))) next.push_back(c2);
|
forCellEx(c2, c) if(c2->mpdist > 7 && (nonbitrunc || !ctof(c2))) next.push_back(c2);
|
||||||
if(size(next)) {
|
if(size(next)) {
|
||||||
c->item = itHunting;
|
c->item = itHunting;
|
||||||
cell *c3 = next[hrand(size(next))];
|
cell *c3 = next[hrand(size(next))];
|
||||||
@ -1851,7 +1851,7 @@ void giantLandSwitch(cell *c, int d, cell *from) {
|
|||||||
|
|
||||||
case laMirrorOld:
|
case laMirrorOld:
|
||||||
ONEMPTY {
|
ONEMPTY {
|
||||||
if((nonchamfered?pseudohept(c):!ishept(c)) && hrand(5000) < 120 && (peace::on || notDippingFor(itShard)))
|
if((nonbitrunc?pseudohept(c):!ishept(c)) && hrand(5000) < 120 && (peace::on || notDippingFor(itShard)))
|
||||||
c->wall = hrand(2) ? waMirror : waCloud;
|
c->wall = hrand(2) ? waMirror : waCloud;
|
||||||
else if(ishept(c) && hrand(5000) < 10 * PRIZEMUL)
|
else if(ishept(c) && hrand(5000) < 10 * PRIZEMUL)
|
||||||
placePrizeOrb(c);
|
placePrizeOrb(c);
|
||||||
@ -1864,7 +1864,7 @@ void giantLandSwitch(cell *c, int d, cell *from) {
|
|||||||
|
|
||||||
case laMirror:
|
case laMirror:
|
||||||
ONEMPTY {
|
ONEMPTY {
|
||||||
if((nonchamfered?pseudohept(c):!ishept(c)) && hrand(1250) < 120 && (peace::on || notDippingFor(itShard)))
|
if((nonbitrunc?pseudohept(c):!ishept(c)) && hrand(1250) < 120 && (peace::on || notDippingFor(itShard)))
|
||||||
c->wall = hrand(2) ? waMirror : waCloud;
|
c->wall = hrand(2) ? waMirror : waCloud;
|
||||||
else if(ishept(c) && hrand(5000) < 10 * PRIZEMUL)
|
else if(ishept(c) && hrand(5000) < 10 * PRIZEMUL)
|
||||||
placePrizeOrb(c);
|
placePrizeOrb(c);
|
||||||
@ -1968,7 +1968,7 @@ void giantLandSwitch(cell *c, int d, cell *from) {
|
|||||||
else
|
else
|
||||||
si.id = (zebra40(c)&2) ? 0 : zebra40(c) == 4 ? 8 : 1;
|
si.id = (zebra40(c)&2) ? 0 : zebra40(c) == 4 ? 8 : 1;
|
||||||
c->wall = waSea;
|
c->wall = waSea;
|
||||||
if(among(si.id, 0, 4, 16, nonchamfered ? -1 : 24))
|
if(among(si.id, 0, 4, 16, nonbitrunc ? -1 : 24))
|
||||||
c->wall = waDock;
|
c->wall = waDock;
|
||||||
if(si.id == 8 && hrand(100) < 75) {
|
if(si.id == 8 && hrand(100) < 75) {
|
||||||
c->wall = waBoat;
|
c->wall = waBoat;
|
||||||
@ -2039,7 +2039,7 @@ void giantLandSwitch(cell *c, int d, cell *from) {
|
|||||||
case laCrossroads5:
|
case laCrossroads5:
|
||||||
if(c->wall == waTower) c->land = laCamelot;
|
if(c->wall == waTower) c->land = laCamelot;
|
||||||
ONEMPTY {
|
ONEMPTY {
|
||||||
if(nonchamfered && c->land == laCrossroads5 && hrand(100) < 60)
|
if(nonbitrunc && c->land == laCrossroads5 && hrand(100) < 60)
|
||||||
c->wall = waBarrier;
|
c->wall = waBarrier;
|
||||||
else if(!ctof(c) && !inv::on && items[itShard] >= 10 && hrand(8000) < 120*orbcrossfun(items[itShard]))
|
else if(!ctof(c) && !inv::on && items[itShard] >= 10 && hrand(8000) < 120*orbcrossfun(items[itShard]))
|
||||||
c->wall = hrand(2) ? waMirror : waCloud;
|
c->wall = hrand(2) ? waMirror : waCloud;
|
||||||
@ -2251,7 +2251,7 @@ void setdist(cell *c, int d, cell *from) {
|
|||||||
|
|
||||||
if(buggyGeneration) {
|
if(buggyGeneration) {
|
||||||
if(d < BARLEV) for(int i=0; i<c->type; i++) {
|
if(d < BARLEV) for(int i=0; i<c->type; i++) {
|
||||||
setdist(createMov(c, i), d+(nonchamfered?2:1), c);
|
setdist(createMov(c, i), d+(nonbitrunc?2:1), c);
|
||||||
}
|
}
|
||||||
if(d >= BARLEV) c->item = itBuggy2;
|
if(d >= BARLEV) c->item = itBuggy2;
|
||||||
return;
|
return;
|
||||||
@ -2336,7 +2336,7 @@ void setdist(cell *c, int d, cell *from) {
|
|||||||
placeLocalOrbs(c);
|
placeLocalOrbs(c);
|
||||||
}
|
}
|
||||||
|
|
||||||
if(nonchamfered && c->wall == waMirrorWall && c->land == laMirror)
|
if(nonbitrunc && c->wall == waMirrorWall && c->land == laMirror)
|
||||||
c->land = laMirrorWall; // , c->item = itPirate; // not really a proper bugfix
|
c->land = laMirrorWall; // , c->item = itPirate; // not really a proper bugfix
|
||||||
|
|
||||||
if(d == 7) playSeenSound(c);
|
if(d == 7) playSeenSound(c);
|
||||||
|
32
landlock.cpp
32
landlock.cpp
@ -1023,10 +1023,10 @@ int isLandValid(eLand l) {
|
|||||||
return 1;
|
return 1;
|
||||||
|
|
||||||
// not enough space
|
// not enough space
|
||||||
if(l == laStorms && nonchamfered && elliptic)
|
if(l == laStorms && nonbitrunc && elliptic)
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
if(l == laStorms && nonchamfered && S3 == 3)
|
if(l == laStorms && nonbitrunc && S3 == 3)
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
// available only in weird geometries
|
// available only in weird geometries
|
||||||
@ -1046,8 +1046,8 @@ int isLandValid(eLand l) {
|
|||||||
if((l == laWildWest || l == laDual) && normalgame)
|
if((l == laWildWest || l == laDual) && normalgame)
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
// Crystal World is designed for chamfered geometries
|
// Crystal World is designed for bitrunc geometries
|
||||||
if(l == laDual && nonchamfered)
|
if(l == laDual && nonbitrunc)
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
if(l == laHaunted && chaosmode)
|
if(l == laHaunted && chaosmode)
|
||||||
@ -1096,11 +1096,11 @@ int isLandValid(eLand l) {
|
|||||||
|
|
||||||
// works correctly only in some geometries
|
// works correctly only in some geometries
|
||||||
if(l == laClearing)
|
if(l == laClearing)
|
||||||
if(chaosmode || !(stdeuc || a38 || (a45 && !nonchamfered) || (a47 && !nonchamfered)))
|
if(chaosmode || !(stdeuc || a38 || (a45 && !nonbitrunc) || (a47 && !nonbitrunc)))
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
// does not work in non-chamfered a4
|
// does not work in non-bitrunc a4
|
||||||
if(l == laOvergrown && a4 && nonchamfered)
|
if(l == laOvergrown && a4 && nonbitrunc)
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
// does not work in bounded either
|
// does not work in bounded either
|
||||||
@ -1119,9 +1119,9 @@ int isLandValid(eLand l) {
|
|||||||
if((l == laBlizzard || l == laVolcano) && elliptic && S7 < 5)
|
if((l == laBlizzard || l == laVolcano) && elliptic && S7 < 5)
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
// Kraken does not really work in odd non-chamfered geometries
|
// Kraken does not really work in odd non-bitrunc geometries
|
||||||
// (but we do have to allow it in Standard)
|
// (but we do have to allow it in Standard)
|
||||||
if(l == laKraken && nonchamfered && (S7&1)) {
|
if(l == laKraken && nonbitrunc && (S7&1)) {
|
||||||
if(!geometry) return 1;
|
if(!geometry) return 1;
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
@ -1132,7 +1132,7 @@ int isLandValid(eLand l) {
|
|||||||
|
|
||||||
// works in most spheres, Zebra quotient, and stdeuc
|
// works in most spheres, Zebra quotient, and stdeuc
|
||||||
if(l == laWhirlwind)
|
if(l == laWhirlwind)
|
||||||
if(!(stdeuc || quotient == 1 || (S7 == 4 && !nonchamfered) || (bigsphere && nonchamfered && !elliptic)))
|
if(!(stdeuc || quotient == 1 || (S7 == 4 && !nonbitrunc) || (bigsphere && nonbitrunc && !elliptic)))
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
// needs standard/Euclidean (needs fractal landscape)
|
// needs standard/Euclidean (needs fractal landscape)
|
||||||
@ -1154,12 +1154,12 @@ int isLandValid(eLand l) {
|
|||||||
if(l == laDragon && bounded)
|
if(l == laDragon && bounded)
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
// Graveyard pattern does not work on non-chamfered weird geometries
|
// Graveyard pattern does not work on non-bitrunc weird geometries
|
||||||
if(l == laGraveyard)
|
if(l == laGraveyard)
|
||||||
return geosupport_graveyard();
|
return geosupport_graveyard();
|
||||||
|
|
||||||
// Warped Coast does not work on non-chamfered S3s (except standard heptagonal where we have to keep it)
|
// Warped Coast does not work on non-bitrunc S3s (except standard heptagonal where we have to keep it)
|
||||||
if(l == laWarpCoast && (S3==3) && nonchamfered) {
|
if(l == laWarpCoast && (S3==3) && nonbitrunc) {
|
||||||
if(!geometry) return 1;
|
if(!geometry) return 1;
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
@ -1177,7 +1177,7 @@ int isLandValid(eLand l) {
|
|||||||
if(l == laTrollheim && !stdeuc)
|
if(l == laTrollheim && !stdeuc)
|
||||||
return 1;
|
return 1;
|
||||||
|
|
||||||
if(l == laReptile && (!stdeuc || nonchamfered))
|
if(l == laReptile && (!stdeuc || nonbitrunc))
|
||||||
return 1;
|
return 1;
|
||||||
|
|
||||||
if(l == laCrossroads && weirdhyperbolic)
|
if(l == laCrossroads && weirdhyperbolic)
|
||||||
@ -1193,14 +1193,14 @@ int isLandValid(eLand l) {
|
|||||||
if(l == laCrossroads4 && !(stdeuc || smallbounded))
|
if(l == laCrossroads4 && !(stdeuc || smallbounded))
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
if(l == laZebra && !(stdeuc || (a4 && nonchamfered) || a46 || quotient == 1))
|
if(l == laZebra && !(stdeuc || (a4 && nonbitrunc) || a46 || quotient == 1))
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
if(l == laCrossroads3 && euclid)
|
if(l == laCrossroads3 && euclid)
|
||||||
return 1; // because it is not accurate
|
return 1; // because it is not accurate
|
||||||
|
|
||||||
if(l == laPrairie) {
|
if(l == laPrairie) {
|
||||||
if(stdeuc || (bigsphere && !nonchamfered && !elliptic) || (quotient == 2)) ;
|
if(stdeuc || (bigsphere && !nonbitrunc && !elliptic) || (quotient == 2)) ;
|
||||||
else if(!bounded) return 1;
|
else if(!bounded) return 1;
|
||||||
else return 0;
|
else return 0;
|
||||||
}
|
}
|
||||||
|
@ -6354,7 +6354,7 @@ S(
|
|||||||
"You can try many different geometries here. We start by gluing "
|
"You can try many different geometries here. We start by gluing "
|
||||||
"n-gons in such a way that k of them meet in every vertex. "
|
"n-gons in such a way that k of them meet in every vertex. "
|
||||||
"Depending on n and k, this either folds into a sphere, unfolds into a plane, "
|
"Depending on n and k, this either folds into a sphere, unfolds into a plane, "
|
||||||
"or requires a hyperbolic space. The result may be then 'chamfered' by "
|
"or requires a hyperbolic space. The result may be then 'bitruncated' by "
|
||||||
"replacing each vertex by a 2k-gon. Furthermore, you can play "
|
"replacing each vertex by a 2k-gon. Furthermore, you can play "
|
||||||
"with quotient geometries. For example, the elliptic geometry is "
|
"with quotient geometries. For example, the elliptic geometry is "
|
||||||
"obtained from the sphere by making the antipodes be the same point, "
|
"obtained from the sphere by making the antipodes be the same point, "
|
||||||
@ -6362,7 +6362,7 @@ S(
|
|||||||
"Have fun experimenting! "
|
"Have fun experimenting! "
|
||||||
"Achievements and leaderboards do not work in geometry experiments, "
|
"Achievements and leaderboards do not work in geometry experiments, "
|
||||||
"except some specific ones.\n\n"
|
"except some specific ones.\n\n"
|
||||||
"In standard geometry (chamfered or not), you can play the full game, but in other geometries "
|
"In standard geometry (bitruncated or not), you can play the full game, but in other geometries "
|
||||||
"you select a particular land. Lands are unlocked by visiting them in this "
|
"you select a particular land. Lands are unlocked by visiting them in this "
|
||||||
"session, or permanently by collecting 25 treasure. Try Crossroads in Euclidean "
|
"session, or permanently by collecting 25 treasure. Try Crossroads in Euclidean "
|
||||||
"or chaos mode in non-standard non-quotient hyperbolic to visit many lands. "
|
"or chaos mode in non-standard non-quotient hyperbolic to visit many lands. "
|
||||||
@ -6407,7 +6407,7 @@ S("tetrahedron (buggy)", "čtyřstěn (problémový)")
|
|||||||
S("tetrahedron", "čtyřstěn") // in case if it gets better
|
S("tetrahedron", "čtyřstěn") // in case if it gets better
|
||||||
|
|
||||||
S("land", "kraj")
|
S("land", "kraj")
|
||||||
S("chamfered", "seříznutí")
|
S("bitruncated", "seříznutí")
|
||||||
S("does not matter", "nehraje roli")
|
S("does not matter", "nehraje roli")
|
||||||
S("sides per face", "počet stran")
|
S("sides per face", "počet stran")
|
||||||
S("faces per vertex", "stupeň vrcholů")
|
S("faces per vertex", "stupeň vrcholů")
|
||||||
@ -6418,7 +6418,7 @@ S("quotient space", "kvocientový prostor")
|
|||||||
S("size of the world", "velikost světa")
|
S("size of the world", "velikost světa")
|
||||||
S("flat", "placka")
|
S("flat", "placka")
|
||||||
|
|
||||||
// chamfered or not chamfered
|
// bitruncated or not bitrunc
|
||||||
S(" (c)", " (s)")
|
S(" (c)", " (s)")
|
||||||
S(" (n)", " (n)")
|
S(" (n)", " (n)")
|
||||||
|
|
||||||
|
@ -6206,7 +6206,7 @@ S(
|
|||||||
"You can try many different geometries here. We start by gluing "
|
"You can try many different geometries here. We start by gluing "
|
||||||
"n-gons in such a way that k of them meet in every vertex. "
|
"n-gons in such a way that k of them meet in every vertex. "
|
||||||
"Depending on n and k, this either folds into a sphere, unfolds into a plane, "
|
"Depending on n and k, this either folds into a sphere, unfolds into a plane, "
|
||||||
"or requires a hyperbolic space. The result may be then 'chamfered' by "
|
"or requires a hyperbolic space. The result may be then 'bitruncated' by "
|
||||||
"replacing each vertex by a 2k-gon. Furthermore, you can play "
|
"replacing each vertex by a 2k-gon. Furthermore, you can play "
|
||||||
"with quotient geometries. For example, the elliptic geometry is "
|
"with quotient geometries. For example, the elliptic geometry is "
|
||||||
"obtained from the sphere by making the antipodes be the same point, "
|
"obtained from the sphere by making the antipodes be the same point, "
|
||||||
@ -6214,7 +6214,7 @@ S(
|
|||||||
"Have fun experimenting! "
|
"Have fun experimenting! "
|
||||||
"Achievements and leaderboards do not work in geometry experiments, "
|
"Achievements and leaderboards do not work in geometry experiments, "
|
||||||
"except some specific ones.\n\n"
|
"except some specific ones.\n\n"
|
||||||
"In standard geometry (chamfered or not), you can play the full game, but in other geometries "
|
"In standard geometry (bitruncated or not), you can play the full game, but in other geometries "
|
||||||
"you select a particular land. Lands are unlocked by visiting them in this "
|
"you select a particular land. Lands are unlocked by visiting them in this "
|
||||||
"session, or permanently by collecting 25 treasure. Try Crossroads in Euclidean "
|
"session, or permanently by collecting 25 treasure. Try Crossroads in Euclidean "
|
||||||
"or chaos mode in non-standard non-quotient hyperbolic to visit many lands. "
|
"or chaos mode in non-standard non-quotient hyperbolic to visit many lands. "
|
||||||
@ -6257,7 +6257,7 @@ S("tetrahedron (buggy)", "czworościan (bugi)")
|
|||||||
S("tetrahedron", "czworościan") // in case if it gets better
|
S("tetrahedron", "czworościan") // in case if it gets better
|
||||||
|
|
||||||
S("land", "kraina")
|
S("land", "kraina")
|
||||||
S("chamfered", "przycięte")
|
S("bitruncated", "przycięte")
|
||||||
S("does not matter", "bez znaczenia")
|
S("does not matter", "bez znaczenia")
|
||||||
S("sides per face", "boki ścian")
|
S("sides per face", "boki ścian")
|
||||||
S("faces per vertex", "wierzchołki")
|
S("faces per vertex", "wierzchołki")
|
||||||
@ -6268,8 +6268,8 @@ S("quotient space", "przestrzeń ilorazowa")
|
|||||||
S("size of the world", "wielkość świata")
|
S("size of the world", "wielkość świata")
|
||||||
S("flat", "płaska")
|
S("flat", "płaska")
|
||||||
|
|
||||||
// chamfered or not chamfered
|
// bitruncated or not bitrunc
|
||||||
S(" (c)", " (p)")
|
S(" (b)", " (b)")
|
||||||
S(" (n)", " (n)")
|
S(" (n)", " (n)")
|
||||||
|
|
||||||
S("(locked)", "(blok)")
|
S("(locked)", "(blok)")
|
||||||
@ -6328,7 +6328,7 @@ S(
|
|||||||
|
|
||||||
S("find the next prime", "znajdź następną liczbę pierwszą")
|
S("find the next prime", "znajdź następną liczbę pierwszą")
|
||||||
S("activate", "uruchom")
|
S("activate", "uruchom")
|
||||||
S("order %1%2 (non-chamfered cells: %3)", "rząd %1%2 (nieprzyciętych pól: %3)")
|
S("order %1%2 (non-bitrunc cells: %3)", "rząd %1%2 (nieprzyciętych pól: %3)")
|
||||||
|
|
||||||
// Torus/Klein bottle, Euclidean Squares, and their advanced configuration
|
// Torus/Klein bottle, Euclidean Squares, and their advanced configuration
|
||||||
//-------------------------------------------------------------------------
|
//-------------------------------------------------------------------------
|
||||||
@ -6347,7 +6347,7 @@ S("Klein bottle (squares)", "butelka Kleina (kwadraty)")
|
|||||||
S("Klein bottle (hex)", "butelka Kleina (heksy)")
|
S("Klein bottle (hex)", "butelka Kleina (heksy)")
|
||||||
|
|
||||||
S("this mode has bad patterns", "nieprawidłowe wzorki dla tego trybu")
|
S("this mode has bad patterns", "nieprawidłowe wzorki dla tego trybu")
|
||||||
S("incompatible with chamfering", "niekompatybilne z przycinaniem")
|
S("incompatible with bitruncating", "niekompatybilne z przycinaniem")
|
||||||
S("best if %1 is divisible by %2", "najlepiej gdy %1 jest podzielne przez %2")
|
S("best if %1 is divisible by %2", "najlepiej gdy %1 jest podzielne przez %2")
|
||||||
|
|
||||||
S("number of cells (n)", "liczba pól (n)")
|
S("number of cells (n)", "liczba pól (n)")
|
||||||
|
@ -6429,7 +6429,7 @@ S(
|
|||||||
"You can try many different geometries here. We start by gluing "
|
"You can try many different geometries here. We start by gluing "
|
||||||
"n-gons in such a way that k of them meet in every vertex. "
|
"n-gons in such a way that k of them meet in every vertex. "
|
||||||
"Depending on n and k, this either folds into a sphere, unfolds into a plane, "
|
"Depending on n and k, this either folds into a sphere, unfolds into a plane, "
|
||||||
"or requires a hyperbolic space. The result may be then 'chamfered' by "
|
"or requires a hyperbolic space. The result may be then 'bitruncated' by "
|
||||||
"replacing each vertex by a 2k-gon. Furthermore, you can play "
|
"replacing each vertex by a 2k-gon. Furthermore, you can play "
|
||||||
"with quotient geometries. For example, the elliptic geometry is "
|
"with quotient geometries. For example, the elliptic geometry is "
|
||||||
"obtained from the sphere by making the antipodes be the same point, "
|
"obtained from the sphere by making the antipodes be the same point, "
|
||||||
@ -6437,7 +6437,7 @@ S(
|
|||||||
"Have fun experimenting! "
|
"Have fun experimenting! "
|
||||||
"Achievements and leaderboards do not work in geometry experiments, "
|
"Achievements and leaderboards do not work in geometry experiments, "
|
||||||
"except some specific ones.\n\n"
|
"except some specific ones.\n\n"
|
||||||
"In standard geometry (chamfered or not), you can play the full game, but in other geometries "
|
"In standard geometry (bitruncated or not), you can play the full game, but in other geometries "
|
||||||
"you select a particular land. Lands are unlocked by visiting them in this "
|
"you select a particular land. Lands are unlocked by visiting them in this "
|
||||||
"session, or permanently by collecting 25 treasure. Try Crossroads in Euclidean "
|
"session, or permanently by collecting 25 treasure. Try Crossroads in Euclidean "
|
||||||
"or chaos mode in non-standard non-quotient hyperbolic to visit many lands. "
|
"or chaos mode in non-standard non-quotient hyperbolic to visit many lands. "
|
||||||
@ -6478,7 +6478,7 @@ S("tetrahedron (buggy)", "тетраэдр (ошибки)")
|
|||||||
S("tetrahedron", "тетраэдр") // in case if it gets better
|
S("tetrahedron", "тетраэдр") // in case if it gets better
|
||||||
|
|
||||||
S("land", "земля")
|
S("land", "земля")
|
||||||
S("chamfered", "усеченный")
|
S("bitruncated", "усеченный")
|
||||||
S("does not matter", "не важно")
|
S("does not matter", "не важно")
|
||||||
S("sides per face", "сторон у клетка")
|
S("sides per face", "сторон у клетка")
|
||||||
S("faces per vertex", "клеток в вершине")
|
S("faces per vertex", "клеток в вершине")
|
||||||
@ -6489,7 +6489,7 @@ S("quotient space", "факторпространство")
|
|||||||
S("size of the world", "размер мира")
|
S("size of the world", "размер мира")
|
||||||
S("flat", "плоскость")
|
S("flat", "плоскость")
|
||||||
|
|
||||||
// chamfered or not chamfered
|
// bitruncated or not bitrunc
|
||||||
S(" (c)", " (у)")
|
S(" (c)", " (у)")
|
||||||
S(" (n)", " (н)")
|
S(" (n)", " (н)")
|
||||||
|
|
||||||
|
@ -88,7 +88,7 @@ namespace mapstream {
|
|||||||
int32_t i = VERNUM; save(i);
|
int32_t i = VERNUM; save(i);
|
||||||
save(patterns::whichPattern);
|
save(patterns::whichPattern);
|
||||||
save(geometry);
|
save(geometry);
|
||||||
save(nonchamfered);
|
save(nonbitrunc);
|
||||||
if(geometry == gTorus) {
|
if(geometry == gTorus) {
|
||||||
save(torusconfig::qty);
|
save(torusconfig::qty);
|
||||||
save(torusconfig::dx);
|
save(torusconfig::dx);
|
||||||
@ -173,7 +173,7 @@ namespace mapstream {
|
|||||||
|
|
||||||
if(vernum >= 10203) {
|
if(vernum >= 10203) {
|
||||||
load(geometry);
|
load(geometry);
|
||||||
load(nonchamfered);
|
load(nonbitrunc);
|
||||||
if(geometry == gTorus) {
|
if(geometry == gTorus) {
|
||||||
load(torusconfig::qty);
|
load(torusconfig::qty);
|
||||||
load(torusconfig::dx);
|
load(torusconfig::dx);
|
||||||
@ -631,7 +631,7 @@ namespace mapeditor {
|
|||||||
if(painttype == 4 && radius) {
|
if(painttype == 4 && radius) {
|
||||||
if(where.c->type != copysource.c->type) return;
|
if(where.c->type != copysource.c->type) return;
|
||||||
if(where.spin<0) where.spin=0;
|
if(where.spin<0) where.spin=0;
|
||||||
if(!nonchamfered && !ctof(mouseover) && ((where.spin&1) != (copysource.spin&1)))
|
if(!nonbitrunc && !ctof(mouseover) && ((where.spin&1) != (copysource.spin&1)))
|
||||||
cwspin(where, 1);
|
cwspin(where, 1);
|
||||||
}
|
}
|
||||||
if(painttype != 4) copysource.c = NULL;
|
if(painttype != 4) copysource.c = NULL;
|
||||||
@ -1280,7 +1280,7 @@ namespace mapeditor {
|
|||||||
fscanf(f, "%d%d%d%d\n", &tg, &nt, &wp, &patterns::subpattern_flags);
|
fscanf(f, "%d%d%d%d\n", &tg, &nt, &wp, &patterns::subpattern_flags);
|
||||||
patterns::whichPattern = wp;
|
patterns::whichPattern = wp;
|
||||||
if(tg != geometry) { targetgeometry = eGeometry(tg); restartGame('g', 0, true); }
|
if(tg != geometry) { targetgeometry = eGeometry(tg); restartGame('g', 0, true); }
|
||||||
if(nt != nonchamfered) { restartGame('7', 0, true); }
|
if(nt != nonbitrunc) { restartGame('7', 0, true); }
|
||||||
}
|
}
|
||||||
|
|
||||||
while(true) {
|
while(true) {
|
||||||
@ -1324,7 +1324,7 @@ namespace mapeditor {
|
|||||||
fprintf(f, "HyperRogue saved picture\n");
|
fprintf(f, "HyperRogue saved picture\n");
|
||||||
fprintf(f, "%x\n", VERNUM_HEX);
|
fprintf(f, "%x\n", VERNUM_HEX);
|
||||||
if(VERNUM_HEX >= 0xA0A0)
|
if(VERNUM_HEX >= 0xA0A0)
|
||||||
fprintf(f, "%d %d %d %d\n", geometry, nonchamfered, patterns::whichPattern, patterns::subpattern_flags);
|
fprintf(f, "%d %d %d %d\n", geometry, nonbitrunc, patterns::whichPattern, patterns::subpattern_flags);
|
||||||
for(int i=0; i<USERSHAPEGROUPS; i++) for(int j=0; j<USERSHAPEIDS; j++) {
|
for(int i=0; i<USERSHAPEGROUPS; i++) for(int j=0; j<USERSHAPEIDS; j++) {
|
||||||
usershape *us = usershapes[i][j];
|
usershape *us = usershapes[i][j];
|
||||||
if(!us) continue;
|
if(!us) continue;
|
||||||
|
@ -431,7 +431,7 @@ void showChangeMode() {
|
|||||||
dialog::addBoolItem(XLAT("Tutorial"), tour::on, 'T');
|
dialog::addBoolItem(XLAT("Tutorial"), tour::on, 'T');
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
dialog::addBoolItem(XLAT("experiment with geometry"), geometry || nonchamfered || viewdists, 'e');
|
dialog::addBoolItem(XLAT("experiment with geometry"), geometry || nonbitrunc || viewdists, 'e');
|
||||||
dialog::addBoolItem(XLAT(SHMUPTITLE), (shmup::on || multi::players > 1), 's');
|
dialog::addBoolItem(XLAT(SHMUPTITLE), (shmup::on || multi::players > 1), 's');
|
||||||
if(!shmup::on) dialog::addSelItem(XLAT("hardcore mode"),
|
if(!shmup::on) dialog::addSelItem(XLAT("hardcore mode"),
|
||||||
hardcore && !pureHardcore() ? XLAT("PARTIAL") : ONOFF(hardcore), 'h');
|
hardcore && !pureHardcore() ? XLAT("PARTIAL") : ONOFF(hardcore), 'h');
|
||||||
|
@ -641,7 +641,7 @@ void generateSnake(cell *c, int i) {
|
|||||||
c->monst = moHexSnake;
|
c->monst = moHexSnake;
|
||||||
int cpair = (1<<pattern_threecolor(c)) | (1<<pattern_threecolor(c->mov[i]));
|
int cpair = (1<<pattern_threecolor(c)) | (1<<pattern_threecolor(c->mov[i]));
|
||||||
preventbarriers(c);
|
preventbarriers(c);
|
||||||
int len = nonchamfered ? 2 : ROCKSNAKELENGTH;
|
int len = nonbitrunc ? 2 : ROCKSNAKELENGTH;
|
||||||
cell *c2 = c;
|
cell *c2 = c;
|
||||||
vector<cell*> rocksnake;
|
vector<cell*> rocksnake;
|
||||||
while(--len) {
|
while(--len) {
|
||||||
@ -665,7 +665,7 @@ void generateSnake(cell *c, int i) {
|
|||||||
i = goodsteps[hrand(size(goodsteps))];
|
i = goodsteps[hrand(size(goodsteps))];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if(size(rocksnake) < ROCKSNAKELENGTH/2 && !nonchamfered) {
|
if(size(rocksnake) < ROCKSNAKELENGTH/2 && !nonbitrunc) {
|
||||||
for(int i=0; i<size(rocksnake); i++)
|
for(int i=0; i<size(rocksnake); i++)
|
||||||
rocksnake[i]->monst = moNone;
|
rocksnake[i]->monst = moNone;
|
||||||
}
|
}
|
||||||
|
@ -378,7 +378,7 @@ ld orbcrossfun(int tr) {
|
|||||||
|
|
||||||
bool buildPrizeMirror(cell *c, int freq) {
|
bool buildPrizeMirror(cell *c, int freq) {
|
||||||
if(inv::on) return false;
|
if(inv::on) return false;
|
||||||
if(c->type == 7 && !nonchamfered) return false;
|
if(c->type == 7 && !nonbitrunc) return false;
|
||||||
if(items[itShard] < 25) return false;
|
if(items[itShard] < 25) return false;
|
||||||
if(freq && hrand(freq * 100 / orbprizefun(items[itShard])) >= 100)
|
if(freq && hrand(freq * 100 / orbprizefun(items[itShard])) >= 100)
|
||||||
return false;
|
return false;
|
||||||
|
80
pattern2.cpp
80
pattern2.cpp
@ -205,7 +205,7 @@ int fiftyval200(cell *c) {
|
|||||||
|
|
||||||
// zebraval
|
// zebraval
|
||||||
|
|
||||||
int dir_chamfered457(cell *c) {
|
int dir_bitrunc457(cell *c) {
|
||||||
int wset = 0;
|
int wset = 0;
|
||||||
int has1 = 0;
|
int has1 = 0;
|
||||||
for(int i=0; i<4; i++) {
|
for(int i=0; i<4; i++) {
|
||||||
@ -233,7 +233,7 @@ int zebra40(cell *c) {
|
|||||||
}
|
}
|
||||||
else if(ctof(c)) return (c->master->zebraval/10);
|
else if(ctof(c)) return (c->master->zebraval/10);
|
||||||
else if(a4) {
|
else if(a4) {
|
||||||
int ws = dir_chamfered457(c);
|
int ws = dir_bitrunc457(c);
|
||||||
if(ws < 0) return -ws;
|
if(ws < 0) return -ws;
|
||||||
int tot = 0;
|
int tot = 0;
|
||||||
array<int, 4> zebras;
|
array<int, 4> zebras;
|
||||||
@ -526,7 +526,7 @@ namespace patterns {
|
|||||||
si.dir = i;
|
si.dir = i;
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
int d = dir_chamfered457(c);
|
int d = dir_bitrunc457(c);
|
||||||
if(d >= 0) si.dir = d;
|
if(d >= 0) si.dir = d;
|
||||||
else si.dir = (zebra40(createMov(c, 0)) & 4) ? 2 : 0;
|
else si.dir = (zebra40(createMov(c, 0)) & 4) ? 2 : 0;
|
||||||
}
|
}
|
||||||
@ -540,11 +540,11 @@ namespace patterns {
|
|||||||
si.id = (c->master->fiftyval >> 1) & 3;
|
si.id = (c->master->fiftyval >> 1) & 3;
|
||||||
else
|
else
|
||||||
si.id = 0;
|
si.id = 0;
|
||||||
if(nonchamfered)
|
if(nonbitrunc)
|
||||||
si.id *= 4;
|
si.id *= 4;
|
||||||
else
|
else
|
||||||
si.id += 4;
|
si.id += 4;
|
||||||
si.dir = (pat == PAT_COLORING && !nonchamfered ? 1 : 0) + (c->master->fiftyval | (c->master->fiftyval & 8 ? 0 : 2));
|
si.dir = (pat == PAT_COLORING && !nonbitrunc ? 1 : 0) + (c->master->fiftyval | (c->master->fiftyval & 8 ? 0 : 2));
|
||||||
si.symmetries = 2;
|
si.symmetries = 2;
|
||||||
si.id += 8;
|
si.id += 8;
|
||||||
si.id %= 12;
|
si.id %= 12;
|
||||||
@ -687,13 +687,13 @@ namespace patterns {
|
|||||||
if(subpattern_flags & SPF_FULLSYM)
|
if(subpattern_flags & SPF_FULLSYM)
|
||||||
si.symmetries = 1;
|
si.symmetries = 1;
|
||||||
}
|
}
|
||||||
if(sphere && !(nonchamfered) && !(S7 == 3))
|
if(sphere && !(nonbitrunc) && !(S7 == 3))
|
||||||
si.symmetries = ctof(c) ? 1 : 2;
|
si.symmetries = ctof(c) ? 1 : 2;
|
||||||
if(sphere && (sub & SPF_EXTRASYM)) {
|
if(sphere && (sub & SPF_EXTRASYM)) {
|
||||||
si.symmetries = ctof(c) ? 1 : 2;
|
si.symmetries = ctof(c) ? 1 : 2;
|
||||||
}
|
}
|
||||||
if(a38)
|
if(a38)
|
||||||
si.symmetries = (ctof(c) && !nonchamfered) ? 1 : 2;
|
si.symmetries = (ctof(c) && !nonbitrunc) ? 1 : 2;
|
||||||
if(a457) {
|
if(a457) {
|
||||||
si.symmetries = ctof(c) ? 1 : 2;
|
si.symmetries = ctof(c) ? 1 : 2;
|
||||||
if(!ctof(c)) si.dir = 0;
|
if(!ctof(c)) si.dir = 0;
|
||||||
@ -746,7 +746,7 @@ namespace patterns {
|
|||||||
si.id = zebra40(c); // 4 to 43
|
si.id = zebra40(c); // 4 to 43
|
||||||
int t4 = si.id>>2, tcdir = 0;
|
int t4 = si.id>>2, tcdir = 0;
|
||||||
|
|
||||||
if(nonchamfered) tcdir = si.id^1;
|
if(nonbitrunc) tcdir = si.id^1;
|
||||||
|
|
||||||
else if(t4 == 10) tcdir = si.id-20;
|
else if(t4 == 10) tcdir = si.id-20;
|
||||||
else if(t4 >= 4 && t4 < 7) tcdir = 40 + (si.id&3);
|
else if(t4 >= 4 && t4 < 7) tcdir = 40 + (si.id&3);
|
||||||
@ -801,11 +801,11 @@ namespace patterns {
|
|||||||
int look_for = -1;
|
int look_for = -1;
|
||||||
int shft = 0;
|
int shft = 0;
|
||||||
if(inr(si.id, 0, 4)) {
|
if(inr(si.id, 0, 4)) {
|
||||||
look_for = si.id + (nonchamfered ? 4 : 60);
|
look_for = si.id + (nonbitrunc ? 4 : 60);
|
||||||
if(symRotation) si.symmetries = 1;
|
if(symRotation) si.symmetries = 1;
|
||||||
}
|
}
|
||||||
else if(inr(si.id, 4, 32)) look_for = si.id + (nonchamfered ? 28 : 168);
|
else if(inr(si.id, 4, 32)) look_for = si.id + (nonbitrunc ? 28 : 168);
|
||||||
else if(inr(si.id, 32, 60)) look_for = si.id + (nonchamfered ? -28 : 112);
|
else if(inr(si.id, 32, 60)) look_for = si.id + (nonbitrunc ? -28 : 112);
|
||||||
else if(inr(si.id, 60, 88)) look_for = si.id - 56, shft = si.reflect ? 1 : 5;
|
else if(inr(si.id, 60, 88)) look_for = si.id - 56, shft = si.reflect ? 1 : 5;
|
||||||
else if(inr(si.id, 88, 116)) look_for = si.id - 84, shft = 3;
|
else if(inr(si.id, 88, 116)) look_for = si.id - 84, shft = 3;
|
||||||
else if(inr(si.id, 116, 144)) look_for = si.id + 56;
|
else if(inr(si.id, 116, 144)) look_for = si.id + 56;
|
||||||
@ -849,7 +849,7 @@ namespace patterns {
|
|||||||
if(euclid)
|
if(euclid)
|
||||||
// use the torus ID
|
// use the torus ID
|
||||||
si.id = fieldpattern::fieldval_uniq(c);
|
si.id = fieldpattern::fieldval_uniq(c);
|
||||||
else if(nonchamfered)
|
else if(nonbitrunc)
|
||||||
// use the actual field codes
|
// use the actual field codes
|
||||||
si.id = fieldpattern::fieldval(c).first;
|
si.id = fieldpattern::fieldval(c).first;
|
||||||
else
|
else
|
||||||
@ -888,7 +888,7 @@ namespace patterns {
|
|||||||
}
|
}
|
||||||
|
|
||||||
int geosupport_threecolor() {
|
int geosupport_threecolor() {
|
||||||
if(!nonchamfered) {
|
if(!nonbitrunc) {
|
||||||
if(S7 % 2) return 1;
|
if(S7 % 2) return 1;
|
||||||
return 2;
|
return 2;
|
||||||
}
|
}
|
||||||
@ -898,8 +898,8 @@ int geosupport_threecolor() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
int geosupport_graveyard() {
|
int geosupport_graveyard() {
|
||||||
// always works in chamfered geometries
|
// always works in bitrunc geometries
|
||||||
if(!nonchamfered) return 2;
|
if(!nonbitrunc) return 2;
|
||||||
|
|
||||||
// always works in patterns supporting three-color
|
// always works in patterns supporting three-color
|
||||||
return geosupport_threecolor();
|
return geosupport_threecolor();
|
||||||
@ -911,19 +911,19 @@ int pattern_threecolor(cell *c) {
|
|||||||
patterns::val38(c, si, patterns::SPF_ROT, patterns::PAT_COLORING);
|
patterns::val38(c, si, patterns::SPF_ROT, patterns::PAT_COLORING);
|
||||||
return si.id >> 2;
|
return si.id >> 2;
|
||||||
}
|
}
|
||||||
if(a46 && !nonchamfered) {
|
if(a46 && !nonbitrunc) {
|
||||||
patterns::patterninfo si;
|
patterns::patterninfo si;
|
||||||
patterns::val46(c, si, 0, patterns::PAT_COLORING);
|
patterns::val46(c, si, 0, patterns::PAT_COLORING);
|
||||||
int i = si.id;
|
int i = si.id;
|
||||||
return i >> 2;
|
return i >> 2;
|
||||||
}
|
}
|
||||||
if(euclid) {
|
if(euclid) {
|
||||||
if(a4 && nonchamfered) return eupattern4(c);
|
if(a4 && nonbitrunc) return eupattern4(c);
|
||||||
return eupattern(c) % 3;
|
return eupattern(c) % 3;
|
||||||
}
|
}
|
||||||
if(S7 == 4 && S3 == 3) {
|
if(S7 == 4 && S3 == 3) {
|
||||||
int codesN[6] = {0,1,2,1,2,0};
|
int codesN[6] = {0,1,2,1,2,0};
|
||||||
if(nonchamfered)
|
if(nonbitrunc)
|
||||||
return codesN[c->master->fiftyval];
|
return codesN[c->master->fiftyval];
|
||||||
if(ctof(c))
|
if(ctof(c))
|
||||||
return 0;
|
return 0;
|
||||||
@ -935,7 +935,7 @@ int pattern_threecolor(cell *c) {
|
|||||||
return 2 - (c->spin(i)&1);
|
return 2 - (c->spin(i)&1);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if(stdhyperbolic && nonchamfered) {
|
if(stdhyperbolic && nonbitrunc) {
|
||||||
int z = zebra40(c);
|
int z = zebra40(c);
|
||||||
if(z == 5 || z == 8 || z == 15) return 0;
|
if(z == 5 || z == 8 || z == 15) return 0;
|
||||||
if(z == 10 || z == 12 || z == 7) return 2;
|
if(z == 10 || z == 12 || z == 7) return 2;
|
||||||
@ -943,16 +943,16 @@ int pattern_threecolor(cell *c) {
|
|||||||
if(z == 14 || z == 11) return 4;
|
if(z == 14 || z == 11) return 4;
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
if(a46 && nonchamfered) {
|
if(a46 && nonbitrunc) {
|
||||||
patterns::patterninfo si;
|
patterns::patterninfo si;
|
||||||
patterns::val46(c, si, 0, patterns::PAT_COLORING);
|
patterns::val46(c, si, 0, patterns::PAT_COLORING);
|
||||||
return si.id;
|
return si.id;
|
||||||
}
|
}
|
||||||
if(S7 == 5 && nonchamfered) {
|
if(S7 == 5 && nonbitrunc) {
|
||||||
const int codes[12] = {1, 2, 0, 3, 2, 0, 0, 1, 3, 1, 2, 3};
|
const int codes[12] = {1, 2, 0, 3, 2, 0, 0, 1, 3, 1, 2, 3};
|
||||||
return codes[c->master->fiftyval];
|
return codes[c->master->fiftyval];
|
||||||
}
|
}
|
||||||
if(S7 == 3 && nonchamfered)
|
if(S7 == 3 && nonbitrunc)
|
||||||
return c->master->fiftyval;
|
return c->master->fiftyval;
|
||||||
return !ishept(c);
|
return !ishept(c);
|
||||||
}
|
}
|
||||||
@ -965,7 +965,7 @@ bool pseudohept(cell *c) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
bool warptype(cell *c) {
|
bool warptype(cell *c) {
|
||||||
if(a4 && nonchamfered) {
|
if(a4 && nonbitrunc) {
|
||||||
if(euclid)
|
if(euclid)
|
||||||
return among(eupattern4(c), 1, 2);
|
return among(eupattern4(c), 1, 2);
|
||||||
else
|
else
|
||||||
@ -1123,7 +1123,7 @@ namespace patterns {
|
|||||||
}
|
}
|
||||||
|
|
||||||
dialog::addItem(XLAT("football"), 'F');
|
dialog::addItem(XLAT("football"), 'F');
|
||||||
if(S3 == 4 && nonchamfered)
|
if(S3 == 4 && nonbitrunc)
|
||||||
dialog::addItem(XLAT("chessboard"), 'c');
|
dialog::addItem(XLAT("chessboard"), 'c');
|
||||||
|
|
||||||
dialog::addItem(XLAT("nice coloring"), 'T');
|
dialog::addItem(XLAT("nice coloring"), 'T');
|
||||||
@ -1205,7 +1205,7 @@ namespace patterns {
|
|||||||
if(stdhyperbolic || euclid)
|
if(stdhyperbolic || euclid)
|
||||||
dialog::addBoolItem(XLAT("Palace Pattern"), (whichPattern == PAT_PALACE), PAT_PALACE);
|
dialog::addBoolItem(XLAT("Palace Pattern"), (whichPattern == PAT_PALACE), PAT_PALACE);
|
||||||
|
|
||||||
if(nonchamfered && S3 == 4)
|
if(nonbitrunc && S3 == 4)
|
||||||
dialog::addBoolItem(XLAT("chessboard"), (whichPattern == PAT_CHESS), PAT_CHESS);
|
dialog::addBoolItem(XLAT("chessboard"), (whichPattern == PAT_CHESS), PAT_CHESS);
|
||||||
|
|
||||||
if(a38 || a46 || euclid || S3 == 4)
|
if(a38 || a46 || euclid || S3 == 4)
|
||||||
@ -1232,7 +1232,7 @@ namespace patterns {
|
|||||||
|
|
||||||
if((euclid && whichPattern == PAT_COLORING) ||
|
if((euclid && whichPattern == PAT_COLORING) ||
|
||||||
(a38 && whichPattern == PAT_COLORING) ||
|
(a38 && whichPattern == PAT_COLORING) ||
|
||||||
(a4 && nonchamfered && whichPattern == PAT_COLORING && !a46))
|
(a4 && nonbitrunc && whichPattern == PAT_COLORING && !a46))
|
||||||
dialog::addBoolItem(XLAT("edit all three colors"), subpattern_flags & SPF_ROT, '0');
|
dialog::addBoolItem(XLAT("edit all three colors"), subpattern_flags & SPF_ROT, '0');
|
||||||
|
|
||||||
if(euclid && whichPattern == PAT_COLORING)
|
if(euclid && whichPattern == PAT_COLORING)
|
||||||
@ -1241,8 +1241,8 @@ namespace patterns {
|
|||||||
if(a46 && whichPattern == PAT_COLORING)
|
if(a46 && whichPattern == PAT_COLORING)
|
||||||
dialog::addBoolItem(XLAT("rotate the color groups"), subpattern_flags & SPF_CHANGEROT, '4');
|
dialog::addBoolItem(XLAT("rotate the color groups"), subpattern_flags & SPF_CHANGEROT, '4');
|
||||||
|
|
||||||
if(a46 && whichPattern == PAT_COLORING && !nonchamfered)
|
if(a46 && whichPattern == PAT_COLORING && !nonbitrunc)
|
||||||
dialog::addBoolItem(XLAT("edit both chamfered colors"), subpattern_flags & SPF_TWOCOL, '5');
|
dialog::addBoolItem(XLAT("edit both bitrunc colors"), subpattern_flags & SPF_TWOCOL, '5');
|
||||||
|
|
||||||
if(
|
if(
|
||||||
(whichPattern == PAT_EMERALD && (stdhyperbolic || a38)) ||
|
(whichPattern == PAT_EMERALD && (stdhyperbolic || a38)) ||
|
||||||
@ -1261,15 +1261,15 @@ namespace patterns {
|
|||||||
if(euclid && among(whichPattern, PAT_COLORING, 0))
|
if(euclid && among(whichPattern, PAT_COLORING, 0))
|
||||||
dialog::addBoolItem(XLAT("full symmetry"), subpattern_flags & SPF_FULLSYM, '!');
|
dialog::addBoolItem(XLAT("full symmetry"), subpattern_flags & SPF_FULLSYM, '!');
|
||||||
|
|
||||||
if(a38 && nonchamfered && whichPattern == 0) {
|
if(a38 && nonbitrunc && whichPattern == 0) {
|
||||||
dialog::addBoolItem(XLAT("extra symmetries"), subpattern_flags & SPF_EXTRASYM, '=');
|
dialog::addBoolItem(XLAT("extra symmetries"), subpattern_flags & SPF_EXTRASYM, '=');
|
||||||
}
|
}
|
||||||
|
|
||||||
if(a46 && nonchamfered && whichPattern == PAT_COLORING) {
|
if(a46 && nonbitrunc && whichPattern == PAT_COLORING) {
|
||||||
dialog::addBoolItem(XLAT("extra symmetries"), subpattern_flags & SPF_EXTRASYM, '=');
|
dialog::addBoolItem(XLAT("extra symmetries"), subpattern_flags & SPF_EXTRASYM, '=');
|
||||||
}
|
}
|
||||||
|
|
||||||
if((a38 || (sphere && S7 == 4) || euclid4 || a46) && !nonchamfered) {
|
if((a38 || (sphere && S7 == 4) || euclid4 || a46) && !nonbitrunc) {
|
||||||
dialog::addBoolItem(XLAT("alternate coloring"), subpattern_flags & SPF_ALTERNATE, '\'');
|
dialog::addBoolItem(XLAT("alternate coloring"), subpattern_flags & SPF_ALTERNATE, '\'');
|
||||||
dialog::addBoolItem(XLAT("football pattern"), subpattern_flags & SPF_FOOTBALL, '*');
|
dialog::addBoolItem(XLAT("football pattern"), subpattern_flags & SPF_FOOTBALL, '*');
|
||||||
}
|
}
|
||||||
@ -1350,7 +1350,7 @@ namespace patterns {
|
|||||||
|
|
||||||
struct changeable_pattern_geometry {
|
struct changeable_pattern_geometry {
|
||||||
eGeometry geo;
|
eGeometry geo;
|
||||||
bool nonchamf;
|
bool nonbitru;
|
||||||
char whichPattern;
|
char whichPattern;
|
||||||
int subpattern_flags;
|
int subpattern_flags;
|
||||||
};
|
};
|
||||||
@ -1445,7 +1445,7 @@ namespace patterns {
|
|||||||
for(int j=0; j<size(cpatterns[cgroup].geometries); j++) {
|
for(int j=0; j<size(cpatterns[cgroup].geometries); j++) {
|
||||||
auto &g = cpatterns[cgroup].geometries[j];
|
auto &g = cpatterns[cgroup].geometries[j];
|
||||||
string s = XLAT(ginf[g.geo].name);
|
string s = XLAT(ginf[g.geo].name);
|
||||||
s += chamfernames[g.nonchamf];
|
s += bitruncnames[g.nonbitru];
|
||||||
if(g.subpattern_flags & SPF_ALTERNATE) s += " (alt)";
|
if(g.subpattern_flags & SPF_ALTERNATE) s += " (alt)";
|
||||||
if(g.subpattern_flags & SPF_DOCKS) s += " (Docks)";
|
if(g.subpattern_flags & SPF_DOCKS) s += " (Docks)";
|
||||||
if(cgroup == cpZebra) {
|
if(cgroup == cpZebra) {
|
||||||
@ -1453,7 +1453,7 @@ namespace patterns {
|
|||||||
else if(g.whichPattern == PAT_EMERALD) s += " (Emerald)";
|
else if(g.whichPattern == PAT_EMERALD) s += " (Emerald)";
|
||||||
else s += " (Zebra)";
|
else s += " (Zebra)";
|
||||||
}
|
}
|
||||||
dialog::addBoolItem(s, geometry == g.geo && nonchamfered == g.nonchamf && whichPattern == g.whichPattern && subpattern_flags == g.subpattern_flags, 'a'+j);
|
dialog::addBoolItem(s, geometry == g.geo && nonbitrunc == g.nonbitru && whichPattern == g.whichPattern && subpattern_flags == g.subpattern_flags, 'a'+j);
|
||||||
}
|
}
|
||||||
dialog::addBreak(100);
|
dialog::addBreak(100);
|
||||||
dialog::addItem("more tuning", 'r');
|
dialog::addItem("more tuning", 'r');
|
||||||
@ -1471,7 +1471,7 @@ namespace patterns {
|
|||||||
#endif
|
#endif
|
||||||
auto &g = cpatterns[cgroup].geometries[uni - 'a'];
|
auto &g = cpatterns[cgroup].geometries[uni - 'a'];
|
||||||
if(g.geo != geometry) { targetgeometry = g.geo; restartGame('g', false, true); }
|
if(g.geo != geometry) { targetgeometry = g.geo; restartGame('g', false, true); }
|
||||||
if(g.nonchamf != nonchamfered) restartGame('7', false, true);
|
if(g.nonbitru != nonbitrunc) restartGame('7', false, true);
|
||||||
whichPattern = g.whichPattern;
|
whichPattern = g.whichPattern;
|
||||||
subpattern_flags = g.subpattern_flags;
|
subpattern_flags = g.subpattern_flags;
|
||||||
#if CAP_TEXTURE
|
#if CAP_TEXTURE
|
||||||
@ -1488,7 +1488,7 @@ namespace patterns {
|
|||||||
for(int i=0; i<size(cpatterns); i++)
|
for(int i=0; i<size(cpatterns); i++)
|
||||||
for(int j=0; j<size(cpatterns[i].geometries); j++) {
|
for(int j=0; j<size(cpatterns[i].geometries); j++) {
|
||||||
auto &g = cpatterns[i].geometries[j];
|
auto &g = cpatterns[i].geometries[j];
|
||||||
if(geometry == g.geo && nonchamfered == g.nonchamf && whichPattern == g.whichPattern && subpattern_flags == g.subpattern_flags)
|
if(geometry == g.geo && nonbitrunc == g.nonbitru && whichPattern == g.whichPattern && subpattern_flags == g.subpattern_flags)
|
||||||
cgroup = cpatterntype(i);
|
cgroup = cpatterntype(i);
|
||||||
}
|
}
|
||||||
old_cgroup = cgroup;
|
old_cgroup = cgroup;
|
||||||
@ -1672,7 +1672,7 @@ namespace linepatterns {
|
|||||||
case patBigTriangles: {
|
case patBigTriangles: {
|
||||||
if(pseudohept(c) && !euclid) for(int i=0; i<S7; i++)
|
if(pseudohept(c) && !euclid) for(int i=0; i<S7; i++)
|
||||||
if(c->master->move[i] < c->master) {
|
if(c->master->move[i] < c->master) {
|
||||||
queueline(tC0(V), V*xspinpush0((nonchamfered?M_PI:0) -2*M_PI*i/S7, tessf), col, 2);
|
queueline(tC0(V), V*xspinpush0((nonbitrunc?M_PI:0) -2*M_PI*i/S7, tessf), col, 2);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@ -1680,20 +1680,20 @@ namespace linepatterns {
|
|||||||
case patBigRings: {
|
case patBigRings: {
|
||||||
if(pseudohept(c) && !euclid) for(int i=0; i<S7; i++)
|
if(pseudohept(c) && !euclid) for(int i=0; i<S7; i++)
|
||||||
if(c->master->move[i] && c->master->move[i] < c->master && c->master->move[i]->dm4 == c->master->dm4)
|
if(c->master->move[i] && c->master->move[i] < c->master && c->master->move[i]->dm4 == c->master->dm4)
|
||||||
queueline(tC0(V), V*xspinpush0((nonchamfered?M_PI:0) -2*M_PI*i/S7, tessf), col, 2);
|
queueline(tC0(V), V*xspinpush0((nonbitrunc?M_PI:0) -2*M_PI*i/S7, tessf), col, 2);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
case patTree:
|
case patTree:
|
||||||
if(ctof(c) && !euclid)
|
if(ctof(c) && !euclid)
|
||||||
queueline(tC0(V), V*ddi0(nonchamfered?S42:0, tessf), col, 2);
|
queueline(tC0(V), V*ddi0(nonbitrunc?S42:0, tessf), col, 2);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case patAltTree:
|
case patAltTree:
|
||||||
if(ctof(c) && !euclid && c->master->alt) {
|
if(ctof(c) && !euclid && c->master->alt) {
|
||||||
for(int i=0; i<S7; i++)
|
for(int i=0; i<S7; i++)
|
||||||
if(c->master->move[i] && c->master->move[i]->alt == c->master->alt->move[0])
|
if(c->master->move[i] && c->master->move[i]->alt == c->master->alt->move[0])
|
||||||
queueline(tC0(V), V*xspinpush0((nonchamfered?M_PI:0) -2*M_PI*i/S7, tessf), col, 2);
|
queueline(tC0(V), V*xspinpush0((nonbitrunc?M_PI:0) -2*M_PI*i/S7, tessf), col, 2);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
108
polygons.cpp
108
polygons.cpp
@ -1098,12 +1098,12 @@ hyperpoint hpxd(ld d, ld x, ld y, ld z) {
|
|||||||
double scalef;
|
double scalef;
|
||||||
|
|
||||||
hyperpoint hpxyzsc(double x, double y, double z) {
|
hyperpoint hpxyzsc(double x, double y, double z) {
|
||||||
if(nonchamfered) return hpxd(scalef, x, y, z);
|
if(nonbitrunc) return hpxd(scalef, x, y, z);
|
||||||
else return hpxyz(x,y,z);
|
else return hpxyz(x,y,z);
|
||||||
}
|
}
|
||||||
|
|
||||||
hyperpoint turtlevertex(int u, double x, double y, double z) {
|
hyperpoint turtlevertex(int u, double x, double y, double z) {
|
||||||
ld scale = nonchamfered ? scalef : 1;
|
ld scale = nonbitrunc ? scalef : 1;
|
||||||
if(u) scale /= 2;
|
if(u) scale /= 2;
|
||||||
return hpxd(scale, x, y, z);
|
return hpxd(scale, x, y, z);
|
||||||
}
|
}
|
||||||
@ -1148,7 +1148,7 @@ void bshape(hpcshape& sh, int p, double shzoom, int shapeid, double bonus = 0) {
|
|||||||
while(polydata[whereis + 2*qty] != NEWSHAPE) qty++;
|
while(polydata[whereis + 2*qty] != NEWSHAPE) qty++;
|
||||||
double shzoomx = shzoom;
|
double shzoomx = shzoom;
|
||||||
double shzoomy = shzoom;
|
double shzoomy = shzoom;
|
||||||
if(shzoom == WOLF) shzoomx = 1.5 * (nonchamfered ? crossf / hcrossf : 1), shzoomy = 1.6 * (nonchamfered ? crossf / hcrossf : 1);
|
if(shzoom == WOLF) shzoomx = 1.5 * (nonbitrunc ? crossf / hcrossf : 1), shzoomy = 1.6 * (nonbitrunc ? crossf / hcrossf : 1);
|
||||||
int rots2 = rots;
|
int rots2 = rots;
|
||||||
// shapes 368..370 are specially designed
|
// shapes 368..370 are specially designed
|
||||||
if(!(shapeid >= 368 && shapeid <= 370)) {
|
if(!(shapeid >= 368 && shapeid <= 370)) {
|
||||||
@ -1267,21 +1267,21 @@ void buildpolys() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// scales
|
// scales
|
||||||
scalef = nonchamfered ? crossf / hcrossf7 : hcrossf / hcrossf7;
|
scalef = nonbitrunc ? crossf / hcrossf7 : hcrossf / hcrossf7;
|
||||||
|
|
||||||
if(euclid) scalef *= .52/crossf;
|
if(euclid) scalef *= .52/crossf;
|
||||||
|
|
||||||
double scalef2 = nonchamfered ? crossf / hcrossf7 * .88 : euclid ? scalef : hcrossf / hcrossf7;
|
double scalef2 = nonbitrunc ? crossf / hcrossf7 * .88 : euclid ? scalef : hcrossf / hcrossf7;
|
||||||
|
|
||||||
double spzoom = sphere ? 1.4375 : 1;
|
double spzoom = sphere ? 1.4375 : 1;
|
||||||
|
|
||||||
double spzoom6 = sphere ? 1.2375 : 1;
|
double spzoom6 = sphere ? 1.2375 : 1;
|
||||||
double spzoom7 = sphere ? .8 : 1;
|
double spzoom7 = sphere ? .8 : 1;
|
||||||
|
|
||||||
double spzoomd7 = (nonchamfered && sphere) ? 1 : spzoom7;
|
double spzoomd7 = (nonbitrunc && sphere) ? 1 : spzoom7;
|
||||||
|
|
||||||
double fac80 = a45 ? 1.4 : a46 ? 1.2 : (a38) ? .7 : .8;
|
double fac80 = a45 ? 1.4 : a46 ? 1.2 : (a38) ? .7 : .8;
|
||||||
double fac94 = euclid ? .8 : a4 ? (nonchamfered ? 1.1 : .9) : .94;
|
double fac94 = euclid ? .8 : a4 ? (nonbitrunc ? 1.1 : .9) : .94;
|
||||||
|
|
||||||
if(euclid) fac80 = fac94 = .9;
|
if(euclid) fac80 = fac94 = .9;
|
||||||
|
|
||||||
@ -1296,11 +1296,11 @@ void buildpolys() {
|
|||||||
#define SHADMUL (S3==4 ? 1.05 : 1.3)
|
#define SHADMUL (S3==4 ? 1.05 : 1.3)
|
||||||
|
|
||||||
// procedural floors
|
// procedural floors
|
||||||
double shexf = nonchamfered ? crossf* .55 : hexf;
|
double shexf = nonbitrunc ? crossf* .55 : hexf;
|
||||||
|
|
||||||
double p = -.006;
|
double p = -.006;
|
||||||
|
|
||||||
int td = ((nonchamfered || euclid) && !(S7&1)) ? S42+S6 : 0;
|
int td = ((nonbitrunc || euclid) && !(S7&1)) ? S42+S6 : 0;
|
||||||
|
|
||||||
double trihepta0 = scalef*spzoom6*(.2776+p) * gsca(a4, 1.3, a46, .975, a47, .85, a38, .9) * bscale6;
|
double trihepta0 = scalef*spzoom6*(.2776+p) * gsca(a4, 1.3, a46, .975, a47, .85, a38, .9) * bscale6;
|
||||||
double trihepta1 = (sphere ? .54 : scalef*spzoom6*(.5273-2*p)) * gsca(a4, .8, a46, 1.075, sphere4, 1.3) * bscale7;
|
double trihepta1 = (sphere ? .54 : scalef*spzoom6*(.5273-2*p)) * gsca(a4, .8, a46, 1.075, sphere4, 1.3) * bscale7;
|
||||||
@ -1353,16 +1353,16 @@ void buildpolys() {
|
|||||||
|
|
||||||
bool strict = false;
|
bool strict = false;
|
||||||
|
|
||||||
if(a4 && nonchamfered) fac94 *= 1.1;
|
if(a4 && nonbitrunc) fac94 *= 1.1;
|
||||||
|
|
||||||
if(a46 && nonchamfered) fac94 *= .9;
|
if(a46 && nonbitrunc) fac94 *= .9;
|
||||||
|
|
||||||
double floorrad0 = shexf*fac80*spzoom;
|
double floorrad0 = shexf*fac80*spzoom;
|
||||||
|
|
||||||
double floorrad1 = strict ? hcrossf : euclid ? shexf*fac80*spzoom : shexf*fac94;
|
double floorrad1 = strict ? hcrossf : euclid ? shexf*fac80*spzoom : shexf*fac94;
|
||||||
|
|
||||||
if(euclid4) {
|
if(euclid4) {
|
||||||
if(nonchamfered)
|
if(nonbitrunc)
|
||||||
floorrad0 = floorrad1 = rhexf * .94;
|
floorrad0 = floorrad1 = rhexf * .94;
|
||||||
else
|
else
|
||||||
floorrad0 = hexvdist * .9,
|
floorrad0 = hexvdist * .9,
|
||||||
@ -1513,7 +1513,7 @@ void buildpolys() {
|
|||||||
hpcpush(ddi(0, -shexf*2.4) * C0);
|
hpcpush(ddi(0, -shexf*2.4) * C0);
|
||||||
|
|
||||||
bshape(shMirror, PPR_WALL);
|
bshape(shMirror, PPR_WALL);
|
||||||
if(nonchamfered) {
|
if(nonbitrunc) {
|
||||||
for(int t=0; t<=S7; t++) hpcpush(ddi(t*12, shexf*MF(fac80,7)) * C0);
|
for(int t=0; t<=S7; t++) hpcpush(ddi(t*12, shexf*MF(fac80,7)) * C0);
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
@ -1577,9 +1577,9 @@ void buildpolys() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
double disksize = crossf;
|
double disksize = crossf;
|
||||||
if(nonchamfered && a38) disksize *= 2;
|
if(nonbitrunc && a38) disksize *= 2;
|
||||||
else if(a38) disksize *= 1.5;
|
else if(a38) disksize *= 1.5;
|
||||||
else if(nonchamfered && S6 == 8) disksize *= 1.5;
|
else if(nonbitrunc && S6 == 8) disksize *= 1.5;
|
||||||
|
|
||||||
bshape(shDisk, PPR_ITEM);
|
bshape(shDisk, PPR_ITEM);
|
||||||
for(int i=0; i<=S84; i+=S3)
|
for(int i=0; i<=S84; i+=S3)
|
||||||
@ -1793,9 +1793,9 @@ void buildpolys() {
|
|||||||
|
|
||||||
if(a38) spzoom6 *= .9;
|
if(a38) spzoom6 *= .9;
|
||||||
|
|
||||||
if(a4 && !nonchamfered) spzoom6 *= 1.9, spzoom7 *= .9, spzoomd7 *= .9;
|
if(a4 && !nonbitrunc) spzoom6 *= 1.9, spzoom7 *= .9, spzoomd7 *= .9;
|
||||||
if(a46 && !nonchamfered) spzoom6 *= .9;
|
if(a46 && !nonbitrunc) spzoom6 *= .9;
|
||||||
if(a47 && !nonchamfered) spzoom6 *= .85;
|
if(a47 && !nonbitrunc) spzoom6 *= .85;
|
||||||
|
|
||||||
double espzoom6 = spzoom6, espzoomd7 = spzoomd7;
|
double espzoom6 = spzoom6, espzoomd7 = spzoomd7;
|
||||||
|
|
||||||
@ -1823,18 +1823,18 @@ void buildpolys() {
|
|||||||
bshape(shCrossFloor[0], PPR_FLOOR, scalef*espzoom6*gsca(sphere,.9)*ffscale2, 5, ffspin2);
|
bshape(shCrossFloor[0], PPR_FLOOR, scalef*espzoom6*gsca(sphere,.9)*ffscale2, 5, ffspin2);
|
||||||
bshape(shCrossFloor[1], PPR_FLOOR, scalef*espzoomd7*gsca(sphere,.9)*ffscale2 * gsca(a47,1.3), 6, octroll);
|
bshape(shCrossFloor[1], PPR_FLOOR, scalef*espzoomd7*gsca(sphere,.9)*ffscale2 * gsca(a47,1.3), 6, octroll);
|
||||||
|
|
||||||
double ntscale = gsca(nonchamfered, gsca(a38, 1.4, a47, 2, a46, 1.525));
|
double ntscale = gsca(nonbitrunc, gsca(a38, 1.4, a47, 2, a46, 1.525));
|
||||||
double ntrot = grot(a46&&nonchamfered, .25, a38&&nonchamfered, -.2);
|
double ntrot = grot(a46&&nonbitrunc, .25, a38&&nonbitrunc, -.2);
|
||||||
|
|
||||||
bshape(shChargedFloor[0], PPR_FLOOR, scalef*espzoom6*gsca(sphere,.9)*ffscale2, 7, ffspin2);
|
bshape(shChargedFloor[0], PPR_FLOOR, scalef*espzoom6*gsca(sphere,.9)*ffscale2, 7, ffspin2);
|
||||||
bshape(shChargedFloor[1], PPR_FLOOR, scalef*spzoomd7, 9);
|
bshape(shChargedFloor[1], PPR_FLOOR, scalef*spzoomd7, 9);
|
||||||
bshape(shChargedFloor[2], PPR_FLOOR, scalef*espzoom6, 7);
|
bshape(shChargedFloor[2], PPR_FLOOR, scalef*espzoom6, 7);
|
||||||
bshape(shChargedFloor[3], 12, spzoomd7 * gsca(a4 && euclid, .4, a4,1.2,sphere&&nonchamfered,.9)* ntscale, 10, ntrot + grot(euclid4 && nonchamfered, M_PI/4 + .1)); // nonchamfered variant
|
bshape(shChargedFloor[3], 12, spzoomd7 * gsca(a4 && euclid, .4, a4,1.2,sphere&&nonbitrunc,.9)* ntscale, 10, ntrot + grot(euclid4 && nonbitrunc, M_PI/4 + .1)); // nonbitrunc variant
|
||||||
|
|
||||||
bshape(shSStarFloor[0], PPR_FLOOR, scalef*spzoom6*gsca(sphere,.8)*ffscale2, 11, grot(a4,.775));
|
bshape(shSStarFloor[0], PPR_FLOOR, scalef*spzoom6*gsca(sphere,.8)*ffscale2, 11, grot(a4,.775));
|
||||||
bshape(shSStarFloor[1], PPR_FLOOR, scalef*spzoomd7*gsca(a4,.85), 12, octroll);
|
bshape(shSStarFloor[1], PPR_FLOOR, scalef*spzoomd7*gsca(a4,.85), 12, octroll);
|
||||||
bshape(shOverFloor[0], PPR_FLOOR, scalef*spzoom * gsca(a47,1.3, a45,1.3, a46,1.1), 13, grot(a47,-.75, a45,-.7, a46,.9));
|
bshape(shOverFloor[0], PPR_FLOOR, scalef*spzoom * gsca(a47,1.3, a45,1.3, a46,1.1), 13, grot(a47,-.75, a45,-.7, a46,.9));
|
||||||
if(nonchamfered) {
|
if(nonbitrunc) {
|
||||||
if(a4) bshape(shOverFloor[1], PPR_FLOOR, 1, 368 + S7 - 5, 0);
|
if(a4) bshape(shOverFloor[1], PPR_FLOOR, 1, 368 + S7 - 5, 0);
|
||||||
else bshape(shOverFloor[1], PPR_FLOOR, gsca(a38,1.3, sphere, .83), 14, octroll + grot(a38,.4));
|
else bshape(shOverFloor[1], PPR_FLOOR, gsca(a38,1.3, sphere, .83), 14, octroll + grot(a38,.4));
|
||||||
}
|
}
|
||||||
@ -1843,12 +1843,12 @@ void buildpolys() {
|
|||||||
bshape(shTriFloor[0], PPR_FLOOR, scalef*espzoom6*gsca(sphere,.9, a4,.9)*ffscale2, 17, ffspin2 + grot(a47,.1));
|
bshape(shTriFloor[0], PPR_FLOOR, scalef*espzoom6*gsca(sphere,.9, a4,.9)*ffscale2, 17, ffspin2 + grot(a47,.1));
|
||||||
bshape(shTriFloor[1], PPR_FLOOR, scalef*espzoomd7*ffscale2*gsca(a4,1.2, a47,1.5), 18, octroll + grot(a4,.25, a47,-.1, sphere4,.7) + grot(euclid&&a4, M_PI/8));
|
bshape(shTriFloor[1], PPR_FLOOR, scalef*espzoomd7*ffscale2*gsca(a4,1.2, a47,1.5), 18, octroll + grot(a4,.25, a47,-.1, sphere4,.7) + grot(euclid&&a4, M_PI/8));
|
||||||
bshape(shFeatherFloor[0], PPR_FLOOR, scalef*spzoom6*ffscale2, 19, ffspin2);
|
bshape(shFeatherFloor[0], PPR_FLOOR, scalef*spzoom6*ffscale2, 19, ffspin2);
|
||||||
if(nonchamfered) bshape(shFeatherFloor[1], PPR_FLOOR, sphere ? .83 : gsca(ap4,1.1) * ntscale, 20, ntrot);
|
if(nonbitrunc) bshape(shFeatherFloor[1], PPR_FLOOR, sphere ? .83 : gsca(ap4,1.1) * ntscale, 20, ntrot);
|
||||||
else bshape(shFeatherFloor[1], PPR_FLOOR, scalef*spzoom7*gsca(sphere,1.1,a4,1.1)*ffscale2*ntscale, 21, sphere?1.3:ntrot);
|
else bshape(shFeatherFloor[1], PPR_FLOOR, scalef*spzoom7*gsca(sphere,1.1,a4,1.1)*ffscale2*ntscale, 21, sphere?1.3:ntrot);
|
||||||
bshape(shFeatherFloor[2], PPR_FLOOR, scalef*1.1, 22); // Euclidean variant
|
bshape(shFeatherFloor[2], PPR_FLOOR, scalef*1.1, 22); // Euclidean variant
|
||||||
bshape(shBarrowFloor[0], PPR_FLOOR, gsca(euclid,.9) * spzoom6 * gsca(a467,1.7, a46,.8, a38,1.4) * gsca(euclid&&a4, .7), 23);
|
bshape(shBarrowFloor[0], PPR_FLOOR, gsca(euclid,.9) * spzoom6 * gsca(a467,1.7, a46,.8, a38,1.4) * gsca(euclid&&a4, .7), 23);
|
||||||
bshape(shBarrowFloor[1], PPR_FLOOR, spzoomd7 * gsca(a4,1.15, a467,1.9, a46,.8, a38,1.5, sphere&&nonchamfered,.9) * gsca(euclid&&a4, .5), 24, octroll - grot(a47,.1));
|
bshape(shBarrowFloor[1], PPR_FLOOR, spzoomd7 * gsca(a4,1.15, a467,1.9, a46,.8, a38,1.5, sphere&&nonbitrunc,.9) * gsca(euclid&&a4, .5), 24, octroll - grot(a47,.1));
|
||||||
bshape(shBarrowFloor[2], PPR_FLOOR, ntscale*gsca(sphere||euclid,.9) * gsca(euclid&&a4&&nonchamfered, .5), 25, ntrot + grot(euclid&&a4&&nonchamfered, M_PI/4));
|
bshape(shBarrowFloor[2], PPR_FLOOR, ntscale*gsca(sphere||euclid,.9) * gsca(euclid&&a4&&nonbitrunc, .5), 25, ntrot + grot(euclid&&a4&&nonbitrunc, M_PI/4));
|
||||||
bshape(shNewFloor[0], PPR_FLOOR, scalef*espzoom6 * ffscale2, 26, ffspin2);
|
bshape(shNewFloor[0], PPR_FLOOR, scalef*espzoom6 * ffscale2, 26, ffspin2);
|
||||||
bshape(shNewFloor[1], PPR_FLOOR, scalef*espzoomd7 * ffscale2, 27, octroll);
|
bshape(shNewFloor[1], PPR_FLOOR, scalef*espzoomd7 * ffscale2, 27, octroll);
|
||||||
|
|
||||||
@ -1930,7 +1930,7 @@ void buildpolys() {
|
|||||||
zoomShape(shDesertFloor[j], shRedRockFloor[i-1][j], 1 - .1 * i, PPR_FLOORa+i);
|
zoomShape(shDesertFloor[j], shRedRockFloor[i-1][j], 1 - .1 * i, PPR_FLOORa+i);
|
||||||
bshape(shPowerFloor[0], PPR_FLOOR_DRAGON, scalef*espzoom6*gsca(sphere,.8)*ffscale2, 57, ffspin2);
|
bshape(shPowerFloor[0], PPR_FLOOR_DRAGON, scalef*espzoom6*gsca(sphere,.8)*ffscale2, 57, ffspin2);
|
||||||
bshape(shPowerFloor[1], PPR_FLOOR_DRAGON, scalef*espzoomd7*ffscale2, 58, octroll);
|
bshape(shPowerFloor[1], PPR_FLOOR_DRAGON, scalef*espzoomd7*ffscale2, 58, octroll);
|
||||||
bshape(shRoseFloor[2], PPR_FLOOR, 1, 173); // nonchamfered
|
bshape(shRoseFloor[2], PPR_FLOOR, 1, 173); // nonbitrunc
|
||||||
bshape(shRoseFloor[0], PPR_FLOOR, gsca(euclid,.9), 174);
|
bshape(shRoseFloor[0], PPR_FLOOR, gsca(euclid,.9), 174);
|
||||||
bshape(shRoseFloor[1], PPR_FLOOR, gsca(euclid,.9) * scalef * gsca(ap4,.85), 175, grot(ap4, M_PI/8));
|
bshape(shRoseFloor[1], PPR_FLOOR, gsca(euclid,.9) * scalef * gsca(ap4,.85), 175, grot(ap4, M_PI/8));
|
||||||
|
|
||||||
@ -1942,7 +1942,7 @@ void buildpolys() {
|
|||||||
|
|
||||||
bshape(shTurtleFloor[0], PPR_FLOOR, gsca(euclid,.9, sphere, .9*1.3, a4, 1.6, a38, 1.3, a467, 1.4) * gsca(euclid&&a4, .9), 176);
|
bshape(shTurtleFloor[0], PPR_FLOOR, gsca(euclid,.9, sphere, .9*1.3, a4, 1.6, a38, 1.3, a467, 1.4) * gsca(euclid&&a4, .9), 176);
|
||||||
bshape(shTurtleFloor[1], PPR_FLOOR, scalef * gsca(euclid,.9, a4, .9, a47,1.3) * gsca(euclid&&a4, .8), 177, octroll - grot(a47,.1));
|
bshape(shTurtleFloor[1], PPR_FLOOR, scalef * gsca(euclid,.9, a4, .9, a47,1.3) * gsca(euclid&&a4, .8), 177, octroll - grot(a47,.1));
|
||||||
bshape(shTurtleFloor[2], PPR_FLOOR, ntscale * gsca(sphere && nonchamfered, .9) * gsca(euclid&&a4&&nonchamfered, .5), 178, ntrot + grot(euclid&&a4&&nonchamfered, M_PI/4)); // nonchamfered
|
bshape(shTurtleFloor[2], PPR_FLOOR, ntscale * gsca(sphere && nonbitrunc, .9) * gsca(euclid&&a4&&nonbitrunc, .5), 178, ntrot + grot(euclid&&a4&&nonbitrunc, M_PI/4)); // nonbitrunc
|
||||||
|
|
||||||
bshape(shDragonFloor[0], PPR_FLOOR_DRAGON, gsca(a4,1.6, a38, 1.3) * gsca(euclid&&a4, .5), 181, ffspin2);
|
bshape(shDragonFloor[0], PPR_FLOOR_DRAGON, gsca(a4,1.6, a38, 1.3) * gsca(euclid&&a4, .5), 181, ffspin2);
|
||||||
bshape(shDragonFloor[1], PPR_FLOOR_DRAGON, gsca(sphere, .9, a38, 1.1, a4,.9) * scalef, 182, octroll);
|
bshape(shDragonFloor[1], PPR_FLOOR_DRAGON, gsca(sphere, .9, a38, 1.1, a4,.9) * scalef, 182, octroll);
|
||||||
@ -1951,7 +1951,7 @@ void buildpolys() {
|
|||||||
bshape(shZebra[1], PPR_FLOOR, scalef, 163);
|
bshape(shZebra[1], PPR_FLOOR, scalef, 163);
|
||||||
bshape(shZebra[2], PPR_FLOOR, scalef, 164);
|
bshape(shZebra[2], PPR_FLOOR, scalef, 164);
|
||||||
bshape(shZebra[3], PPR_FLOOR, scalef, 165);
|
bshape(shZebra[3], PPR_FLOOR, scalef, 165);
|
||||||
bshape(shZebra[4], PPR_FLOOR, 1, 166); // for nonchamfered
|
bshape(shZebra[4], PPR_FLOOR, 1, 166); // for nonbitrunc
|
||||||
bshape(shEmeraldFloor[0], PPR_FLOOR, scalef, 167); // 4
|
bshape(shEmeraldFloor[0], PPR_FLOOR, scalef, 167); // 4
|
||||||
bshape(shEmeraldFloor[1], PPR_FLOOR, scalef, 168); // 12
|
bshape(shEmeraldFloor[1], PPR_FLOOR, scalef, 168); // 12
|
||||||
bshape(shEmeraldFloor[2], PPR_FLOOR, scalef, 169); // 16
|
bshape(shEmeraldFloor[2], PPR_FLOOR, scalef, 169); // 16
|
||||||
@ -1965,9 +1965,9 @@ void buildpolys() {
|
|||||||
bshape(shTower[4], PPR_FLOOR_TOWER, scalef, 200); // 9
|
bshape(shTower[4], PPR_FLOOR_TOWER, scalef, 200); // 9
|
||||||
bshape(shTower[5], PPR_FLOOR_TOWER, scalef, 201); // 10
|
bshape(shTower[5], PPR_FLOOR_TOWER, scalef, 201); // 10
|
||||||
bshape(shTower[6], PPR_FLOOR_TOWER, scalef, 202); // 10
|
bshape(shTower[6], PPR_FLOOR_TOWER, scalef, 202); // 10
|
||||||
bshape(shTower[7], PPR_FLOOR_TOWER, 1, 203); // nonchamfered 7
|
bshape(shTower[7], PPR_FLOOR_TOWER, 1, 203); // nonbitrunc 7
|
||||||
bshape(shTower[8], PPR_FLOOR_TOWER, 1, 204); // nonchamfered 11
|
bshape(shTower[8], PPR_FLOOR_TOWER, 1, 204); // nonbitrunc 11
|
||||||
bshape(shTower[9], PPR_FLOOR_TOWER, 1, 205); // nonchamfered 15
|
bshape(shTower[9], PPR_FLOOR_TOWER, 1, 205); // nonbitrunc 15
|
||||||
bshape(shTower[10], PPR_FLOOR_TOWER, scalef, 206); // Euclidean
|
bshape(shTower[10], PPR_FLOOR_TOWER, scalef, 206); // Euclidean
|
||||||
|
|
||||||
// structures & walls
|
// structures & walls
|
||||||
@ -2000,17 +2000,17 @@ void buildpolys() {
|
|||||||
copyshape(shJoint, shDisk, PPR_ONTENTACLE);
|
copyshape(shJoint, shDisk, PPR_ONTENTACLE);
|
||||||
bshape(shTentHead, PPR_ONTENTACLE, scalef, 79);
|
bshape(shTentHead, PPR_ONTENTACLE, scalef, 79);
|
||||||
bshape(shWormHead, PPR_ONTENTACLE, scalef, 80);
|
bshape(shWormHead, PPR_ONTENTACLE, scalef, 80);
|
||||||
if(nonchamfered) bshape(shDragonSegment, PPR_TENTACLE1, 1, 233);
|
if(nonbitrunc) bshape(shDragonSegment, PPR_TENTACLE1, 1, 233);
|
||||||
else bshape(shDragonSegment, PPR_TENTACLE1, scalef, 234);
|
else bshape(shDragonSegment, PPR_TENTACLE1, scalef, 234);
|
||||||
bshape(shDragonWings, PPR_ONTENTACLE, scalef, 237);
|
bshape(shDragonWings, PPR_ONTENTACLE, scalef, 237);
|
||||||
bshape(shDragonLegs, PPR_TENTACLE0, scalef, 238);
|
bshape(shDragonLegs, PPR_TENTACLE0, scalef, 238);
|
||||||
if(nonchamfered) bshape(shDragonTail, PPR_TENTACLE1, 1, 239);
|
if(nonbitrunc) bshape(shDragonTail, PPR_TENTACLE1, 1, 239);
|
||||||
else bshape(shDragonTail, PPR_TENTACLE1, scalef, 240);
|
else bshape(shDragonTail, PPR_TENTACLE1, scalef, 240);
|
||||||
bshape(shDragonNostril, PPR_ONTENTACLE_EYES, scalef, 241);
|
bshape(shDragonNostril, PPR_ONTENTACLE_EYES, scalef, 241);
|
||||||
bshape(shDragonHead, PPR_ONTENTACLE, scalef, 242);
|
bshape(shDragonHead, PPR_ONTENTACLE, scalef, 242);
|
||||||
if(nonchamfered) bshape(shSeaTentacle, PPR_TENTACLE1, 1, 245);
|
if(nonbitrunc) bshape(shSeaTentacle, PPR_TENTACLE1, 1, 245);
|
||||||
else bshape(shSeaTentacle, PPR_TENTACLE1, 1, 246);
|
else bshape(shSeaTentacle, PPR_TENTACLE1, 1, 246);
|
||||||
ld ksc = nonchamfered ? 1.8 : 1.5;
|
ld ksc = nonbitrunc ? 1.8 : 1.5;
|
||||||
bshape(shKrakenHead, PPR_ONTENTACLE, ksc, 247);
|
bshape(shKrakenHead, PPR_ONTENTACLE, ksc, 247);
|
||||||
bshape(shKrakenEye, PPR_ONTENTACLE_EYES, ksc, 248);
|
bshape(shKrakenEye, PPR_ONTENTACLE_EYES, ksc, 248);
|
||||||
bshape(shKrakenEye2, PPR_ONTENTACLE_EYES2, ksc, 249);
|
bshape(shKrakenEye2, PPR_ONTENTACLE_EYES2, ksc, 249);
|
||||||
@ -2241,10 +2241,10 @@ void buildpolys() {
|
|||||||
for(int v=0; v<13; v++) for(int z=0; z<2; z++)
|
for(int v=0; v<13; v++) for(int z=0; z<2; z++)
|
||||||
copyshape(shTortoise[v][4+z], shTortoise[v][2+z], shTortoise[v][2+z].prio + (PPR_CARRIED-PPR_ITEM));
|
copyshape(shTortoise[v][4+z], shTortoise[v][2+z], shTortoise[v][2+z].prio + (PPR_CARRIED-PPR_ITEM));
|
||||||
|
|
||||||
if(nonchamfered) bshape(shMagicSword, PPR_MAGICSWORD, 1, 243);
|
if(nonbitrunc) bshape(shMagicSword, PPR_MAGICSWORD, 1, 243);
|
||||||
else bshape(shMagicSword, PPR_MAGICSWORD, 1, 244);
|
else bshape(shMagicSword, PPR_MAGICSWORD, 1, 244);
|
||||||
|
|
||||||
if(nonchamfered) bshape(shMagicShovel, PPR_MAGICSWORD, 1, 333);
|
if(nonbitrunc) bshape(shMagicShovel, PPR_MAGICSWORD, 1, 333);
|
||||||
else bshape(shMagicShovel, PPR_MAGICSWORD, 1, 333);
|
else bshape(shMagicShovel, PPR_MAGICSWORD, 1, 333);
|
||||||
|
|
||||||
bshape(shBead0, 20, 1, 250);
|
bshape(shBead0, 20, 1, 250);
|
||||||
@ -2378,7 +2378,7 @@ bool isSpecial(const hpcshape &h) {
|
|||||||
const hpcshape& getSeabed(const hpcshape& c) {
|
const hpcshape& getSeabed(const hpcshape& c) {
|
||||||
if(&c == &shCloudFloor[2]) return shCloudSeabed[2];
|
if(&c == &shCloudFloor[2]) return shCloudSeabed[2];
|
||||||
if(&c == &shCaveFloor[2]) return shCaveSeabed[2];
|
if(&c == &shCaveFloor[2]) return shCaveSeabed[2];
|
||||||
if(nonchamfered || euclid || sphere) return c;
|
if(nonbitrunc || euclid || sphere) return c;
|
||||||
if(&c == &shFloor[0]) return shFullFloor[0];
|
if(&c == &shFloor[0]) return shFullFloor[0];
|
||||||
if(&c == &shFloor[1]) return shFullFloor[1];
|
if(&c == &shFloor[1]) return shFullFloor[1];
|
||||||
if(&c == &shCaveFloor[0]) return shCaveSeabed[0];
|
if(&c == &shCaveFloor[0]) return shCaveSeabed[0];
|
||||||
@ -3430,7 +3430,7 @@ NEWSHAPE, 366, 1, 2, 0.120242,0.202432, 0.476077,0.202192,
|
|||||||
|
|
||||||
NEWSHAPE, 367, 1, 2, -0.096569,0.019944, 0.040859,0.019906, 0.037742,0.058710, 0.116624,-0.000000,
|
NEWSHAPE, 367, 1, 2, -0.096569,0.019944, 0.040859,0.019906, 0.037742,0.058710, 0.116624,-0.000000,
|
||||||
|
|
||||||
// overgrown for 4-5 to 4-7 non-chamfered
|
// overgrown for 4-5 to 4-7 non-bitrunc
|
||||||
NEWSHAPE, 368, 5, 1, -0.722750,-0.522024, -0.310675,-0.189104, -0.809015,-0.052887, -0.464722,0.060902, -1.057795,0.207750,
|
NEWSHAPE, 368, 5, 1, -0.722750,-0.522024, -0.310675,-0.189104, -0.809015,-0.052887, -0.464722,0.060902, -1.057795,0.207750,
|
||||||
NEWSHAPE, 369, 6, 1, 1.125689,-0.648796, 0.574166,-0.456509, 0.822679,-1.131184, 0.174168,-0.605003, 0.411340,-1.336854,
|
NEWSHAPE, 369, 6, 1, 1.125689,-0.648796, 0.574166,-0.456509, 0.822679,-1.131184, 0.174168,-0.605003, 0.411340,-1.336854,
|
||||||
NEWSHAPE, 370, 7, 1, 1.034599,-1.366924, 0.528060,-0.892063, 0.490794,-1.701844, 0.081991,-0.819912, 0.042928,-1.637383,
|
NEWSHAPE, 370, 7, 1, 1.034599,-1.366924, 0.528060,-0.892063, 0.490794,-1.701844, 0.081991,-0.819912, 0.042928,-1.637383,
|
||||||
@ -3457,20 +3457,20 @@ NEWSHAPE
|
|||||||
/* floors */
|
/* floors */
|
||||||
|
|
||||||
// need eswap
|
// need eswap
|
||||||
#define DESERTFLOOR (nonchamfered ? shCloudFloor : shDesertFloor)[ct6]
|
#define DESERTFLOOR (nonbitrunc ? shCloudFloor : shDesertFloor)[ct6]
|
||||||
#define BUTTERFLYFLOOR (nonchamfered ? shFloor : shButterflyFloor)[ct6]
|
#define BUTTERFLYFLOOR (nonbitrunc ? shFloor : shButterflyFloor)[ct6]
|
||||||
#define PALACEFLOOR (nonchamfered?shFloor:shPalaceFloor)[ct6]
|
#define PALACEFLOOR (nonbitrunc?shFloor:shPalaceFloor)[ct6]
|
||||||
#define SSTARFLOOR (nonchamfered ? shCloudFloor : shSStarFloor)[ct6]
|
#define SSTARFLOOR (nonbitrunc ? shCloudFloor : shSStarFloor)[ct6]
|
||||||
#define POWERFLOOR (nonchamfered ? shStarFloor : shPowerFloor)[ct6]
|
#define POWERFLOOR (nonbitrunc ? shStarFloor : shPowerFloor)[ct6]
|
||||||
#define CHARGEDFLOOR (nonchamfered ? shChargedFloor[3] : ct6 ? shFloor[1] : shChargedFloor[0])
|
#define CHARGEDFLOOR (nonbitrunc ? shChargedFloor[3] : ct6 ? shFloor[1] : shChargedFloor[0])
|
||||||
#define DEMONFLOOR shDemonFloor[ct6]
|
#define DEMONFLOOR shDemonFloor[ct6]
|
||||||
#define NEWFLOOR (nonchamfered ? shCloudFloor : shNewFloor)[ct6]
|
#define NEWFLOOR (nonbitrunc ? shCloudFloor : shNewFloor)[ct6]
|
||||||
#define CROSSFLOOR (nonchamfered ? shFloor : shCrossFloor)[ct6]
|
#define CROSSFLOOR (nonbitrunc ? shFloor : shCrossFloor)[ct6]
|
||||||
#define TROLLFLOOR shTrollFloor[ct6]
|
#define TROLLFLOOR shTrollFloor[ct6]
|
||||||
#define BARROWFLOOR shBarrowFloor[(euclid&&!a4)?0:nonchamfered?2:ct6]
|
#define BARROWFLOOR shBarrowFloor[(euclid&&!a4)?0:nonbitrunc?2:ct6]
|
||||||
#define LAVAFLOOR (nonchamfered ? shFloor : shLavaFloor)[ct6]
|
#define LAVAFLOOR (nonbitrunc ? shFloor : shLavaFloor)[ct6]
|
||||||
#define TRIFLOOR ((nonchamfered ? shFloor : shTriFloor)[ct6])
|
#define TRIFLOOR ((nonbitrunc ? shFloor : shTriFloor)[ct6])
|
||||||
#define TURTLEFLOOR shTurtleFloor[nonchamfered ? 2 : ct6]
|
#define TURTLEFLOOR shTurtleFloor[nonbitrunc ? 2 : ct6]
|
||||||
#define ROSEFLOOR shRoseFloor[ct6]
|
#define ROSEFLOOR shRoseFloor[ct6]
|
||||||
|
|
||||||
#define ECT ((euclid&&!a4)?2:ct6)
|
#define ECT ((euclid&&!a4)?2:ct6)
|
||||||
@ -3479,14 +3479,14 @@ NEWSHAPE
|
|||||||
#define PLAINFLOOR shFloor[ct6]
|
#define PLAINFLOOR shFloor[ct6]
|
||||||
#define FULLFLOOR shFullFloor[ct6]
|
#define FULLFLOOR shFullFloor[ct6]
|
||||||
#define CAVEFLOOR shCaveFloor[ECT]
|
#define CAVEFLOOR shCaveFloor[ECT]
|
||||||
#define OVERFLOOR shOverFloor[euclid&&a4&&nonchamfered?2:ECT]
|
#define OVERFLOOR shOverFloor[euclid&&a4&&nonbitrunc?2:ECT]
|
||||||
#define CLOUDFLOOR shCloudFloor[ECT]
|
#define CLOUDFLOOR shCloudFloor[ECT]
|
||||||
#define FEATHERFLOOR shFeatherFloor[euclid&&a4&&nonchamfered?2:ECT]
|
#define FEATHERFLOOR shFeatherFloor[euclid&&a4&&nonbitrunc?2:ECT]
|
||||||
#define MFLOOR1 shMFloor[ct6]
|
#define MFLOOR1 shMFloor[ct6]
|
||||||
#define MFLOOR2 shMFloor2[ct6]
|
#define MFLOOR2 shMFloor2[ct6]
|
||||||
#define STARFLOOR shStarFloor[ECT]
|
#define STARFLOOR shStarFloor[ECT]
|
||||||
#define DRAGONFLOOR shDragonFloor[ECT]
|
#define DRAGONFLOOR shDragonFloor[ECT]
|
||||||
#define SWITCHFLOOR shSwitchFloor[nonchamfered?2:ct6]
|
#define SWITCHFLOOR shSwitchFloor[nonbitrunc?2:ct6]
|
||||||
|
|
||||||
// fix Warp
|
// fix Warp
|
||||||
// fix Kraken
|
// fix Kraken
|
||||||
|
@ -520,7 +520,7 @@ namespace sag {
|
|||||||
}
|
}
|
||||||
|
|
||||||
void initSnake(int n) {
|
void initSnake(int n) {
|
||||||
if(sphere && nonchamfered) n = 12;
|
if(sphere && nonbitrunc) n = 12;
|
||||||
else if(sphere) n = 32;
|
else if(sphere) n = 32;
|
||||||
numsnake = n;
|
numsnake = n;
|
||||||
snakecells.resize(numsnake);
|
snakecells.resize(numsnake);
|
||||||
@ -1127,7 +1127,7 @@ void drawVertex(const transmatrix &V, cell *c, shmup::monster *m) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
hyperpoint h = tC0(V * m->at);
|
hyperpoint h = tC0(V * m->at);
|
||||||
transmatrix V2 = rgpushxto0(h) * ypush(nonchamfered ? .3 : .2);
|
transmatrix V2 = rgpushxto0(h) * ypush(nonbitrunc ? .3 : .2);
|
||||||
if(doshow) queuestr(V2, (svg::in ? .28 : .2) * crossf / hcrossf, vd.name, backcolor ? 0x000000 : 0xFFFF00, svg::in ? 0 : 1);
|
if(doshow) queuestr(V2, (svg::in ? .28 : .2) * crossf / hcrossf, vd.name, backcolor ? 0x000000 : 0xFFFF00, svg::in ? 0 : 1);
|
||||||
lastptd().info = vd.info;
|
lastptd().info = vd.info;
|
||||||
}
|
}
|
||||||
@ -1768,7 +1768,7 @@ using namespace tour;
|
|||||||
|
|
||||||
string cname() {
|
string cname() {
|
||||||
if(euclid) return "coord-6.txt";
|
if(euclid) return "coord-6.txt";
|
||||||
if(nonchamfered) return "coord-7.txt";
|
if(nonbitrunc) return "coord-7.txt";
|
||||||
return "coord-67.txt";
|
return "coord-67.txt";
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -43,7 +43,7 @@ int modediff(score *S) {
|
|||||||
if(S->box[238]) g = gSphere;
|
if(S->box[238]) g = gSphere;
|
||||||
if(S->box[239]) g = gElliptic;
|
if(S->box[239]) g = gElliptic;
|
||||||
if(max(S->box[197], 1) != multi::players) diff += 8;
|
if(max(S->box[197], 1) != multi::players) diff += 8;
|
||||||
if(S->box[186] != nonchamfered) diff += 16;
|
if(S->box[186] != nonbitrunc) diff += 16;
|
||||||
if(S->box[196] != chaosmode) diff += 32;
|
if(S->box[196] != chaosmode) diff += 32;
|
||||||
if(S->box[119] != shmup::on) diff += 64;
|
if(S->box[119] != shmup::on) diff += 64;
|
||||||
if(pureHardcore() && !isHardcore(S)) diff += 128;
|
if(pureHardcore() && !isHardcore(S)) diff += 128;
|
||||||
|
@ -3344,7 +3344,7 @@ transmatrix calc_relative_matrix_help(cell *c, heptagon *h1) {
|
|||||||
transmatrix gm = Id;
|
transmatrix gm = Id;
|
||||||
heptagon *h2 = c->master;
|
heptagon *h2 = c->master;
|
||||||
transmatrix where = Id;
|
transmatrix where = Id;
|
||||||
if(!nonchamfered) for(int d=0; d<S7; d++) if(h2->c7->mov[d] == c)
|
if(!nonbitrunc) for(int d=0; d<S7; d++) if(h2->c7->mov[d] == c)
|
||||||
where = hexmove[d];
|
where = hexmove[d];
|
||||||
// always add to last!
|
// always add to last!
|
||||||
while(h1 != h2) {
|
while(h1 != h2) {
|
||||||
@ -3413,8 +3413,8 @@ void virtualRebase(cell*& base, transmatrix& at, bool tohex) {
|
|||||||
hs.h = h;
|
hs.h = h;
|
||||||
hs.spin = d;
|
hs.spin = d;
|
||||||
heptspin hs2 = hsstep(hs, 0);
|
heptspin hs2 = hsstep(hs, 0);
|
||||||
transmatrix V2 = spin((nonchamfered?M_PI:0)-hs2.spin*2*M_PI/S7) * invheptmove[d];
|
transmatrix V2 = spin((nonbitrunc?M_PI:0)-hs2.spin*2*M_PI/S7) * invheptmove[d];
|
||||||
if(nonchamfered) V2 = V2 * spin(M_PI);
|
if(nonbitrunc) V2 = V2 * spin(M_PI);
|
||||||
double newz = (V2 * at * C0) [2];
|
double newz = (V2 * at * C0) [2];
|
||||||
if(newz < currz) {
|
if(newz < currz) {
|
||||||
currz = newz;
|
currz = newz;
|
||||||
@ -3424,7 +3424,7 @@ void virtualRebase(cell*& base, transmatrix& at, bool tohex) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
if(!newbase) {
|
if(!newbase) {
|
||||||
if(tohex && !nonchamfered) for(int d=0; d<S7; d++) {
|
if(tohex && !nonbitrunc) for(int d=0; d<S7; d++) {
|
||||||
cell *c = createMov(base, d);
|
cell *c = createMov(base, d);
|
||||||
transmatrix V2 = spin(-base->spn(d)*2*M_PI/S6) * invhexmove[d];
|
transmatrix V2 = spin(-base->spn(d)*2*M_PI/S6) * invhexmove[d];
|
||||||
double newz = (V2 *at * C0) [2];
|
double newz = (V2 *at * C0) [2];
|
||||||
|
18
system.cpp
18
system.cpp
@ -114,7 +114,7 @@ void initgame() {
|
|||||||
if(firstland == laElementalWall) cwt.c->land = randomElementalLand();
|
if(firstland == laElementalWall) cwt.c->land = randomElementalLand();
|
||||||
|
|
||||||
if(tactic::on && (isGravityLand(firstland) || firstland == laOcean) && firstland != laMountain)
|
if(tactic::on && (isGravityLand(firstland) || firstland == laOcean) && firstland != laMountain)
|
||||||
cwt.c->land = nonchamfered ? laCrossroads : laCrossroads2;
|
cwt.c->land = nonbitrunc ? laCrossroads : laCrossroads2;
|
||||||
createMov(cwt.c, 0);
|
createMov(cwt.c, 0);
|
||||||
|
|
||||||
setdist(cwt.c, BARLEV, NULL);
|
setdist(cwt.c, BARLEV, NULL);
|
||||||
@ -547,7 +547,7 @@ void applyBoxes() {
|
|||||||
applyBoxBool(survivalist);
|
applyBoxBool(survivalist);
|
||||||
if(loadingHi) applyBoxI(itLotus);
|
if(loadingHi) applyBoxI(itLotus);
|
||||||
else applyBoxNum(truelotus, "lotus/escape");
|
else applyBoxNum(truelotus, "lotus/escape");
|
||||||
applyBoxBool(nonchamfered, "heptagons only");
|
applyBoxBool(nonbitrunc, "heptagons only");
|
||||||
applyBoxI(itRose);
|
applyBoxI(itRose);
|
||||||
applyBoxOrb(itOrbBeauty);
|
applyBoxOrb(itOrbBeauty);
|
||||||
applyBoxI(itCoral);
|
applyBoxI(itCoral);
|
||||||
@ -686,7 +686,7 @@ void loadBoxHigh() {
|
|||||||
dynamicval<eGeometry> sp2(geometry, (eGeometry) savebox[116]);
|
dynamicval<eGeometry> sp2(geometry, (eGeometry) savebox[116]);
|
||||||
dynamicval<bool> sp3(shmup::on, savebox[119]);
|
dynamicval<bool> sp3(shmup::on, savebox[119]);
|
||||||
dynamicval<bool> sp4(chaosmode, savebox[196]);
|
dynamicval<bool> sp4(chaosmode, savebox[196]);
|
||||||
dynamicval<bool> sp5(nonchamfered, savebox[186]);
|
dynamicval<bool> sp5(nonbitrunc, savebox[186]);
|
||||||
if(savebox[238]) geometry = gSphere;
|
if(savebox[238]) geometry = gSphere;
|
||||||
if(savebox[239]) geometry = gElliptic;
|
if(savebox[239]) geometry = gElliptic;
|
||||||
|
|
||||||
@ -823,7 +823,7 @@ void saveStats(bool emergency = false) {
|
|||||||
fprintf(f, "Total enemies killed: %d\n", tkills());
|
fprintf(f, "Total enemies killed: %d\n", tkills());
|
||||||
fprintf(f, "cells generated: %d\n", cellcount);
|
fprintf(f, "cells generated: %d\n", cellcount);
|
||||||
if(pureHardcore()) fprintf(f, "Pure hardcore mode\n");
|
if(pureHardcore()) fprintf(f, "Pure hardcore mode\n");
|
||||||
if(nonchamfered) fprintf(f, "Heptagons only mode\n");
|
if(nonbitrunc) fprintf(f, "Heptagons only mode\n");
|
||||||
if(chaosmode) fprintf(f, "Chaos mode\n");
|
if(chaosmode) fprintf(f, "Chaos mode\n");
|
||||||
if(shmup::on) fprintf(f, "Shoot-em up mode\n");
|
if(shmup::on) fprintf(f, "Shoot-em up mode\n");
|
||||||
if(inv::on) fprintf(f, "Inventory mode\n");
|
if(inv::on) fprintf(f, "Inventory mode\n");
|
||||||
@ -1021,7 +1021,7 @@ namespace gamestack {
|
|||||||
gdn.View = View;
|
gdn.View = View;
|
||||||
gdn.geometry = geometry;
|
gdn.geometry = geometry;
|
||||||
gdn.shmup = shmup::on;
|
gdn.shmup = shmup::on;
|
||||||
gdn.hepta = nonchamfered;
|
gdn.hepta = nonbitrunc;
|
||||||
gd.push_back(gdn);
|
gd.push_back(gdn);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1032,7 +1032,7 @@ namespace gamestack {
|
|||||||
viewctr = gdn.viewctr;
|
viewctr = gdn.viewctr;
|
||||||
View = gdn.View;
|
View = gdn.View;
|
||||||
geometry = gdn.geometry;
|
geometry = gdn.geometry;
|
||||||
nonchamfered = gdn.hepta;
|
nonbitrunc = gdn.hepta;
|
||||||
if(shmup::on) shmup::clearMonsters();
|
if(shmup::on) shmup::clearMonsters();
|
||||||
shmup::on = gdn.shmup;
|
shmup::on = gdn.shmup;
|
||||||
resetGeometry();
|
resetGeometry();
|
||||||
@ -1113,7 +1113,7 @@ void restartGame(char switchWhat, bool push, bool keep_screens) {
|
|||||||
if(switchWhat == 'T') {
|
if(switchWhat == 'T') {
|
||||||
geometry = gNormal;
|
geometry = gNormal;
|
||||||
yendor::on = tactic::on = princess::challenge = peace::on = inv::on = false;
|
yendor::on = tactic::on = princess::challenge = peace::on = inv::on = false;
|
||||||
chaosmode = nonchamfered = randomPatternsMode = false;
|
chaosmode = nonbitrunc = randomPatternsMode = false;
|
||||||
shmup::on = false;
|
shmup::on = false;
|
||||||
resetGeometry();
|
resetGeometry();
|
||||||
tour::on = !tour::on;
|
tour::on = !tour::on;
|
||||||
@ -1121,7 +1121,7 @@ void restartGame(char switchWhat, bool push, bool keep_screens) {
|
|||||||
#endif
|
#endif
|
||||||
if(switchWhat == '7') {
|
if(switchWhat == '7') {
|
||||||
if(euclid6) geometry = gNormal;
|
if(euclid6) geometry = gNormal;
|
||||||
nonchamfered = !nonchamfered;
|
nonbitrunc = !nonbitrunc;
|
||||||
resetGeometry();
|
resetGeometry();
|
||||||
#if CAP_TEXTURE
|
#if CAP_TEXTURE
|
||||||
if(texture::tstate == texture::tsActive)
|
if(texture::tstate == texture::tsActive)
|
||||||
@ -1134,7 +1134,7 @@ void restartGame(char switchWhat, bool push, bool keep_screens) {
|
|||||||
if(geometry == targetgeometry) geometry = gNormal;
|
if(geometry == targetgeometry) geometry = gNormal;
|
||||||
else geometry = targetgeometry;
|
else geometry = targetgeometry;
|
||||||
if(chaosmode && (euclid || sphere || quotient)) chaosmode = false;
|
if(chaosmode && (euclid || sphere || quotient)) chaosmode = false;
|
||||||
if(nonchamfered && euclid6) nonchamfered = false;
|
if(nonbitrunc && euclid6) nonbitrunc = false;
|
||||||
|
|
||||||
resetGeometry();
|
resetGeometry();
|
||||||
#if CAP_TEXTURE
|
#if CAP_TEXTURE
|
||||||
|
10
textures.cpp
10
textures.cpp
@ -373,7 +373,7 @@ bool apply(cell *c, const transmatrix &V, int col) {
|
|||||||
|
|
||||||
typedef tuple<eGeometry, bool, char, int, eModel, ld, ld> texture_parameters;
|
typedef tuple<eGeometry, bool, char, int, eModel, ld, ld> texture_parameters;
|
||||||
|
|
||||||
static const auto current_texture_parameters = tie(geometry, nonchamfered, patterns::whichPattern, patterns::subpattern_flags, pmodel, vid.scale, vid.alpha);
|
static const auto current_texture_parameters = tie(geometry, nonbitrunc, patterns::whichPattern, patterns::subpattern_flags, pmodel, vid.scale, vid.alpha);
|
||||||
|
|
||||||
texture_parameters orig_texture_parameters;
|
texture_parameters orig_texture_parameters;
|
||||||
|
|
||||||
@ -661,7 +661,7 @@ patterns::patterninfo si_save;
|
|||||||
|
|
||||||
saverlist texturesavers;
|
saverlist texturesavers;
|
||||||
|
|
||||||
bool target_nonchamf;
|
bool target_nonbitru;
|
||||||
|
|
||||||
void init_textureconfig() {
|
void init_textureconfig() {
|
||||||
texturesavers = move(savers);
|
texturesavers = move(savers);
|
||||||
@ -679,7 +679,7 @@ void init_textureconfig() {
|
|||||||
addsaver(vid.yposition, "Y position", 0);
|
addsaver(vid.yposition, "Y position", 0);
|
||||||
addsaver(vid.xposition, "X position", 0);
|
addsaver(vid.xposition, "X position", 0);
|
||||||
addsaver(vid.camera_angle, "camera angle", 0);
|
addsaver(vid.camera_angle, "camera angle", 0);
|
||||||
addsaverenum(target_nonchamf, "chamfering", false);
|
addsaverenum(target_nonbitru, "bitruncated", false);
|
||||||
// ... geometry parameters
|
// ... geometry parameters
|
||||||
|
|
||||||
addsaver(patterns::whichPattern, "pattern", 0);
|
addsaver(patterns::whichPattern, "pattern", 0);
|
||||||
@ -713,7 +713,7 @@ bool save_textureconfig() {
|
|||||||
if(!f) return false;
|
if(!f) return false;
|
||||||
|
|
||||||
targetgeometry = geometry;
|
targetgeometry = geometry;
|
||||||
target_nonchamf = nonchamfered;
|
target_nonbitru = nonbitrunc;
|
||||||
|
|
||||||
for(auto s: texturesavers) if(s->dosave())
|
for(auto s: texturesavers) if(s->dosave())
|
||||||
fprintf(f, "%s=%s\n", s->name.c_str(), s->save().c_str());
|
fprintf(f, "%s=%s\n", s->name.c_str(), s->save().c_str());
|
||||||
@ -742,7 +742,7 @@ bool load_textureconfig() {
|
|||||||
return load_textureconfig();
|
return load_textureconfig();
|
||||||
}
|
}
|
||||||
|
|
||||||
if(nonchamfered != target_nonchamf) {
|
if(nonbitrunc != target_nonbitru) {
|
||||||
restartGame('7');
|
restartGame('7');
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
8
tour.cpp
8
tour.cpp
@ -79,7 +79,7 @@ bool handleKeyTour(int sym, int uni) {
|
|||||||
int flags = slides[currentslide].flags;
|
int flags = slides[currentslide].flags;
|
||||||
if((sym == SDLK_RETURN || sym == SDLK_KP_ENTER) && (!inhelp || (flags & QUICKSKIP))) {
|
if((sym == SDLK_RETURN || sym == SDLK_KP_ENTER) && (!inhelp || (flags & QUICKSKIP))) {
|
||||||
popScreenAll();
|
popScreenAll();
|
||||||
if(geometry || nonchamfered) {
|
if(geometry || nonbitrunc) {
|
||||||
popGame();
|
popGame();
|
||||||
if(!(flags & QUICKGEO)) return true;
|
if(!(flags & QUICKGEO)) return true;
|
||||||
}
|
}
|
||||||
@ -91,7 +91,7 @@ bool handleKeyTour(int sym, int uni) {
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
if(sym == SDLK_BACKSPACE) {
|
if(sym == SDLK_BACKSPACE) {
|
||||||
if(geometry || nonchamfered) {
|
if(geometry || nonbitrunc) {
|
||||||
popGame();
|
popGame();
|
||||||
if(!(flags & QUICKGEO)) return true;
|
if(!(flags & QUICKGEO)) return true;
|
||||||
}
|
}
|
||||||
@ -139,7 +139,7 @@ bool handleKeyTour(int sym, int uni) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if(geometry || nonchamfered) {
|
if(geometry || nonbitrunc) {
|
||||||
popGame();
|
popGame();
|
||||||
presentation(pmGeometryReset);
|
presentation(pmGeometryReset);
|
||||||
return true;
|
return true;
|
||||||
@ -253,7 +253,7 @@ namespace ss {
|
|||||||
dialog::display();
|
dialog::display();
|
||||||
keyhandler = [] (int sym, int uni) {
|
keyhandler = [] (int sym, int uni) {
|
||||||
if(uni >= 'a' && uni < 'a' + sssize) {
|
if(uni >= 'a' && uni < 'a' + sssize) {
|
||||||
if(geometry || nonchamfered) {
|
if(geometry || nonbitrunc) {
|
||||||
popGame();
|
popGame();
|
||||||
presentation(pmGeometryReset);
|
presentation(pmGeometryReset);
|
||||||
}
|
}
|
||||||
|
@ -817,12 +817,12 @@ int modecode() {
|
|||||||
else if(pureHardcore()) xcode ++;
|
else if(pureHardcore()) xcode ++;
|
||||||
|
|
||||||
if(euclid) xcode += 6;
|
if(euclid) xcode += 6;
|
||||||
else if(nonchamfered) xcode += 3;
|
else if(nonbitrunc) xcode += 3;
|
||||||
|
|
||||||
if(sphere) {
|
if(sphere) {
|
||||||
xcode += 9;
|
xcode += 9;
|
||||||
if(elliptic) xcode += 6;
|
if(elliptic) xcode += 6;
|
||||||
if(nonchamfered) xcode += 3;
|
if(nonbitrunc) xcode += 3;
|
||||||
}
|
}
|
||||||
|
|
||||||
if(chaosmode) xcode += 21;
|
if(chaosmode) xcode += 21;
|
||||||
@ -860,7 +860,7 @@ void buildmodetable() {
|
|||||||
extern bool hardcore;
|
extern bool hardcore;
|
||||||
hardcore = (b%3 == 1);
|
hardcore = (b%3 == 1);
|
||||||
shmup::on = (b%3 == 2);
|
shmup::on = (b%3 == 2);
|
||||||
nonchamfered = (b/3)%7 == 1 || (b/3)%7 == 4 || (b/3)%7 == 6;
|
nonbitrunc = (b/3)%7 == 1 || (b/3)%7 == 4 || (b/3)%7 == 6;
|
||||||
geometry = gNormal;
|
geometry = gNormal;
|
||||||
if((b/3)%7 == 2) geometry = gEuclid;
|
if((b/3)%7 == 2) geometry = gEuclid;
|
||||||
if((b/3)%7 >= 3) geometry = gSphere;
|
if((b/3)%7 >= 3) geometry = gSphere;
|
||||||
@ -879,7 +879,7 @@ void buildmodetable() {
|
|||||||
if(hardcore) printf(" hardcore");
|
if(hardcore) printf(" hardcore");
|
||||||
else if(shmup::on) printf(" shmup");
|
else if(shmup::on) printf(" shmup");
|
||||||
else printf(" softcore");
|
else printf(" softcore");
|
||||||
if(nonchamfered) printf(" heptagonal");
|
if(nonbitrunc) printf(" heptagonal");
|
||||||
if(euclid) printf(" euclidean");
|
if(euclid) printf(" euclidean");
|
||||||
else if(elliptic) printf(" elliptic");
|
else if(elliptic) printf(" elliptic");
|
||||||
else if(sphere) printf(" spherical");
|
else if(sphere) printf(" spherical");
|
||||||
|
Loading…
Reference in New Issue
Block a user