1
0
mirror of https://github.com/zenorogue/hyperrogue.git synced 2025-01-11 18:00:34 +00:00

racing:: more arrangements

This commit is contained in:
Zeno Rogue 2018-11-24 01:30:05 +01:00
parent 410c05554c
commit bf23d42e4c
4 changed files with 58 additions and 12 deletions

View File

@ -4459,6 +4459,7 @@ void removeIvy(cell *c) {
void moveivy() { void moveivy() {
if(isize(ivies) == 0) return; if(isize(ivies) == 0) return;
if(racing::on) return;
pathdata pd(moIvyRoot); pathdata pd(moIvyRoot);
for(int i=0; i<isize(ivies); i++) { for(int i=0; i<isize(ivies); i++) {
cell *c = ivies[i]; cell *c = ivies[i];

View File

@ -305,7 +305,7 @@ eItem wanderingTreasure(cell *c) {
void wandering() { void wandering() {
if(!canmove) return; if(!canmove) return;
if(!gen_wandering) return; if(!gen_wandering) return;
if(racing::on) return;
pathdata pd(moYeti); pathdata pd(moYeti);
int seepcount = getSeepcount(); int seepcount = getSeepcount();
int ghostcount = getGhostcount(); int ghostcount = getGhostcount();

View File

@ -19,7 +19,24 @@ static const int TWIDTH = 6;
vector<cell*> track; vector<cell*> track;
map<cell*, pair<int, int> > trackstage; map<cell*, pair<int, int> > trackstage;
void fix_cave(cell *c) {
int v = 0;
// if(c->wall == waCavewall) v++;
// if(c->wall == waCavefloor) v--;
forCellEx(c2, c) {
if(c2->wall == waCavewall) v++;
if(c2->wall == waCavefloor) v--;
}
else v--;
if(v>0 && c->wall == waCavefloor) c->wall = waCavewall;
if(v<0 && c->wall == waCavewall) c->wall = waCavefloor;
}
bool bad(cell *c2, cell *c) { bool bad(cell *c2, cell *c) {
if(c2->land == laCaves) {
forCellEx(c3, c2) fix_cave(c3);
fix_cave(c2);
}
if(!passable(c2, c, P_ISPLAYER)) return true; if(!passable(c2, c, P_ISPLAYER)) return true;
if((c2->land == laCrossroads) ^ (c->land == laCrossroads)) return true; if((c2->land == laCrossroads) ^ (c->land == laCrossroads)) return true;
return false; return false;
@ -58,9 +75,13 @@ void generate_track() {
cellbydist[0].push_back(s); cellbydist[0].push_back(s);
cell *goal; cell *goal;
int traversed = 0;
while(true) { while(true) {
traversed++;
if(cellbydist.empty()) { if(cellbydist.empty()) {
printf("reset after traversing %d\n", traversed);
stop_game(); stop_game();
start_game(); start_game();
return; return;
@ -193,23 +214,49 @@ void generate_track() {
if(c->wall == waMirror || c->wall == waCloud) c->wall = waNone; if(c->wall == waMirror || c->wall == waCloud) c->wall = waNone;
if(!isIvy(c)) if(!isIvy(c))
c->monst = moNone; c->monst = moNone;
if(c->monst == moIvyHead) c->monst = moIvyWait;
if(inmirror(c->land)) if(inmirror(c->land))
; ;
else if(p.first == TWIDTH) else if(p.first == TWIDTH) {
c->wall = waBarrier, killMonster(c, moNone, 0);
c->wall = waBarrier;
c->land = laBarrier; c->land = laBarrier;
else if(p.first > TWIDTH) }
c->land = laMemory, else if(p.first > TWIDTH) {
killMonster(c, moNone, 0);
c->land = laMemory;
c->wall = waChasm; c->wall = waChasm;
if(p.second >= win && p.first < TWIDTH) c->wall = hrand(2) ? waMirror : waCloud; }
if(p.second >= win && p.first < TWIDTH) {
c->wall = hrand(2) ? waMirror : waCloud;
killMonster(c, moNone, 0);
}
} }
} }
for(int i=0; i<motypes; i++) kills[i] = 0;
int byat[256]; int byat[256];
for(int a=0; a<16; a++) byat[a] = 0; for(int a=0; a<16; a++) byat[a] = 0;
for(auto s: trackstage) byat[s.second.first]++; for(auto s: trackstage) byat[s.second.first]++;
for(int a=0; a<16; a++) printf("%d: %d\n", a, byat[a]); for(int a=0; a<16; a++) printf("%d: %d\n", a, byat[a]);
if(s->land == laCaves) {
set<unsigned> hash;
while(true) {
unsigned hashval = 7;
int id = 0;
for(auto s: trackstage) {
fix_cave(s.first);
if(s.first->wall == waCavewall)
hashval = (3+2*(id++)) * hashval + 1;
if(s.first->wall == waCavefloor)
hashval = (3+2*(id++)) * hashval + 2;
}
printf("hashval = %x id = %d\n", hashval, id);
if(hash.count(hashval)) break;
hash.insert(hashval);
}
}
if(1) { if(1) {
manual_celllister cl; manual_celllister cl;
cl.add(s); cl.add(s);
@ -260,7 +307,6 @@ void set_view() {
shmup::monster *who = shmup::pc[current_player]; shmup::monster *who = shmup::pc[current_player];
safety = true; safety = true;
printf("%d\n", ticks);
if(!inrec) history.emplace_back(ticks, who->base, who->at, who->footphase); if(!inrec) history.emplace_back(ticks, who->base, who->at, who->footphase);
transmatrix at = ggmatrix(who->base) * who->at; transmatrix at = ggmatrix(who->base) * who->at;
@ -375,9 +421,9 @@ vector<eLand> race_lands = {
laIce, laIce,
laDesert, laDesert,
laCrossroads, /* need editing */ laCrossroads,
laCaves, /* need fixing */ laCaves,
laJungle, /* need pacifying Ivy */ laJungle,
laMirror, laMirror,
laHell, laHell,
laDryForest, laDryForest,
@ -386,7 +432,7 @@ vector<eLand> race_lands = {
laElementalWall, laElementalWall,
laWildWest, laWildWest,
laDragon, laDragon,
laTerracotta, /* disable traps and warriors */ laTerracotta,
laRuins, laRuins,
}; };

View File

@ -1636,7 +1636,6 @@ void movePlayer(monster *m, int delta) {
if(m->vel * mgo < 0) mgo *= 3; if(m->vel * mgo < 0) mgo *= 3;
m->vel += mgo * delta / 600; m->vel += mgo * delta / 600;
playergo[cpid] = m->vel * SCALE * delta / 600; playergo[cpid] = m->vel * SCALE * delta / 600;
printf("vel = %lf go = %lf\n", m->vel, playergo[cpid]);
} }
else { else {