mirror of
https://github.com/ZDoom/raze-gles.git
synced 2025-01-16 20:50:38 +00:00
- detonate and movemasterswitch.
# Conflicts: # source/games/duke/src/actors.cpp
This commit is contained in:
parent
89d750c94f
commit
81717b54ee
3 changed files with 39 additions and 29 deletions
|
@ -927,20 +927,17 @@ void moveflammable(DDukeActor* actor, int tire, int box, int pool)
|
|||
//
|
||||
//---------------------------------------------------------------------------
|
||||
|
||||
void detonate(int i, int explosion)
|
||||
void detonate(DDukeActor *actor, int explosion)
|
||||
{
|
||||
auto spri = &sprite[i];
|
||||
auto actor = &hittype[i];
|
||||
auto t = &hittype[i].temp_data[0];
|
||||
auto spri = &actor->s;
|
||||
int* t = &actor->temp_data[0];
|
||||
earthquaketime = 16;
|
||||
|
||||
int j;
|
||||
StatIterator itj(STAT_EFFECTOR);
|
||||
while ((j = itj.NextIndex()) >= 0)
|
||||
DukeStatIterator itj(STAT_EFFECTOR);
|
||||
while (auto effector = itj.Next())
|
||||
{
|
||||
auto sj = &sprite[j];
|
||||
auto effector = &hittype[j];
|
||||
if (spri->hitag == sj->hitag)
|
||||
auto sj = &effector->s;
|
||||
if (actor->s.hitag == sj->hitag)
|
||||
{
|
||||
if (sj->lotag == SE_13_EXPLOSIVE)
|
||||
{
|
||||
|
@ -964,15 +961,15 @@ void detonate(int i, int explosion)
|
|||
if ((t[3] == 1 && spri->xrepeat) || spri->lotag == -99)
|
||||
{
|
||||
int x = spri->extra;
|
||||
fi.spawn(i, explosion);
|
||||
fi.hitradius(i, seenineblastradius, x >> 2, x - (x >> 1), x - (x >> 2), x);
|
||||
S_PlayActorSound(PIPEBOMB_EXPLODE, i);
|
||||
spawn(actor, explosion);
|
||||
fi.hitradius(actor->GetIndex(), seenineblastradius, x >> 2, x - (x >> 1), x - (x >> 2), x);
|
||||
S_PlayActorSound(PIPEBOMB_EXPLODE, actor);
|
||||
}
|
||||
|
||||
if (spri->xrepeat)
|
||||
for (int x = 0; x < 8; x++) RANDOMSCRAP(spri, i);
|
||||
for (int x = 0; x < 8; x++) RANDOMSCRAP(actor);
|
||||
|
||||
deletesprite(i);
|
||||
deletesprite(actor);
|
||||
|
||||
}
|
||||
|
||||
|
@ -982,23 +979,21 @@ void detonate(int i, int explosion)
|
|||
//
|
||||
//---------------------------------------------------------------------------
|
||||
|
||||
void movemasterswitch(int i, int spectype1, int spectype2)
|
||||
void movemasterswitch(DDukeActor *actor, int spectype1, int spectype2)
|
||||
{
|
||||
auto spri = &sprite[i];
|
||||
auto t = &hittype[i].temp_data[0];
|
||||
auto spri = &actor->s;
|
||||
if (spri->yvel == 1)
|
||||
{
|
||||
spri->hitag--;
|
||||
if (spri->hitag <= 0)
|
||||
{
|
||||
operatesectors(spri->sectnum, i);
|
||||
operatesectors(spri->sectnum, actor);
|
||||
|
||||
SectIterator it(spri->sectnum);
|
||||
int j;
|
||||
while ((j = it.NextIndex()) >= 0)
|
||||
DukeSectIterator it(spri->sectnum);
|
||||
while (auto effector = it.Next())
|
||||
{
|
||||
auto sj = &sprite[j];
|
||||
if (sj->statnum == 3)
|
||||
auto sj = &effector->s;
|
||||
if (sj->statnum == STAT_EFFECTOR)
|
||||
{
|
||||
switch (sj->lotag)
|
||||
{
|
||||
|
@ -1007,10 +1002,10 @@ void movemasterswitch(int i, int spectype1, int spectype2)
|
|||
case SE_31_FLOOR_RISE_FALL:
|
||||
case SE_32_CEILING_RISE_FALL:
|
||||
case SE_36_PROJ_SHOOTER:
|
||||
hittype[j].temp_data[0] = 1;
|
||||
effector->temp_data[0] = 1;
|
||||
break;
|
||||
case SE_3_RANDOM_LIGHTS_AFTER_SHOT_OUT:
|
||||
hittype[j].temp_data[4] = 1;
|
||||
effector->temp_data[4] = 1;
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
@ -1022,7 +1017,7 @@ void movemasterswitch(int i, int spectype1, int spectype2)
|
|||
}
|
||||
}
|
||||
}
|
||||
deletesprite(i);
|
||||
deletesprite(actor);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
|
@ -260,4 +260,19 @@ inline int findplayer(DDukeActor* act, int* x)
|
|||
return findplayer(&act->s, x);
|
||||
}
|
||||
|
||||
inline void operatesectors(int s, DDukeActor* i)
|
||||
{
|
||||
operatesectors(s, i->GetIndex());
|
||||
}
|
||||
|
||||
inline void detonate(int i, int explosion)
|
||||
{
|
||||
detonate(&hittype[i], explosion);
|
||||
}
|
||||
|
||||
inline void movemasterswitch(int i, int spectype1, int spectype2)
|
||||
{
|
||||
movemasterswitch(&hittype[i], spectype1, spectype2);
|
||||
}
|
||||
|
||||
END_DUKE_NS
|
||||
|
|
|
@ -33,8 +33,8 @@ void ms(DDukeActor* i);
|
|||
void movecrane(DDukeActor* i, int crane);
|
||||
void movefountain(DDukeActor* i, int fountain);
|
||||
void moveflammable(DDukeActor* i, int tire, int box, int pool);
|
||||
void detonate(int i, int explosion);
|
||||
void movemasterswitch(int i, int spectype1, int spectype2);
|
||||
void detonate(DDukeActor* i, int explosion);
|
||||
void movemasterswitch(DDukeActor* i, int spectype1, int spectype2);
|
||||
void movetrash(int i);
|
||||
void movewaterdrip(int i, int drip);
|
||||
void movedoorshock(int i);
|
||||
|
|
Loading…
Reference in a new issue