mirror of
https://github.com/ZDoom/raze-gles.git
synced 2025-01-04 07:20:39 +00:00
- made SE06 and SE28 separate functions.
This commit is contained in:
parent
f5338d0acb
commit
c438061b83
2 changed files with 266 additions and 222 deletions
|
@ -3470,6 +3470,155 @@ void moveexplosions_d(void) // STATNUM 5
|
||||||
//
|
//
|
||||||
//---------------------------------------------------------------------------
|
//---------------------------------------------------------------------------
|
||||||
|
|
||||||
|
void handle_se06_d(DDukeActor* actor)
|
||||||
|
{
|
||||||
|
auto s = &actor->s;
|
||||||
|
auto t = &actor->temp_data[0];
|
||||||
|
|
||||||
|
auto sc = §or[s->sectnum];
|
||||||
|
int st = s->lotag;
|
||||||
|
int sh = s->hitag;
|
||||||
|
|
||||||
|
int k = sc->extra;
|
||||||
|
|
||||||
|
if (t[4] > 0)
|
||||||
|
{
|
||||||
|
t[4]--;
|
||||||
|
if (t[4] >= (k - (k >> 3)))
|
||||||
|
s->xvel -= (k >> 5);
|
||||||
|
if (t[4] > ((k >> 1) - 1) && t[4] < (k - (k >> 3)))
|
||||||
|
s->xvel = 0;
|
||||||
|
if (t[4] < (k >> 1))
|
||||||
|
s->xvel += (k >> 5);
|
||||||
|
if (t[4] < ((k >> 1) - (k >> 3)))
|
||||||
|
{
|
||||||
|
t[4] = 0;
|
||||||
|
s->xvel = k;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else s->xvel = k;
|
||||||
|
|
||||||
|
DukeStatIterator it(STAT_EFFECTOR);
|
||||||
|
while (auto act2 = it.Next())
|
||||||
|
{
|
||||||
|
if ((act2->s.lotag == 14) && (sh == act2->s.hitag) && (act2->temp_data[0] == t[0]))
|
||||||
|
{
|
||||||
|
act2->s.xvel = s->xvel;
|
||||||
|
//if( t[4] == 1 )
|
||||||
|
{
|
||||||
|
if (act2->temp_data[5] == 0)
|
||||||
|
act2->temp_data[5] = dist(act2, actor);
|
||||||
|
int x = sgn(dist(act2, actor) - act2->temp_data[5]);
|
||||||
|
if (act2->s.extra)
|
||||||
|
x = -x;
|
||||||
|
s->xvel += x;
|
||||||
|
}
|
||||||
|
act2->temp_data[4] = t[4];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
handle_se14(actor, true, RPG, JIBS6);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
//---------------------------------------------------------------------------
|
||||||
|
//
|
||||||
|
//
|
||||||
|
//
|
||||||
|
//---------------------------------------------------------------------------
|
||||||
|
|
||||||
|
static void handle_se28(DDukeActor* actor)
|
||||||
|
{
|
||||||
|
auto s = &actor->s;
|
||||||
|
auto sc = §or[s->sectnum];
|
||||||
|
int st = s->lotag;
|
||||||
|
int sh = s->hitag;
|
||||||
|
int* t = &actor->temp_data[0];
|
||||||
|
|
||||||
|
if (t[5] > 0)
|
||||||
|
{
|
||||||
|
t[5]--;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (t[0] == 0)
|
||||||
|
{
|
||||||
|
int x;
|
||||||
|
int p = findplayer(&actor->s, &x);
|
||||||
|
if (x > 15500)
|
||||||
|
return;
|
||||||
|
t[0] = 1;
|
||||||
|
t[1] = 64 + (krand() & 511);
|
||||||
|
t[2] = 0;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
t[2]++;
|
||||||
|
if (t[2] > t[1])
|
||||||
|
{
|
||||||
|
t[0] = 0;
|
||||||
|
ps[screenpeek].visibility = ud.const_visibility;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
else if (t[2] == (t[1] >> 1))
|
||||||
|
S_PlayActorSound(THUNDER, actor);
|
||||||
|
else if (t[2] == (t[1] >> 3))
|
||||||
|
S_PlayActorSound(LIGHTNING_SLAP, actor);
|
||||||
|
else if (t[2] == (t[1] >> 2))
|
||||||
|
{
|
||||||
|
DukeStatIterator it(STAT_DEFAULT);
|
||||||
|
while (auto act2 = it.Next())
|
||||||
|
{
|
||||||
|
if (act2->s.picnum == NATURALLIGHTNING && act2->s.hitag == s->hitag)
|
||||||
|
act2->s.cstat |= 32768;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else if (t[2] > (t[1] >> 3) && t[2] < (t[1] >> 2))
|
||||||
|
{
|
||||||
|
int j = !!cansee(s->x, s->y, s->z, s->sectnum, ps[screenpeek].posx, ps[screenpeek].posy, ps[screenpeek].posz, ps[screenpeek].cursectnum);
|
||||||
|
|
||||||
|
if (rnd(192) && (t[2] & 1))
|
||||||
|
{
|
||||||
|
if (j) ps[screenpeek].visibility = 0;
|
||||||
|
}
|
||||||
|
else if (j) ps[screenpeek].visibility = ud.const_visibility;
|
||||||
|
|
||||||
|
DukeStatIterator it(STAT_DEFAULT);
|
||||||
|
while (auto act2 = it.Next())
|
||||||
|
{
|
||||||
|
if (act2->s.picnum == NATURALLIGHTNING && act2->s.hitag == s->hitag)
|
||||||
|
{
|
||||||
|
if (rnd(32) && (t[2] & 1))
|
||||||
|
{
|
||||||
|
act2->s.cstat &= 32767;
|
||||||
|
fi.spawn(j, SMALLSMOKE);
|
||||||
|
|
||||||
|
int x;
|
||||||
|
int p = findplayer(&actor->s, &x);
|
||||||
|
auto psa = ps[p].GetActor();
|
||||||
|
x = ldist(psa, act2);
|
||||||
|
if (x < 768)
|
||||||
|
{
|
||||||
|
if (S_CheckSoundPlaying(psa->GetIndex(), DUKE_LONGTERM_PAIN) < 1)
|
||||||
|
S_PlayActorSound(DUKE_LONGTERM_PAIN, psa);
|
||||||
|
S_PlayActorSound(SHORT_CIRCUIT, psa);
|
||||||
|
psa->s.extra -= 8 + (krand() & 7);
|
||||||
|
SetPlayerPal(&ps[p], PalEntry(32, 16, 0, 0));
|
||||||
|
}
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
else act2->s.cstat |= 32768;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
//---------------------------------------------------------------------------
|
||||||
|
//
|
||||||
|
//
|
||||||
|
//
|
||||||
|
//---------------------------------------------------------------------------
|
||||||
|
|
||||||
void moveeffectors_d(void) //STATNUM 3
|
void moveeffectors_d(void) //STATNUM 3
|
||||||
{
|
{
|
||||||
int q = 0, l, x, st, j, * t;
|
int q = 0, l, x, st, j, * t;
|
||||||
|
@ -3505,48 +3654,9 @@ void moveeffectors_d(void) //STATNUM 3
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case SE_6_SUBWAY:
|
case SE_6_SUBWAY:
|
||||||
{
|
handle_se06_d(&hittype[i]);
|
||||||
k = sc->extra;
|
break;
|
||||||
|
|
||||||
if (t[4] > 0)
|
|
||||||
{
|
|
||||||
t[4]--;
|
|
||||||
if (t[4] >= (k - (k >> 3)))
|
|
||||||
s->xvel -= (k >> 5);
|
|
||||||
if (t[4] > ((k >> 1) - 1) && t[4] < (k - (k >> 3)))
|
|
||||||
s->xvel = 0;
|
|
||||||
if (t[4] < (k >> 1))
|
|
||||||
s->xvel += (k >> 5);
|
|
||||||
if (t[4] < ((k >> 1) - (k >> 3)))
|
|
||||||
{
|
|
||||||
t[4] = 0;
|
|
||||||
s->xvel = k;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else s->xvel = k;
|
|
||||||
|
|
||||||
StatIterator it(STAT_EFFECTOR);
|
|
||||||
int j;
|
|
||||||
while ((j = it.NextIndex()) >= 0)
|
|
||||||
{
|
|
||||||
auto sj = &sprite[j];
|
|
||||||
if ((sj->lotag == 14) && (sh == sj->hitag) && (hittype[j].temp_data[0] == t[0]))
|
|
||||||
{
|
|
||||||
sj->xvel = s->xvel;
|
|
||||||
// if( t[4] == 1 )
|
|
||||||
{
|
|
||||||
if (hittype[j].temp_data[5] == 0)
|
|
||||||
hittype[j].temp_data[5] = dist(sj, s);
|
|
||||||
x = sgn(dist(sj, s) - hittype[j].temp_data[5]);
|
|
||||||
if (sj->extra)
|
|
||||||
x = -x;
|
|
||||||
s->xvel += x;
|
|
||||||
}
|
|
||||||
hittype[j].temp_data[4] = t[4];
|
|
||||||
}
|
|
||||||
}
|
|
||||||
x = 0;
|
|
||||||
}
|
|
||||||
case SE_14_SUBWAY_CAR:
|
case SE_14_SUBWAY_CAR:
|
||||||
handle_se14(&hittype[i], true, RPG, JIBS6);
|
handle_se14(&hittype[i], true, RPG, JIBS6);
|
||||||
break;
|
break;
|
||||||
|
@ -3655,86 +3765,9 @@ void moveeffectors_d(void) //STATNUM 3
|
||||||
handle_se27(&hittype[i]);
|
handle_se27(&hittype[i]);
|
||||||
break;
|
break;
|
||||||
case 28:
|
case 28:
|
||||||
if (t[5] > 0)
|
handle_se28(&hittype[i]);
|
||||||
{
|
|
||||||
t[5]--;
|
|
||||||
break;
|
break;
|
||||||
}
|
|
||||||
|
|
||||||
if (hittype[i].temp_data[0] == 0)
|
|
||||||
{
|
|
||||||
p = findplayer(s, &x);
|
|
||||||
if (x > 15500)
|
|
||||||
break;
|
|
||||||
hittype[i].temp_data[0] = 1;
|
|
||||||
hittype[i].temp_data[1] = 64 + (krand() & 511);
|
|
||||||
hittype[i].temp_data[2] = 0;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
hittype[i].temp_data[2]++;
|
|
||||||
if (hittype[i].temp_data[2] > hittype[i].temp_data[1])
|
|
||||||
{
|
|
||||||
hittype[i].temp_data[0] = 0;
|
|
||||||
ps[screenpeek].visibility = ud.const_visibility;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
else if (hittype[i].temp_data[2] == (hittype[i].temp_data[1] >> 1))
|
|
||||||
S_PlayActorSound(THUNDER, i);
|
|
||||||
else if (hittype[i].temp_data[2] == (hittype[i].temp_data[1] >> 3))
|
|
||||||
S_PlayActorSound(LIGHTNING_SLAP, i);
|
|
||||||
else if (hittype[i].temp_data[2] == (hittype[i].temp_data[1] >> 2))
|
|
||||||
{
|
|
||||||
StatIterator it(STAT_DEFAULT);
|
|
||||||
while ((j = it.NextIndex()) >= 0)
|
|
||||||
{
|
|
||||||
if (sprite[j].picnum == NATURALLIGHTNING && sprite[j].hitag == s->hitag)
|
|
||||||
sprite[j].cstat |= 32768;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else if (hittype[i].temp_data[2] > (hittype[i].temp_data[1] >> 3) && hittype[i].temp_data[2] < (hittype[i].temp_data[1] >> 2))
|
|
||||||
{
|
|
||||||
if (cansee(s->x, s->y, s->z, s->sectnum, ps[screenpeek].posx, ps[screenpeek].posy, ps[screenpeek].posz, ps[screenpeek].cursectnum))
|
|
||||||
j = 1;
|
|
||||||
else j = 0;
|
|
||||||
|
|
||||||
if (rnd(192) && (hittype[i].temp_data[2] & 1))
|
|
||||||
{
|
|
||||||
if (j)
|
|
||||||
ps[screenpeek].visibility = 0;
|
|
||||||
}
|
|
||||||
else if (j)
|
|
||||||
ps[screenpeek].visibility = ud.const_visibility;
|
|
||||||
|
|
||||||
StatIterator it(STAT_DEFAULT);
|
|
||||||
while ((j = it.NextIndex()) >= 0)
|
|
||||||
{
|
|
||||||
auto sj = &sprite[j];
|
|
||||||
if (sj->picnum == NATURALLIGHTNING && sj->hitag == s->hitag)
|
|
||||||
{
|
|
||||||
if (rnd(32) && (hittype[i].temp_data[2] & 1))
|
|
||||||
{
|
|
||||||
sj->cstat &= 32767;
|
|
||||||
fi.spawn(j, SMALLSMOKE);
|
|
||||||
|
|
||||||
p = findplayer(s, &x);
|
|
||||||
x = ldist(&sprite[ps[p].i], sj);
|
|
||||||
if (x < 768)
|
|
||||||
{
|
|
||||||
if (S_CheckSoundPlaying(ps[p].i, DUKE_LONGTERM_PAIN) < 1)
|
|
||||||
S_PlayActorSound(DUKE_LONGTERM_PAIN, ps[p].i);
|
|
||||||
S_PlayActorSound(SHORT_CIRCUIT, ps[p].i);
|
|
||||||
sprite[ps[p].i].extra -= 8 + (krand() & 7);
|
|
||||||
SetPlayerPal(&ps[p], PalEntry(32, 16, 0, 0));
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
else sj->cstat |= 32768;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
case 29:
|
case 29:
|
||||||
s->hitag += 64;
|
s->hitag += 64;
|
||||||
l = mulscale12((int)s->yvel, sintable[s->hitag & 2047]);
|
l = mulscale12((int)s->yvel, sintable[s->hitag & 2047]);
|
||||||
|
|
|
@ -3376,11 +3376,120 @@ void moveexplosions_r(void) // STATNUM 5
|
||||||
//
|
//
|
||||||
//---------------------------------------------------------------------------
|
//---------------------------------------------------------------------------
|
||||||
|
|
||||||
|
void handle_se06_r(DDukeActor *actor)
|
||||||
|
{
|
||||||
|
auto s = &actor->s;
|
||||||
|
auto t = &actor->temp_data[0];
|
||||||
|
|
||||||
|
auto sc = §or[s->sectnum];
|
||||||
|
int st = s->lotag;
|
||||||
|
int sh = s->hitag;
|
||||||
|
|
||||||
|
int k = sc->extra;
|
||||||
|
|
||||||
|
if (t[4] > 0)
|
||||||
|
{
|
||||||
|
t[4]--;
|
||||||
|
if (t[4] >= (k - (k >> 3)))
|
||||||
|
s->xvel -= (k >> 5);
|
||||||
|
if (t[4] > ((k >> 1) - 1) && t[4] < (k - (k >> 3)))
|
||||||
|
s->xvel = 0;
|
||||||
|
if (t[4] < (k >> 1))
|
||||||
|
s->xvel += (k >> 5);
|
||||||
|
if (t[4] < ((k >> 1) - (k >> 3)))
|
||||||
|
{
|
||||||
|
t[4] = 0;
|
||||||
|
s->xvel = k;
|
||||||
|
if ((!isRRRA() || lastlevel) && hulkspawn)
|
||||||
|
{
|
||||||
|
hulkspawn--;
|
||||||
|
auto ns = spawn(actor, HULK);
|
||||||
|
ns->s.z = sector[ns->s.sectnum].ceilingz;
|
||||||
|
ns->s.pal = 33;
|
||||||
|
if (!hulkspawn)
|
||||||
|
{
|
||||||
|
ns = EGS(s->sectnum, s->x, s->y, sector[s->sectnum].ceilingz + 119428, 3677, -8, 16, 16, 0, 0, 0, actor, 5);
|
||||||
|
ns->s.cstat = 514;
|
||||||
|
ns->s.pal = 7;
|
||||||
|
ns->s.xrepeat = 80;
|
||||||
|
ns->s.yrepeat = 255;
|
||||||
|
ns = spawn(actor, 296);
|
||||||
|
ns->s.cstat = 0;
|
||||||
|
ns->s.cstat |= 32768;
|
||||||
|
ns->s.z = sector[s->sectnum].floorz - 6144;
|
||||||
|
deletesprite(actor);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
s->xvel = k;
|
||||||
|
DukeSectIterator it(s->sectnum);
|
||||||
|
while (auto a2 = it.Next())
|
||||||
|
{
|
||||||
|
if (a2->s.picnum == UFOBEAM && ufospawn && ++ufocnt == 64)
|
||||||
|
{
|
||||||
|
int pn;
|
||||||
|
ufocnt = 0;
|
||||||
|
ufospawn--;
|
||||||
|
if (!isRRRA())
|
||||||
|
{
|
||||||
|
switch (krand() & 3)
|
||||||
|
{
|
||||||
|
default:
|
||||||
|
case 0:
|
||||||
|
pn = UFO1_RR;
|
||||||
|
break;
|
||||||
|
case 1:
|
||||||
|
pn = UFO2;
|
||||||
|
break;
|
||||||
|
case 2:
|
||||||
|
pn = UFO3;
|
||||||
|
break;
|
||||||
|
case 3:
|
||||||
|
pn = UFO4;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else pn = UFO1_RRRA;
|
||||||
|
auto ns = spawn(actor, pn);
|
||||||
|
ns->s.z = sector[ns->s.sectnum].ceilingz;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
DukeStatIterator it(STAT_EFFECTOR);
|
||||||
|
while (auto act2 = it.Next())
|
||||||
|
{
|
||||||
|
if ((act2->s.lotag == 14) && (sh == act2->s.hitag) && (act2->temp_data[0] == t[0]))
|
||||||
|
{
|
||||||
|
act2->s.xvel = s->xvel;
|
||||||
|
// if( t[4] == 1 )
|
||||||
|
{
|
||||||
|
if (act2->temp_data[5] == 0)
|
||||||
|
act2->temp_data[5] = dist(act2, actor);
|
||||||
|
int x = sgn(dist(act2, actor) - act2->temp_data[5]);
|
||||||
|
if (act2->s.extra) x = -x;
|
||||||
|
s->xvel += x;
|
||||||
|
}
|
||||||
|
act2->temp_data[4] = t[4];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
handle_se14(actor, false, RPG, JIBS6);
|
||||||
|
}
|
||||||
|
|
||||||
|
//---------------------------------------------------------------------------
|
||||||
|
//
|
||||||
|
//
|
||||||
|
//
|
||||||
|
//---------------------------------------------------------------------------
|
||||||
|
|
||||||
void moveeffectors_r(void) //STATNUM 3
|
void moveeffectors_r(void) //STATNUM 3
|
||||||
{
|
{
|
||||||
int l, x, st, j, * t;
|
int l, st, * t;
|
||||||
int sh, ns, pn;
|
int sh;
|
||||||
short k;
|
|
||||||
spritetype* s;
|
spritetype* s;
|
||||||
sectortype* sc;
|
sectortype* sc;
|
||||||
walltype* wal;
|
walltype* wal;
|
||||||
|
@ -3411,105 +3520,7 @@ void moveeffectors_r(void) //STATNUM 3
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case SE_6_SUBWAY:
|
case SE_6_SUBWAY:
|
||||||
{
|
handle_se06_r(&hittype[i]);
|
||||||
k = sc->extra;
|
|
||||||
|
|
||||||
if (t[4] > 0)
|
|
||||||
{
|
|
||||||
t[4]--;
|
|
||||||
if (t[4] >= (k - (k >> 3)))
|
|
||||||
s->xvel -= (k >> 5);
|
|
||||||
if (t[4] > ((k >> 1) - 1) && t[4] < (k - (k >> 3)))
|
|
||||||
s->xvel = 0;
|
|
||||||
if (t[4] < (k >> 1))
|
|
||||||
s->xvel += (k >> 5);
|
|
||||||
if (t[4] < ((k >> 1) - (k >> 3)))
|
|
||||||
{
|
|
||||||
t[4] = 0;
|
|
||||||
s->xvel = k;
|
|
||||||
if ((!isRRRA() || lastlevel) && hulkspawn)
|
|
||||||
{
|
|
||||||
hulkspawn--;
|
|
||||||
ns = fi.spawn(i, HULK);
|
|
||||||
sprite[ns].z = sector[sprite[ns].sectnum].ceilingz;
|
|
||||||
sprite[ns].pal = 33;
|
|
||||||
if (!hulkspawn)
|
|
||||||
{
|
|
||||||
ns = EGS(s->sectnum, s->x, s->y, sector[s->sectnum].ceilingz + 119428, 3677, -8, 16, 16, 0, 0, 0, i, 5);
|
|
||||||
sprite[ns].cstat = 514;
|
|
||||||
sprite[ns].pal = 7;
|
|
||||||
sprite[ns].xrepeat = 80;
|
|
||||||
sprite[ns].yrepeat = 255;
|
|
||||||
ns = fi.spawn(i, 296);
|
|
||||||
sprite[ns].cstat = 0;
|
|
||||||
sprite[ns].cstat |= 32768;
|
|
||||||
sprite[ns].z = sector[s->sectnum].floorz - 6144;
|
|
||||||
deletesprite(i);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
s->xvel = k;
|
|
||||||
SectIterator it(s->sectnum);
|
|
||||||
while ((j = it.NextIndex()) >= 0)
|
|
||||||
{
|
|
||||||
if (sprite[j].picnum == UFOBEAM)
|
|
||||||
if (ufospawn)
|
|
||||||
if (++ufocnt == 64)
|
|
||||||
{
|
|
||||||
ufocnt = 0;
|
|
||||||
ufospawn--;
|
|
||||||
if (!isRRRA())
|
|
||||||
{
|
|
||||||
switch (krand() & 3)
|
|
||||||
{
|
|
||||||
default:
|
|
||||||
case 0:
|
|
||||||
pn = UFO1_RR;
|
|
||||||
break;
|
|
||||||
case 1:
|
|
||||||
pn = UFO2;
|
|
||||||
break;
|
|
||||||
case 2:
|
|
||||||
pn = UFO3;
|
|
||||||
break;
|
|
||||||
case 3:
|
|
||||||
pn = UFO4;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else pn = UFO1_RRRA;
|
|
||||||
ns = fi.spawn(i, pn);
|
|
||||||
sprite[ns].z = sector[sprite[ns].sectnum].ceilingz;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
StatIterator it(STAT_EFFECTOR);
|
|
||||||
while ((j = it.NextIndex()) >= 0)
|
|
||||||
{
|
|
||||||
auto sj = &sprite[j];
|
|
||||||
auto htj = &hittype[j];
|
|
||||||
if ((sj->lotag == 14) && (sh == sj->hitag) && (htj->temp_data[0] == t[0]))
|
|
||||||
{
|
|
||||||
sj->xvel = s->xvel;
|
|
||||||
// if( t[4] == 1 )
|
|
||||||
{
|
|
||||||
if (htj->temp_data[5] == 0)
|
|
||||||
htj->temp_data[5] = dist(&sprite[j], s);
|
|
||||||
x = sgn(dist(&sprite[j], s) - htj->temp_data[5]);
|
|
||||||
if (sj->extra)
|
|
||||||
x = -x;
|
|
||||||
s->xvel += x;
|
|
||||||
}
|
|
||||||
htj->temp_data[4] = t[4];
|
|
||||||
}
|
|
||||||
}
|
|
||||||
x = 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
case SE_14_SUBWAY_CAR:
|
case SE_14_SUBWAY_CAR:
|
||||||
handle_se14(&hittype[i], false, RPG, JIBS6);
|
handle_se14(&hittype[i], false, RPG, JIBS6);
|
||||||
|
|
Loading…
Reference in a new issue