Skip to content

Commit

Permalink
- converted FuncAnim into a class
Browse files Browse the repository at this point in the history
  • Loading branch information
coelckers committed Oct 15, 2021
1 parent 957db8e commit ce78b23
Show file tree
Hide file tree
Showing 3 changed files with 104 additions and 97 deletions.
18 changes: 17 additions & 1 deletion source/games/exhumed/src/aistuff.h
Expand Up @@ -413,11 +413,13 @@ struct RunListEvent

int nRadialDamage; // Radial damage needs a bit more info.
int nDamageRadius;

int RunValue() const;
};

struct ExhumedAI
{
virtual ~ExhumedAI() = default;
//virtual ~ExhumedAI() = default;
virtual void ProcessChannel(RunListEvent* ev) {}
virtual void Tick(RunListEvent* ev) {}
virtual void Process(RunListEvent* ev) {}
Expand All @@ -430,11 +432,25 @@ struct ExhumedAI
virtual void RadialDamage(RunListEvent* ev) {}
};

struct AIAnim : public ExhumedAI
{
void Tick(RunListEvent* ev) override;
void Draw(RunListEvent* ev) override;
};



void runlist_DispatchEvent(ExhumedAI* ai, int nObject, int nMessage, int nDamage, int nRun);

typedef void(*AiFunc)(int, int, int, int nRun);

extern FreeListArray<RunStruct, kMaxRuns> RunData;

inline int RunListEvent::RunValue() const
{
return RunData[nRun].nVal;
}

extern RunChannel sRunChannels[kMaxChannels];
extern short NewRun;
extern int nRadialOwner;
Expand Down
179 changes: 84 additions & 95 deletions source/games/exhumed/src/anims.cpp
Expand Up @@ -150,145 +150,134 @@ short GetAnimSprite(short nAnim)
return AnimList[nAnim].nSprite;
}

void FuncAnim(int nObject, int nMessage, int, int nRun)
void AIAnim::Tick(RunListEvent* ev)
{
short nAnim = RunData[nRun].nVal;
short nAnim = RunData[ev->nRun].nVal;
assert(nAnim >= 0 && nAnim < kMaxAnims);

short nSprite = AnimList[nAnim].nSprite;
short nSeq = AnimList[nAnim].nSeq;
auto pSprite = &sprite[nSprite];
auto pSprite = &sprite[nSprite];

assert(nSprite != -1);

switch (nMessage)
short var_1C = AnimList[nAnim].field_2;

if (!(pSprite->cstat & 0x8000))
{
case 0x20000:
seq_MoveSequence(nSprite, nSeq, var_1C);
}

if (pSprite->statnum == kStatIgnited)
{
short nSpriteB = pSprite->hitag;
if (nSpriteB > -1)
{
short var_1C = AnimList[nAnim].field_2;
auto pSpriteB = &sprite[nSpriteB];
pSprite->x = pSpriteB->x;
pSprite->y = pSpriteB->y;
pSprite->z = pSpriteB->z;

if (!(pSprite->cstat & 0x8000))
if (pSpriteB->sectnum != pSprite->sectnum)
{
seq_MoveSequence(nSprite, nSeq, var_1C);
if (pSpriteB->sectnum < 0 || pSpriteB->sectnum >= kMaxSectors)
{
DestroyAnim(nAnim);
mydeletesprite(nSprite);
return;
}
else
{
mychangespritesect(nSprite, pSpriteB->sectnum);
}
}

if (pSprite->statnum == kStatIgnited)
if (!var_1C)
{
short nSpriteB = pSprite->hitag;
if (nSpriteB > -1)
if (pSpriteB->cstat != 0x8000)
{
auto pSpriteB = &sprite[nSpriteB];
pSprite->x = pSpriteB->x;
pSprite->y = pSpriteB->y;
pSprite->z = pSpriteB->z;
short hitag2 = pSpriteB->hitag;
pSpriteB->hitag--;

if (pSpriteB->sectnum != pSprite->sectnum)
if (hitag2 >= 15)
{
if (pSpriteB->sectnum < 0 || pSpriteB->sectnum >= kMaxSectors)
{
DestroyAnim(nAnim);
mydeletesprite(nSprite);
return;
}
else
{
mychangespritesect(nSprite, pSpriteB->sectnum);
}
}
runlist_DamageEnemy(nSpriteB, -1, (pSpriteB->hitag - 14) * 2);

if (!var_1C)
{
if (pSpriteB->cstat != 0x8000)
if (pSpriteB->shade < 100)
{
short hitag2 = pSpriteB->hitag;
pSpriteB->hitag--;

if (hitag2 >= 15)
{
runlist_DamageEnemy(nSpriteB, -1, (pSpriteB->hitag - 14) * 2);

if (pSpriteB->shade < 100)
{
pSpriteB->pal = 0;
pSpriteB->shade++;
}

if (!(pSpriteB->cstat & 101))
{
DestroyAnim(nAnim);
mydeletesprite(nSprite);
return;
}
}
else
{
pSpriteB->hitag = 1;
DestroyAnim(nAnim);
mydeletesprite(nSprite);
}
pSpriteB->pal = 0;
pSpriteB->shade++;
}
else

if (!(pSpriteB->cstat & 101))
{
pSpriteB->hitag = 1;
DestroyAnim(nAnim);
mydeletesprite(nSprite);
return;
}
}
}
}

AnimList[nAnim].field_2++;
if (AnimList[nAnim].field_2 >= SeqSize[nSeq])
{
if (AnimList[nAnim].AnimFlags & 0x10)
{
AnimList[nAnim].field_2 = 0;
}
else if (nSeq == nPreMagicSeq)
{
AnimList[nAnim].field_2 = 0;
AnimList[nAnim].nSeq = nMagicSeq;
short nAnimSprite = AnimList[nAnim].nSprite;
AnimList[nAnim].AnimFlags |= 0x10;
sprite[nAnimSprite].cstat |= 2;
}
else if (nSeq == nSavePointSeq)
{
AnimList[nAnim].field_2 = 0;
AnimList[nAnim].nSeq++;
AnimList[nAnim].AnimFlags |= 0x10;
else
{
pSpriteB->hitag = 1;
DestroyAnim(nAnim);
mydeletesprite(nSprite);
}
}
else
{
pSpriteB->hitag = 1;
DestroyAnim(nAnim);
mydeletesprite(nSprite);
}
return;
}

return;
}
}

case 0x90000:
AnimList[nAnim].field_2++;
if (AnimList[nAnim].field_2 >= SeqSize[nSeq])
{
if (AnimList[nAnim].AnimFlags & 0x10)
{
seq_PlotSequence(nObject, nSeq, AnimList[nAnim].field_2, 0x101);
mytsprite[nObject].owner = -1;
return;
AnimList[nAnim].field_2 = 0;
}

case 0xA0000:
else if (nSeq == nPreMagicSeq)
{
return;
AnimList[nAnim].field_2 = 0;
AnimList[nAnim].nSeq = nMagicSeq;
short nAnimSprite = AnimList[nAnim].nSprite;
AnimList[nAnim].AnimFlags |= 0x10;
sprite[nAnimSprite].cstat |= 2;
}

default:
else if (nSeq == nSavePointSeq)
{
AnimList[nAnim].field_2 = 0;
AnimList[nAnim].nSeq++;
AnimList[nAnim].AnimFlags |= 0x10;
}
else
{
Printf("unknown msg %x for anim\n", nMessage);
return;
DestroyAnim(nAnim);
mydeletesprite(nSprite);
}
}
}

void AIAnim::Draw(RunListEvent* ev)
{
short nAnim = RunData[ev->nRun].nVal;
assert(nAnim >= 0 && nAnim < kMaxAnims);
short nSeq = AnimList[nAnim].nSeq;

seq_PlotSequence(ev->nIndex, nSeq, AnimList[nAnim].field_2, 0x101);
ev->pTSprite->owner = -1;
}

void FuncAnim(int nObject, int nMessage, int nDamage, int nRun)
{
AIAnim ai;
runlist_DispatchEvent(&ai, nObject, nMessage, nDamage, nRun);
}

void BuildExplosion(short nSprite)
{
auto pSprite = &sprite[nSprite];
Expand Down
4 changes: 3 additions & 1 deletion source/games/exhumed/src/runlist.cpp
Expand Up @@ -1702,9 +1702,11 @@ void runlist_DamageEnemy(int nSprite, int nSprite2, short nDamage)
// This is only temporary so that the event system can be refactored in smaller steps.
void runlist_DispatchEvent(ExhumedAI* ai, int nObject, int nMessage, int nDamage, int nRun)
{
RunListEvent ev;
RunListEvent ev{};
ev.nMessage = (EMessageType)(nMessage >> 16);
ev.nIndex = nObject;
ev.nDamage = nDamage;
ev.nRun = nRun;
switch (ev.nMessage)
{
case EMessageType::ProcessChannel:
Expand Down

0 comments on commit ce78b23

Please sign in to comment.