mirror of
https://github.com/YGGverse/hlsdk-portable.git
synced 2025-01-25 22:24:16 +00:00
Use bullet smoke trail from Zombie-X(Such as in original mod).
This commit is contained in:
parent
0b64830539
commit
689b5a2b9d
@ -244,14 +244,6 @@ char *EV_HLDM_DamageDecal( physent_t *pe )
|
|||||||
return decalname;
|
return decalname;
|
||||||
}
|
}
|
||||||
|
|
||||||
//=====================
|
|
||||||
// EV_WallPuffCallback
|
|
||||||
//=====================
|
|
||||||
void EV_WallPuffCallback( struct tempent_s *ent, float frametime, float currenttime )
|
|
||||||
{
|
|
||||||
ent->entity.angles = ent->entity.baseline.vuser1;
|
|
||||||
}
|
|
||||||
|
|
||||||
void EV_HLDM_GunshotDecalTrace( pmtrace_t *pTrace, char *decalName )
|
void EV_HLDM_GunshotDecalTrace( pmtrace_t *pTrace, char *decalName )
|
||||||
{
|
{
|
||||||
int iRand;
|
int iRand;
|
||||||
@ -292,35 +284,6 @@ void EV_HLDM_GunshotDecalTrace( pmtrace_t *pTrace, char *decalName )
|
|||||||
gEngfuncs.pEfxAPI->R_DecalShoot(
|
gEngfuncs.pEfxAPI->R_DecalShoot(
|
||||||
gEngfuncs.pEfxAPI->Draw_DecalIndex( gEngfuncs.pEfxAPI->Draw_DecalIndexFromName( decalName ) ),
|
gEngfuncs.pEfxAPI->Draw_DecalIndex( gEngfuncs.pEfxAPI->Draw_DecalIndexFromName( decalName ) ),
|
||||||
gEngfuncs.pEventAPI->EV_IndexFromTrace( pTrace ), 0, pTrace->endpos, 0 );
|
gEngfuncs.pEventAPI->EV_IndexFromTrace( pTrace ), 0, pTrace->endpos, 0 );
|
||||||
|
|
||||||
//
|
|
||||||
// Spawn small smoke puffs at the trace end location.
|
|
||||||
//
|
|
||||||
int modelindex = gEngfuncs.pEventAPI->EV_FindModelIndex( "sprites/wallsmoke.spr" );
|
|
||||||
Vector position = pTrace->endpos + pTrace->plane.normal * 2;
|
|
||||||
Vector velocity = pTrace->plane.normal * gEngfuncs.pfnRandomFloat( 8, 10 );
|
|
||||||
|
|
||||||
TEMPENTITY* pSmoke = gEngfuncs.pEfxAPI->R_TempSprite(
|
|
||||||
position, // position
|
|
||||||
velocity, // velocity
|
|
||||||
gEngfuncs.pfnRandomFloat( 0.3f, 0.5f ), // scale
|
|
||||||
modelindex, // model index
|
|
||||||
kRenderNormal, // rendermode
|
|
||||||
kRenderFxNoDissipation, // renderfx
|
|
||||||
0.5, // alpha
|
|
||||||
0.3, // life
|
|
||||||
FTENT_SPRCYCLE | FTENT_FADEOUT ); // flags
|
|
||||||
|
|
||||||
if( pSmoke )
|
|
||||||
{
|
|
||||||
Vector angles;
|
|
||||||
VectorAngles( velocity, angles );
|
|
||||||
|
|
||||||
pSmoke->flags |= FTENT_CLIENTCUSTOM;
|
|
||||||
pSmoke->entity.curstate.framerate = 30;
|
|
||||||
pSmoke->entity.baseline.vuser1 = angles;
|
|
||||||
pSmoke->callback = EV_WallPuffCallback;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -392,6 +355,136 @@ int EV_HLDM_CheckTracer( int idx, float *vecSrc, float *end, float *forward, flo
|
|||||||
return tracer;
|
return tracer;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
TTT: Event which spawns a smokepuff and/or sparks at a given origin
|
||||||
|
Note that you have to precache the sprites in the game dll
|
||||||
|
*/
|
||||||
|
void EV_HLDM_SmokePuff( pmtrace_t *pTrace, float *vecSrc, float *vecEnd )
|
||||||
|
{
|
||||||
|
physent_t *pe;
|
||||||
|
|
||||||
|
// get entity at endpoint
|
||||||
|
pe = gEngfuncs.pEventAPI->EV_GetPhysent( pTrace->ent );
|
||||||
|
|
||||||
|
if( pe && pe->solid == SOLID_BSP )
|
||||||
|
{
|
||||||
|
// if it's a solid wall / entity
|
||||||
|
char chTextureType = CHAR_TEX_CONCRETE;
|
||||||
|
const char *pTextureName;
|
||||||
|
char texname[64];
|
||||||
|
char szbuffer[64];
|
||||||
|
|
||||||
|
// get texture name
|
||||||
|
pTextureName = gEngfuncs.pEventAPI->EV_TraceTexture( pTrace->ent, vecSrc, vecEnd );
|
||||||
|
|
||||||
|
if( pTextureName )
|
||||||
|
{
|
||||||
|
strcpy( texname, pTextureName );
|
||||||
|
pTextureName = texname;
|
||||||
|
|
||||||
|
// strip leading '-0' or '+0~' or '{' or '!'
|
||||||
|
if(*pTextureName == '-' || *pTextureName == '+')
|
||||||
|
{
|
||||||
|
pTextureName += 2;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (*pTextureName == '{' || *pTextureName == '!' || *pTextureName == '~' || *pTextureName == ' ')
|
||||||
|
{
|
||||||
|
pTextureName++;
|
||||||
|
}
|
||||||
|
|
||||||
|
// '}}'
|
||||||
|
strcpy( szbuffer, pTextureName );
|
||||||
|
szbuffer[CBTEXTURENAMEMAX - 1 ] = 0;
|
||||||
|
|
||||||
|
// get texture type
|
||||||
|
chTextureType = PM_FindTextureType( szbuffer );
|
||||||
|
}
|
||||||
|
|
||||||
|
bool fDoPuffs = false;
|
||||||
|
bool fDoSparks = false;
|
||||||
|
int a, r, g, b;
|
||||||
|
|
||||||
|
switch( chTextureType )
|
||||||
|
{
|
||||||
|
// do smoke puff and eventually add sparks
|
||||||
|
case CHAR_TEX_TILE:
|
||||||
|
case CHAR_TEX_CONCRETE:
|
||||||
|
fDoSparks = ( gEngfuncs.pfnRandomLong( 1, 4 ) == 1 );
|
||||||
|
fDoPuffs = true;
|
||||||
|
a = 128;
|
||||||
|
r = 200;
|
||||||
|
g = 200;
|
||||||
|
b = 200;
|
||||||
|
break;
|
||||||
|
// don't draw puff, but add sparks often
|
||||||
|
case CHAR_TEX_VENT:
|
||||||
|
case CHAR_TEX_GRATE:
|
||||||
|
case CHAR_TEX_METAL:
|
||||||
|
fDoSparks = ( gEngfuncs.pfnRandomLong( 1, 2 ) == 1 );
|
||||||
|
break;
|
||||||
|
// draw brown puff, but don't do sparks
|
||||||
|
case CHAR_TEX_DIRT:
|
||||||
|
case CHAR_TEX_WOOD:
|
||||||
|
fDoPuffs = true;
|
||||||
|
a = 250;
|
||||||
|
r = 97;
|
||||||
|
g = 86;
|
||||||
|
b = 53;
|
||||||
|
break;
|
||||||
|
// don't do anything if those textures (perhaps add something later...)
|
||||||
|
default:
|
||||||
|
case CHAR_TEX_GLASS:
|
||||||
|
case CHAR_TEX_COMPUTER:
|
||||||
|
case CHAR_TEX_SLOSH:
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
if( fDoPuffs )
|
||||||
|
{
|
||||||
|
vec3_t angles, forward, right, up;
|
||||||
|
|
||||||
|
VectorAngles( pTrace->plane.normal, angles );
|
||||||
|
|
||||||
|
AngleVectors( angles, forward, up, right );
|
||||||
|
forward.z = -forward.z;
|
||||||
|
|
||||||
|
// get sprite index
|
||||||
|
int iWallsmoke = gEngfuncs.pEventAPI->EV_FindModelIndex( "sprites/wallsmoke.spr" );
|
||||||
|
|
||||||
|
// create sprite
|
||||||
|
TEMPENTITY *pTemp = gEngfuncs.pEfxAPI->R_TempSprite(
|
||||||
|
pTrace->endpos,
|
||||||
|
forward * gEngfuncs.pfnRandomFloat( 10, 30 ) + right * gEngfuncs.pfnRandomFloat( -6, 6 ) + up * gEngfuncs.pfnRandomFloat( 0, 6 ),
|
||||||
|
0.4,
|
||||||
|
iWallsmoke,
|
||||||
|
kRenderTransAlpha,
|
||||||
|
kRenderFxNone,
|
||||||
|
1.0,
|
||||||
|
0.3,
|
||||||
|
FTENT_SPRANIMATE | FTENT_FADEOUT
|
||||||
|
);
|
||||||
|
|
||||||
|
if( pTemp )
|
||||||
|
{
|
||||||
|
// sprite created successfully, adjust some things
|
||||||
|
pTemp->fadeSpeed = 2.0;
|
||||||
|
pTemp->entity.curstate.framerate = 20.0;
|
||||||
|
pTemp->entity.curstate.renderamt = a;
|
||||||
|
pTemp->entity.curstate.rendercolor.r = r;
|
||||||
|
pTemp->entity.curstate.rendercolor.g = g;
|
||||||
|
pTemp->entity.curstate.rendercolor.b = b;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if( fDoSparks )
|
||||||
|
{
|
||||||
|
// spawn some sparks
|
||||||
|
gEngfuncs.pEfxAPI->R_SparkShower( pTrace->endpos );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
================
|
================
|
||||||
FireBullets
|
FireBullets
|
||||||
@ -455,6 +548,7 @@ void EV_HLDM_FireBullets( int idx, float *forward, float *right, float *up, int
|
|||||||
break;
|
break;
|
||||||
case BULLET_PLAYER_BUCKSHOT:
|
case BULLET_PLAYER_BUCKSHOT:
|
||||||
EV_HLDM_DecalGunshot( &tr, iBulletType );
|
EV_HLDM_DecalGunshot( &tr, iBulletType );
|
||||||
|
EV_HLDM_SmokePuff( &tr, vecSrc, vecEnd );
|
||||||
break;
|
break;
|
||||||
case BULLET_PLAYER_357:
|
case BULLET_PLAYER_357:
|
||||||
EV_HLDM_PlayTextureSound( idx, &tr, vecSrc, vecEnd, iBulletType );
|
EV_HLDM_PlayTextureSound( idx, &tr, vecSrc, vecEnd, iBulletType );
|
||||||
|
Loading…
x
Reference in New Issue
Block a user