2015-10-25 16:07:56 +01:00
|
|
|
/***
|
|
|
|
*
|
|
|
|
* Copyright (c) 1996-2002, Valve LLC. All rights reserved.
|
2015-12-27 12:06:55 +01:00
|
|
|
*
|
|
|
|
* This product contains software technology licensed from Id
|
|
|
|
* Software, Inc. ("Id Technology"). Id Technology (c) 1996 Id Software, Inc.
|
2015-10-25 16:07:56 +01:00
|
|
|
* 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.
|
|
|
|
*
|
|
|
|
****/
|
|
|
|
|
2015-12-27 12:06:55 +01:00
|
|
|
#include "stdafx.h"
|
|
|
|
#include "cbase.h"
|
|
|
|
#include "monsters.h"
|
|
|
|
#include "game.h"
|
2015-10-25 16:07:56 +01:00
|
|
|
|
2015-12-27 12:06:55 +01:00
|
|
|
#define NUM_LATERAL_CHECKS 13
|
|
|
|
#define NUM_LATERAL_LOS_CHECKS 6
|
2015-10-25 16:07:56 +01:00
|
|
|
|
2015-12-27 12:06:55 +01:00
|
|
|
DLL_GLOBAL BOOL g_fDrawLines = FALSE;
|
2015-10-25 16:07:56 +01:00
|
|
|
|
2015-12-27 12:06:55 +01:00
|
|
|
BOOL FBoxVisible(entvars_t *pevLooker, entvars_t *pevTarget, Vector &vecTargetOrigin, float flSize)
|
2015-10-25 16:07:56 +01:00
|
|
|
{
|
2015-12-27 12:06:55 +01:00
|
|
|
if ((pevLooker->waterlevel != 3 && pevTarget->waterlevel == 3) || (pevLooker->waterlevel == 3 && pevTarget->waterlevel == 0))
|
2015-10-25 16:07:56 +01:00
|
|
|
return FALSE;
|
|
|
|
|
2015-12-27 12:06:55 +01:00
|
|
|
Vector vecLookerOrigin = pevLooker->origin + pevLooker->view_ofs;
|
|
|
|
|
2015-10-25 16:07:56 +01:00
|
|
|
for (int i = 0; i < 5; i++)
|
|
|
|
{
|
|
|
|
Vector vecTarget = pevTarget->origin;
|
2015-12-27 12:06:55 +01:00
|
|
|
vecTarget.x += RANDOM_FLOAT(pevTarget->mins.x + flSize, pevTarget->maxs.x - flSize);
|
|
|
|
vecTarget.y += RANDOM_FLOAT(pevTarget->mins.y + flSize, pevTarget->maxs.y - flSize);
|
|
|
|
vecTarget.z += RANDOM_FLOAT(pevTarget->mins.z + flSize, pevTarget->maxs.z - flSize);
|
|
|
|
|
|
|
|
TraceResult tr;
|
|
|
|
UTIL_TraceLine(vecLookerOrigin, vecTarget, ignore_monsters, ignore_glass, ENT(pevLooker), &tr);
|
2015-10-25 16:07:56 +01:00
|
|
|
|
2015-12-27 12:06:55 +01:00
|
|
|
if (tr.flFraction == 1)
|
2015-10-25 16:07:56 +01:00
|
|
|
{
|
|
|
|
vecTargetOrigin = vecTarget;
|
2015-12-27 12:06:55 +01:00
|
|
|
return TRUE;
|
2015-10-25 16:07:56 +01:00
|
|
|
}
|
|
|
|
}
|
2015-12-27 12:06:55 +01:00
|
|
|
|
|
|
|
return FALSE;
|
2015-10-25 16:07:56 +01:00
|
|
|
}
|
|
|
|
|
2015-12-27 12:06:55 +01:00
|
|
|
Vector VecCheckToss(entvars_t *pev, const Vector &vecSpot1, Vector vecSpot2, float flGravityAdj)
|
2015-10-25 16:07:56 +01:00
|
|
|
{
|
2015-12-27 12:06:55 +01:00
|
|
|
float flGravity = CVAR_GET_FLOAT("sv_gravity") * flGravityAdj;
|
2015-10-25 16:07:56 +01:00
|
|
|
|
|
|
|
if (vecSpot2.z - vecSpot1.z > 500)
|
|
|
|
return g_vecZero;
|
|
|
|
|
2015-12-27 12:06:55 +01:00
|
|
|
UTIL_MakeVectors(pev->angles);
|
|
|
|
vecSpot2 = vecSpot2 + gpGlobals->v_right * (RANDOM_FLOAT(-8, 8) + RANDOM_FLOAT(-16, 16));
|
|
|
|
vecSpot2 = vecSpot2 + gpGlobals->v_forward * (RANDOM_FLOAT(-8, 8) + RANDOM_FLOAT(-16, 16));
|
2015-10-25 16:07:56 +01:00
|
|
|
|
2015-12-27 12:06:55 +01:00
|
|
|
TraceResult tr;
|
|
|
|
Vector vecMidPoint = vecSpot1 + (vecSpot2 - vecSpot1) * 0.5;
|
|
|
|
UTIL_TraceLine(vecMidPoint, vecMidPoint + Vector(0, 0, 500), ignore_monsters, ENT(pev), &tr);
|
2015-10-25 16:07:56 +01:00
|
|
|
vecMidPoint = tr.vecEndPos;
|
2015-12-27 12:06:55 +01:00
|
|
|
vecMidPoint.z -= 50;
|
2015-10-25 16:07:56 +01:00
|
|
|
|
|
|
|
if (vecMidPoint.z < vecSpot1.z || vecMidPoint.z < vecSpot2.z)
|
|
|
|
return g_vecZero;
|
|
|
|
|
|
|
|
float distance1 = (vecMidPoint.z - vecSpot1.z);
|
|
|
|
float distance2 = (vecMidPoint.z - vecSpot2.z);
|
2015-12-27 12:06:55 +01:00
|
|
|
float time1 = sqrt(distance1 / (0.5 * flGravity));
|
|
|
|
float time2 = sqrt(distance2 / (0.5 * flGravity));
|
2015-10-25 16:07:56 +01:00
|
|
|
|
|
|
|
if (time1 < 0.1)
|
|
|
|
return g_vecZero;
|
|
|
|
|
2015-12-27 12:06:55 +01:00
|
|
|
Vector vecGrenadeVel = (vecSpot2 - vecSpot1) / (time1 + time2);
|
2015-10-25 16:07:56 +01:00
|
|
|
vecGrenadeVel.z = flGravity * time1;
|
2015-12-27 12:06:55 +01:00
|
|
|
Vector vecApex = vecSpot1 + vecGrenadeVel * time1;
|
2015-10-25 16:07:56 +01:00
|
|
|
vecApex.z = vecMidPoint.z;
|
|
|
|
|
|
|
|
UTIL_TraceLine(vecSpot1, vecApex, dont_ignore_monsters, ENT(pev), &tr);
|
2015-12-27 12:06:55 +01:00
|
|
|
|
|
|
|
if (tr.flFraction != 1)
|
2015-10-25 16:07:56 +01:00
|
|
|
return g_vecZero;
|
|
|
|
|
2015-12-27 12:06:55 +01:00
|
|
|
UTIL_TraceLine(vecSpot2, vecApex, ignore_monsters, ENT(pev), &tr);
|
|
|
|
|
|
|
|
if (tr.flFraction != 1)
|
2015-10-25 16:07:56 +01:00
|
|
|
return g_vecZero;
|
2015-12-27 12:06:55 +01:00
|
|
|
|
2015-10-25 16:07:56 +01:00
|
|
|
return vecGrenadeVel;
|
|
|
|
}
|
|
|
|
|
2015-12-27 12:06:55 +01:00
|
|
|
Vector VecCheckThrow(entvars_t *pev, const Vector &vecSpot1, Vector vecSpot2, float flSpeed, float flGravityAdj)
|
2015-10-25 16:07:56 +01:00
|
|
|
{
|
2015-12-27 12:06:55 +01:00
|
|
|
float flGravity = CVAR_GET_FLOAT("sv_gravity") * flGravityAdj;
|
2015-10-25 16:07:56 +01:00
|
|
|
Vector vecGrenadeVel = (vecSpot2 - vecSpot1);
|
2015-12-27 12:06:55 +01:00
|
|
|
float time = vecGrenadeVel.Length() / flSpeed;
|
|
|
|
vecGrenadeVel = vecGrenadeVel * (1 / time);
|
2015-10-25 16:07:56 +01:00
|
|
|
vecGrenadeVel.z += flGravity * time * 0.5;
|
|
|
|
|
|
|
|
Vector vecApex = vecSpot1 + (vecSpot2 - vecSpot1) * 0.5;
|
|
|
|
vecApex.z += 0.5 * flGravity * (time * 0.5) * (time * 0.5);
|
2015-12-27 12:06:55 +01:00
|
|
|
|
2015-10-25 16:07:56 +01:00
|
|
|
TraceResult tr;
|
|
|
|
UTIL_TraceLine(vecSpot1, vecApex, dont_ignore_monsters, ENT(pev), &tr);
|
2015-12-27 12:06:55 +01:00
|
|
|
|
|
|
|
if (tr.flFraction != 1)
|
2015-10-25 16:07:56 +01:00
|
|
|
return g_vecZero;
|
|
|
|
|
|
|
|
UTIL_TraceLine(vecSpot2, vecApex, ignore_monsters, ENT(pev), &tr);
|
2015-12-27 12:06:55 +01:00
|
|
|
|
|
|
|
if (tr.flFraction != 1)
|
2015-10-25 16:07:56 +01:00
|
|
|
return g_vecZero;
|
|
|
|
|
|
|
|
return vecGrenadeVel;
|
2015-12-27 12:06:55 +01:00
|
|
|
}
|