mirror of
https://github.com/ZDoom/raze-gles.git
synced 2025-01-12 19:20:38 +00:00
Minor optimizations
git-svn-id: https://svn.eduke32.com/eduke32@6235 1a8010ca-5511-0410-912e-c29ae57300e0
This commit is contained in:
parent
f698b1e733
commit
302d6bdfd8
1 changed files with 15 additions and 32 deletions
|
@ -478,20 +478,18 @@ static void P_PreFireHitscan(int spriteNum, int playerNum, int projecTile, vec3_
|
||||||
int const statNumMap = ((1 << STAT_ACTOR) | (1 << STAT_ZOMBIEACTOR) | (1 << STAT_PLAYER) | (1 << STAT_DUMMYPLAYER));
|
int const statNumMap = ((1 << STAT_ACTOR) | (1 << STAT_ZOMBIEACTOR) | (1 << STAT_PLAYER) | (1 << STAT_DUMMYPLAYER));
|
||||||
int const statNum = sprite[hitData.sprite].statnum;
|
int const statNum = sprite[hitData.sprite].statnum;
|
||||||
|
|
||||||
if (statNum >= 0 && statNum <= 30 && (statNumMap & (1 << statNum)))
|
if ((unsigned)statNum <= 30 && (statNumMap & (1 << statNum)))
|
||||||
aimSprite = hitData.sprite;
|
aimSprite = hitData.sprite;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (aimSprite == -1)
|
if (aimSprite == -1)
|
||||||
{
|
goto notarget;
|
||||||
*zvel = (100-pPlayer->horiz-pPlayer->horizoff)<<5;
|
|
||||||
Proj_MaybeAddSpread(doSpread, zvel, shootAng, zRange, angRange);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
if (aimSprite == -1) // no target
|
if (aimSprite == -1) // no target
|
||||||
|
notarget:
|
||||||
*zvel = (100-pPlayer->horiz-pPlayer->horizoff)<<5;
|
*zvel = (100-pPlayer->horiz-pPlayer->horizoff)<<5;
|
||||||
Proj_MaybeAddSpread(doSpread, zvel, shootAng, zRange, angRange);
|
Proj_MaybeAddSpread(doSpread, zvel, shootAng, zRange, angRange);
|
||||||
}
|
}
|
||||||
|
@ -510,16 +508,10 @@ static void A_PreFireHitscan(const spritetype *pSprite, vec3_t *srcVect, int32_t
|
||||||
|
|
||||||
srcVect->z -= ZOFFSET6;
|
srcVect->z -= ZOFFSET6;
|
||||||
|
|
||||||
if (pSprite->picnum != BOSS1)
|
if (pSprite->picnum == BOSS1)
|
||||||
{
|
*shootAng = getangle(pPlayer->pos.x - srcVect->x, pPlayer->pos.y - srcVect->y);
|
||||||
Proj_MaybeAddSpread(doSpread, zvel, shootAng, 256, 64);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
*shootAng = getangle(pPlayer->pos.x-srcVect->x, pPlayer->pos.y-srcVect->y);
|
|
||||||
|
|
||||||
Proj_MaybeAddSpread(doSpread, zvel, shootAng, 256, 128);
|
Proj_MaybeAddSpread(doSpread, zvel, shootAng, 256, 128 >> (pSprite->picnum != BOSS1));
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static int Proj_DoHitscan(int spriteNum, int32_t cstatmask, const vec3_t *srcVect, int zvel, int shootAng, hitdata_t *hitData)
|
static int Proj_DoHitscan(int spriteNum, int32_t cstatmask, const vec3_t *srcVect, int zvel, int shootAng, hitdata_t *hitData)
|
||||||
|
@ -534,21 +526,13 @@ static int Proj_DoHitscan(int spriteNum, int32_t cstatmask, const vec3_t *srcVec
|
||||||
return (hitData->sect < 0);
|
return (hitData->sect < 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void Proj_DoRandDecalSize(int spriteNum, int projecTile)
|
static void Proj_DoRandDecalSize(int const spriteNum, int const projecTile)
|
||||||
{
|
{
|
||||||
const projectile_t *const proj = Proj_GetProjectile(projecTile);
|
const projectile_t *const proj = Proj_GetProjectile(projecTile);
|
||||||
spritetype *const pSprite = &sprite[spriteNum];
|
spritetype *const pSprite = &sprite[spriteNum];
|
||||||
|
|
||||||
if (proj->workslike & PROJECTILE_RANDDECALSIZE)
|
if (proj->workslike & PROJECTILE_RANDDECALSIZE)
|
||||||
{
|
pSprite->xrepeat = pSprite->yrepeat = clamp((krand() & proj->xrepeat), pSprite->yrepeat, pSprite->xrepeat);
|
||||||
int projSize = (krand() & proj->xrepeat);
|
|
||||||
|
|
||||||
if (projSize < proj->yrepeat)
|
|
||||||
projSize = proj->yrepeat;
|
|
||||||
|
|
||||||
pSprite->xrepeat = projSize;
|
|
||||||
pSprite->yrepeat = projSize;
|
|
||||||
}
|
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
pSprite->xrepeat = proj->xrepeat;
|
pSprite->xrepeat = proj->xrepeat;
|
||||||
|
@ -718,7 +702,6 @@ static int P_PostFireHitscan(int playerNum, int spriteNum, hitdata_t *hitData, i
|
||||||
|
|
||||||
SKIPBULLETHOLE:
|
SKIPBULLETHOLE:
|
||||||
HandleHitWall(hitData);
|
HandleHitWall(hitData);
|
||||||
|
|
||||||
A_DamageWall(spriteNum, hitData->wall, &hitData->pos, wallDamage);
|
A_DamageWall(spriteNum, hitData->wall, &hitData->pos, wallDamage);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -726,10 +709,10 @@ SKIPBULLETHOLE:
|
||||||
}
|
}
|
||||||
|
|
||||||
// Finish shooting hitscan weapon from actor (sprite <i>).
|
// Finish shooting hitscan weapon from actor (sprite <i>).
|
||||||
static int A_PostFireHitscan(const hitdata_t *hitData, int spriteNum, int projecTile, int zvel, int shootAng, int extra,
|
static int A_PostFireHitscan(const hitdata_t *hitData, int const spriteNum, int const projecTile, int const zvel, int const shootAng,
|
||||||
int spawnTile, int wallDamage)
|
int const extra, int const spawnTile, int const wallDamage)
|
||||||
{
|
{
|
||||||
int returnSprite = Proj_InsertShotspark(hitData, spriteNum, projecTile, 24, shootAng, extra);
|
int const returnSprite = Proj_InsertShotspark(hitData, spriteNum, projecTile, 24, shootAng, extra);
|
||||||
|
|
||||||
if (hitData->sprite >= 0)
|
if (hitData->sprite >= 0)
|
||||||
{
|
{
|
||||||
|
@ -760,7 +743,7 @@ static int A_PostFireHitscan(const hitdata_t *hitData, int spriteNum, int projec
|
||||||
|
|
||||||
// Common "spawn blood?" predicate.
|
// Common "spawn blood?" predicate.
|
||||||
// minzdiff: minimal "step" height for blood to be spawned
|
// minzdiff: minimal "step" height for blood to be spawned
|
||||||
static int Proj_CheckBlood(vec3_t const *const srcVect, hitdata_t const *const hitData, int bloodRange, int minZdiff)
|
static int Proj_CheckBlood(vec3_t const *const srcVect, hitdata_t const *const hitData, int const bloodRange, int const minZdiff)
|
||||||
{
|
{
|
||||||
if (hitData->wall < 0 || hitData->sect < 0)
|
if (hitData->wall < 0 || hitData->sect < 0)
|
||||||
return 0;
|
return 0;
|
||||||
|
@ -777,9 +760,9 @@ static int Proj_CheckBlood(vec3_t const *const srcVect, hitdata_t const *const h
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void Proj_HandleKnee(hitdata_t *hitData, int spriteNum, int playerNum, int projecTile, int shootAng,
|
static void Proj_HandleKnee(hitdata_t *const hitData, int const spriteNum, int const playerNum, int const projecTile, int const shootAng,
|
||||||
const projectile_t *proj, int inserttile,
|
const projectile_t *const proj, int const inserttile, int const randomDamage, int const spawnTile,
|
||||||
int randomDamage, int spawnTile, int soundNum)
|
int const soundNum)
|
||||||
{
|
{
|
||||||
const DukePlayer_t *const pPlayer = playerNum >= 0 ? g_player[playerNum].ps : NULL;
|
const DukePlayer_t *const pPlayer = playerNum >= 0 ? g_player[playerNum].ps : NULL;
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue