mirror of
https://github.com/ZDoom/raze-gles.git
synced 2025-01-16 12:40:38 +00:00
- SE14 part 3
This commit is contained in:
parent
92f95ea195
commit
1cffc76c4e
1 changed files with 20 additions and 12 deletions
|
@ -2867,7 +2867,9 @@ void handle_se14(int i, bool checkstat, int RPG, int JIBS6)
|
||||||
{
|
{
|
||||||
if (ud.clipping == 0 && s->xvel >= 192)
|
if (ud.clipping == 0 && s->xvel >= 192)
|
||||||
for (int p = connecthead; p >= 0; p = connectpoint2[p])
|
for (int p = connecthead; p >= 0; p = connectpoint2[p])
|
||||||
if (sprite[ps[p].i].extra > 0)
|
{
|
||||||
|
auto psp = ps[p].GetActor();
|
||||||
|
if (psp->s.extra > 0)
|
||||||
{
|
{
|
||||||
short k = ps[p].cursectnum;
|
short k = ps[p].cursectnum;
|
||||||
updatesector(ps[p].posx, ps[p].posy, &k);
|
updatesector(ps[p].posx, ps[p].posy, &k);
|
||||||
|
@ -2882,11 +2884,14 @@ void handle_se14(int i, bool checkstat, int RPG, int JIBS6)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
int m = (s->xvel * sintable[(s->ang + 512) & 2047]) >> 14;
|
int m = (s->xvel * sintable[(s->ang + 512) & 2047]) >> 14;
|
||||||
x = (s->xvel * sintable[s->ang & 2047]) >> 14;
|
x = (s->xvel * sintable[s->ang & 2047]) >> 14;
|
||||||
|
|
||||||
for (int p = connecthead; p >= 0; p = connectpoint2[p])
|
for (int p = connecthead; p >= 0; p = connectpoint2[p])
|
||||||
|
{
|
||||||
|
auto psp = ps[p].GetActor();
|
||||||
if (sector[ps[p].cursectnum].lotag != 2)
|
if (sector[ps[p].cursectnum].lotag != 2)
|
||||||
{
|
{
|
||||||
if (po[p].os == s->sectnum)
|
if (po[p].os == s->sectnum)
|
||||||
|
@ -2895,7 +2900,7 @@ void handle_se14(int i, bool checkstat, int RPG, int JIBS6)
|
||||||
po[p].oy += x;
|
po[p].oy += x;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (s->sectnum == sprite[ps[p].i].sectnum)
|
if (s->sectnum == psp->s.sectnum)
|
||||||
{
|
{
|
||||||
rotatepoint(s->x, s->y, ps[p].posx, ps[p].posy, q, &ps[p].posx, &ps[p].posy);
|
rotatepoint(s->x, s->y, ps[p].posx, ps[p].posy, q, &ps[p].posx, &ps[p].posy);
|
||||||
|
|
||||||
|
@ -2912,17 +2917,18 @@ void handle_se14(int i, bool checkstat, int RPG, int JIBS6)
|
||||||
ps[p].oposx = ps[p].posx;
|
ps[p].oposx = ps[p].posx;
|
||||||
ps[p].oposy = ps[p].posy;
|
ps[p].oposy = ps[p].posy;
|
||||||
}
|
}
|
||||||
if (sprite[ps[p].i].extra <= 0)
|
if (psp->s.extra <= 0)
|
||||||
{
|
{
|
||||||
sprite[ps[p].i].x = ps[p].posx;
|
psp->s.x = ps[p].posx;
|
||||||
sprite[ps[p].i].y = ps[p].posy;
|
psp->s.y = ps[p].posy;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
SectIterator it(s->sectnum);
|
}
|
||||||
while ((j = it.NextIndex()) >= 0)
|
DukeSectIterator it(s->sectnum);
|
||||||
|
while (auto a2 = it.Next())
|
||||||
{
|
{
|
||||||
auto sj = &sprite[j];
|
auto sj = &a2->s;
|
||||||
if (sj->statnum != 10 && sector[sj->sectnum].lotag != 2 && sj->picnum != SECTOREFFECTOR && sj->picnum != LOCATORS)
|
if (sj->statnum != 10 && sector[sj->sectnum].lotag != 2 && sj->picnum != SECTOREFFECTOR && sj->picnum != LOCATORS)
|
||||||
{
|
{
|
||||||
rotatepoint(s->x, s->y,
|
rotatepoint(s->x, s->y,
|
||||||
|
@ -2936,8 +2942,8 @@ void handle_se14(int i, bool checkstat, int RPG, int JIBS6)
|
||||||
|
|
||||||
if (numplayers > 1)
|
if (numplayers > 1)
|
||||||
{
|
{
|
||||||
hittype[j].bposx = sj->x;
|
a2->bposx = sj->x;
|
||||||
hittype[j].bposy = sj->y;
|
a2->bposy = sj->y;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -2949,7 +2955,8 @@ void handle_se14(int i, bool checkstat, int RPG, int JIBS6)
|
||||||
{
|
{
|
||||||
if (ud.clipping == 0 && s->xvel >= 192)
|
if (ud.clipping == 0 && s->xvel >= 192)
|
||||||
for (int p = connecthead; p >= 0; p = connectpoint2[p])
|
for (int p = connecthead; p >= 0; p = connectpoint2[p])
|
||||||
if (sprite[ps[p].i].extra > 0)
|
{
|
||||||
|
if (ps[p].GetActor()->s.extra > 0)
|
||||||
{
|
{
|
||||||
short k = ps[p].cursectnum;
|
short k = ps[p].cursectnum;
|
||||||
updatesector(ps[p].posx, ps[p].posy, &k);
|
updatesector(ps[p].posx, ps[p].posy, &k);
|
||||||
|
@ -2959,10 +2966,11 @@ void handle_se14(int i, bool checkstat, int RPG, int JIBS6)
|
||||||
ps[p].oposy = ps[p].posy = s->y;
|
ps[p].oposy = ps[p].posy = s->y;
|
||||||
ps[p].cursectnum = s->sectnum;
|
ps[p].cursectnum = s->sectnum;
|
||||||
|
|
||||||
setsprite(ps[p].i, s->x, s->y, s->z);
|
setsprite(ps[p].GetActor(), s->pos);
|
||||||
quickkill(&ps[p]);
|
quickkill(&ps[p]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
SectIterator itr(sprite[s->owner].sectnum);
|
SectIterator itr(sprite[s->owner].sectnum);
|
||||||
while ((j = itr.NextIndex()) >= 0)
|
while ((j = itr.NextIndex()) >= 0)
|
||||||
|
|
Loading…
Reference in a new issue