mirror of
https://github.com/ZDoom/raze-gles.git
synced 2025-01-12 19:20:38 +00:00
player.c: hitscan projectile handling cleanup continued.
git-svn-id: https://svn.eduke32.com/eduke32@3359 1a8010ca-5511-0410-912e-c29ae57300e0
This commit is contained in:
parent
15b7444b46
commit
f65f547fef
1 changed files with 76 additions and 65 deletions
|
@ -336,7 +336,7 @@ static int32_t GetAutoAimAngle(int32_t i, int32_t p, int32_t atwith,
|
||||||
const vec3_t *srcvect, int32_t vel,
|
const vec3_t *srcvect, int32_t vel,
|
||||||
int32_t *zvel, int16_t *sa)
|
int32_t *zvel, int16_t *sa)
|
||||||
{
|
{
|
||||||
int32_t j;
|
int32_t j = -1;
|
||||||
|
|
||||||
Bassert((unsigned)p < MAXPLAYERS);
|
Bassert((unsigned)p < MAXPLAYERS);
|
||||||
|
|
||||||
|
@ -345,7 +345,6 @@ static int32_t GetAutoAimAngle(int32_t i, int32_t p, int32_t atwith,
|
||||||
if (G_HaveEvent(EVENT_GETAUTOAIMANGLE))
|
if (G_HaveEvent(EVENT_GETAUTOAIMANGLE))
|
||||||
VM_OnEvent(EVENT_GETAUTOAIMANGLE, i, p, -1, 0);
|
VM_OnEvent(EVENT_GETAUTOAIMANGLE, i, p, -1, 0);
|
||||||
|
|
||||||
j = -1;
|
|
||||||
{
|
{
|
||||||
int32_t aimang = Gv_GetVar(g_iAimAngleVarID, i, p);
|
int32_t aimang = Gv_GetVar(g_iAimAngleVarID, i, p);
|
||||||
if (aimang > 0)
|
if (aimang > 0)
|
||||||
|
@ -384,27 +383,38 @@ static void Proj_MaybeSpawn(int32_t k, int32_t atwith, const hitdata_t *hit)
|
||||||
{
|
{
|
||||||
if (ProjectileData[atwith].spawns >= 0)
|
if (ProjectileData[atwith].spawns >= 0)
|
||||||
{
|
{
|
||||||
int32_t wh=A_Spawn(k,ProjectileData[atwith].spawns);
|
int32_t wh = A_Spawn(k,ProjectileData[atwith].spawns);
|
||||||
if (ProjectileData[atwith].sxrepeat > 4) sprite[wh].xrepeat=ProjectileData[atwith].sxrepeat;
|
|
||||||
if (ProjectileData[atwith].syrepeat > 4) sprite[wh].yrepeat=ProjectileData[atwith].syrepeat;
|
if (ProjectileData[atwith].sxrepeat > 4)
|
||||||
|
sprite[wh].xrepeat = ProjectileData[atwith].sxrepeat;
|
||||||
|
if (ProjectileData[atwith].syrepeat > 4)
|
||||||
|
sprite[wh].yrepeat = ProjectileData[atwith].syrepeat;
|
||||||
|
|
||||||
A_SetHitData(wh, hit);
|
A_SetHitData(wh, hit);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static int32_t Proj_InsertShotspark(const hitdata_t *hit, int32_t i, int32_t atwith, int32_t sz, int32_t ang)
|
static int32_t Proj_InsertShotspark(const hitdata_t *hit, int32_t i, int32_t atwith,
|
||||||
|
int32_t xyrepeat, int32_t ang, int32_t extra)
|
||||||
{
|
{
|
||||||
int32_t k = A_InsertSprite(hit->sect,hit->pos.x,hit->pos.y,hit->pos.z,SHOTSPARK1,-15,
|
int32_t k = A_InsertSprite(hit->sect, hit->pos.x, hit->pos.y, hit->pos.z,
|
||||||
sz,sz,ang,0,0,i,4);
|
SHOTSPARK1,-15, xyrepeat,xyrepeat, ang,0,0,i,4);
|
||||||
|
sprite[k].extra = extra;
|
||||||
sprite[k].extra = ProjectileData[atwith].extra;
|
// This is a hack to allow you to detect which weapon spawned a SHOTSPARK1:
|
||||||
if (ProjectileData[atwith].extra_rand > 0)
|
sprite[k].yvel = atwith;
|
||||||
sprite[k].extra += (krand()%ProjectileData[atwith].extra_rand);
|
|
||||||
sprite[k].yvel = atwith; // this is a hack to allow you to detect which weapon spawned a SHOTSPARK1
|
|
||||||
A_SetHitData(k, hit);
|
A_SetHitData(k, hit);
|
||||||
|
|
||||||
return k;
|
return k;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static int32_t Proj_GetExtra(int32_t atwith)
|
||||||
|
{
|
||||||
|
int32_t extra = ProjectileData[atwith].extra;
|
||||||
|
if (ProjectileData[atwith].extra_rand > 0)
|
||||||
|
extra += (krand()%ProjectileData[atwith].extra_rand);
|
||||||
|
return extra;
|
||||||
|
}
|
||||||
|
|
||||||
static void Proj_MaybeAddSpread(int32_t not_accurate_p, int32_t *zvel, int16_t *sa,
|
static void Proj_MaybeAddSpread(int32_t not_accurate_p, int32_t *zvel, int16_t *sa,
|
||||||
int32_t zRange, int32_t angRange)
|
int32_t zRange, int32_t angRange)
|
||||||
{
|
{
|
||||||
|
@ -506,6 +516,27 @@ static void A_PreFireHitscan(const spritetype *s, vec3_t *srcvect, int32_t *zvel
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static inline int32_t Proj_DoHitscan(int32_t i, int32_t cstatmask,
|
||||||
|
const vec3_t *srcvect, int32_t zvel, int16_t sa,
|
||||||
|
hitdata_t *hit)
|
||||||
|
{
|
||||||
|
spritetype *const s = &sprite[i];
|
||||||
|
|
||||||
|
s->cstat &= ~cstatmask;
|
||||||
|
|
||||||
|
if (actor[i].shootzvel)
|
||||||
|
zvel = actor[i].shootzvel;
|
||||||
|
|
||||||
|
hitscan(srcvect, s->sectnum,
|
||||||
|
sintable[(sa+512)&2047],
|
||||||
|
sintable[sa&2047],
|
||||||
|
zvel<<6, hit, CLIPMASK1);
|
||||||
|
|
||||||
|
s->cstat |= cstatmask;
|
||||||
|
|
||||||
|
return (hit->sect < 0);
|
||||||
|
}
|
||||||
|
|
||||||
int32_t A_Shoot(int32_t i, int32_t atwith)
|
int32_t A_Shoot(int32_t i, int32_t atwith)
|
||||||
{
|
{
|
||||||
int16_t l, sa, j, k=-1;
|
int16_t l, sa, j, k=-1;
|
||||||
|
@ -798,23 +829,12 @@ int32_t A_Shoot(int32_t i, int32_t atwith)
|
||||||
A_PreFireHitscan(s, &srcvect, &zvel, &sa,
|
A_PreFireHitscan(s, &srcvect, &zvel, &sa,
|
||||||
!(ProjectileData[atwith].workslike & PROJECTILE_ACCURATE));
|
!(ProjectileData[atwith].workslike & PROJECTILE_ACCURATE));
|
||||||
|
|
||||||
if (ProjectileData[atwith].cstat >= 0) s->cstat &= ~ProjectileData[atwith].cstat;
|
if (Proj_DoHitscan(i, (ProjectileData[atwith].cstat >= 0) ? ProjectileData[atwith].cstat : 256+1,
|
||||||
else s->cstat &= ~257;
|
&srcvect, zvel, sa, &hit))
|
||||||
|
return -1;
|
||||||
|
|
||||||
if (actor[i].shootzvel) zvel = actor[i].shootzvel;
|
if (ProjectileData[atwith].range > 0 &&
|
||||||
hitscan((const vec3_t *)&srcvect,sect,
|
klabs(srcvect.x-hit.pos.x)+klabs(srcvect.y-hit.pos.y) > ProjectileData[atwith].range)
|
||||||
sintable[(sa+512)&2047],
|
|
||||||
sintable[sa&2047],
|
|
||||||
zvel<<6,&hit,CLIPMASK1);
|
|
||||||
|
|
||||||
|
|
||||||
if (ProjectileData[atwith].cstat >= 0) s->cstat |= ProjectileData[atwith].cstat;
|
|
||||||
else s->cstat |= 257;
|
|
||||||
|
|
||||||
if (hit.sect < 0) return -1;
|
|
||||||
|
|
||||||
if ((ProjectileData[atwith].range > 0) &&
|
|
||||||
((klabs(srcvect.x-hit.pos.x)+klabs(srcvect.y-hit.pos.y)) > ProjectileData[atwith].range))
|
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
if (ProjectileData[atwith].trail >= 0)
|
if (ProjectileData[atwith].trail >= 0)
|
||||||
|
@ -823,12 +843,13 @@ int32_t A_Shoot(int32_t i, int32_t atwith)
|
||||||
if (ProjectileData[atwith].workslike & PROJECTILE_WATERBUBBLES)
|
if (ProjectileData[atwith].workslike & PROJECTILE_WATERBUBBLES)
|
||||||
{
|
{
|
||||||
if ((krand()&15) == 0 && sector[hit.sect].lotag == ST_2_UNDERWATER)
|
if ((krand()&15) == 0 && sector[hit.sect].lotag == ST_2_UNDERWATER)
|
||||||
A_DoWaterTracers(hit.pos.x,hit.pos.y,hit.pos.z,srcvect.x,srcvect.y,srcvect.z,8-(ud.multimode>>1));
|
A_DoWaterTracers(hit.pos.x,hit.pos.y,hit.pos.z,
|
||||||
|
srcvect.x,srcvect.y,srcvect.z,8-(ud.multimode>>1));
|
||||||
}
|
}
|
||||||
|
|
||||||
if (p >= 0)
|
if (p >= 0)
|
||||||
{
|
{
|
||||||
k = Proj_InsertShotspark(&hit, i, atwith, 10, sa);
|
k = Proj_InsertShotspark(&hit, i, atwith, 10, sa, Proj_GetExtra(atwith));
|
||||||
|
|
||||||
if (hit.wall == -1 && hit.sprite == -1)
|
if (hit.wall == -1 && hit.sprite == -1)
|
||||||
{
|
{
|
||||||
|
@ -956,7 +977,7 @@ DOSKIPBULLETHOLE:
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
k = Proj_InsertShotspark(&hit, i, atwith, 24, sa);
|
k = Proj_InsertShotspark(&hit, i, atwith, 24, sa, Proj_GetExtra(atwith));
|
||||||
|
|
||||||
if (hit.sprite >= 0)
|
if (hit.sprite >= 0)
|
||||||
{
|
{
|
||||||
|
@ -1223,15 +1244,8 @@ DOSKIPBULLETHOLE:
|
||||||
else
|
else
|
||||||
A_PreFireHitscan(s, &srcvect, &zvel, &sa, 1);
|
A_PreFireHitscan(s, &srcvect, &zvel, &sa, 1);
|
||||||
|
|
||||||
s->cstat &= ~257;
|
if (Proj_DoHitscan(i, 256+1, &srcvect, zvel, sa, &hit))
|
||||||
if (actor[i].shootzvel) zvel = actor[i].shootzvel;
|
return -1;
|
||||||
hitscan((const vec3_t *)&srcvect,sect,
|
|
||||||
sintable[(sa+512)&2047],
|
|
||||||
sintable[sa&2047],
|
|
||||||
zvel<<6,&hit,CLIPMASK1);
|
|
||||||
s->cstat |= 257;
|
|
||||||
|
|
||||||
if (hit.sect < 0) return -1;
|
|
||||||
|
|
||||||
if ((krand()&15) == 0 && sector[hit.sect].lotag == ST_2_UNDERWATER)
|
if ((krand()&15) == 0 && sector[hit.sect].lotag == ST_2_UNDERWATER)
|
||||||
A_DoWaterTracers(hit.pos.x,hit.pos.y,hit.pos.z,
|
A_DoWaterTracers(hit.pos.x,hit.pos.y,hit.pos.z,
|
||||||
|
@ -1239,12 +1253,8 @@ DOSKIPBULLETHOLE:
|
||||||
|
|
||||||
if (p >= 0)
|
if (p >= 0)
|
||||||
{
|
{
|
||||||
k = A_InsertSprite(hit.sect,hit.pos.x,hit.pos.y,hit.pos.z,SHOTSPARK1,-15,10,10,sa,0,0,i,4);
|
k = Proj_InsertShotspark(&hit, i, atwith, 10, sa,
|
||||||
sprite[k].extra = G_InitialActorStrength(atwith);
|
G_InitialActorStrength(atwith) + (krand()%6));
|
||||||
sprite[k].extra += (krand()%6);
|
|
||||||
sprite[k].yvel = atwith; // this is a hack to allow you to detect which weapon spawned a SHOTSPARK1
|
|
||||||
A_SetHitData(k, &hit);
|
|
||||||
|
|
||||||
|
|
||||||
if (hit.wall == -1 && hit.sprite == -1)
|
if (hit.wall == -1 && hit.sprite == -1)
|
||||||
{
|
{
|
||||||
|
@ -1266,8 +1276,9 @@ DOSKIPBULLETHOLE:
|
||||||
if (hit.sprite >= 0)
|
if (hit.sprite >= 0)
|
||||||
{
|
{
|
||||||
A_DamageObject(hit.sprite,k);
|
A_DamageObject(hit.sprite,k);
|
||||||
if (sprite[hit.sprite].picnum == APLAYER && (ud.ffire == 1 || (!GTFLAGS(GAMETYPE_PLAYERSFRIENDLY) &&
|
if (sprite[hit.sprite].picnum == APLAYER &&
|
||||||
GTFLAGS(GAMETYPE_TDM) && g_player[sprite[hit.sprite].yvel].ps->team != g_player[sprite[i].yvel].ps->team)))
|
(ud.ffire == 1 || (!GTFLAGS(GAMETYPE_PLAYERSFRIENDLY) && GTFLAGS(GAMETYPE_TDM) &&
|
||||||
|
g_player[sprite[hit.sprite].yvel].ps->team != g_player[sprite[i].yvel].ps->team)))
|
||||||
{
|
{
|
||||||
l = A_Spawn(k,JIBS6);
|
l = A_Spawn(k,JIBS6);
|
||||||
sprite[k].xrepeat = sprite[k].yrepeat = 0;
|
sprite[k].xrepeat = sprite[k].yrepeat = 0;
|
||||||
|
@ -1329,22 +1340,25 @@ DOSKIPBULLETHOLE:
|
||||||
goto SKIPBULLETHOLE;
|
goto SKIPBULLETHOLE;
|
||||||
l = nextspritestat[l];
|
l = nextspritestat[l];
|
||||||
}
|
}
|
||||||
l = A_Spawn(k,BULLETHOLE);
|
|
||||||
|
|
||||||
if (!A_CheckSpriteFlags(l , SPRITE_DECAL))
|
{
|
||||||
actor[l].flags |= SPRITE_DECAL;
|
l = A_Spawn(k,BULLETHOLE);
|
||||||
|
|
||||||
sprite[l].xvel = -1;
|
if (!A_CheckSpriteFlags(l , SPRITE_DECAL))
|
||||||
sprite[l].x = hit.pos.x;
|
actor[l].flags |= SPRITE_DECAL;
|
||||||
sprite[l].y = hit.pos.y;
|
|
||||||
sprite[l].z = hit.pos.z;
|
|
||||||
|
|
||||||
sprite[l].ang = getangle(wall[hit.wall].x-wall[wall[hit.wall].point2].x,
|
sprite[l].xvel = -1;
|
||||||
wall[hit.wall].y-wall[wall[hit.wall].point2].y)+512;
|
sprite[l].x = hit.pos.x;
|
||||||
|
sprite[l].y = hit.pos.y;
|
||||||
|
sprite[l].z = hit.pos.z;
|
||||||
|
|
||||||
sprite[l].x -= mulscale13(1,sintable[(sprite[l].ang+2560)&2047]);
|
sprite[l].ang = getangle(wall[hit.wall].x-wall[wall[hit.wall].point2].x,
|
||||||
sprite[l].y -= mulscale13(1,sintable[(sprite[l].ang+2048)&2047]);
|
wall[hit.wall].y-wall[wall[hit.wall].point2].y)+512;
|
||||||
A_SetSprite(l,CLIPMASK0);
|
|
||||||
|
sprite[l].x -= mulscale13(1,sintable[(sprite[l].ang+2560)&2047]);
|
||||||
|
sprite[l].y -= mulscale13(1,sintable[(sprite[l].ang+2048)&2047]);
|
||||||
|
A_SetSprite(l,CLIPMASK0);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
SKIPBULLETHOLE:
|
SKIPBULLETHOLE:
|
||||||
|
@ -1359,10 +1373,7 @@ SKIPBULLETHOLE:
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
k = A_InsertSprite(hit.sect,hit.pos.x,hit.pos.y,hit.pos.z,SHOTSPARK1,-15,24,24,sa,0,0,i,4);
|
k = Proj_InsertShotspark(&hit, i, atwith, 24, sa, G_InitialActorStrength(atwith));
|
||||||
sprite[k].extra = G_InitialActorStrength(atwith);
|
|
||||||
sprite[k].yvel = atwith; // this is a hack to allow you to detect which weapon spawned a SHOTSPARK1
|
|
||||||
A_SetHitData(k, &hit);
|
|
||||||
|
|
||||||
if (hit.sprite >= 0)
|
if (hit.sprite >= 0)
|
||||||
{
|
{
|
||||||
|
|
Loading…
Reference in a new issue