mirror of
https://github.com/zenorogue/hyperrogue.git
synced 2025-01-12 10:20:32 +00:00
implemented giving up of Hunting Dogs; also made the sight range grow during an ambush
This commit is contained in:
parent
fae6118161
commit
4cef0e2cfb
58
game.cpp
58
game.cpp
@ -48,6 +48,8 @@ flagtype havewhat, hadwhat;
|
|||||||
#define HF_RIVER Flag(22)
|
#define HF_RIVER Flag(22)
|
||||||
#define HF_MIRROR Flag(23)
|
#define HF_MIRROR Flag(23)
|
||||||
#define HF_VOID Flag(24)
|
#define HF_VOID Flag(24)
|
||||||
|
#define HF_HUNTER Flag(25)
|
||||||
|
#define HF_FAILED_AMBUSH Flag(26)
|
||||||
|
|
||||||
bool seenSevenMines = false;
|
bool seenSevenMines = false;
|
||||||
|
|
||||||
@ -2848,6 +2850,7 @@ void bfs() {
|
|||||||
else if(c2->monst == moEarthElemental) havewhat |= HF_EARTH;
|
else if(c2->monst == moEarthElemental) havewhat |= HF_EARTH;
|
||||||
else if(c2->monst == moWaterElemental) havewhat |= HF_WATER;
|
else if(c2->monst == moWaterElemental) havewhat |= HF_WATER;
|
||||||
else if(c2->monst == moVoidBeast) havewhat |= HF_VOID;
|
else if(c2->monst == moVoidBeast) havewhat |= HF_VOID;
|
||||||
|
else if(c2->monst == moHunterDog) havewhat |= HF_HUNTER;
|
||||||
else if(c2->monst == moShark || c2->monst == moCShark) havewhat |= HF_SHARK;
|
else if(c2->monst == moShark || c2->monst == moCShark) havewhat |= HF_SHARK;
|
||||||
else if(c2->monst == moAirElemental)
|
else if(c2->monst == moAirElemental)
|
||||||
havewhat |= HF_AIR, airmap.push_back(make_pair(c2,0));
|
havewhat |= HF_AIR, airmap.push_back(make_pair(c2,0));
|
||||||
@ -5024,6 +5027,9 @@ void specialMoves() {
|
|||||||
if(m == moHunterGuard && items[itHunting] >= 10)
|
if(m == moHunterGuard && items[itHunting] >= 10)
|
||||||
c->monst = moHunterChanging;
|
c->monst = moHunterChanging;
|
||||||
|
|
||||||
|
if(m == moHunterDog && (havewhat & HF_FAILED_AMBUSH))
|
||||||
|
c->monst = moHunterChanging;
|
||||||
|
|
||||||
if(m == moSleepBull && !peace::on) {
|
if(m == moSleepBull && !peace::on) {
|
||||||
bool wakeup = false;
|
bool wakeup = false;
|
||||||
forCellEx(c2, c) if(c2->monst == moGadfly) {
|
forCellEx(c2, c) if(c2->monst == moGadfly) {
|
||||||
@ -5412,11 +5418,62 @@ void moveNormals(eMonster param) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void markAmbush(cell *c) {
|
||||||
|
if(eq(c->aitmp, sval)) return;
|
||||||
|
c->aitmp = sval;
|
||||||
|
forCellEx(c2, c)
|
||||||
|
if(c2->cpdist < c->cpdist)
|
||||||
|
markAmbush(c2);
|
||||||
|
}
|
||||||
|
|
||||||
|
int ambush_distance;
|
||||||
|
bool ambushed;
|
||||||
|
|
||||||
|
void checkAmbushState() {
|
||||||
|
if(havewhat & HF_HUNTER) {
|
||||||
|
sval++;
|
||||||
|
for(cell *c: dcal) {
|
||||||
|
if(c->monst == moHunterDog) {
|
||||||
|
if(c->cpdist > ambush_distance)
|
||||||
|
ambush_distance = c->cpdist;
|
||||||
|
markAmbush(c);
|
||||||
|
}
|
||||||
|
if(c->monst == moHunterGuard && c->cpdist <= 4)
|
||||||
|
markAmbush(c);
|
||||||
|
}
|
||||||
|
if(items[itHunting] > 5 && items[itHunting] <= 22) {
|
||||||
|
int q = 0;
|
||||||
|
for(int i=0; i<numplayers(); i++)
|
||||||
|
forCellEx(c2, playerpos(i))
|
||||||
|
if(eq(c2->aitmp, sval))
|
||||||
|
q++;
|
||||||
|
if(q == 1) havewhat |= HF_FAILED_AMBUSH;
|
||||||
|
if(q == 2) {
|
||||||
|
for(int i=0; i<numplayers(); i++)
|
||||||
|
forCellEx(c2, playerpos(i))
|
||||||
|
if(eq(c2->aitmp, sval))
|
||||||
|
forCellEx(c3, playerpos(i))
|
||||||
|
if(c3 != c2 && isNeighbor(c2,c3))
|
||||||
|
if(eq(c3->aitmp, sval))
|
||||||
|
havewhat |= HF_FAILED_AMBUSH;
|
||||||
|
}
|
||||||
|
if(havewhat & HF_FAILED_AMBUSH && ambushed) {
|
||||||
|
addMessage(XLAT("The Hunting Dogs give up."));
|
||||||
|
ambushed = false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
void movemonsters() {
|
void movemonsters() {
|
||||||
|
ambush_distance = 0;
|
||||||
|
|
||||||
DEBT("lava1");
|
DEBT("lava1");
|
||||||
orboflava(1);
|
orboflava(1);
|
||||||
|
|
||||||
|
checkAmbushState();
|
||||||
|
|
||||||
sagefresh = true;
|
sagefresh = true;
|
||||||
turncount++;
|
turncount++;
|
||||||
|
|
||||||
@ -6130,6 +6187,7 @@ void ambush(cell *c, eItem what) {
|
|||||||
|
|
||||||
int gaps = dogs;
|
int gaps = dogs;
|
||||||
if(!N) return;
|
if(!N) return;
|
||||||
|
ambushed = true;
|
||||||
int shift = hrand(N);
|
int shift = hrand(N);
|
||||||
dogs = min(dogs, N);
|
dogs = min(dogs, N);
|
||||||
gaps = min(gaps, N);
|
gaps = min(gaps, N);
|
||||||
|
@ -2995,7 +2995,7 @@ bool dodrawcell(cell *c) {
|
|||||||
// in the Yendor Challenge, scrolling back is forbidden
|
// in the Yendor Challenge, scrolling back is forbidden
|
||||||
if(c->cpdist > 7 && (yendor::on && !cheater)) return false;
|
if(c->cpdist > 7 && (yendor::on && !cheater)) return false;
|
||||||
// (incorrect comment) too far, no bugs nearby
|
// (incorrect comment) too far, no bugs nearby
|
||||||
if(playermoved && sightrange <= 7 && c->cpdist > sightrange) return false;
|
if(playermoved && sightrange <= 7 && c->cpdist > sightrange && c->cpdist > ambush_distance) return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
@ -4769,9 +4769,10 @@ void drawthemap() {
|
|||||||
drawEuclidean();
|
drawEuclidean();
|
||||||
else {
|
else {
|
||||||
if(sphere && vid.alpha > 1) sphereflip[2][2] = -1;
|
if(sphere && vid.alpha > 1) sphereflip[2][2] = -1;
|
||||||
|
int sr = max(sightrange, ambush_distance);
|
||||||
maxreclevel =
|
maxreclevel =
|
||||||
conformal::on ? sightrange + 2:
|
conformal::on ? sr + 2:
|
||||||
(!playermoved) ? sightrange+1 : sightrange + 4;
|
(!playermoved) ? sr+1 : sr + 4;
|
||||||
|
|
||||||
drawrec(viewctr,
|
drawrec(viewctr,
|
||||||
maxreclevel,
|
maxreclevel,
|
||||||
|
Loading…
Reference in New Issue
Block a user