cpp_photon/include/math/Vector2.hpp

244 lines
5.7 KiB
C++
Raw Normal View History

2005-02-27 09:00:13 +00:00
//This file is part of Photon (http://photon.sourceforge.net)
//Copyright (C) 2004-2005 James Turk
//
// Author:
// James Turk (jpt2433@rit.edu)
//
// Version:
2005-11-13 07:59:48 +00:00
// $Id: Vector2.hpp,v 1.6 2005/11/13 07:59:48 cozman Exp $
2005-02-27 09:00:13 +00:00
#ifndef PHOTON_MATH_VECTOR2_HPP
#define PHOTON_MATH_VECTOR2_HPP
#include <ostream>
#include "types.hpp"
namespace photon
{
namespace math
{
// Class: Vector2
// Represents a two-dimensional vector. A quantity specified by a magnitude
2005-11-13 07:59:48 +00:00
// and a direction. Vector is oriented in classic 2D graphics format with
2005-07-17 02:40:39 +00:00
// origin at top corner of screen.
2005-02-27 09:00:13 +00:00
//
// Operators:
// - Vector2 == Vector2
// - Vector2 != Vector2
// - Vector2 + Vector2
// - Vector2 - Vector2
// - Vector2 * scalar or scalar * Vector2
// - Vector2 / scalar
// - Vector2 += Vector2
// - Vector2 -= Vector2
// - Vector2 *= scalar
// - Vector2 /= scalar
// - ostream& << Vector2
class Vector2
{
// Group: Data Members
public:
// Variable: x
// x component of vector
scalar x;
// Variable: y
// y component of vector
scalar y;
// Group: (Con/De)structors
public:
// Function: Vector2
// Initializes zero length vector.
Vector2();
// Function: Vector2
// Initialize vector given an x and y component.
//
// Parameters:
// nx - X component of vector.
// ny - Y component of vector.
//
// See Also:
// <set>
Vector2(scalar nx, scalar ny);
// Group: General
public:
// Function: set
// Initialize vector given an x and y component.
//
// Parameters:
// nx - X component of vector.
// ny - Y component of vector.
//
// See Also:
// <set>
void set(scalar nx, scalar ny);
// Function: resolveDeg
2005-11-13 07:59:48 +00:00
// Resolve vector, given a magnitude & angle in degrees.
2005-02-27 09:00:13 +00:00
//
// Parameters:
// magnitude - Magnitude of new vector.
// angle - Angle of new vector, in degrees.
//
// See Also:
// <resolveRad>
void resolveDeg(scalar magnitude, scalar angle);
// Function: resolveRad
2005-11-13 07:59:48 +00:00
// Resolve vector, given a magnitude & angle in radians.
2005-02-27 09:00:13 +00:00
//
// Parameters:
// magnitude - Magnitude of new vector.
// angle - Angle of new vector, in radians.
//
// See Also:
// <resolveDeg>
void resolveRad(scalar magnitude, scalar angle);
// Function: normalize
// Normalizes the vector. (makes it length of 1.0 but leaves ratio of
// components intact)
void normalize();
// Function: dot
// Calculates dot product of two vectors.
//
// Parameters:
// rhs - Vector to calculate dot product with.
//
// Returns:
// Dot product of two vectors.
scalar dot(const Vector2 &rhs) const;
bool operator==(const Vector2 &rhs) const;
bool operator!=(const Vector2 &rhs) const;
Vector2 operator-() const;
Vector2 operator+(const Vector2 &rhs) const;
Vector2 operator-(const Vector2 &rhs) const;
Vector2 operator*(scalar rhs) const;
Vector2 operator/(scalar rhs) const;
Vector2& operator+=(const Vector2 &rhs);
Vector2& operator-=(const Vector2 &rhs);
// Group: Special Accessors
public:
// Function: getMagnitude
2005-11-13 07:59:48 +00:00
// Determine length of vector.
2005-02-27 09:00:13 +00:00
//
// Returns:
// Length of the vector.
scalar getMagnitude() const;
// Function: getAngleDeg
// Angle of vector in degrees, angle is calculated with respect to positive
// X axis.
//
2005-11-13 07:59:48 +00:00
// | |90
2005-02-27 09:00:13 +00:00
// | |
// | |
2005-11-13 07:59:48 +00:00
// |180-----------------------0 or 360
2005-02-27 09:00:13 +00:00
// | |
// | |
2005-11-13 07:59:48 +00:00
// | |270
2005-02-27 09:00:13 +00:00
//
// Returns:
// Angle of vector (in degrees).
scalar getAngleDeg() const;
// Function: getAngleRad
// Angle of vector in radians, angle is calculated with respect to positive
// X axis.
//
// | | pi/2
// | |
// | |
// | pi-----------------------0 or 2pi
// | |
// | |
// | | 3pi/4
//
// Returns:
// Angle of vector (in radians).
scalar getAngleRad() const;
// Function: calcNormal
// Calculate the normal vector.
//
// Returns:
// Normal vector (vector w/ magnitude of 1) but same angle.
Vector2 calcNormal() const;
// Function: calcInnerAngleRad
// Calculates angle between two vectors.
//
// Parameters:
// vec - Vector to calculate angle between.
//
// Returns:
// Angle between the two vectors in radians.
scalar calcInnerAngleRad(const Vector2 &vec) const;
// Function: calcInnerAngleDeg
// Calculates angle between two vectors.
//
// Parameters:
// vec - Vector to calculate angle between.
//
// Returns:
// Angle between the two vectors in degrees.
scalar calcInnerAngleDeg(const Vector2 &vec) const;
friend std::ostream& operator<<(std::ostream &o, const Vector2 &v);
};
Vector2 operator*(scalar lhs, const Vector2 &rhs);
2005-03-01 07:51:23 +00:00
// Group: External Utilities
2005-02-27 09:00:13 +00:00
// Function: magnitude
2005-03-01 07:51:23 +00:00
// Find length of a vector.
// Same as a call to v.getMagnitude() but provided for convinience.
2005-02-27 09:00:13 +00:00
//
// Parameters:
// v - Vector to calculate magnitude of
//
// Returns:
// Length of the vector.
scalar magnitude(const Vector2 &v);
2005-07-06 04:27:23 +00:00
// Function: distance
// Determine distance between two points.
//
// Parameters:
// v1 - First point.
// v2 - Second point.
//
// Returns:
// Scalar distance between the two points.
scalar distance(const Vector2& v1, const Vector2& v2);
2005-03-01 07:51:23 +00:00
// Group: Aliases
2005-02-27 09:00:13 +00:00
// Typedef: Point2
// Alias for Vector2 type.
typedef Vector2 Point2;
}
}
#endif //PHOTON_MATH_VECTOR2_HPP