2021-04-19 07:27:49 +00:00
|
|
|
#include "script_component.hpp"
|
|
|
|
/*
|
2023-09-09 16:30:39 +00:00
|
|
|
* Author: tcvm
|
2021-04-19 07:27:49 +00:00
|
|
|
* Attack profile: JDAM
|
2021-06-12 02:37:36 +00:00
|
|
|
* Uses LINE navigation type to guide projectile onto target
|
2021-04-19 07:27:49 +00:00
|
|
|
*
|
|
|
|
* Arguments:
|
|
|
|
* 0: Seeker Target PosASL <ARRAY>
|
|
|
|
* 1: Guidance Arg Array <ARRAY>
|
|
|
|
* 2: Seeker State <ARRAY>
|
|
|
|
*
|
|
|
|
* Return Value:
|
|
|
|
* Missile Aim PosASL <ARRAY>
|
|
|
|
*
|
|
|
|
* Example:
|
|
|
|
* [[1,2,3], [], []] call ace_missileguidance_fnc_attackProfile_jdam;
|
|
|
|
*
|
|
|
|
* Public: No
|
|
|
|
*/
|
2021-04-20 17:10:29 +00:00
|
|
|
params ["_seekerTargetPos", "_args", "_attackProfileStateParams", "_timestep"];
|
2021-04-19 07:27:49 +00:00
|
|
|
_args params ["_firedEH", "", "_flightParams", "", "", "_targetData"];
|
|
|
|
_firedEH params ["_shooter","","","","","","_projectile"];
|
2021-04-20 21:31:38 +00:00
|
|
|
_attackProfileStateParams params ["_gpsData", "_initialProjectileHeight", "_terminal"];
|
2021-04-19 07:27:49 +00:00
|
|
|
_gpsData params ["", "_impactAngle", "_attackDirection"];
|
|
|
|
_targetData params ["_directionToTarget", "", "_distanceToTarget"];
|
|
|
|
_flightParams params ["_pitchRate", "_yawRate"];
|
|
|
|
|
|
|
|
if (_impactAngle <= 0) then {
|
2021-06-12 02:37:36 +00:00
|
|
|
_impactAngle = 45; // immediate pitch over to attack
|
2021-04-19 07:27:49 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
if (_attackDirection < 0) then {
|
2021-05-02 05:04:08 +00:00
|
|
|
_attackDirection = direction _projectile;
|
2021-06-12 02:37:36 +00:00
|
|
|
_gpsData set [2, _attackDirection];
|
2021-04-19 07:27:49 +00:00
|
|
|
};
|
|
|
|
|
2021-04-20 21:31:38 +00:00
|
|
|
private _projectilePos = getPosASLVisual _projectile;
|
2021-06-12 02:37:36 +00:00
|
|
|
private _lineDir = [1, 180 + _attackDirection, _impactAngle] call CBA_fnc_polar2vect;
|
2021-04-20 21:31:38 +00:00
|
|
|
|
2021-06-12 02:37:36 +00:00
|
|
|
private _leadDistance = linearConversion [0, 1000, _projectilePos vectorDistance _seekerTargetPos, 5, 500, true];
|
2021-04-19 07:27:49 +00:00
|
|
|
|
2021-06-12 02:37:36 +00:00
|
|
|
private _missilePosProjected = _seekerTargetPos vectorAdd (_lineDir vectorMultiply ((_projectilePos vectorDistance _seekerTargetPos) - _leadDistance));
|
|
|
|
// don't climb
|
|
|
|
if (_missilePosProjected#2 > _projectilePos#2) then {
|
|
|
|
_missilePosProjected set [2, _projectilePos#2];
|
2021-04-19 07:27:49 +00:00
|
|
|
};
|
2021-06-12 02:37:36 +00:00
|
|
|
_targetData set [2, (_projectilePos vectorDistance _missilePosProjected)];
|
2021-04-19 07:27:49 +00:00
|
|
|
|
|
|
|
if (GVAR(debug_drawGuidanceInfo)) then {
|
2021-06-12 02:37:36 +00:00
|
|
|
private _projectilePitch = ((vectorDir _projectile) call CBA_fnc_vect2polar) select 2;
|
2022-06-03 02:11:35 +00:00
|
|
|
//IGNORE_PRIVATE_WARNING ["_attackProfileName"];
|
2021-06-12 02:37:36 +00:00
|
|
|
_attackProfileName = format ["JDAM [Pitch - %1 Impact Pitch - %2]", _projectilePitch, _impactAngle];
|
|
|
|
drawIcon3D ["\a3\ui_f\data\IGUI\Cfg\Cursors\selectover_ca.paa", [1,0,0,1], ASLtoAGL _missilePosProjected, 0.75, 0.75, 0, "P", 1, 0.025, "TahomaB"];
|
|
|
|
private _desiredAngle = _lineDir vectorMultiply 5000;
|
2021-05-02 05:04:08 +00:00
|
|
|
private _targetPosAGL = ASLtoAGL _seekerTargetPos;
|
|
|
|
drawLine3D [_targetPosAGL, _targetPosAGL vectorAdd _desiredAngle, [1, 1, 1, 1]];
|
2021-04-19 07:27:49 +00:00
|
|
|
};
|
|
|
|
|
2021-06-12 02:37:36 +00:00
|
|
|
_missilePosProjected
|
2021-04-19 07:27:49 +00:00
|
|
|
|