2016-02-25 08:39:15 -05:00
|
|
|
/* ScummVM - Graphic Adventure Engine
|
|
|
|
*
|
|
|
|
* ScummVM is the legal property of its developers, whose names
|
|
|
|
* are too numerous to list here. Please refer to the COPYRIGHT
|
|
|
|
* file distributed with this source distribution.
|
|
|
|
*
|
|
|
|
* This program is free software; you can redistribute it and/or
|
|
|
|
* modify it under the terms of the GNU General Public License
|
|
|
|
* as published by the Free Software Foundation; either version 2
|
|
|
|
* of the License, or (at your option) any later version.
|
|
|
|
*
|
|
|
|
* This program 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 General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU General Public License
|
|
|
|
* along with this program; if not, write to the Free Software
|
|
|
|
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
2016-03-05 15:44:39 -05:00
|
|
|
#include "titanic/star_control/star_control_sub6.h"
|
2016-02-25 08:39:15 -05:00
|
|
|
|
|
|
|
namespace Titanic {
|
|
|
|
|
2016-07-16 18:23:25 -04:00
|
|
|
CStarControlSub6 *CStarControlSub6::_static;
|
|
|
|
|
2016-06-30 13:40:55 -04:00
|
|
|
CStarControlSub6::CStarControlSub6() {
|
|
|
|
clear();
|
|
|
|
}
|
|
|
|
|
2017-03-12 20:18:53 -04:00
|
|
|
CStarControlSub6::CStarControlSub6(Axis axis, double amount) {
|
|
|
|
setRotationMatrix(axis, amount);
|
2016-07-16 18:23:25 -04:00
|
|
|
}
|
|
|
|
|
2016-07-17 16:43:53 -04:00
|
|
|
CStarControlSub6::CStarControlSub6(const CStarControlSub6 *src) {
|
|
|
|
copyFrom(src);
|
|
|
|
}
|
|
|
|
|
2016-07-16 18:23:25 -04:00
|
|
|
void CStarControlSub6::init() {
|
|
|
|
_static = nullptr;
|
|
|
|
}
|
|
|
|
|
|
|
|
void CStarControlSub6::deinit() {
|
|
|
|
delete _static;
|
2016-07-16 21:41:51 -04:00
|
|
|
_static = nullptr;
|
2016-07-16 18:23:25 -04:00
|
|
|
}
|
|
|
|
|
2017-03-12 19:55:56 -04:00
|
|
|
void CStarControlSub6::identity() {
|
|
|
|
FMatrix::identity();
|
2017-03-08 22:05:43 -05:00
|
|
|
_vector.clear();
|
2016-02-25 08:39:15 -05:00
|
|
|
}
|
|
|
|
|
2017-03-12 20:18:53 -04:00
|
|
|
void CStarControlSub6::setRotationMatrix(Axis axis, double amount) {
|
2017-03-14 22:06:24 +01:00
|
|
|
const double ROTATION = 2 * M_PI / 360.0;
|
2016-07-16 18:23:25 -04:00
|
|
|
double sinVal = sin(amount * ROTATION);
|
|
|
|
double cosVal = cos(amount * ROTATION);
|
|
|
|
|
2017-03-12 20:18:53 -04:00
|
|
|
switch (axis) {
|
|
|
|
case X_AXIS:
|
2017-03-02 21:54:22 -05:00
|
|
|
_row1._x = 1.0;
|
|
|
|
_row1._y = 0.0;
|
|
|
|
_row1._z = 0.0;
|
|
|
|
_row2._x = 0.0;
|
|
|
|
_row2._y = cosVal;
|
|
|
|
_row2._z = sinVal;
|
|
|
|
_row3._x = 0.0;
|
|
|
|
_row3._y = -sinVal;
|
|
|
|
_row3._z = cosVal;
|
2016-07-16 18:23:25 -04:00
|
|
|
break;
|
|
|
|
|
2017-03-12 20:18:53 -04:00
|
|
|
case Y_AXIS:
|
2017-03-02 21:54:22 -05:00
|
|
|
_row1._x = cosVal;
|
|
|
|
_row1._y = 0.0;
|
|
|
|
_row1._z = sinVal;
|
|
|
|
_row2._x = 0.0;
|
|
|
|
_row2._y = 1.0;
|
|
|
|
_row2._z = 0.0;
|
|
|
|
_row3._x = -sinVal;
|
|
|
|
_row3._y = 0.0;
|
|
|
|
_row3._z = sinVal;
|
2016-07-16 18:23:25 -04:00
|
|
|
break;
|
|
|
|
|
2017-03-12 20:18:53 -04:00
|
|
|
case Z_AXIS:
|
2017-03-02 21:54:22 -05:00
|
|
|
_row1._x = cosVal;
|
|
|
|
_row1._y = sinVal;
|
|
|
|
_row1._z = 0.0;
|
|
|
|
_row2._x = -sinVal;
|
|
|
|
_row2._y = cosVal;
|
|
|
|
_row2._z = 0.0;
|
|
|
|
_row3._x = 0.0;
|
|
|
|
_row3._y = 0.0;
|
|
|
|
_row3._z = 1.0;
|
2016-07-16 18:23:25 -04:00
|
|
|
break;
|
|
|
|
|
|
|
|
default:
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
2017-03-08 22:05:43 -05:00
|
|
|
_vector.clear();
|
2016-07-16 18:23:25 -04:00
|
|
|
}
|
|
|
|
|
2016-07-17 16:43:53 -04:00
|
|
|
void CStarControlSub6::copyFrom(const CStarControlSub6 *src) {
|
2017-03-02 21:54:22 -05:00
|
|
|
_row1 = src->_row1;
|
|
|
|
_row2 = src->_row2;
|
|
|
|
_row3 = src->_row3;
|
2017-03-08 22:05:43 -05:00
|
|
|
_vector = src->_vector;
|
2016-07-17 16:43:53 -04:00
|
|
|
}
|
|
|
|
|
2017-03-11 14:30:31 -05:00
|
|
|
void CStarControlSub6::copyFrom(const FMatrix &src) {
|
|
|
|
_row1 = src._row1;
|
|
|
|
_row2 = src._row2;
|
|
|
|
_row3 = src._row3;
|
|
|
|
}
|
|
|
|
|
2017-03-11 15:03:34 -05:00
|
|
|
CStarControlSub6 *CStarControlSub6::setup(CStarControlSub6 *dest, const CStarControlSub6 *s2, const CStarControlSub6 *s3) {
|
2017-03-08 23:27:26 -05:00
|
|
|
CStarControlSub6 &d = *dest;
|
|
|
|
|
|
|
|
d._row1._x = s3->_row1._x * s2->_row1._x
|
|
|
|
+ s2->_row1._z * s3->_row3._x
|
|
|
|
+ s2->_row1._y * s3->_row2._x;
|
|
|
|
d._row1._y = s2->_row1._x * s3->_row1._y
|
|
|
|
+ s3->_row3._y * s2->_row1._z
|
|
|
|
+ s3->_row2._y * s2->_row1._y;
|
|
|
|
d._row1._z = s2->_row1._x * s3->_row1._z
|
|
|
|
+ s3->_row3._z * s2->_row1._z
|
|
|
|
+ s3->_row2._z * s2->_row1._y;
|
|
|
|
d._row2._x = s3->_row1._x * s2->_row2._x
|
|
|
|
+ s2->_row2._y * s3->_row2._x
|
|
|
|
+ s2->_row2._z * s3->_row3._x;
|
|
|
|
d._row2._y = s2->_row2._y * s3->_row2._y
|
|
|
|
+ s2->_row2._z * s3->_row3._y
|
|
|
|
+ s3->_row1._y * s2->_row2._x;
|
|
|
|
d._row2._z = s3->_row1._z * s2->_row2._x
|
|
|
|
+ s2->_row2._y * s3->_row2._z
|
|
|
|
+ s2->_row2._z * s3->_row3._z;
|
|
|
|
d._row3._x = s3->_row1._x * s2->_row3._x
|
|
|
|
+ s2->_row3._y * s3->_row2._x
|
|
|
|
+ s2->_row3._z * s3->_row3._x;
|
|
|
|
d._row3._y = s2->_row3._z * s3->_row3._y
|
|
|
|
+ s2->_row3._y * s3->_row2._y
|
|
|
|
+ s3->_row1._y * s2->_row3._x;
|
|
|
|
d._row3._z = s3->_row3._z * s2->_row3._z
|
|
|
|
+ s3->_row2._z * s2->_row3._y
|
|
|
|
+ s3->_row1._z * s2->_row3._x;
|
|
|
|
d._vector._x = s3->_row1._x * s2->_vector._x
|
|
|
|
+ s2->_vector._y * s3->_row2._x
|
|
|
|
+ s2->_vector._z * s3->_row3._x
|
|
|
|
+ s3->_vector._x;
|
|
|
|
d._vector._y = s2->_vector._z * s3->_row3._y
|
|
|
|
+ s2->_vector._y * s3->_row2._y
|
|
|
|
+ s2->_vector._x * s3->_row1._y
|
|
|
|
+ s3->_vector._y;
|
|
|
|
d._vector._z = s2->_vector._y * s3->_row2._z
|
|
|
|
+ s2->_vector._z * s3->_row3._z
|
|
|
|
+ s2->_vector._x * s3->_row1._z
|
|
|
|
+ s3->_vector._z;
|
2017-03-11 15:03:34 -05:00
|
|
|
return dest;
|
2017-03-08 23:27:26 -05:00
|
|
|
}
|
|
|
|
|
2017-03-17 21:01:15 -04:00
|
|
|
void CStarControlSub6::fn4(CStarControlSub6 *sub6) {
|
|
|
|
double v2, v3, v6, v7, v8, v9, v10, v11;
|
|
|
|
double v12, v13, v14, v15, v16, v17, v18;
|
|
|
|
|
|
|
|
v16 = _row3._z * _row2._y;
|
|
|
|
v2 = _row1._x * v16;
|
|
|
|
v3 = 0.0;
|
|
|
|
v18 = v2;
|
|
|
|
if (v2 < 0.0) {
|
|
|
|
v3 = v18;
|
|
|
|
v2 = 0.0;
|
|
|
|
}
|
|
|
|
v6 = _row3._x * _row1._y * _row2._z;
|
|
|
|
if (v6 < 0.0)
|
|
|
|
v3 = v3 + v6;
|
|
|
|
else
|
|
|
|
v2 = v2 + v6;
|
|
|
|
v7 = _row3._y * _row1._z * _row2._x;
|
|
|
|
if (v7 < 0.0)
|
|
|
|
v3 = v3 + v7;
|
|
|
|
else
|
|
|
|
v2 = v2 + v7;
|
|
|
|
if (-(_row3._x * _row1._z * _row2._y) < 0.0)
|
|
|
|
v3 = v3 - _row3._x * _row1._z * _row2._y;
|
|
|
|
else
|
|
|
|
v2 = v2 - _row3._x * _row1._z * _row2._y;
|
|
|
|
if (-(_row1._y * _row2._x * _row3._z) < 0.0)
|
|
|
|
v3 = v3 - _row1._y * _row2._x * _row3._z;
|
|
|
|
else
|
|
|
|
v2 = v2 - _row1._y * _row2._x * _row3._z;
|
|
|
|
v17 = _row2._z * _row3._y;
|
|
|
|
if (-(_row1._x * v17) < 0.0)
|
|
|
|
v3 = v3 - _row1._x * v17;
|
|
|
|
else
|
|
|
|
v2 = v2 - _row1._x * v17;
|
|
|
|
v18 = v3 + v2;
|
|
|
|
assert(!(v18 == 0.0 || fabs(v18 / (v2 - v3)) < 1.0e-10));
|
|
|
|
|
|
|
|
v8 = 1.0 / v18;
|
|
|
|
v18 = v8;
|
|
|
|
sub6->_row1._x = (v16 - v17) * v8;
|
|
|
|
sub6->_row2._x = -(_row2._x * _row3._z - _row3._x * _row2._z) * v8;
|
|
|
|
sub6->_row3._x = (_row3._y * _row2._x - _row3._x * _row2._y) * v8;
|
|
|
|
sub6->_row1._y = -(_row1._y * _row3._z - _row3._y * _row1._z) * v8;
|
|
|
|
sub6->_row2._y = (_row1._x * _row3._z - _row3._x * _row1._z) * v8;
|
|
|
|
sub6->_row3._y = -(_row1._x * _row3._y - _row3._x * _row1._y) * v8;
|
|
|
|
sub6->_row1._z = (_row1._y * _row2._z - _row1._z * _row2._y) * v8;
|
|
|
|
sub6->_row2._z = -(_row1._x * _row2._z - _row1._z * _row2._x) * v8;
|
|
|
|
v9 = sub6->_row1._x;
|
|
|
|
v10 = sub6->_row2._y;
|
|
|
|
v11 = sub6->_row3._y;
|
|
|
|
v12 = sub6->_row1._z;
|
|
|
|
v13 = sub6->_row2._z;
|
|
|
|
sub6->_row3._z = (_row1._x * _row2._y - _row1._y * _row2._x) * v18;
|
|
|
|
v14 = v9;
|
|
|
|
v15 = sub6->_row3._z;
|
|
|
|
sub6->_vector._x = -(v14 * _vector._x
|
|
|
|
+ _vector._y * sub6->_row2._x
|
|
|
|
+ _vector._z * sub6->_row3._x);
|
|
|
|
sub6->_vector._y = -(_vector._x * sub6->_row1._y + v10 * _vector._y + v11 * _vector._z);
|
|
|
|
sub6->_vector._z = -(v12 * _vector._x + v13 * _vector._y + v15 * _vector._z);
|
2017-03-08 23:27:26 -05:00
|
|
|
}
|
|
|
|
|
2016-02-25 08:39:15 -05:00
|
|
|
} // End of namespace Titanic
|