mirror of https://github.com/mosra/magnum.git
Browse Source
Vector4 doesn't set W component to one by default anymore, this is now handled by Point*D itself. This finally allows creating of 2D primitives and 2D position vectors without messing explicitly with Z = 1. All classes which should use Point instead of Vector were updated to use Point instead.pull/279/head
36 changed files with 399 additions and 52 deletions
@ -0,0 +1,74 @@ |
|||||||
|
#ifndef Magnum_Math_Point2D_h |
||||||
|
#define Magnum_Math_Point2D_h |
||||||
|
/*
|
||||||
|
Copyright © 2010, 2011, 2012 Vladimír Vondruš <mosra@centrum.cz> |
||||||
|
|
||||||
|
This file is part of Magnum. |
||||||
|
|
||||||
|
Magnum is free software: you can redistribute it and/or modify |
||||||
|
it under the terms of the GNU Lesser General Public License version 3 |
||||||
|
only, as published by the Free Software Foundation. |
||||||
|
|
||||||
|
Magnum is distributed in the hope that it will be useful, |
||||||
|
but WITHOUT ANY WARRANTY; without even the implied warranty of |
||||||
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
||||||
|
GNU Lesser General Public License version 3 for more details. |
||||||
|
*/ |
||||||
|
|
||||||
|
/** @file
|
||||||
|
* @brief Class Magnum::Math::Point2D |
||||||
|
*/ |
||||||
|
|
||||||
|
#include "Vector3.h" |
||||||
|
|
||||||
|
namespace Magnum { namespace Math { |
||||||
|
|
||||||
|
/**
|
||||||
|
@brief Two-dimensional homogeneous coordinates |
||||||
|
@tparam T Data type |
||||||
|
|
||||||
|
Same as Vector3, except that constructors have default value for Z component |
||||||
|
set to one. See also @ref matrix-vector for brief introduction. |
||||||
|
@configurationvalueref{Magnum::Math::Point2D} |
||||||
|
*/ |
||||||
|
template<class T> class Point2D: public Vector3<T> { |
||||||
|
public: |
||||||
|
/**
|
||||||
|
* @brief Default constructor |
||||||
|
* |
||||||
|
* X and Y components are set to zero, Z is set to one. |
||||||
|
*/ |
||||||
|
inline constexpr Point2D(): Vector3<T>(T(0), T(0), T(1)) {} |
||||||
|
|
||||||
|
/** @brief Copy constructor */ |
||||||
|
inline constexpr Point2D(const RectangularMatrix<1, 3, T>& other): Vector3<T>(other) {} |
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Constructor |
||||||
|
* @param x X component |
||||||
|
* @param y Y component |
||||||
|
* @param z Z component |
||||||
|
*/ |
||||||
|
inline constexpr Point2D(T x, T y, T z = T(1)): Vector3<T>(x, y, z) {} |
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Constructor |
||||||
|
* @param xy Two-component vector |
||||||
|
* @param z Z component |
||||||
|
*/ |
||||||
|
inline constexpr Point2D(const Vector<2, T>& xy, T z = T(1)): Vector3<T>(xy, z) {} |
||||||
|
}; |
||||||
|
|
||||||
|
/** @debugoperator{Magnum::Math::Point2D} */ |
||||||
|
template<class T> Corrade::Utility::Debug operator<<(Corrade::Utility::Debug debug, const Magnum::Math::Point2D<T>& value) { |
||||||
|
return debug << static_cast<const Magnum::Math::Vector<3, T>&>(value); |
||||||
|
} |
||||||
|
|
||||||
|
}} |
||||||
|
|
||||||
|
namespace Corrade { namespace Utility { |
||||||
|
/** @configurationvalue{Magnum::Math::Point2D} */ |
||||||
|
template<class T> struct ConfigurationValue<Magnum::Math::Point2D<T>>: public ConfigurationValue<Magnum::Math::Vector<3, T>> {}; |
||||||
|
}} |
||||||
|
|
||||||
|
#endif |
||||||
@ -0,0 +1,75 @@ |
|||||||
|
#ifndef Magnum_Math_Point3D_h |
||||||
|
#define Magnum_Math_Point3D_h |
||||||
|
/*
|
||||||
|
Copyright © 2010, 2011, 2012 Vladimír Vondruš <mosra@centrum.cz> |
||||||
|
|
||||||
|
This file is part of Magnum. |
||||||
|
|
||||||
|
Magnum is free software: you can redistribute it and/or modify |
||||||
|
it under the terms of the GNU Lesser General Public License version 3 |
||||||
|
only, as published by the Free Software Foundation. |
||||||
|
|
||||||
|
Magnum is distributed in the hope that it will be useful, |
||||||
|
but WITHOUT ANY WARRANTY; without even the implied warranty of |
||||||
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
||||||
|
GNU Lesser General Public License version 3 for more details. |
||||||
|
*/ |
||||||
|
|
||||||
|
/** @file
|
||||||
|
* @brief Class Magnum::Math::Point3D |
||||||
|
*/ |
||||||
|
|
||||||
|
#include "Vector4.h" |
||||||
|
|
||||||
|
namespace Magnum { namespace Math { |
||||||
|
|
||||||
|
/**
|
||||||
|
@brief Three-dimensional homogeneous coordinates |
||||||
|
@tparam T Data type |
||||||
|
|
||||||
|
Same as Vector4, except that constructors have default value for W component |
||||||
|
set to one. See also @ref matrix-vector for brief introduction. |
||||||
|
@configurationvalueref{Magnum::Math::Point3D} |
||||||
|
*/ |
||||||
|
template<class T> class Point3D: public Vector4<T> { |
||||||
|
public: |
||||||
|
/**
|
||||||
|
* @brief Default constructor |
||||||
|
* |
||||||
|
* X, Y and Z components are set to zero, W is set to one. |
||||||
|
*/ |
||||||
|
inline constexpr Point3D(): Vector4<T>(T(0), T(0), T(0), T(1)) {} |
||||||
|
|
||||||
|
/** @brief Copy constructor */ |
||||||
|
inline constexpr Point3D(const RectangularMatrix<1, 4, T>& other): Vector4<T>(other) {} |
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Constructor |
||||||
|
* @param x X component |
||||||
|
* @param y Y component |
||||||
|
* @param z Z component |
||||||
|
* @param w W component |
||||||
|
*/ |
||||||
|
inline constexpr Point3D(T x, T y, T z, T w = T(1)): Vector4<T>(x, y, z, w) {} |
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Constructor |
||||||
|
* @param xyz Three-component vector |
||||||
|
* @param w W component |
||||||
|
*/ |
||||||
|
inline constexpr Point3D(const Vector<3, T>& xyz, T w = T(1)): Vector4<T>(xyz, w) {} |
||||||
|
}; |
||||||
|
|
||||||
|
/** @debugoperator{Magnum::Math::Point3D} */ |
||||||
|
template<class T> Corrade::Utility::Debug operator<<(Corrade::Utility::Debug debug, const Magnum::Math::Point3D<T>& value) { |
||||||
|
return debug << static_cast<const Magnum::Math::Vector<4, T>&>(value); |
||||||
|
} |
||||||
|
|
||||||
|
}} |
||||||
|
|
||||||
|
namespace Corrade { namespace Utility { |
||||||
|
/** @configurationvalue{Magnum::Math::Point3D} */ |
||||||
|
template<class T> struct ConfigurationValue<Magnum::Math::Point3D<T>>: public ConfigurationValue<Magnum::Math::Vector<4, T>> {}; |
||||||
|
}} |
||||||
|
|
||||||
|
#endif |
||||||
@ -0,0 +1,56 @@ |
|||||||
|
/*
|
||||||
|
Copyright © 2010, 2011, 2012 Vladimír Vondruš <mosra@centrum.cz> |
||||||
|
|
||||||
|
This file is part of Magnum. |
||||||
|
|
||||||
|
Magnum is free software: you can redistribute it and/or modify |
||||||
|
it under the terms of the GNU Lesser General Public License version 3 |
||||||
|
only, as published by the Free Software Foundation. |
||||||
|
|
||||||
|
Magnum is distributed in the hope that it will be useful, |
||||||
|
but WITHOUT ANY WARRANTY; without even the implied warranty of |
||||||
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
||||||
|
GNU Lesser General Public License version 3 for more details. |
||||||
|
*/ |
||||||
|
|
||||||
|
#include "Point2DTest.h" |
||||||
|
|
||||||
|
#include <sstream> |
||||||
|
|
||||||
|
#include "Point2D.h" |
||||||
|
|
||||||
|
CORRADE_TEST_MAIN(Magnum::Math::Test::Point2DTest) |
||||||
|
|
||||||
|
using namespace std; |
||||||
|
using namespace Corrade::Utility; |
||||||
|
|
||||||
|
namespace Magnum { namespace Math { namespace Test { |
||||||
|
|
||||||
|
typedef Math::Point2D<float> Point2D; |
||||||
|
|
||||||
|
Point2DTest::Point2DTest() { |
||||||
|
addTests(&Point2DTest::construct, |
||||||
|
&Point2DTest::debug, |
||||||
|
&Point2DTest::configuration); |
||||||
|
} |
||||||
|
|
||||||
|
void Point2DTest::construct() { |
||||||
|
CORRADE_COMPARE(Point2D(), (Vector<3, float>(0.0f, 0.0f, 1.0f))); |
||||||
|
CORRADE_COMPARE(Point2D(1, 2), (Vector<3, float>(1.0f, 2.0f, 1.0f))); |
||||||
|
CORRADE_COMPARE(Point2D(Vector<2, float>(1.0f, 2.0f), 3), (Vector<3, float>(1.0f, 2.0f, 3.0f))); |
||||||
|
} |
||||||
|
|
||||||
|
void Point2DTest::debug() { |
||||||
|
ostringstream o; |
||||||
|
Debug(&o) << Point2D(0.5f, 15.0f, 1.0f); |
||||||
|
CORRADE_COMPARE(o.str(), "Vector(0.5, 15, 1)\n"); |
||||||
|
} |
||||||
|
|
||||||
|
void Point2DTest::configuration() { |
||||||
|
Point2D vec(3.0f, 3.125f, 9.55f); |
||||||
|
string value("3 3.125 9.55"); |
||||||
|
CORRADE_COMPARE(ConfigurationValue<Point2D>::toString(vec), value); |
||||||
|
CORRADE_COMPARE(ConfigurationValue<Point2D>::fromString(value), vec); |
||||||
|
} |
||||||
|
|
||||||
|
}}} |
||||||
@ -0,0 +1,33 @@ |
|||||||
|
#ifndef Magnum_Math_Test_Point2DTest_h |
||||||
|
#define Magnum_Math_Test_Point2DTest_h |
||||||
|
/*
|
||||||
|
Copyright © 2010, 2011, 2012 Vladimír Vondruš <mosra@centrum.cz> |
||||||
|
|
||||||
|
This file is part of Magnum. |
||||||
|
|
||||||
|
Magnum is free software: you can redistribute it and/or modify |
||||||
|
it under the terms of the GNU Lesser General Public License version 3 |
||||||
|
only, as published by the Free Software Foundation. |
||||||
|
|
||||||
|
Magnum is distributed in the hope that it will be useful, |
||||||
|
but WITHOUT ANY WARRANTY; without even the implied warranty of |
||||||
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
||||||
|
GNU Lesser General Public License version 3 for more details. |
||||||
|
*/ |
||||||
|
|
||||||
|
#include <TestSuite/Tester.h> |
||||||
|
|
||||||
|
namespace Magnum { namespace Math { namespace Test { |
||||||
|
|
||||||
|
class Point2DTest: public Corrade::TestSuite::Tester<Point2DTest> { |
||||||
|
public: |
||||||
|
Point2DTest(); |
||||||
|
|
||||||
|
void construct(); |
||||||
|
void debug(); |
||||||
|
void configuration(); |
||||||
|
}; |
||||||
|
|
||||||
|
}}} |
||||||
|
|
||||||
|
#endif |
||||||
@ -0,0 +1,56 @@ |
|||||||
|
/*
|
||||||
|
Copyright © 2010, 2011, 2012 Vladimír Vondruš <mosra@centrum.cz> |
||||||
|
|
||||||
|
This file is part of Magnum. |
||||||
|
|
||||||
|
Magnum is free software: you can redistribute it and/or modify |
||||||
|
it under the terms of the GNU Lesser General Public License version 3 |
||||||
|
only, as published by the Free Software Foundation. |
||||||
|
|
||||||
|
Magnum is distributed in the hope that it will be useful, |
||||||
|
but WITHOUT ANY WARRANTY; without even the implied warranty of |
||||||
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
||||||
|
GNU Lesser General Public License version 3 for more details. |
||||||
|
*/ |
||||||
|
|
||||||
|
#include "Point3DTest.h" |
||||||
|
|
||||||
|
#include <sstream> |
||||||
|
|
||||||
|
#include "Point3D.h" |
||||||
|
|
||||||
|
CORRADE_TEST_MAIN(Magnum::Math::Test::Point3DTest) |
||||||
|
|
||||||
|
using namespace std; |
||||||
|
using namespace Corrade::Utility; |
||||||
|
|
||||||
|
namespace Magnum { namespace Math { namespace Test { |
||||||
|
|
||||||
|
typedef Math::Point3D<float> Point3D; |
||||||
|
|
||||||
|
Point3DTest::Point3DTest() { |
||||||
|
addTests(&Point3DTest::construct, |
||||||
|
&Point3DTest::debug, |
||||||
|
&Point3DTest::configuration); |
||||||
|
} |
||||||
|
|
||||||
|
void Point3DTest::construct() { |
||||||
|
CORRADE_COMPARE(Point3D(), Point3D(0.0f, 0.0f, 0.0f, 1.0f)); |
||||||
|
CORRADE_COMPARE(Point3D(1, 2, 3, 4), (Vector<4, float>(1.0f, 2.0f, 3.0f, 4.0f))); |
||||||
|
CORRADE_COMPARE(Point3D(Vector<3, float>(1.0f, 2.0f, 3.0f), 4), (Vector<4, float>(1.0f, 2.0f, 3.0f, 4.0f))); |
||||||
|
} |
||||||
|
|
||||||
|
void Point3DTest::debug() { |
||||||
|
ostringstream o; |
||||||
|
Debug(&o) << Point3D(0.5f, 15.0f, 1.0f, 1.0f); |
||||||
|
CORRADE_COMPARE(o.str(), "Vector(0.5, 15, 1, 1)\n"); |
||||||
|
} |
||||||
|
|
||||||
|
void Point3DTest::configuration() { |
||||||
|
Point3D vec(3.0f, 3.125f, 9.0f, 9.55f); |
||||||
|
string value("3 3.125 9 9.55"); |
||||||
|
CORRADE_COMPARE(ConfigurationValue<Point3D>::toString(vec), value); |
||||||
|
CORRADE_COMPARE(ConfigurationValue<Point3D>::fromString(value), vec); |
||||||
|
} |
||||||
|
|
||||||
|
}}} |
||||||
@ -0,0 +1,33 @@ |
|||||||
|
#ifndef Magnum_Math_Test_Point3DTest_h |
||||||
|
#define Magnum_Math_Test_Point3DTest_h |
||||||
|
/*
|
||||||
|
Copyright © 2010, 2011, 2012 Vladimír Vondruš <mosra@centrum.cz> |
||||||
|
|
||||||
|
This file is part of Magnum. |
||||||
|
|
||||||
|
Magnum is free software: you can redistribute it and/or modify |
||||||
|
it under the terms of the GNU Lesser General Public License version 3 |
||||||
|
only, as published by the Free Software Foundation. |
||||||
|
|
||||||
|
Magnum is distributed in the hope that it will be useful, |
||||||
|
but WITHOUT ANY WARRANTY; without even the implied warranty of |
||||||
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
||||||
|
GNU Lesser General Public License version 3 for more details. |
||||||
|
*/ |
||||||
|
|
||||||
|
#include <TestSuite/Tester.h> |
||||||
|
|
||||||
|
namespace Magnum { namespace Math { namespace Test { |
||||||
|
|
||||||
|
class Point3DTest: public Corrade::TestSuite::Tester<Point3DTest> { |
||||||
|
public: |
||||||
|
Point3DTest(); |
||||||
|
|
||||||
|
void construct(); |
||||||
|
void debug(); |
||||||
|
void configuration(); |
||||||
|
}; |
||||||
|
|
||||||
|
}}} |
||||||
|
|
||||||
|
#endif |
||||||
Loading…
Reference in new issue