mirror of
https://github.com/ZDoom/raze-gles.git
synced 2025-01-04 07:20:39 +00:00
- Interators for SE00 and a few others.
This commit is contained in:
parent
5d734eafa0
commit
69e6bee64a
1 changed files with 47 additions and 48 deletions
|
@ -554,7 +554,6 @@ void movefx(void)
|
||||||
{
|
{
|
||||||
int i, j, p;
|
int i, j, p;
|
||||||
int x, ht;
|
int x, ht;
|
||||||
spritetype* s;
|
|
||||||
|
|
||||||
StatIterator iti(STAT_FX);
|
StatIterator iti(STAT_FX);
|
||||||
while ((i = iti.NextIndex()) >= 0)
|
while ((i = iti.NextIndex()) >= 0)
|
||||||
|
@ -1310,7 +1309,7 @@ void movecanwithsomething(int i)
|
||||||
void bounce(int i)
|
void bounce(int i)
|
||||||
{
|
{
|
||||||
int k, l, daang, dax, day, daz, xvect, yvect, zvect;
|
int k, l, daang, dax, day, daz, xvect, yvect, zvect;
|
||||||
short hitsect;
|
int hitsect;
|
||||||
spritetype* s = &sprite[i];
|
spritetype* s = &sprite[i];
|
||||||
|
|
||||||
xvect = mulscale10(s->xvel, sintable[(s->ang + 512) & 2047]);
|
xvect = mulscale10(s->xvel, sintable[(s->ang + 512) & 2047]);
|
||||||
|
@ -2580,9 +2579,10 @@ void scrap(int i, int SCRAP1, int SCRAP6)
|
||||||
|
|
||||||
void handle_se00(int i, int LASERLINE)
|
void handle_se00(int i, int LASERLINE)
|
||||||
{
|
{
|
||||||
spritetype* s = &sprite[i];
|
auto s = &sprite[i];
|
||||||
|
auto ht = &hittype[i];
|
||||||
int sect = s->sectnum;
|
int sect = s->sectnum;
|
||||||
auto t = &hittype[i].temp_data[0];
|
auto t = &ht->temp_data[0];
|
||||||
sectortype *sc = §or[s->sectnum];
|
sectortype *sc = §or[s->sectnum];
|
||||||
int st = s->lotag;
|
int st = s->lotag;
|
||||||
int sh = s->hitag;
|
int sh = s->hitag;
|
||||||
|
@ -2590,8 +2590,9 @@ void handle_se00(int i, int LASERLINE)
|
||||||
int zchange = 0;
|
int zchange = 0;
|
||||||
|
|
||||||
int j = s->owner;
|
int j = s->owner;
|
||||||
|
auto sprowner = &sprite[j];
|
||||||
|
|
||||||
if (sprite[j].lotag == (short)65535)
|
if (sprowner->lotag == (short)65535)
|
||||||
{
|
{
|
||||||
deletesprite(i);
|
deletesprite(i);
|
||||||
return;
|
return;
|
||||||
|
@ -2606,15 +2607,15 @@ void handle_se00(int i, int LASERLINE)
|
||||||
|
|
||||||
if (sprite[i].extra == 1)
|
if (sprite[i].extra == 1)
|
||||||
{
|
{
|
||||||
if (hittype[i].tempang < 256)
|
if (ht->tempang < 256)
|
||||||
{
|
{
|
||||||
hittype[i].tempang += 4;
|
ht->tempang += 4;
|
||||||
if (hittype[i].tempang >= 256)
|
if (ht->tempang >= 256)
|
||||||
callsound(s->sectnum, i);
|
callsound(s->sectnum, i);
|
||||||
if (s->clipdist) l = 1;
|
if (s->clipdist) l = 1;
|
||||||
else l = -1;
|
else l = -1;
|
||||||
}
|
}
|
||||||
else hittype[i].tempang = 256;
|
else ht->tempang = 256;
|
||||||
|
|
||||||
if (sc->floorz > s->z) //z's are touching
|
if (sc->floorz > s->z) //z's are touching
|
||||||
{
|
{
|
||||||
|
@ -2634,30 +2635,30 @@ void handle_se00(int i, int LASERLINE)
|
||||||
}
|
}
|
||||||
else if (sprite[i].extra == 3)
|
else if (sprite[i].extra == 3)
|
||||||
{
|
{
|
||||||
if (hittype[i].tempang > 0)
|
if (ht->tempang > 0)
|
||||||
{
|
{
|
||||||
hittype[i].tempang -= 4;
|
ht->tempang -= 4;
|
||||||
if (hittype[i].tempang <= 0)
|
if (ht->tempang <= 0)
|
||||||
callsound(s->sectnum, i);
|
callsound(s->sectnum, i);
|
||||||
if (s->clipdist) l = -1;
|
if (s->clipdist) l = -1;
|
||||||
else l = 1;
|
else l = 1;
|
||||||
}
|
}
|
||||||
else hittype[i].tempang = 0;
|
else ht->tempang = 0;
|
||||||
|
|
||||||
if (sc->floorz > hittype[i].temp_data[3]) //z's are touching
|
if (sc->floorz > ht->temp_data[3]) //z's are touching
|
||||||
{
|
{
|
||||||
sc->floorz -= 512;
|
sc->floorz -= 512;
|
||||||
zchange = -512;
|
zchange = -512;
|
||||||
if (sc->floorz < hittype[i].temp_data[3])
|
if (sc->floorz < ht->temp_data[3])
|
||||||
sc->floorz = hittype[i].temp_data[3];
|
sc->floorz = ht->temp_data[3];
|
||||||
}
|
}
|
||||||
|
|
||||||
else if (sc->floorz < hittype[i].temp_data[3]) //z's are touching
|
else if (sc->floorz < ht->temp_data[3]) //z's are touching
|
||||||
{
|
{
|
||||||
sc->floorz += 512;
|
sc->floorz += 512;
|
||||||
zchange = 512;
|
zchange = 512;
|
||||||
if (sc->floorz > hittype[i].temp_data[3])
|
if (sc->floorz > ht->temp_data[3])
|
||||||
sc->floorz = hittype[i].temp_data[3];
|
sc->floorz = ht->temp_data[3];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2673,14 +2674,14 @@ void handle_se00(int i, int LASERLINE)
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (sprite[j].ang > 1024)
|
if (sprowner->ang > 1024)
|
||||||
l = -1;
|
l = -1;
|
||||||
else l = 1;
|
else l = 1;
|
||||||
if (t[3] == 0)
|
if (t[3] == 0)
|
||||||
t[3] = ldist(s, &sprite[j]);
|
t[3] = ldist(s, &sprite[j]);
|
||||||
s->xvel = t[3];
|
s->xvel = t[3];
|
||||||
s->x = sprite[j].x;
|
s->x = sprowner->x;
|
||||||
s->y = sprite[j].y;
|
s->y = sprowner->y;
|
||||||
s->ang += (l * q);
|
s->ang += (l * q);
|
||||||
t[2] += (l * q);
|
t[2] += (l * q);
|
||||||
}
|
}
|
||||||
|
@ -2697,7 +2698,7 @@ void handle_se00(int i, int LASERLINE)
|
||||||
ps[p].posz += zchange;
|
ps[p].posz += zchange;
|
||||||
|
|
||||||
int m, x;
|
int m, x;
|
||||||
rotatepoint(sprite[j].x, sprite[j].y,
|
rotatepoint(sprowner->x, sprowner->y,
|
||||||
ps[p].posx, ps[p].posy, (q * l),
|
ps[p].posx, ps[p].posy, (q * l),
|
||||||
&m, &x);
|
&m, &x);
|
||||||
|
|
||||||
|
@ -2714,30 +2715,28 @@ void handle_se00(int i, int LASERLINE)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
SectIterator itp(s->sectnum);
|
||||||
p = headspritesect[s->sectnum];
|
while ((p = itp.NextIndex()) >= 0)
|
||||||
while (p >= 0)
|
|
||||||
{
|
{
|
||||||
if (sprite[p].statnum != 3 && sprite[p].statnum != 4)
|
auto sprp = &sprite[p];
|
||||||
if (LASERLINE < 0 || sprite[p].picnum != LASERLINE)
|
if (sprp->statnum != 3 && sprp->statnum != 4)
|
||||||
|
if (LASERLINE < 0 || sprp->picnum != LASERLINE)
|
||||||
{
|
{
|
||||||
if (sprite[p].picnum == TILE_APLAYER && sprite[p].owner >= 0)
|
if (sprp->picnum == TILE_APLAYER && sprp->owner >= 0)
|
||||||
{
|
{
|
||||||
p = nextspritesect[p];
|
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
sprite[p].ang += (l * q);
|
sprp->ang += (l * q);
|
||||||
sprite[p].ang &= 2047;
|
sprp->ang &= 2047;
|
||||||
|
|
||||||
sprite[p].z += zchange;
|
sprp->z += zchange;
|
||||||
|
|
||||||
rotatepoint(sprite[j].x, sprite[j].y,
|
rotatepoint(sprowner->x, sprowner->y,
|
||||||
sprite[p].x, sprite[p].y, (q * l),
|
sprp->x, sprp->y, (q * l),
|
||||||
&sprite[p].x, &sprite[p].y);
|
&sprp->x, &sprp->y);
|
||||||
|
|
||||||
}
|
}
|
||||||
p = nextspritesect[p];
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -2759,15 +2758,16 @@ void handle_se01(int i)
|
||||||
{
|
{
|
||||||
s->owner = i;
|
s->owner = i;
|
||||||
|
|
||||||
int j = headspritestat[STAT_EFFECTOR];
|
StatIterator it(STAT_EFFECTOR);
|
||||||
while (j >= 0)
|
int j;
|
||||||
|
while ((j = it.NextIndex()) >= 0)
|
||||||
{
|
{
|
||||||
if (sprite[j].lotag == 19 && sprite[j].hitag == sh)
|
auto ss = &sprite[j];
|
||||||
|
if (ss->lotag == 19 && ss->hitag == sh)
|
||||||
{
|
{
|
||||||
t[0] = 0;
|
t[0] = 0;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
j = nextspritestat[j];
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -2943,11 +2943,11 @@ void handle_se14(int i, bool checkstat, int RPG, int JIBS6)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
j = headspritesect[sprite[sprite[i].owner].sectnum];
|
SectIterator itr(sprite[s->owner].sectnum);
|
||||||
while (j >= 0)
|
while ((j = itr.NextIndex()) >= 0)
|
||||||
{
|
{
|
||||||
auto spj = &sprite[j];
|
auto spj = &sprite[j];
|
||||||
int l = nextspritesect[j];
|
|
||||||
if (spj->statnum == 1 && badguy(spj) && spj->picnum != SECTOREFFECTOR && spj->picnum != LOCATORS)
|
if (spj->statnum == 1 && badguy(spj) && spj->picnum != SECTOREFFECTOR && spj->picnum != LOCATORS)
|
||||||
{
|
{
|
||||||
short k = spj->sectnum;
|
short k = spj->sectnum;
|
||||||
|
@ -2959,7 +2959,6 @@ void handle_se14(int i, bool checkstat, int RPG, int JIBS6)
|
||||||
deletesprite(j);
|
deletesprite(j);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
j = l;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -3079,8 +3078,9 @@ void handle_se30(int i, int JIBS6)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
int j = headspritesect[s->sectnum];
|
SectIterator its(s->sectnum);
|
||||||
while (j >= 0)
|
int j;
|
||||||
|
while ((j = its.NextIndex()) >= 0)
|
||||||
{
|
{
|
||||||
auto sprj = &sprite[j];
|
auto sprj = &sprite[j];
|
||||||
auto htj = &hittype[j];
|
auto htj = &hittype[j];
|
||||||
|
@ -3101,7 +3101,6 @@ void handle_se30(int i, int JIBS6)
|
||||||
htj->bposy = sprj->y;
|
htj->bposy = sprj->y;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
j = nextspritesect[j];
|
|
||||||
}
|
}
|
||||||
|
|
||||||
ms(i);
|
ms(i);
|
||||||
|
|
Loading…
Reference in a new issue