mirror of
https://github.com/alliedmodders/hl2sdk.git
synced 2025-01-05 17:13:36 +08:00
72 lines
1.7 KiB
C++
72 lines
1.7 KiB
C++
|
//========= Copyright <20> 1996-2005, Valve Corporation, All rights reserved. ============//
|
|||
|
//
|
|||
|
// Purpose:
|
|||
|
//
|
|||
|
// $NoKeywords: $
|
|||
|
//=============================================================================//
|
|||
|
#include "cbase.h"
|
|||
|
#include "game.h"
|
|||
|
#include "cplane.h"
|
|||
|
|
|||
|
// memdbgon must be the last include file in a .cpp file!!!
|
|||
|
#include "tier0/memdbgon.h"
|
|||
|
|
|||
|
//=========================================================
|
|||
|
// Plane
|
|||
|
//=========================================================
|
|||
|
CPlane::CPlane ( void )
|
|||
|
{
|
|||
|
m_fInitialized = FALSE;
|
|||
|
}
|
|||
|
|
|||
|
//=========================================================
|
|||
|
// InitializePlane - Takes a normal for the plane and a
|
|||
|
// point on the plane and
|
|||
|
//=========================================================
|
|||
|
void CPlane::InitializePlane ( const Vector &vecNormal, const Vector &vecPoint )
|
|||
|
{
|
|||
|
m_vecNormal = vecNormal;
|
|||
|
m_flDist = DotProduct ( m_vecNormal, vecPoint );
|
|||
|
m_fInitialized = TRUE;
|
|||
|
}
|
|||
|
|
|||
|
|
|||
|
//=========================================================
|
|||
|
// PointInFront - determines whether the given vector is
|
|||
|
// in front of the plane.
|
|||
|
//=========================================================
|
|||
|
bool CPlane::PointInFront ( const Vector &vecPoint )
|
|||
|
{
|
|||
|
float flFace;
|
|||
|
|
|||
|
if ( !m_fInitialized )
|
|||
|
{
|
|||
|
return FALSE;
|
|||
|
}
|
|||
|
|
|||
|
flFace = DotProduct ( m_vecNormal, vecPoint ) - m_flDist;
|
|||
|
|
|||
|
if ( flFace >= 0 )
|
|||
|
{
|
|||
|
return TRUE;
|
|||
|
}
|
|||
|
|
|||
|
return FALSE;
|
|||
|
}
|
|||
|
|
|||
|
//=========================================================
|
|||
|
//=========================================================
|
|||
|
float CPlane::PointDist ( const Vector &vecPoint )
|
|||
|
{
|
|||
|
float flDist;
|
|||
|
|
|||
|
if ( !m_fInitialized )
|
|||
|
{
|
|||
|
return FALSE;
|
|||
|
}
|
|||
|
|
|||
|
flDist = DotProduct ( m_vecNormal, vecPoint ) - m_flDist;
|
|||
|
|
|||
|
return flDist;
|
|||
|
}
|