mirror of
https://github.com/ZDoom/raze-gles.git
synced 2025-01-02 14:40:40 +00:00
- ooz, reactor and camera.
This commit is contained in:
parent
876b6d5081
commit
6e1d3a025a
4 changed files with 45 additions and 48 deletions
|
@ -1837,21 +1837,20 @@ void recon(DDukeActor *actor, int explosion, int firelaser, int attacksnd, int p
|
||||||
//
|
//
|
||||||
//---------------------------------------------------------------------------
|
//---------------------------------------------------------------------------
|
||||||
|
|
||||||
void ooz(int i)
|
void ooz(DDukeActor *actor)
|
||||||
{
|
{
|
||||||
getglobalz(i);
|
getglobalz(actor);
|
||||||
|
|
||||||
int j = (hittype[i].floorz - hittype[i].ceilingz) >> 9;
|
int j = (actor->floorz - actor->ceilingz) >> 9;
|
||||||
if (j > 255) j = 255;
|
if (j > 255) j = 255;
|
||||||
|
|
||||||
int x = 25 - (j >> 1);
|
int x = 25 - (j >> 1);
|
||||||
if (x < 8) x = 8;
|
if (x < 8) x = 8;
|
||||||
else if (x > 48) x = 48;
|
else if (x > 48) x = 48;
|
||||||
|
|
||||||
spritetype* s = &sprite[i];
|
actor->s.yrepeat = j;
|
||||||
s->yrepeat = j;
|
actor->s.xrepeat = x;
|
||||||
s->xrepeat = x;
|
actor->s.z = actor->floorz;
|
||||||
s->z = hittype[i].floorz;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
//---------------------------------------------------------------------------
|
//---------------------------------------------------------------------------
|
||||||
|
@ -1860,19 +1859,18 @@ void ooz(int i)
|
||||||
//
|
//
|
||||||
//---------------------------------------------------------------------------
|
//---------------------------------------------------------------------------
|
||||||
|
|
||||||
void reactor(int i, int REACTOR, int REACTOR2, int REACTORBURNT, int REACTOR2BURNT, int REACTORSPARK, int REACTOR2SPARK)
|
void reactor(DDukeActor* actor, int REACTOR, int REACTOR2, int REACTORBURNT, int REACTOR2BURNT, int REACTORSPARK, int REACTOR2SPARK)
|
||||||
{
|
{
|
||||||
spritetype* s = &sprite[i];
|
spritetype* s = &actor->s;
|
||||||
auto t = &hittype[i].temp_data[0];
|
int* t = &actor->temp_data[0];
|
||||||
int sect = s->sectnum;
|
int sect = actor->s.sectnum;
|
||||||
|
|
||||||
if (t[4] == 1)
|
if (t[4] == 1)
|
||||||
{
|
{
|
||||||
SectIterator it(sect);
|
DukeSectIterator it(sect);
|
||||||
int j;
|
while (auto act2 = it.Next())
|
||||||
while ((j = it.NextIndex()) >= 0)
|
|
||||||
{
|
{
|
||||||
auto sprj = &sprite[j];
|
auto sprj = &act2->s;
|
||||||
if (sprj->picnum == SECTOREFFECTOR)
|
if (sprj->picnum == SECTOREFFECTOR)
|
||||||
{
|
{
|
||||||
if (sprj->lotag == 1)
|
if (sprj->lotag == 1)
|
||||||
|
@ -1893,7 +1891,8 @@ void reactor(int i, int REACTOR, int REACTOR2, int REACTORBURNT, int REACTOR2BUR
|
||||||
{
|
{
|
||||||
sprj->cstat = (short)32768;
|
sprj->cstat = (short)32768;
|
||||||
}
|
}
|
||||||
} return;
|
}
|
||||||
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (t[1] >= 20)
|
if (t[1] >= 20)
|
||||||
|
@ -1903,7 +1902,7 @@ void reactor(int i, int REACTOR, int REACTOR2, int REACTORBURNT, int REACTOR2BUR
|
||||||
}
|
}
|
||||||
|
|
||||||
int x;
|
int x;
|
||||||
int p = findplayer(s, &x);
|
int p = findplayer(&actor->s, &x);
|
||||||
|
|
||||||
t[2]++;
|
t[2]++;
|
||||||
if (t[2] == 4) t[2] = 0;
|
if (t[2] == 4) t[2] = 0;
|
||||||
|
@ -1913,11 +1912,11 @@ void reactor(int i, int REACTOR, int REACTOR2, int REACTORBURNT, int REACTOR2BUR
|
||||||
if ((krand() & 255) < 16)
|
if ((krand() & 255) < 16)
|
||||||
{
|
{
|
||||||
if (!S_CheckSoundPlaying(DUKE_LONGTERM_PAIN))
|
if (!S_CheckSoundPlaying(DUKE_LONGTERM_PAIN))
|
||||||
S_PlayActorSound(DUKE_LONGTERM_PAIN, ps[p].i);
|
S_PlayActorSound(DUKE_LONGTERM_PAIN, ps[p].GetActor());
|
||||||
|
|
||||||
S_PlayActorSound(SHORT_CIRCUIT, i);
|
S_PlayActorSound(SHORT_CIRCUIT, actor);
|
||||||
|
|
||||||
sprite[ps[p].i].extra--;
|
ps[p].GetActor()->s.extra--;
|
||||||
SetPlayerPal(&ps[p], PalEntry(32, 32, 0, 0));
|
SetPlayerPal(&ps[p], PalEntry(32, 32, 0, 0));
|
||||||
}
|
}
|
||||||
t[0] += 128;
|
t[0] += 128;
|
||||||
|
@ -1928,7 +1927,6 @@ void reactor(int i, int REACTOR, int REACTOR2, int REACTORBURNT, int REACTOR2BUR
|
||||||
|
|
||||||
if (t[1])
|
if (t[1])
|
||||||
{
|
{
|
||||||
int j;
|
|
||||||
t[1]++;
|
t[1]++;
|
||||||
|
|
||||||
t[4] = s->z;
|
t[4] = s->z;
|
||||||
|
@ -1939,16 +1937,15 @@ void reactor(int i, int REACTOR, int REACTOR2, int REACTORBURNT, int REACTOR2BUR
|
||||||
case 3:
|
case 3:
|
||||||
{
|
{
|
||||||
//Turn on all of those flashing sectoreffector.
|
//Turn on all of those flashing sectoreffector.
|
||||||
fi.hitradius(&hittype[i], 4096,
|
fi.hitradius(actor, 4096,
|
||||||
impact_damage << 2,
|
impact_damage << 2,
|
||||||
impact_damage << 2,
|
impact_damage << 2,
|
||||||
impact_damage << 2,
|
impact_damage << 2,
|
||||||
impact_damage << 2);
|
impact_damage << 2);
|
||||||
StatIterator it(STAT_STANDABLE);
|
DukeStatIterator it(STAT_STANDABLE);
|
||||||
int j;
|
while (auto act2 = it.Next())
|
||||||
while ((j = it.NextIndex()) >= 0)
|
|
||||||
{
|
{
|
||||||
auto sj = &sprite[j];
|
auto sj = &act2->s;
|
||||||
if (sj->picnum == MASTERSWITCH)
|
if (sj->picnum == MASTERSWITCH)
|
||||||
if (sj->hitag == s->hitag)
|
if (sj->hitag == s->hitag)
|
||||||
if (sj->yvel == 0)
|
if (sj->yvel == 0)
|
||||||
|
@ -1961,12 +1958,12 @@ void reactor(int i, int REACTOR, int REACTOR2, int REACTORBURNT, int REACTOR2BUR
|
||||||
case 10:
|
case 10:
|
||||||
case 15:
|
case 15:
|
||||||
{
|
{
|
||||||
SectIterator it(sect);
|
DukeSectIterator it(sect);
|
||||||
while ((j = it.NextIndex()) >= 0)
|
while (auto a2 = it.Next())
|
||||||
{
|
{
|
||||||
if (j != i)
|
if (a2 != actor)
|
||||||
{
|
{
|
||||||
deletesprite(j);
|
deletesprite(a2);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1974,7 +1971,7 @@ void reactor(int i, int REACTOR, int REACTOR2, int REACTORBURNT, int REACTOR2BUR
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
for (x = 0; x < 16; x++)
|
for (x = 0; x < 16; x++)
|
||||||
RANDOMSCRAP(s, i);
|
RANDOMSCRAP(actor);
|
||||||
|
|
||||||
s->z = t[4];
|
s->z = t[4];
|
||||||
t[4] = 0;
|
t[4] = 0;
|
||||||
|
@ -1982,11 +1979,11 @@ void reactor(int i, int REACTOR, int REACTOR2, int REACTORBURNT, int REACTOR2BUR
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
int j = fi.ifhitbyweapon(&hittype[i]);
|
int j = fi.ifhitbyweapon(actor);
|
||||||
if (j >= 0)
|
if (j >= 0)
|
||||||
{
|
{
|
||||||
for (x = 0; x < 32; x++)
|
for (x = 0; x < 32; x++)
|
||||||
RANDOMSCRAP(s, i);
|
RANDOMSCRAP(actor);
|
||||||
if (s->extra < 0)
|
if (s->extra < 0)
|
||||||
t[1] = 1;
|
t[1] = 1;
|
||||||
}
|
}
|
||||||
|
@ -1999,27 +1996,27 @@ void reactor(int i, int REACTOR, int REACTOR2, int REACTORBURNT, int REACTOR2BUR
|
||||||
//
|
//
|
||||||
//---------------------------------------------------------------------------
|
//---------------------------------------------------------------------------
|
||||||
|
|
||||||
void camera(int i)
|
void camera(DDukeActor *actor)
|
||||||
{
|
{
|
||||||
spritetype* s = &sprite[i];
|
spritetype* s = &actor->s;
|
||||||
auto t = &hittype[i].temp_data[0];
|
int* t = &actor->temp_data[0];
|
||||||
if (t[0] == 0)
|
if (t[0] == 0)
|
||||||
{
|
{
|
||||||
if (camerashitable)
|
if (camerashitable)
|
||||||
{
|
{
|
||||||
int j = fi.ifhitbyweapon(&hittype[i]);
|
int j = fi.ifhitbyweapon(actor);
|
||||||
if (j >= 0)
|
if (j >= 0)
|
||||||
{
|
{
|
||||||
t[0] = 1; // static
|
t[0] = 1; // static
|
||||||
s->cstat = (short)32768;
|
s->cstat = (short)32768;
|
||||||
for (int x = 0; x < 5; x++)
|
for (int x = 0; x < 5; x++)
|
||||||
RANDOMSCRAP(s, i);
|
RANDOMSCRAP(actor);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// backup current angle for interpolating camera angle.
|
// backup current angle for interpolating camera angle.
|
||||||
hittype[i].tempang = s->ang;
|
actor->tempang = s->ang;
|
||||||
|
|
||||||
if (s->hitag > 0)
|
if (s->hitag > 0)
|
||||||
{
|
{
|
||||||
|
|
|
@ -3248,7 +3248,7 @@ void moveactors_d(void)
|
||||||
|
|
||||||
case OOZ:
|
case OOZ:
|
||||||
case OOZ2:
|
case OOZ2:
|
||||||
ooz(i);
|
ooz(&hittype[i]);
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
case GREENSLIME:
|
case GREENSLIME:
|
||||||
|
@ -3277,11 +3277,11 @@ void moveactors_d(void)
|
||||||
|
|
||||||
case REACTOR:
|
case REACTOR:
|
||||||
case REACTOR2:
|
case REACTOR2:
|
||||||
reactor(i, REACTOR, REACTOR2, REACTORBURNT, REACTOR2BURNT, REACTORSPARK, REACTOR2SPARK);
|
reactor(&hittype[i], REACTOR, REACTOR2, REACTORBURNT, REACTOR2BURNT, REACTORSPARK, REACTOR2SPARK);
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
case CAMERA1:
|
case CAMERA1:
|
||||||
camera(i);
|
camera(&hittype[i]);
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -3131,7 +3131,7 @@ void moveactors_r(void)
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
case OOZ:
|
case OOZ:
|
||||||
ooz(i);
|
ooz(&hittype[i]);
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
case EMPTYBIKE:
|
case EMPTYBIKE:
|
||||||
|
@ -3175,11 +3175,11 @@ void moveactors_r(void)
|
||||||
|
|
||||||
case REACTOR:
|
case REACTOR:
|
||||||
case REACTOR2:
|
case REACTOR2:
|
||||||
reactor(i, REACTOR, REACTOR2, REACTORBURNT, REACTOR2BURNT, REACTORSPARK, REACTOR2SPARK);
|
reactor(&hittype[i], REACTOR, REACTOR2, REACTORBURNT, REACTOR2BURNT, REACTORSPARK, REACTOR2SPARK);
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
case CAMERA1:
|
case CAMERA1:
|
||||||
camera(i);
|
camera(&hittype[i]);
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -50,9 +50,9 @@ bool rat(DDukeActor* i, bool makesound);
|
||||||
bool queball(DDukeActor* i, int pocket, int queball, int stripeball);
|
bool queball(DDukeActor* i, int pocket, int queball, int stripeball);
|
||||||
void forcesphere(DDukeActor* i, int forcesphere);
|
void forcesphere(DDukeActor* i, int forcesphere);
|
||||||
void recon(DDukeActor* i, int explosion, int firelaser, int attacksnd, int painsnd, int roamsnd, int shift, int (*getspawn)(DDukeActor* i));
|
void recon(DDukeActor* i, int explosion, int firelaser, int attacksnd, int painsnd, int roamsnd, int shift, int (*getspawn)(DDukeActor* i));
|
||||||
void ooz(int i);
|
void ooz(DDukeActor* i);
|
||||||
void reactor(int i, int REACTOR, int REACTOR2, int REACTORBURNT, int REACTOR2BURNT, int REACTORSPARK, int REACTOR2SPARK);
|
void reactor(DDukeActor* i, int REACTOR, int REACTOR2, int REACTORBURNT, int REACTOR2BURNT, int REACTORSPARK, int REACTOR2SPARK);
|
||||||
void camera(int i);
|
void camera(DDukeActor* i);
|
||||||
void forcesphere(int i);
|
void forcesphere(int i);
|
||||||
void watersplash2(int i);
|
void watersplash2(int i);
|
||||||
void frameeffect1(int i);
|
void frameeffect1(int i);
|
||||||
|
|
Loading…
Reference in a new issue