scummvm/matrix4.h

57 lines
1.4 KiB
C
Raw Normal View History

// Residual - Virtual machine to run LucasArts' 3D adventure games
// Copyright (C) 2003-2004 The ScummVM-Residual Team (www.scummvm.org)
//
// This library is free software; you can redistribute it and/or
// modify it under the terms of the GNU Lesser General Public
// License as published by the Free Software Foundation; either
// version 2.1 of the License, or (at your option) any later version.
//
// This library 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 for more details.
//
// You should have received a copy of the GNU Lesser General Public
// License along with this library; if not, write to the Free Software
// Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
#ifndef MATRIX4_HH
#define MATRIX4_HH
#include "vector3d.h"
#include "matrix3.h"
// matrix 4 is a rotation matrix + position
2004-02-25 08:45:56 +00:00
class Matrix4 {
public:
2004-12-09 23:55:43 +00:00
Matrix3 _rot;
Vector3d _pos;
2004-02-25 08:45:56 +00:00
Matrix4();
Matrix4& operator =(const Matrix4& s) {
2004-12-09 23:55:43 +00:00
_pos = s._pos;
_rot = s._rot;
return *this;
}
Matrix4& operator *=(const Matrix4& s) {
Vector3d v;
2004-12-09 23:55:43 +00:00
v = s._pos;
_rot.transform(&v);
_pos += v;
_rot *= s._rot;
return *this;
}
2004-02-25 08:45:56 +00:00
void translate(float x, float y, float z);
private:
};
2003-08-28 02:01:48 +00:00
#endif // MATRIX_HH