2024-01-11 20:01:50 +00:00
|
|
|
#include "..\script_component.hpp"
|
2024-01-08 21:22:52 +00:00
|
|
|
/*
|
2024-01-09 17:54:52 +00:00
|
|
|
* Author: Jaynus, NouberNou, Lambda.Tiger
|
2024-02-16 03:03:12 +00:00
|
|
|
* This function handles creating both random and targeted fragments as well as handling some of the performance optimizations.
|
2024-01-08 21:22:52 +00:00
|
|
|
*
|
|
|
|
* Arguments:
|
2024-02-16 03:03:12 +00:00
|
|
|
* 0: Position (posASL) of projectile <ARRAY>
|
2024-01-18 02:50:20 +00:00
|
|
|
* 1: Velocity of projectile <ARRAY>
|
|
|
|
* 2: Projectile CfgAmmo classname <STRING>
|
|
|
|
* 3: getShotParents of projectile at EH <ARRAY>
|
2024-01-13 06:35:22 +00:00
|
|
|
*
|
2024-01-08 21:22:52 +00:00
|
|
|
* Return Value:
|
|
|
|
* None
|
|
|
|
*
|
|
|
|
* Example:
|
2024-03-29 00:33:56 +00:00
|
|
|
* [getPosASL _projectile, velocity _projectile, typeOf _projectile, getShotParents _projectile] call ace_frag_fnc_doFrag
|
2024-01-08 21:22:52 +00:00
|
|
|
*
|
|
|
|
* Public: No
|
|
|
|
*/
|
2024-03-13 19:34:13 +00:00
|
|
|
|
2024-03-03 01:17:38 +00:00
|
|
|
#define ACE_FRAG_MIN_FRAG_BUDGET_FOR_RANDOM 3
|
2024-03-13 19:34:13 +00:00
|
|
|
|
2024-02-16 03:03:12 +00:00
|
|
|
params ["_posASL", "_velocity", "_ammo", "_shotParents"];
|
2024-03-13 19:34:13 +00:00
|
|
|
TRACE_4("doFrag",_posASL,_velocity,_ammo,_shotParents);
|
2024-01-09 03:41:31 +00:00
|
|
|
|
2024-01-16 21:49:20 +00:00
|
|
|
// Don't let a single object cause all fragmentation events
|
2024-03-03 05:55:32 +00:00
|
|
|
_shotParents params ["_shotParentVehicle"];
|
|
|
|
if (_shotParentVehicle getVariable [QGVAR(obj_nextFragTime), -1] > CBA_missionTime) exitWith {
|
|
|
|
TRACE_1("vehicleTimeExit",_shotParentVehicle);
|
2024-01-09 03:41:31 +00:00
|
|
|
};
|
2024-01-08 21:22:52 +00:00
|
|
|
|
2024-01-13 06:35:22 +00:00
|
|
|
// Check normal round timeout and adjust _max frags
|
2024-01-15 21:18:42 +00:00
|
|
|
private _timeSinceLastFrag = CBA_missionTime - GVAR(lastFragTime);
|
2024-02-16 03:03:12 +00:00
|
|
|
if (_timeSinceLastFrag < ACE_FRAG_HOLDOFF || {_posASL isEqualTo [0, 0, 0]} || {_ammo isEqualTo ""}) exitWith {
|
2024-01-15 21:18:42 +00:00
|
|
|
TRACE_3("timeExit",_timeSinceLastFrag,CBA_missionTime,GVAR(lastFragTime));
|
2024-01-09 03:41:31 +00:00
|
|
|
};
|
2024-01-15 21:18:42 +00:00
|
|
|
TRACE_3("willFrag",_timeSinceLastFrag,CBA_missionTime,_maxFragCount);
|
2024-03-03 05:55:32 +00:00
|
|
|
_shotParentVehicle setVariable [QGVAR(obj_nextFragTime), CBA_missionTime + ACE_FRAG_HOLDOFF_VEHICLE];
|
2024-03-03 04:31:30 +00:00
|
|
|
private _maxFragCount = round linearConversion [ACE_FRAG_COUNT_MIN_TIME, ACE_FRAG_COUNT_MAX_TIME, _timeSinceLastFrag, ACE_FRAG_COUNT_MIN, ACE_FRAG_COUNT_MAX, true];
|
2024-01-09 03:41:31 +00:00
|
|
|
|
2024-03-03 04:31:30 +00:00
|
|
|
[_ammo] call FUNC(getFragInfo) params ["_fragRange", "_fragVel", "_fragTypes", "_modFragCount"];
|
2024-01-15 21:18:42 +00:00
|
|
|
// For low frag rounds limit the # of frags created
|
2024-02-08 23:11:36 +00:00
|
|
|
if (_modFragCount < ACE_FRAG_LOW_FRAG_MOD_COUNT) then {
|
2024-01-15 21:18:42 +00:00
|
|
|
_maxFragCount = _modFragCount * ACE_FRAG_LOW_FRAG_COEFF;
|
|
|
|
GVAR(lastFragTime) = CBA_missionTime - ACE_FRAG_LOW_FRAG_HOLDOFF_REDUCTION;
|
2024-01-12 07:50:01 +00:00
|
|
|
} else {
|
|
|
|
GVAR(lastFragTime) = CBA_missionTime;
|
|
|
|
};
|
2024-01-08 21:22:52 +00:00
|
|
|
|
2024-03-03 04:31:30 +00:00
|
|
|
TRACE_3("doFrag choices",_maxFragCount,_fragRange,GVAR(fragSimComplexity));
|
2024-01-15 21:18:42 +00:00
|
|
|
if (GVAR(fragSimComplexity) != 1 && _fragRange > 3) then {
|
|
|
|
_maxFragCount = _maxFragCount - ([_posASL, _fragVel, _fragRange, _maxFragCount, _fragTypes, _modFragCount, _shotParents] call FUNC(doFragTargeted));
|
2024-01-08 21:22:52 +00:00
|
|
|
};
|
|
|
|
|
2024-03-03 01:17:38 +00:00
|
|
|
if (GVAR(fragSimComplexity) > 0 && _maxFragCount >= ACE_FRAG_MIN_FRAG_BUDGET_FOR_RANDOM) then {
|
2024-03-05 04:19:38 +00:00
|
|
|
[_posASL, _velocity, _fragTypes, _maxFragCount, _shotParents] call FUNC(doFragRandom);
|
2024-01-15 19:42:45 +00:00
|
|
|
};
|