From bc6ae872aedd35e0cea1fd4806b4e42312b469b2 Mon Sep 17 00:00:00 2001 From: Christoph Oelckers Date: Mon, 26 Oct 2020 07:30:34 +0100 Subject: [PATCH] - cleaned up the checkhitswitch interface to receive sprites as pointers. --- source/games/duke/src/constants.h | 6 --- source/games/duke/src/dispatch.cpp | 4 +- source/games/duke/src/duke3d.h | 2 +- source/games/duke/src/global.cpp | 3 +- source/games/duke/src/global.h | 3 +- source/games/duke/src/player_d.cpp | 12 +++--- source/games/duke/src/player_r.cpp | 16 ++++---- source/games/duke/src/premap.cpp | 4 +- source/games/duke/src/sectors_d.cpp | 44 ++++++++++----------- source/games/duke/src/sectors_r.cpp | 59 ++++++++++++++--------------- source/games/duke/src/sounds.cpp | 8 ++-- source/games/duke/src/sounds.h | 2 +- 12 files changed, 78 insertions(+), 85 deletions(-) diff --git a/source/games/duke/src/constants.h b/source/games/duke/src/constants.h index 9b6673540..638806f6f 100644 --- a/source/games/duke/src/constants.h +++ b/source/games/duke/src/constants.h @@ -288,12 +288,6 @@ enum amoveflags_t antifaceplayerslow = 32768 }; -enum -{ - SWITCH_WALL, - SWITCH_SPRITE -}; - enum sflags_t { SFLAG_SHADOW = 0x00000001, diff --git a/source/games/duke/src/dispatch.cpp b/source/games/duke/src/dispatch.cpp index 4e756c763..6eabf9e59 100644 --- a/source/games/duke/src/dispatch.cpp +++ b/source/games/duke/src/dispatch.cpp @@ -43,8 +43,8 @@ void operaterespawns_d(int low); void operaterespawns_r(int low); void operateforcefields_r(int s, int low); void operateforcefields_d(int s, int low); -bool checkhitswitch_d(int snum, int w, int switchtype); -bool checkhitswitch_r(int snum, int w, int switchtype); +bool checkhitswitch_d(int snum, int w, DDukeActor *act); +bool checkhitswitch_r(int snum, int w, DDukeActor* act); void activatebysector_d(int sect, int j); void activatebysector_r(int sect, int j); void checkhitwall_d(DDukeActor* spr, int dawallnum, int x, int y, int z, int atwith); diff --git a/source/games/duke/src/duke3d.h b/source/games/duke/src/duke3d.h index 03e88cd8b..7f26ec7c3 100644 --- a/source/games/duke/src/duke3d.h +++ b/source/games/duke/src/duke3d.h @@ -76,7 +76,7 @@ struct Dispatcher void (*animatewalls)(); void (*operaterespawns)(int low); void (*operateforcefields)(int s, int low); - bool (*checkhitswitch)(int snum, int w, int switchtype); + bool (*checkhitswitch)(int snum, int w, DDukeActor* act); void (*activatebysector)(int sect, int j); void (*checkhitwall)(DDukeActor* spr, int dawallnum, int x, int y, int z, int atwith); bool (*checkhitceiling)(int sn); diff --git a/source/games/duke/src/global.cpp b/source/games/duke/src/global.cpp index 8d049f2ee..b0dea6561 100644 --- a/source/games/duke/src/global.cpp +++ b/source/games/duke/src/global.cpp @@ -135,7 +135,8 @@ unsigned ambientfx; int msx[MAXANIMPOINTS], msy[MAXANIMPOINTS]; int WindTime, WindDir; short fakebubba_spawn, mamaspawn_count, banjosound; -short BellTime, BellSprite /* word_119BE0*/; +short BellTime; +DDukeActor* BellSprite /* word_119BE0*/; uint8_t enemysizecheat /*raat607*/, ufospawnsminion, pistonsound, chickenphase /* raat605*/, RRRA_ExitedLevel, fogactive; uint32_t everyothertime; player_orig po[MAXPLAYERS]; diff --git a/source/games/duke/src/global.h b/source/games/duke/src/global.h index 92138011e..81d9bddde 100644 --- a/source/games/duke/src/global.h +++ b/source/games/duke/src/global.h @@ -127,7 +127,8 @@ extern unsigned ambientfx; extern int msx[MAXANIMPOINTS], msy[MAXANIMPOINTS]; extern int WindTime, WindDir; extern short fakebubba_spawn, mamaspawn_count, banjosound; -extern short BellTime, BellSprite /* word_119BE0*/; +extern short BellTime; +extern DDukeActor* BellSprite /* word_119BE0*/; extern uint8_t enemysizecheat /*raat607*/, ufospawnsminion, pistonsound, chickenphase /* raat605*/, RRRA_ExitedLevel, fogactive; extern uint32_t everyothertime; extern player_orig po[MAXPLAYERS]; diff --git a/source/games/duke/src/player_d.cpp b/source/games/duke/src/player_d.cpp index 0cc30fd78..396142a19 100644 --- a/source/games/duke/src/player_d.cpp +++ b/source/games/duke/src/player_d.cpp @@ -277,7 +277,7 @@ static void shootknee(DDukeActor* actor, int p, int sx, int sy, int sz, int sa) if (hitsprt && hitsprt->s.picnum != ACCESSSWITCH && hitsprt->s.picnum != ACCESSSWITCH2) { fi.checkhitsprite(hitsprt, knee); - if (p >= 0) fi.checkhitswitch(p, hitsprt->GetIndex(), 1); + if (p >= 0) fi.checkhitswitch(p, -1, hitsprt); } else if (hitwall >= 0) @@ -290,7 +290,7 @@ static void shootknee(DDukeActor* actor, int p, int sx, int sy, int sz, int sa) if (hitwall >= 0 && wall[hitwall].picnum != ACCESSSWITCH && wall[hitwall].picnum != ACCESSSWITCH2) { fi.checkhitwall(knee, hitwall, hitx, hity, hitz, KNEE); - if (p >= 0) fi.checkhitswitch(p, hitwall, 0); + if (p >= 0) fi.checkhitswitch(p, hitwall, nullptr); } } } @@ -462,7 +462,7 @@ static void shootweapon(DDukeActor *actor, int p, int sx, int sy, int sz, int sa hitact->s.picnum == HANDSWITCH || hitact->s.picnum == HANDSWITCH + 1)) { - fi.checkhitswitch(p, hitact->GetIndex(), 1); + fi.checkhitswitch(p, -1, hitact); return; } } @@ -482,7 +482,7 @@ static void shootweapon(DDukeActor *actor, int p, int sx, int sy, int sz, int sa wall[hitwall].picnum == HANDSWITCH || wall[hitwall].picnum == HANDSWITCH + 1)) { - fi.checkhitswitch(p, hitwall, 0); + fi.checkhitswitch(p, hitwall, nullptr); return; } @@ -1517,7 +1517,7 @@ int doincrements_d(struct player_struct* p) { if (p->access_spritenum != nullptr) { - fi.checkhitswitch(snum, p->access_spritenum->GetIndex(), 1); + fi.checkhitswitch(snum, -1, p->access_spritenum); switch (p->access_spritenum->s.pal) { case 0:p->got_access &= (0xffff - 0x1); break; @@ -1528,7 +1528,7 @@ int doincrements_d(struct player_struct* p) } else { - fi.checkhitswitch(snum, p->access_wallnum, 0); + fi.checkhitswitch(snum, p->access_wallnum, nullptr); switch (wall[p->access_wallnum].pal) { case 0:p->got_access &= (0xffff - 0x1); break; diff --git a/source/games/duke/src/player_r.cpp b/source/games/duke/src/player_r.cpp index 88b5fae99..ce0c38fbf 100644 --- a/source/games/duke/src/player_r.cpp +++ b/source/games/duke/src/player_r.cpp @@ -175,7 +175,7 @@ static void shootmelee(DDukeActor *actor, int p, int sx, int sy, int sz, int sa, if (hitsprt && hitsprt->s.picnum != ACCESSSWITCH && hitsprt->s.picnum != ACCESSSWITCH2) { fi.checkhitsprite(hitsprt, wpn); - if (p >= 0) fi.checkhitswitch(p, hitsprt->GetIndex(), 1); + if (p >= 0) fi.checkhitswitch(p, -1, hitsprt); } else if (hitwall >= 0) { @@ -187,7 +187,7 @@ static void shootmelee(DDukeActor *actor, int p, int sx, int sy, int sz, int sa, if (hitwall >= 0 && wall[hitwall].picnum != ACCESSSWITCH && wall[hitwall].picnum != ACCESSSWITCH2) { fi.checkhitwall(wpn, hitwall, hitx, hity, hitz, atwith); - if (p >= 0) fi.checkhitswitch(p, hitwall, 0); + if (p >= 0) fi.checkhitswitch(p, hitwall, nullptr); } } } @@ -364,7 +364,7 @@ static void shootweapon(DDukeActor* actor, int p, int sx, int sy, int sz, int sa hitsprt->s.picnum == HANDSWITCH || hitsprt->s.picnum == HANDSWITCH + 1)) { - fi.checkhitswitch(p, hitsprt->GetIndex(), 1); + fi.checkhitswitch(p, -1, hitsprt); return; } } @@ -387,7 +387,7 @@ static void shootweapon(DDukeActor* actor, int p, int sx, int sy, int sz, int sa wall[hitwall].picnum == HANDSWITCH || wall[hitwall].picnum == HANDSWITCH + 1)) { - fi.checkhitswitch(p, hitwall, 0); + fi.checkhitswitch(p, hitwall, nullptr); return; } @@ -1220,8 +1220,8 @@ int doincrements_r(struct player_struct* p) if (BellTime > 0) { BellTime--; - if (BellTime == 0) - sprite[BellSprite].picnum++; + if (BellTime == 0 && BellSprite) + BellSprite->s.picnum++; } if (chickenphase > 0) chickenphase--; @@ -1369,7 +1369,7 @@ int doincrements_r(struct player_struct* p) { if (p->access_spritenum != nullptr) { - fi.checkhitswitch(snum, p->access_spritenum->GetIndex(), 1); + fi.checkhitswitch(snum, -1, p->access_spritenum); switch (p->access_spritenum->s.pal) { case 0:p->keys[1] = 1; break; @@ -1380,7 +1380,7 @@ int doincrements_r(struct player_struct* p) } else { - fi.checkhitswitch(snum, p->access_wallnum, 0); + fi.checkhitswitch(snum, p->access_wallnum, nullptr); switch (wall[p->access_wallnum].pal) { case 0:p->keys[1] = 1; break; diff --git a/source/games/duke/src/premap.cpp b/source/games/duke/src/premap.cpp index 805c6d172..8908a86b7 100644 --- a/source/games/duke/src/premap.cpp +++ b/source/games/duke/src/premap.cpp @@ -426,7 +426,7 @@ void resetprestat(int snum,int g) fakebubba_spawn = 0; RRRA_ExitedLevel = 0; BellTime = 0; - BellSprite = 0; + BellSprite = nullptr; numinterpolations = 0; //startofdynamicinterpolations = 0; @@ -677,7 +677,7 @@ void prelevel_common(int g) RRRA_ExitedLevel = 0; mamaspawn_count = 15; BellTime = 0; - BellSprite = 0; + BellSprite = nullptr; // RRRA E2L1 fog handling. fogactive = 0; diff --git a/source/games/duke/src/sectors_d.cpp b/source/games/duke/src/sectors_d.cpp index 322354679..9f1ed7fb8 100644 --- a/source/games/duke/src/sectors_d.cpp +++ b/source/games/duke/src/sectors_d.cpp @@ -223,20 +223,18 @@ void operateforcefields_d(int s, int low) // //--------------------------------------------------------------------------- -bool checkhitswitch_d(int snum, int w, int switchtype) +bool checkhitswitch_d(int snum, int ww, DDukeActor *act) { uint8_t switchpal; int i, x, lotag, hitag, picnum, correctdips, numdips; int sx, sy; - if (w < 0) return 0; + if (ww < 0 && act == nullptr) return 0; correctdips = 1; numdips = 0; - DDukeActor* act = nullptr; - - if (switchtype == SWITCH_SPRITE) // A wall sprite + + if (act) { - act = &hittype[w]; lotag = act->s.lotag; if (lotag == 0) return 0; hitag = act->s.hitag; @@ -247,7 +245,7 @@ bool checkhitswitch_d(int snum, int w, int switchtype) } else { - auto wal = &wall[w]; + auto wal = &wall[ww]; lotag = wal->lotag; if (lotag == 0) return 0; hitag = wal->hitag; @@ -267,7 +265,7 @@ bool checkhitswitch_d(int snum, int w, int switchtype) case ALIENSWITCH + 1: break; case DEVELOPERCOMMENTARY + 1: //Twentieth Anniversary World Tour - if (switchtype == 1) + if (act) { StopCommentary(); act->s.picnum = DEVELOPERCOMMENTARY; @@ -275,9 +273,9 @@ bool checkhitswitch_d(int snum, int w, int switchtype) } return false; case DEVELOPERCOMMENTARY: //Twentieth Anniversary World Tour - if (switchtype == 1) + if (act) { - if (StartCommentary(lotag, w)) + if (StartCommentary(lotag, act)) act->s.picnum = DEVELOPERCOMMENTARY+1; return true; } @@ -309,8 +307,8 @@ bool checkhitswitch_d(int snum, int w, int switchtype) if (ps[snum].access_incs == 1) { - if (switchtype == SWITCH_WALL) - ps[snum].access_wallnum = w; + if (!act) + ps[snum].access_wallnum = ww; else ps[snum].access_spritenum = act; } @@ -363,14 +361,14 @@ bool checkhitswitch_d(int snum, int w, int switchtype) case DIPSWITCH: case TECHSWITCH: case ALIENSWITCH: - if (switchtype == SWITCH_SPRITE && act == other) si->picnum++; + if (act && act == other) si->picnum++; else if (si->hitag == 0) correctdips++; numdips++; break; case TECHSWITCH + 1: case DIPSWITCH + 1: case ALIENSWITCH + 1: - if (switchtype == SWITCH_SPRITE && act == other) si->picnum--; + if (act && act == other) si->picnum--; else if (si->hitag == 1) correctdips++; numdips++; break; @@ -426,14 +424,14 @@ bool checkhitswitch_d(int snum, int w, int switchtype) case DIPSWITCH: case TECHSWITCH: case ALIENSWITCH: - if (switchtype == SWITCH_WALL && i == w) wall[x].picnum++; + if (!act && i == ww) wall[x].picnum++; else if (wall[x].hitag == 0) correctdips++; numdips++; break; case DIPSWITCH + 1: case TECHSWITCH + 1: case ALIENSWITCH + 1: - if (switchtype == SWITCH_WALL && i == w) wall[x].picnum--; + if (!act && i == ww) wall[x].picnum--; else if (wall[x].hitag == 1) correctdips++; numdips++; break; @@ -501,13 +499,13 @@ bool checkhitswitch_d(int snum, int w, int switchtype) { if (picnum == ALIENSWITCH || picnum == ALIENSWITCH + 1) { - if (switchtype == SWITCH_SPRITE) + if (act) S_PlaySound3D(ALIEN_SWITCH1, act, &v); else S_PlaySound3D(ALIEN_SWITCH1, ps[snum].GetActor(), &v); } else { - if (switchtype == SWITCH_SPRITE) + if (act) S_PlaySound3D(SWITCH_ON, act, &v); else S_PlaySound3D(SWITCH_ON, ps[snum].GetActor(), &v); } @@ -590,7 +588,7 @@ bool checkhitswitch_d(int snum, int w, int switchtype) if (hitag == 0 && fi.isadoorwall(picnum) == 0) { - if (switchtype == SWITCH_SPRITE) + if (act) S_PlaySound3D(SWITCH_ON, act, &v); else S_PlaySound3D(SWITCH_ON, ps[snum].GetActor(), &v); } @@ -598,7 +596,7 @@ bool checkhitswitch_d(int snum, int w, int switchtype) { auto flags = S_GetUserFlags(hitag); - if (switchtype == SWITCH_SPRITE && (flags & SF_TALK) == 0) + if (act && (flags & SF_TALK) == 0) S_PlaySound3D(hitag, act, &v); else S_PlayActorSound(hitag, ps[snum].i); @@ -1641,7 +1639,7 @@ void checksectors_d(int snum) if (neartagsprite >= 0) { - if (fi.checkhitswitch(snum, neartagsprite, 1)) return; + if (fi.checkhitswitch(snum, -1, &hittype[neartagsprite])) return; switch (sprite[neartagsprite].picnum) { @@ -1772,7 +1770,7 @@ void checksectors_d(int snum) if (wall[neartagwall].lotag > 0 && fi.isadoorwall(wall[neartagwall].picnum)) { if (hitscanwall == neartagwall || hitscanwall == -1) - fi.checkhitswitch(snum, neartagwall, 0); + fi.checkhitswitch(snum, neartagwall, nullptr); return; } else if (p->newowner >= 0) @@ -1803,7 +1801,7 @@ void checksectors_d(int snum) } operatesectors(p->GetActor()->s.sectnum, p->GetActor()); } - else fi.checkhitswitch(snum, neartagwall, 0); + else fi.checkhitswitch(snum, neartagwall, nullptr); } } } diff --git a/source/games/duke/src/sectors_r.cpp b/source/games/duke/src/sectors_r.cpp index 5fe741189..a6b81ba92 100644 --- a/source/games/duke/src/sectors_r.cpp +++ b/source/games/duke/src/sectors_r.cpp @@ -343,20 +343,18 @@ void operateforcefields_r(int s, int low) // //--------------------------------------------------------------------------- -bool checkhitswitch_r(int snum, int w, int switchtype) +bool checkhitswitch_r(int snum, int ww, DDukeActor* act) { uint8_t switchpal; int i, x, lotag, hitag, picnum, correctdips, numdips; int sx, sy; - if (w < 0) return 0; + if (ww < 0 && act == nullptr) return 0; correctdips = 1; numdips = 0; - DDukeActor* act = nullptr; - if (switchtype == SWITCH_SPRITE) // A wall sprite + if (act) { - act = &hittype[w]; lotag = act->s.lotag; if (lotag == 0) return 0; hitag = act->s.hitag; @@ -367,7 +365,7 @@ bool checkhitswitch_r(int snum, int w, int switchtype) } else { - auto wal = &wall[w]; + auto wal = &wall[ww]; lotag = wal->lotag; if (lotag == 0) return 0; hitag = wal->hitag; @@ -397,7 +395,7 @@ bool checkhitswitch_r(int snum, int w, int switchtype) else { FTA(70, &ps[snum]); - if (isRRRA()) S_PlayActorSound(99, w); + if (isRRRA()) S_PlayActorSound(99, act? act : ps[snum].GetActor()); } } @@ -408,7 +406,7 @@ bool checkhitswitch_r(int snum, int w, int switchtype) else { FTA(71, &ps[snum]); - if (isRRRA()) S_PlayActorSound(99, w); + if (isRRRA()) S_PlayActorSound(99, act ? act : ps[snum].GetActor()); } } @@ -419,14 +417,14 @@ bool checkhitswitch_r(int snum, int w, int switchtype) else { FTA(72, &ps[snum]); - if (isRRRA()) S_PlayActorSound(99, w); + if (isRRRA()) S_PlayActorSound(99, act ? act : ps[snum].GetActor()); } } if (ps[snum].access_incs == 1) { - if (switchtype == 0) - ps[snum].access_wallnum = w; + if (!act) + ps[snum].access_wallnum = ww; else ps[snum].access_spritenum = act; } @@ -496,14 +494,14 @@ bool checkhitswitch_r(int snum, int w, int switchtype) case DIPSWITCH: case TECHSWITCH: case ALIENSWITCH: - if (switchtype == SWITCH_SPRITE && act == other) si->picnum++; + if (act && act == other) si->picnum++; else if (si->hitag == 0) correctdips++; numdips++; break; case TECHSWITCH + 1: case DIPSWITCH + 1: case ALIENSWITCH + 1: - if (switchtype == SWITCH_SPRITE && act == other) si->picnum--; + if (act && act == other) si->picnum--; else if (si->hitag == 1) correctdips++; numdips++; break; @@ -610,14 +608,14 @@ bool checkhitswitch_r(int snum, int w, int switchtype) case DIPSWITCH: case TECHSWITCH: case ALIENSWITCH: - if (switchtype == SWITCH_WALL && i == w) wall[x].picnum++; + if (!act && i == ww) wall[x].picnum++; else if (wall[x].hitag == 0) correctdips++; numdips++; break; case DIPSWITCH + 1: case TECHSWITCH + 1: case ALIENSWITCH + 1: - if (switchtype == SWITCH_WALL && i == w) wall[x].picnum--; + if (!act && i == ww) wall[x].picnum--; else if (wall[x].hitag == 1) correctdips++; numdips++; break; @@ -699,13 +697,13 @@ bool checkhitswitch_r(int snum, int w, int switchtype) { if (picnum == ALIENSWITCH || picnum == ALIENSWITCH + 1) { - if (switchtype == SWITCH_SPRITE) + if (act) S_PlaySound3D(ALIEN_SWITCH1, act, &v); else S_PlaySound3D(ALIEN_SWITCH1, ps[snum].GetActor(), &v); } else { - if (switchtype == SWITCH_SPRITE) + if (act) S_PlaySound3D(SWITCH_ON, act, &v); else S_PlaySound3D(SWITCH_ON, ps[snum].GetActor(), &v); } @@ -759,10 +757,10 @@ bool checkhitswitch_r(int snum, int w, int switchtype) goOn2: if (isRRRA()) { - if (picnum == RRTILE8660) + if (picnum == RRTILE8660 && act) { BellTime = 132; - BellSprite = w; + BellSprite = act; act->s.picnum++; } else if (picnum == RRTILE8464) @@ -785,7 +783,8 @@ bool checkhitswitch_r(int snum, int w, int switchtype) picnum == MULTISWITCH2 || picnum == (MULTISWITCH2 + 1) || picnum == (MULTISWITCH2 + 2) || picnum == (MULTISWITCH2 + 3)) { - int switches[3], switchcount = 0, j; + DDukeActor* switches[3]; + int switchcount = 0, j; S_PlaySound3D(SWITCH_ON, act, &v); DukeSpriteIterator it; while (auto actt = it.Next()) @@ -796,7 +795,7 @@ bool checkhitswitch_r(int snum, int w, int switchtype) { if (switchcount < 3) { - switches[switchcount] = actt->GetIndex(); + switches[switchcount] = actt; switchcount++; } } @@ -806,12 +805,12 @@ bool checkhitswitch_r(int snum, int w, int switchtype) S_PlaySound3D(78, act, &v); for (j = 0; j < switchcount; j++) { - sprite[switches[j]].hitag = 0; + switches[j]->s.hitag = 0; if (picnum >= MULTISWITCH2) - sprite[switches[j]].picnum = MULTISWITCH2 + 3; + switches[j]->s.picnum = MULTISWITCH2 + 3; else - sprite[switches[j]].picnum = MULTISWITCH + 3; - checkhitswitch_r(snum, switches[j], 1); + switches[j]->s.picnum = MULTISWITCH + 3; + checkhitswitch_r(snum, -1, switches[j]); } } return 1; @@ -871,7 +870,7 @@ bool checkhitswitch_r(int snum, int w, int switchtype) if (hitag == 0 && fi.isadoorwall(picnum) == 0) { - if (switchtype == SWITCH_SPRITE) + if (act) S_PlaySound3D(SWITCH_ON, act, &v); else S_PlaySound3D(SWITCH_ON, ps[snum].GetActor(), &v); } @@ -879,7 +878,7 @@ bool checkhitswitch_r(int snum, int w, int switchtype) { auto flags = S_GetUserFlags(hitag); - if (switchtype == SWITCH_SPRITE && (flags & SF_TALK) == 0) + if (act && (flags & SF_TALK) == 0) S_PlaySound3D(hitag, act, &v); else S_PlayActorSound(hitag, ps[snum].GetActor()); @@ -2604,7 +2603,7 @@ void checksectors_r(int snum) if (neartagsprite >= 0) { - if (fi.checkhitswitch(snum, neartagsprite, 1)) return; + if (fi.checkhitswitch(snum, -1, &hittype[neartagsprite])) return; switch (sprite[neartagsprite].picnum) { @@ -2721,7 +2720,7 @@ void checksectors_r(int snum) if (wall[neartagwall].lotag > 0 && fi.isadoorwall(wall[neartagwall].picnum)) { if (hitscanwall == neartagwall || hitscanwall == -1) - fi.checkhitswitch(snum, neartagwall, 0); + fi.checkhitswitch(snum, neartagwall, nullptr); return; } } @@ -2766,7 +2765,7 @@ void checksectors_r(int snum) FTA(41, p); } } - else fi.checkhitswitch(snum, neartagwall, 0); + else fi.checkhitswitch(snum, neartagwall, nullptr); } } } diff --git a/source/games/duke/src/sounds.cpp b/source/games/duke/src/sounds.cpp index c2e8f16c9..5e86fbc25 100644 --- a/source/games/duke/src/sounds.cpp +++ b/source/games/duke/src/sounds.cpp @@ -54,7 +54,7 @@ BEGIN_DUKE_NS TArray specialmusic; static FSoundID currentCommentarySound; -static int currentCommentarySprite; +static DDukeActor* currentCommentarySprite; // todo: GC this once actors become objects class DukeSoundEngine : public SoundEngine @@ -90,7 +90,7 @@ public: { UnloadSound(schan->SoundID); currentCommentarySound = 0; - sprite[currentCommentarySprite].picnum = DEVELOPERCOMMENTARY; + currentCommentarySprite->s.picnum = DEVELOPERCOMMENTARY; I_SetRelativeVolume(1.0f); } SoundEngine::SoundDone(schan); @@ -815,7 +815,7 @@ void StopCommentary() } } -bool StartCommentary(int tag, int sprnum) +bool StartCommentary(int tag, DDukeActor* actor) { if (wt_commentary && Commentaries.Size() > tag && Commentaries[tag].IsNotEmpty()) { @@ -833,7 +833,7 @@ bool StartCommentary(int tag, int sprnum) StopCommentary(); soundEngine->StartSound(SOURCE_None, nullptr, nullptr, CHAN_VOICE, CHANF_UI | CHANF_TRANSIENT | CHANF_OVERLAP, id, 1.f, 0.f); currentCommentarySound = id; - currentCommentarySprite = sprnum; + currentCommentarySprite = actor; I_SetRelativeVolume(0.25f); return true; } diff --git a/source/games/duke/src/sounds.h b/source/games/duke/src/sounds.h index 47a18f55a..d42a6bfc3 100644 --- a/source/games/duke/src/sounds.h +++ b/source/games/duke/src/sounds.h @@ -72,7 +72,7 @@ void S_ContinueLevelMusic(void); void S_ParseDeveloperCommentary(); void StopCommentary(); -bool StartCommentary(int tag, int sprnum); +bool StartCommentary(int tag, DDukeActor* sprnum); extern TArray specialmusic;