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.
|
|
|
|
*
|
|
|
|
****/
|
2017-12-11 01:40:41 +05:00
|
|
|
#pragma once
|
2021-06-20 03:53:07 +05:00
|
|
|
#if !defined(VECTOR_H)
|
2016-06-04 18:24:23 +05:00
|
|
|
#define VECTOR_H
|
|
|
|
|
|
|
|
//=========================================================
|
|
|
|
// 2DVector - used for many pathfinding and many other
|
|
|
|
// operations that are treated as planar rather than 3d.
|
|
|
|
//=========================================================
|
|
|
|
class Vector2D
|
|
|
|
{
|
|
|
|
public:
|
2017-06-29 18:56:03 +05:00
|
|
|
inline Vector2D(void): x( 0.0f ), y( 0.0f ) { }
|
|
|
|
inline Vector2D(float X, float Y): x( 0.0f ), y( 0.0f ) { x = X; y = Y; }
|
2016-07-31 18:48:50 +05:00
|
|
|
inline Vector2D operator+(const Vector2D& v) const { return Vector2D( x + v.x, y + v.y ); }
|
|
|
|
inline Vector2D operator-(const Vector2D& v) const { return Vector2D( x - v.x, y - v.y ); }
|
|
|
|
inline Vector2D operator*(float fl) const { return Vector2D( x * fl, y * fl ); }
|
|
|
|
inline Vector2D operator/(float fl) const { return Vector2D( x / fl, y / fl ); }
|
2016-06-25 21:33:39 +05:00
|
|
|
|
2016-07-31 18:48:50 +05:00
|
|
|
inline float Length(void) const { return sqrt(x * x + y * y ); }
|
2016-06-04 18:24:23 +05:00
|
|
|
|
|
|
|
inline Vector2D Normalize ( void ) const
|
|
|
|
{
|
2017-06-29 18:56:03 +05:00
|
|
|
//Vector2D vec2;
|
2016-06-04 18:24:23 +05:00
|
|
|
|
|
|
|
float flLen = Length();
|
2016-07-31 18:48:50 +05:00
|
|
|
if( flLen == 0 )
|
2016-06-04 18:24:23 +05:00
|
|
|
{
|
|
|
|
return Vector2D( 0, 0 );
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
flLen = 1 / flLen;
|
|
|
|
return Vector2D( x * flLen, y * flLen );
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
vec_t x, y;
|
|
|
|
};
|
|
|
|
|
2016-07-31 18:48:50 +05:00
|
|
|
inline float DotProduct( const Vector2D& a, const Vector2D& b ) { return( a.x * b.x + a.y * b.y ); }
|
|
|
|
inline Vector2D operator*( float fl, const Vector2D& v ) { return v * fl; }
|
2016-06-04 18:24:23 +05:00
|
|
|
|
|
|
|
//=========================================================
|
|
|
|
// 3D Vector
|
|
|
|
//=========================================================
|
|
|
|
class Vector // same data-layout as engine's vec3_t,
|
|
|
|
{ // which is a vec_t[3]
|
|
|
|
public:
|
|
|
|
// Construction/destruction
|
2017-06-29 18:56:03 +05:00
|
|
|
inline Vector( void ): x( 0.0f ), y( 0.0f ), z( 0.0f ) { }
|
|
|
|
inline Vector( float X, float Y, float Z ): x( 0.0f ), y( 0.0f ), z( 0.0f ) { x = X; y = Y; z = Z; }
|
2016-07-31 18:48:50 +05:00
|
|
|
//inline Vector( double X, double Y, double Z ) { x = (float)X; y = (float)Y; z = (float)Z; }
|
|
|
|
//inline Vector( int X, int Y, int Z ) { x = (float)X; y = (float)Y; z = (float)Z; }
|
2017-06-29 18:56:03 +05:00
|
|
|
inline Vector( const Vector& v ): x( 0.0f ), y( 0.0f ), z( 0.0f ) { x = v.x; y = v.y; z = v.z; }
|
|
|
|
inline Vector( float rgfl[3] ): x( 0.0f ), y( 0.0f ), z( 0.0f ) { x = rgfl[0]; y = rgfl[1]; z = rgfl[2]; }
|
2016-06-04 18:24:23 +05:00
|
|
|
|
|
|
|
// Operators
|
2016-07-31 18:48:50 +05:00
|
|
|
inline Vector operator-( void ) const { return Vector( -x, -y, -z ); }
|
|
|
|
inline int operator==( const Vector& v ) const { return x==v.x && y==v.y && z==v.z; }
|
|
|
|
inline int operator!=( const Vector& v ) const { return !( *this==v ); }
|
|
|
|
inline Vector operator+( const Vector& v ) const { return Vector( x + v.x, y + v.y, z + v.z ); }
|
|
|
|
inline Vector operator-( const Vector& v ) const { return Vector( x - v.x, y - v.y, z - v.z ); }
|
|
|
|
inline Vector operator*( float fl) const { return Vector( x * fl, y * fl, z * fl ); }
|
|
|
|
inline Vector operator/( float fl) const { return Vector( x / fl, y / fl, z / fl ); }
|
2016-06-25 21:33:39 +05:00
|
|
|
|
2016-06-04 18:24:23 +05:00
|
|
|
// Methods
|
2016-07-31 18:48:50 +05:00
|
|
|
inline void CopyToArray( float* rgfl ) const { rgfl[0] = x, rgfl[1] = y, rgfl[2] = z; }
|
|
|
|
inline float Length( void ) const { return sqrt( x * x + y * y + z * z ); }
|
2016-06-04 18:24:23 +05:00
|
|
|
operator float *() { return &x; } // Vectors will now automatically convert to float * when needed
|
|
|
|
operator const float *() const { return &x; } // Vectors will now automatically convert to float * when needed
|
2016-07-31 18:48:50 +05:00
|
|
|
inline Vector Normalize( void ) const
|
2016-06-04 18:24:23 +05:00
|
|
|
{
|
|
|
|
float flLen = Length();
|
2016-07-31 18:48:50 +05:00
|
|
|
if( flLen == 0 ) return Vector( 0, 0, 1 ); // ????
|
2016-06-04 18:24:23 +05:00
|
|
|
flLen = 1 / flLen;
|
2016-07-31 18:48:50 +05:00
|
|
|
return Vector( x * flLen, y * flLen, z * flLen );
|
2016-06-04 18:24:23 +05:00
|
|
|
}
|
|
|
|
|
2016-07-31 18:48:50 +05:00
|
|
|
inline Vector2D Make2D( void ) const
|
2016-06-04 18:24:23 +05:00
|
|
|
{
|
|
|
|
Vector2D Vec2;
|
|
|
|
|
|
|
|
Vec2.x = x;
|
|
|
|
Vec2.y = y;
|
|
|
|
|
|
|
|
return Vec2;
|
|
|
|
}
|
2016-07-31 18:48:50 +05:00
|
|
|
inline float Length2D( void ) const { return sqrt( x * x + y * y ); }
|
2016-06-04 18:24:23 +05:00
|
|
|
|
|
|
|
// Members
|
|
|
|
vec_t x, y, z;
|
|
|
|
};
|
2016-07-31 18:48:50 +05:00
|
|
|
inline Vector operator*( float fl, const Vector& v ) { return v * fl; }
|
|
|
|
inline float DotProduct( const Vector& a, const Vector& b ) { return( a.x * b.x + a.y * b.y + a.z * b.z); }
|
|
|
|
inline Vector CrossProduct( const Vector& a, const Vector& b ) { return Vector( a.y * b.z - a.z * b.y, a.z * b.x - a.x * b.z, a.x * b.y - a.y * b.x ); }
|
2016-06-25 21:33:39 +05:00
|
|
|
#endif
|