- converted FuncRoach to a class.

This commit is contained in:
Christoph Oelckers 2021-10-15 23:07:38 +02:00
parent 25de6fe4c5
commit 5418c4326f
2 changed files with 267 additions and 251 deletions

View file

@ -609,6 +609,14 @@ struct AIRex : public ExhumedAI
void RadialDamage(RunListEvent* ev) override; void RadialDamage(RunListEvent* ev) override;
}; };
struct AIRoach : public ExhumedAI
{
void Tick(RunListEvent* ev) override;
void Damage(RunListEvent* ev) override;
void Draw(RunListEvent* ev) override;
void RadialDamage(RunListEvent* ev) override;
};
void runlist_DispatchEvent(ExhumedAI* ai, int nObject, int nMessage, int nDamage, int nRun); void runlist_DispatchEvent(ExhumedAI* ai, int nObject, int nMessage, int nDamage, int nRun);
typedef void(*AiFunc)(int, int, int, int nRun); typedef void(*AiFunc)(int, int, int, int nRun);

View file

@ -151,45 +151,42 @@ void GoRoach(short nSprite)
pSprite->yvel = bsin(pSprite->ang, -1) - bsin(pSprite->ang, -3); pSprite->yvel = bsin(pSprite->ang, -1) - bsin(pSprite->ang, -3);
} }
void FuncRoach(int nObject, int nMessage, int nDamage, int nRun) void AIRoach::Draw(RunListEvent* ev)
{ {
short nRoach = RunData[nRun].nVal; short nRoach = RunData[ev->nRun].nVal;
assert(nRoach >= 0 && nRoach < (int)RoachList.Size());
short nAction = RoachList[nRoach].nAction;
seq_PlotSequence(ev->nIndex, RoachSeq[nAction].a + SeqOffsets[kSeqRoach], RoachList[nRoach].nFrame, RoachSeq[nAction].b);
return;
}
void AIRoach::RadialDamage(RunListEvent* ev)
{
short nRoach = RunData[ev->nRun].nVal;
assert(nRoach >= 0 && nRoach < (int)RoachList.Size());
short nSprite = RoachList[nRoach].nSprite;
ev->nDamage = runlist_CheckRadialDamage(nSprite);
Damage(ev);
}
void AIRoach::Damage(RunListEvent* ev)
{
short nRoach = RunData[ev->nRun].nVal;
assert(nRoach >= 0 && nRoach < (int)RoachList.Size()); assert(nRoach >= 0 && nRoach < (int)RoachList.Size());
short nSprite = RoachList[nRoach].nSprite; short nSprite = RoachList[nRoach].nSprite;
auto pSprite = &sprite[nSprite]; auto pSprite = &sprite[nSprite];
short nAction = RoachList[nRoach].nAction; short nAction = RoachList[nRoach].nAction;
bool bVal = false; if (ev->nDamage)
switch (nMessage)
{
default:
{
Printf("unknown msg %d for Roach\n", nMessage);
return;
}
case 0x90000:
{
seq_PlotSequence(nObject, RoachSeq[nAction].a + SeqOffsets[kSeqRoach], RoachList[nRoach].nFrame, RoachSeq[nAction].b);
return;
}
case 0xA0000: // fall through to next case
{
nDamage = runlist_CheckRadialDamage(nSprite);
fallthrough__;
}
case 0x80000:
{
if (nDamage)
{ {
if (RoachList[nRoach].nHealth <= 0) { if (RoachList[nRoach].nHealth <= 0) {
return; return;
} }
RoachList[nRoach].nHealth -= dmgAdjust(nDamage); RoachList[nRoach].nHealth -= dmgAdjust(ev->nDamage);
if (RoachList[nRoach].nHealth <= 0) if (RoachList[nRoach].nHealth <= 0)
{ {
pSprite->xvel = 0; pSprite->xvel = 0;
@ -210,7 +207,7 @@ void FuncRoach(int nObject, int nMessage, int nDamage, int nRun)
} }
else else
{ {
short nSprite2 = nObject; short nSprite2 = ev->nIndex;
if (nSprite2 >= 0) if (nSprite2 >= 0)
{ {
if (sprite[nSprite2].statnum < 199) { if (sprite[nSprite2].statnum < 199) {
@ -234,12 +231,18 @@ void FuncRoach(int nObject, int nMessage, int nDamage, int nRun)
} }
} }
} }
}
return; void AIRoach::Tick(RunListEvent* ev)
} {
short nRoach = RunData[ev->nRun].nVal;
assert(nRoach >= 0 && nRoach < (int)RoachList.Size());
short nSprite = RoachList[nRoach].nSprite;
auto pSprite = &sprite[nSprite];
short nAction = RoachList[nRoach].nAction;
bool bVal = false;
case 0x20000:
{
Gravity(nSprite); Gravity(nSprite);
int nSeq = SeqOffsets[kSeqRoach] + RoachSeq[RoachList[nRoach].nAction].a; int nSeq = SeqOffsets[kSeqRoach] + RoachSeq[RoachList[nRoach].nAction].a;
@ -426,7 +429,12 @@ void FuncRoach(int nObject, int nMessage, int nDamage, int nRun)
return; return;
} }
} }
}
}
} }
void FuncRoach(int nObject, int nMessage, int nDamage, int nRun)
{
AIRoach ai;
runlist_DispatchEvent(&ai, nObject, nMessage, nDamage, nRun);
}
END_PS_NS END_PS_NS