2016-05-30 16:37:03 +00:00
|
|
|
//#define DEBUG_MODE_FULL
|
|
|
|
#include "script_component.hpp"
|
|
|
|
|
2016-10-26 22:16:31 +00:00
|
|
|
params ["_gun", "_type", "_round", ["_doFragTrack", false]];
|
2016-05-30 16:37:03 +00:00
|
|
|
|
|
|
|
if (!GVAR(enabled)) exitWith {};
|
|
|
|
|
|
|
|
//_enabled = getNumber (configFile >> "CfgAmmo" >> _type >> QGVAR(enabled));
|
2016-10-26 22:16:31 +00:00
|
|
|
//if (_enabled < 1) exitWith {};
|
2016-05-30 16:37:03 +00:00
|
|
|
|
2016-10-26 22:16:31 +00:00
|
|
|
if (_round in GVAR(blackList)) exitWith {
|
|
|
|
REM(GVAR(blackList),_round);
|
2016-05-30 16:37:03 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
// Exit on max track
|
2017-02-10 18:28:27 +00:00
|
|
|
if ((count GVAR(objects)) > GVAR(maxTrack)) exitWith {};
|
2016-05-30 16:37:03 +00:00
|
|
|
|
2016-10-26 22:16:31 +00:00
|
|
|
if (
|
|
|
|
_gun == ACE_player ||
|
|
|
|
{(gunner _gun) == ACE_player} ||
|
|
|
|
{local _gun && {!(isPlayer (gunner _gun))} && {!(isPlayer _gun)}}
|
|
|
|
) then {
|
2016-05-30 16:37:03 +00:00
|
|
|
_doFragTrack = true;
|
|
|
|
};
|
|
|
|
|
2016-10-26 22:16:31 +00:00
|
|
|
private _doSpall = false;
|
|
|
|
if (GVAR(SpallEnabled)) then {
|
|
|
|
if (GVAR(spallIsTrackingCount) <= 0) then {
|
2016-05-30 16:37:03 +00:00
|
|
|
GVAR(spallHPData) = [];
|
|
|
|
};
|
2016-10-26 22:16:31 +00:00
|
|
|
if (GVAR(spallIsTrackingCount) > 5) then {
|
2016-05-30 16:37:03 +00:00
|
|
|
// ACE_player sideChat "LIMT!";
|
|
|
|
} else {
|
|
|
|
_doSpall = true;
|
2016-10-26 22:16:31 +00:00
|
|
|
INC(GVAR(spallIsTrackingCount));
|
2016-05-30 16:37:03 +00:00
|
|
|
};
|
|
|
|
};
|
2016-10-26 22:16:31 +00:00
|
|
|
// ACE_player sideChat format ["c: %1", GVAR(spallIsTrackingCount)];
|
2016-05-30 16:37:03 +00:00
|
|
|
|
2016-10-26 22:16:31 +00:00
|
|
|
if (GVAR(autoTrace)) then {
|
|
|
|
[ACE_player, _round, [1, 0, 0, 1]] call FUNC(addTrack);
|
2016-05-30 16:37:03 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
// We only do the single track object check here.
|
|
|
|
// We should do an {!(_round in GVAR(objects))}
|
|
|
|
// But we leave that out here for optimization. So this cannot be a framework function
|
|
|
|
// Otherwise, it should only be added once and from the FiredEH
|
2016-10-26 22:16:31 +00:00
|
|
|
if (_doFragTrack && {alive _round}) then {
|
|
|
|
private _spallTrack = [];
|
|
|
|
private _spallTrackID = [];
|
2016-05-30 16:37:03 +00:00
|
|
|
|
2016-10-26 22:16:31 +00:00
|
|
|
private _args = [
|
|
|
|
_round, getPosASL _round, velocity _round, _type, diag_frameno, _gun, _doSpall, _spallTrack, _spallTrackID,
|
|
|
|
getNumber (configFile >> "CfgAmmo" >> _type >> QGVAR(skip)),
|
|
|
|
getNumber (configFile >> "CfgAmmo" >> _type >> "explosive"),
|
|
|
|
getNumber (configFile >> "CfgAmmo" >> _type >> "indirectHitRange"),
|
|
|
|
getNumber (configFile >> "CfgAmmo" >> _type >> QGVAR(force)),
|
|
|
|
getNumber (configFile >> "CfgAmmo" >> _type >> "indirecthit") * (sqrt (getNumber (configFile >> "CfgAmmo" >> _type >> "indirectHitRange")))
|
2016-05-30 16:37:03 +00:00
|
|
|
];
|
|
|
|
TRACE_1("Initializing track", _round);
|
|
|
|
GVAR(objects) pushBack _round;
|
|
|
|
GVAR(arguments) pushBack _args;
|
|
|
|
|
2016-10-26 22:16:31 +00:00
|
|
|
if (_doSpall) then {
|
2016-05-30 16:37:03 +00:00
|
|
|
[_round, 1, _spallTrack, _spallTrackID] call FUNC(spallTrack);
|
|
|
|
};
|
|
|
|
// ACE_player sideChat "WTF2";
|
|
|
|
};
|