2015-02-08 09:01:32 +00:00
|
|
|
/*
|
|
|
|
* Author: Glowbal
|
|
|
|
* Calculate the total blood loss of a unit.
|
|
|
|
*
|
|
|
|
* Arguments:
|
|
|
|
* 0: The Unit <OBJECT>
|
|
|
|
*
|
2017-06-08 13:31:51 +00:00
|
|
|
* Return Value:
|
2015-02-08 09:01:32 +00:00
|
|
|
* Total blood loss of unit <NUMBER>
|
2015-02-07 22:55:48 +00:00
|
|
|
*
|
2017-06-08 13:31:51 +00:00
|
|
|
* Example:
|
|
|
|
* [bob] call ACE_medical_fnc_getBloodLoss
|
|
|
|
*
|
2015-02-08 09:01:32 +00:00
|
|
|
* Public: No
|
2015-02-07 22:55:48 +00:00
|
|
|
*/
|
|
|
|
|
|
|
|
#include "script_component.hpp"
|
|
|
|
|
2015-04-14 18:40:38 +00:00
|
|
|
#define BLOODLOSSRATE_BASIC 0.2
|
2015-04-05 19:38:15 +00:00
|
|
|
|
2015-02-07 22:55:48 +00:00
|
|
|
// TODO Only use this calculation if medium or higher, otherwise use vanilla calculations (for basic medical).
|
2015-08-22 14:25:10 +00:00
|
|
|
params ["_unit"];
|
2015-02-07 22:55:48 +00:00
|
|
|
|
2016-06-13 10:18:56 +00:00
|
|
|
private _totalBloodLoss = 0;
|
|
|
|
private _tourniquets = _unit getVariable [QGVAR(tourniquets), [0,0,0,0,0,0]];
|
|
|
|
{
|
|
|
|
if ((_tourniquets select (_x select 2)) == 0) then {
|
|
|
|
// total bleeding ratio * percentage of injury left
|
2015-02-28 18:28:05 +00:00
|
|
|
_totalBloodLoss = _totalBloodLoss + ((_x select 4) * (_x select 3));
|
2016-06-13 10:18:56 +00:00
|
|
|
// (((BLOODLOSS_SMALL_WOUNDS * (_x select 0))) + ((BLOODLOSS_MEDIUM_WOUNDS * (_x select 1))) + ((BLOODLOSS_LARGE_WOUNDS * (_x select 2))) * (_cardiacOutput / DEFAULT_CARDIAC_OUTPUT));
|
|
|
|
};
|
|
|
|
} forEach (_unit getVariable [QGVAR(openWounds), []]);
|
|
|
|
|
|
|
|
{
|
|
|
|
_totalBloodLoss = _totalBloodLoss + ((_x select 4) * (_x select 3));
|
|
|
|
} forEach (_unit getVariable [QGVAR(internalWounds), []]);
|
2015-02-13 21:55:13 +00:00
|
|
|
|
2015-04-22 20:38:48 +00:00
|
|
|
_totalBloodLoss * ((_unit getVariable [QGVAR(bleedingCoefficient), GVAR(bleedingCoefficient)]) max 0);
|