2023-09-12 18:58:10 +00:00
|
|
|
#include "..\script_component.hpp"
|
2017-06-08 13:31:51 +00:00
|
|
|
/*
|
|
|
|
* Author: ACE-Team
|
|
|
|
*
|
|
|
|
*
|
|
|
|
* Arguments:
|
|
|
|
* None
|
|
|
|
*
|
|
|
|
* Return Value:
|
|
|
|
* None
|
|
|
|
*
|
|
|
|
* Example:
|
|
|
|
* call ace_laser_fnc_rotateVectLineGetMap
|
|
|
|
*
|
|
|
|
* Public: No
|
|
|
|
*/
|
|
|
|
|
2016-10-08 10:55:30 +00:00
|
|
|
params ["_p", "_p1", "_p2"];
|
2016-05-30 16:37:03 +00:00
|
|
|
|
2016-10-08 10:55:30 +00:00
|
|
|
private _q2 = [];
|
2016-05-30 16:37:03 +00:00
|
|
|
|
|
|
|
/* Step 1 */
|
2016-10-08 10:55:30 +00:00
|
|
|
private _q1 = _p vectorDiff _p1;
|
|
|
|
private _u = _p2 vectorDiff _p1;
|
2016-05-30 16:37:03 +00:00
|
|
|
_u = vectorNormalized _u;
|
2016-10-08 10:55:30 +00:00
|
|
|
private _d = sqrt((_u select 1)*(_u select 1) + (_u select 2)*(_u select 2));
|
2016-05-30 16:37:03 +00:00
|
|
|
|
|
|
|
/* Step 2 */
|
|
|
|
if (_d != 0) then {
|
|
|
|
_q2 set[0, (_q1 select 0)];
|
|
|
|
_q2 set[1, (_q1 select 1) * (_u select 2) / _d - (_q1 select 2) * (_u select 1) / _d];
|
|
|
|
_q2 set[2, (_q1 select 1) * (_u select 1) / _d + (_q1 select 2) * (_u select 2) / _d];
|
|
|
|
} else {
|
|
|
|
_q2 = _q1;
|
|
|
|
};
|
|
|
|
|
|
|
|
/* Step 3 */
|
|
|
|
_q1 set[0, (_q2 select 0) * _d - (_q2 select 2) * (_u select 0)];
|
|
|
|
_q1 set[1, (_q2 select 1)];
|
|
|
|
_q1 set[2, (_q2 select 0) * (_u select 0) + (_q2 select 2) * _d];
|
|
|
|
|
2016-10-08 10:55:30 +00:00
|
|
|
[_p, _p1, _p2, _q1, _q2, _u, _d]
|