1
0
mirror of https://github.com/zenorogue/hyperrogue.git synced 2025-10-24 18:37:39 +00:00

crossbow:: crossbow in shmup

This commit is contained in:
Zeno Rogue
2023-10-27 23:22:31 +02:00
parent 079094799d
commit 3a35d351c4

View File

@@ -1378,7 +1378,7 @@ void movePlayer(monster *m, int delta) {
} }
playerfire[cpid] = true; playerfire[cpid] = true;
m->nextshot = curtime + (250 + 250 * players); m->nextshot = curtime + (250 + 250 * players) * (bow::crossbow_mode() ? 4 : 1);
turncount++; turncount++;
shootBullet(m); shootBullet(m);
@@ -1813,14 +1813,19 @@ void moveBullet(monster *m, int delta) {
m2->stunoff = curtime + 600; m2->stunoff = curtime + 600;
continue; continue;
} }
bool deadval = bow::crossbow_mode() ? false : true;
// multi-HP monsters // multi-HP monsters
if((m2->type == moPalace || m2->type == moFatGuard || m2->type == moSkeleton || if((m2->type == moPalace || m2->type == moFatGuard || m2->type == moSkeleton ||
m2->type == moVizier || isMetalBeast(m2->type) || m2->type == moTortoise || m2->type == moBrownBug || m2->type == moVizier || isMetalBeast(m2->type) || m2->type == moTortoise || m2->type == moBrownBug ||
m2->type == moReptile || m2->type == moSalamander || m2->type == moTerraWarrior) && m2->hitpoints > 1 && !slayer) { m2->type == moReptile || m2->type == moSalamander || m2->type == moTerraWarrior) && m2->hitpoints > 1 && !slayer) {
m2->rebasePat(spin_towards(m2->pat, m->ori, nat0 * C0, 0, 1), m2->base); m2->rebasePat(spin_towards(m2->pat, m->ori, nat0 * C0, 0, 1), m2->base);
if(m2->type != moSkeleton && !isMetalBeast(m2->type) && m2->type != moReptile && m2->type != moSalamander && m2->type != moBrownBug) if(m2->type != moSkeleton && !isMetalBeast(m2->type) && m2->type != moReptile && m2->type != moSalamander && m2->type != moBrownBug) {
m2->hitpoints--; if(!(bow::crossbow_mode() && m2->stunoff > curtime))
m->dead = true; m2->hitpoints--;
}
m->dead = deadval;
if(m2->type == moVizier) ; if(m2->type == moVizier) ;
else if(m2->type == moFatGuard) else if(m2->type == moFatGuard)
m2->stunoff = curtime + 600; m2->stunoff = curtime + 600;
@@ -1844,27 +1849,27 @@ void moveBullet(monster *m, int delta) {
// Raiders are unaffected // Raiders are unaffected
if((m2->type == moCrusher || m2->type == moPair || m2->type == moMonk || if((m2->type == moCrusher || m2->type == moPair || m2->type == moMonk ||
m2->type == moAltDemon || m2->type == moHexDemon) && conv) { m2->type == moAltDemon || m2->type == moHexDemon) && conv) {
m->dead = true; m->dead = deadval;
continue; continue;
} }
if(m2->type == moGreater && conv) { if(m2->type == moGreater && conv) {
m->dead = true; m->dead = deadval;
continue; continue;
} }
if(m2->type == moRoseBeauty && conv && !markOrb(itOrbBeauty)) { if(m2->type == moRoseBeauty && conv && !markOrb(itOrbBeauty)) {
m->dead = true; m->dead = deadval;
continue; continue;
} }
if(m2->type == moDraugr && conv) { if(m2->type == moDraugr && conv) {
m->dead = true; m->dead = deadval;
continue; continue;
} }
if(m2->type == moButterfly && conv) { if(m2->type == moButterfly && conv) {
m->dead = true; m->dead = deadval;
continue; continue;
} }
if(isBull(m2->type) && conv) { if(isBull(m2->type) && conv) {
m->dead = true; m->dead = deadval;
// enrage herd bulls, awaken sleeping bulls // enrage herd bulls, awaken sleeping bulls
m2->type = moRagingBull; m2->type = moRagingBull;
continue; continue;
@@ -1878,7 +1883,7 @@ void moveBullet(monster *m, int delta) {
m->set_parent(m2); m->set_parent(m2);
continue; continue;
} }
m->dead = true; m->dead = deadval;
if(m->type == moFireball) makeflame(m->base, 20, false); if(m->type == moFireball) makeflame(m->base, 20, false);
// Orb of Winter protects from fireballs // Orb of Winter protects from fireballs
if(m->type == moFireball && ((isPlayer(m2) && markOrb(itOrbWinter)) || m2->type == moWitchWinter)) if(m->type == moFireball && ((isPlayer(m2) && markOrb(itOrbWinter)) || m2->type == moWitchWinter))
@@ -3104,6 +3109,10 @@ bool celldrawer::draw_shmup_monster() {
queuepolyat(at_missile_level(view), cgi.shDisk, col, PPR::MISSILE); queuepolyat(at_missile_level(view), cgi.shDisk, col, PPR::MISSILE);
ShadowV(view, cgi.shPHead); ShadowV(view, cgi.shPHead);
} }
else if(bow::crossbow_mode()) {
queuepoly(at_missile_level(view), cgi.shTrapArrow, col);
ShadowV(view, cgi.shTrapArrow);
}
else { else {
shiftmatrix t = view * spin(curtime / 50.0); shiftmatrix t = view * spin(curtime / 50.0);
queuepoly(at_missile_level(t), cgi.shKnife, col); queuepoly(at_missile_level(t), cgi.shKnife, col);