X-Git-Url: http://git.tdb.fi/?p=libs%2Fgl.git;a=blobdiff_plain;f=source%2Ftransform.h;h=01c783bd7aa3ede6fe428f85f28c4cb4878ff079;hp=83f190b3c95af7d4fc928e5eac647ce31a679762;hb=13cf58be0e455227e8e5ae418b276a11c7873869;hpb=2316272b57cf9bea26d2c35b9451910c169efafa diff --git a/source/transform.h b/source/transform.h index 83f190b3..01c783bd 100644 --- a/source/transform.h +++ b/source/transform.h @@ -1,8 +1,59 @@ -/* $Id$ +#ifndef MSP_GL_TRANSFORM_H_ +#define MSP_GL_TRANSFORM_H_ -This file is part of libmspgl -Copyright © 2007 Mikko Rasa, Mikkosoft Productions -Distributed under the LGPL +#include +#include "matrix.h" + +namespace Msp { +namespace GL { + +/** +Stores a coordinate space transform as individual components. Primarily +intended for loading data from external sources. At runtime transforms +should generally be stored as matrices. */ +class Transform +{ +public: + class Loader: public DataFile::ObjectLoader + { + public: + Loader(Transform &); -#include "matrix.h" + private: + void position(float, float, float); + void euler(float, float, float); + void rotation(float, float, float, float); + void scale_uniform(float); + void scale(float, float, float); + }; + + typedef Geometry::Angle Angle; + typedef LinAl::Vector AngleVector3; + +private: + Vector3 position; + AngleVector3 euler; + Vector3 scale; + +public: + Transform(); + + static Transform from_matrix(const Matrix &); + + void set_position(const Vector3 &); + void set_euler(const AngleVector3 &); + void set_rotation(const Angle &, const Vector3 &); + void set_scale(float); + void set_scale(const Vector3 &); + const Vector3 &get_position() const { return position; } + const AngleVector3 &get_euler() const { return euler; } + const Vector3 &get_scale() const { return scale; } + + Matrix to_matrix() const; +}; + +} // namespace GL +} // namespace Msp + +#endif