hlsdk-portable/cl_dll/ev_common.cpp

207 lines
4.1 KiB
C++
Raw Normal View History

2016-06-04 18:24:23 +05:00
/***
*
* Copyright (c) 1996-2002, Valve LLC. All rights reserved.
*
* This product contains software technology licensed from Id
* Software, Inc. ("Id Technology"). Id Technology (c) 1996 Id Software, Inc.
* All Rights Reserved.
*
* Use, distribution, and modification of this source code and/or resulting
* object code is restricted to non-commercial enhancements to products from
* Valve LLC. All other use, distribution, or modification is prohibited
* without written permission from Valve LLC.
*
****/
// shared event functions
2016-07-03 18:39:55 +05:00
2016-06-04 18:24:23 +05:00
#include "hud.h"
#include "cl_util.h"
#include "const.h"
#include "entity_state.h"
#include "cl_entity.h"
#include "r_efx.h"
#include "eventscripts.h"
#include "event_api.h"
#include "pm_shared.h"
2016-07-03 18:39:55 +05:00
#define IS_FIRSTPERSON_SPEC ( g_iUser1 == OBS_IN_EYE || ( g_iUser1 && ( gHUD.m_Spectator.m_pip->value == INSET_IN_EYE ) ) )
2016-06-04 18:24:23 +05:00
/*
=================
GetEntity
Return's the requested cl_entity_t
=================
*/
struct cl_entity_s *GetEntity( int idx )
{
return gEngfuncs.GetEntityByIndex( idx );
}
/*
=================
GetViewEntity
Return's the current weapon/view model
=================
*/
struct cl_entity_s *GetViewEntity( void )
{
return gEngfuncs.GetViewModel();
}
/*
=================
EV_CreateTracer
Creates a tracer effect
=================
*/
void EV_CreateTracer( float *start, float *end )
{
gEngfuncs.pEfxAPI->R_TracerEffect( start, end );
}
/*
=================
EV_IsPlayer
Is the entity's index in the player range?
=================
*/
qboolean EV_IsPlayer( int idx )
{
2016-07-03 18:39:55 +05:00
if( idx >= 1 && idx <= gEngfuncs.GetMaxClients() )
2016-06-04 18:24:23 +05:00
return true;
return false;
}
/*
=================
EV_IsLocal
Is the entity == the local player
=================
*/
qboolean EV_IsLocal( int idx )
{
// check if we are in some way in first person spec mode
2016-07-03 18:39:55 +05:00
if( IS_FIRSTPERSON_SPEC )
return ( g_iUser2 == idx );
2016-06-04 18:24:23 +05:00
else
return gEngfuncs.pEventAPI->EV_IsLocal( idx - 1 ) ? true : false;
}
/*
=================
EV_GetGunPosition
Figure out the height of the gun
=================
*/
void EV_GetGunPosition( event_args_t *args, float *pos, float *origin )
{
int idx;
vec3_t view_ofs;
idx = args->entindex;
VectorClear( view_ofs );
view_ofs[2] = DEFAULT_VIEWHEIGHT;
2016-07-03 18:39:55 +05:00
if( EV_IsPlayer( idx ) )
2016-06-04 18:24:23 +05:00
{
// in spec mode use entity viewheigh, not own
2016-07-03 18:39:55 +05:00
if( EV_IsLocal( idx ) && !IS_FIRSTPERSON_SPEC )
2016-06-04 18:24:23 +05:00
{
// Grab predicted result for local player
gEngfuncs.pEventAPI->EV_LocalPlayerViewheight( view_ofs );
}
2016-07-03 18:39:55 +05:00
else if( args->ducking == 1 )
2016-06-04 18:24:23 +05:00
{
view_ofs[2] = VEC_DUCK_VIEW;
}
}
VectorAdd( origin, view_ofs, pos );
}
/*
=================
EV_EjectBrass
Bullet shell casings
=================
*/
void EV_EjectBrass( float *origin, float *velocity, float rotation, int model, int soundtype )
{
vec3_t endpos;
VectorClear( endpos );
endpos[1] = rotation;
gEngfuncs.pEfxAPI->R_TempModel( origin, velocity, endpos, 2.5, model, soundtype );
}
/*
=================
EV_GetDefaultShellInfo
Determine where to eject shells from
=================
*/
void EV_GetDefaultShellInfo( event_args_t *args, float *origin, float *velocity, float *ShellVelocity, float *ShellOrigin, float *forward, float *right, float *up, float forwardScale, float upScale, float rightScale )
{
int i;
vec3_t view_ofs;
float fR, fU;
int idx;
idx = args->entindex;
VectorClear( view_ofs );
view_ofs[2] = DEFAULT_VIEWHEIGHT;
2016-07-03 18:39:55 +05:00
if( EV_IsPlayer( idx ) )
2016-06-04 18:24:23 +05:00
{
2016-07-03 18:39:55 +05:00
if( EV_IsLocal( idx ) )
2016-06-04 18:24:23 +05:00
{
gEngfuncs.pEventAPI->EV_LocalPlayerViewheight( view_ofs );
}
2016-07-03 18:39:55 +05:00
else if( args->ducking == 1 )
2016-06-04 18:24:23 +05:00
{
view_ofs[2] = VEC_DUCK_VIEW;
}
}
fR = gEngfuncs.pfnRandomFloat( 50, 70 );
fU = gEngfuncs.pfnRandomFloat( 100, 150 );
2016-07-03 18:39:55 +05:00
for( i = 0; i < 3; i++ )
2016-06-04 18:24:23 +05:00
{
ShellVelocity[i] = velocity[i] + right[i] * fR + up[i] * fU + forward[i] * 25;
2016-07-03 18:39:55 +05:00
ShellOrigin[i] = origin[i] + view_ofs[i] + up[i] * upScale + forward[i] * forwardScale + right[i] * rightScale;
2016-06-04 18:24:23 +05:00
}
}
/*
=================
EV_MuzzleFlash
Flag weapon/view model for muzzle flash
=================
*/
void EV_MuzzleFlash( void )
{
// Add muzzle flash to current weapon model
cl_entity_t *ent = GetViewEntity();
2016-07-03 18:39:55 +05:00
if( !ent )
2016-06-04 18:24:23 +05:00
{
return;
}
// Or in the muzzle flash
ent->curstate.effects |= EF_MUZZLEFLASH;
2016-07-03 18:39:55 +05:00
}