diff options
author | David Fioramonti | 2017-08-26 06:28:25 -0700 |
---|---|---|
committer | David Fioramonti | 2017-08-27 05:29:50 -0700 |
commit | a95df4aa72ceb690a15550cbf52c2a55f18b5e3e (patch) | |
tree | 2bed3580325347def076e8f210b4a657b7593cfa /engines/titanic | |
parent | 91f67a10ae3db0727db24b29eb5e53fb1b0212b5 (diff) | |
download | scummvm-rg350-a95df4aa72ceb690a15550cbf52c2a55f18b5e3e.tar.gz scummvm-rg350-a95df4aa72ceb690a15550cbf52c2a55f18b5e3e.tar.bz2 scummvm-rg350-a95df4aa72ceb690a15550cbf52c2a55f18b5e3e.zip |
TITANIC: Add fpose product helper function
This adds a non-member function that computes the
product between two fpose "matrices" and puts it in
a third. One of the constructor was doing that so now
it calls this non-member function.
Diffstat (limited to 'engines/titanic')
-rw-r--r-- | engines/titanic/star_control/fpose.cpp | 59 | ||||
-rw-r--r-- | engines/titanic/star_control/fpose.h | 11 |
2 files changed, 31 insertions, 39 deletions
diff --git a/engines/titanic/star_control/fpose.cpp b/engines/titanic/star_control/fpose.cpp index e7aafcfe2d..e0c042a74d 100644 --- a/engines/titanic/star_control/fpose.cpp +++ b/engines/titanic/star_control/fpose.cpp @@ -24,6 +24,25 @@ namespace Titanic { +// Non-member functions + +void fposeProd(const FPose &a, const FPose &m, FPose &C) { + C._row1._x = a._row1._y * m._row2._x + a._row1._z * m._row3._x + a._row1._x * m._row1._x; + C._row1._y = a._row1._x * m._row1._y + m._row2._y * a._row1._y + m._row3._y * a._row1._z; + C._row1._z = a._row1._x * m._row1._z + a._row1._y * m._row2._z + a._row1._z * m._row3._z; + C._row2._x = m._row1._x * a._row2._x + m._row3._x * a._row2._z + m._row2._x * a._row2._y; + C._row2._y = m._row3._y * a._row2._z + m._row1._y * a._row2._x + m._row2._y * a._row2._y; + C._row2._z = a._row2._z * m._row3._z + a._row2._x * m._row1._z + a._row2._y * m._row2._z; + C._row3._x = m._row1._x * a._row3._x + a._row3._z * m._row3._x + a._row3._y * m._row2._x; + C._row3._y = a._row3._y * m._row2._y + a._row3._z * m._row3._y + a._row3._x * m._row1._y; + C._row3._z = a._row3._x * m._row1._z + a._row3._y * m._row2._z + a._row3._z * m._row3._z; + C._vector._x = m._row1._x * a._vector._x + a._vector._y * m._row2._x + a._vector._z * m._row3._x + m._vector._x; + C._vector._y = a._vector._z * m._row3._y + a._vector._y * m._row2._y + a._vector._x * m._row1._y + a._vector._y; + C._vector._z = a._vector._y * m._row2._z + a._vector._z * m._row3._z + a._vector._x * m._row1._z + m._vector._z; +} + +// Member functions + FPose::FPose() { clear(); } @@ -37,45 +56,7 @@ FPose::FPose(const FPose &src) : FMatrix() { } FPose::FPose(const FPose &s1, const FPose &s2) { - _row1._x = s2._row1._x * s1._row1._x - + s1._row1._z * s2._row3._x - + s1._row1._y * s2._row2._x; - _row1._y = s1._row1._x * s2._row1._y - + s2._row3._y * s1._row1._z - + s2._row2._y * s1._row1._y; - _row1._z = s1._row1._x * s2._row1._z - + s2._row3._z * s1._row1._z - + s2._row2._z * s1._row1._y; - _row2._x = s2._row1._x * s1._row2._x - + s1._row2._y * s2._row2._x - + s1._row2._z * s2._row3._x; - _row2._y = s1._row2._y * s2._row2._y - + s1._row2._z * s2._row3._y - + s2._row1._y * s1._row2._x; - _row2._z = s2._row1._z * s1._row2._x - + s1._row2._y * s2._row2._z - + s1._row2._z * s2._row3._z; - _row3._x = s2._row1._x * s1._row3._x - + s1._row3._y * s2._row2._x - + s1._row3._z * s2._row3._x; - _row3._y = s1._row3._z * s2._row3._y - + s1._row3._y * s2._row2._y - + s2._row1._y * s1._row3._x; - _row3._z = s2._row3._z * s1._row3._z - + s2._row2._z * s1._row3._y - + s2._row1._z * s1._row3._x; - _vector._x = s2._row1._x * s1._vector._x - + s1._vector._y * s2._row2._x - + s1._vector._z * s2._row3._x - + s2._vector._x; - _vector._y = s1._vector._z * s2._row3._y - + s1._vector._y * s2._row2._y - + s1._vector._x * s2._row1._y - + s2._vector._y; - _vector._z = s1._vector._y * s2._row2._z - + s1._vector._z * s2._row3._z - + s1._vector._x * s2._row1._z - + s2._vector._z; + fposeProd(s1,s2,*this); } void FPose::identity() { diff --git a/engines/titanic/star_control/fpose.h b/engines/titanic/star_control/fpose.h index c25790f527..5287ff0516 100644 --- a/engines/titanic/star_control/fpose.h +++ b/engines/titanic/star_control/fpose.h @@ -38,6 +38,10 @@ public: FPose(); FPose(Axis axis, float amount); FPose(const FPose &src); + + /** + * This fpose is the fpose product of s1 (on the left) and s2 (on the right) + */ FPose(const FPose &s1, const FPose &s2); /** @@ -66,6 +70,13 @@ public: FPose inverseTransform() const; }; +/** + * Puts the fpose product between a and m in C, C = am + * Caller must preallocate output matrix + * Similar to matProd + */ +void fposeProd(const FPose &a, const FPose &m, FPose &C); + } // End of namespace Titanic #endif /* TITANIC_FPOSE_H */ |