ACE3/addons/medical/functions/fnc_getBloodLoss.sqf

50 lines
1.8 KiB
Plaintext
Raw Normal View History

/*
* Author: Glowbal
* Calculate the total blood loss of a unit.
*
* Arguments:
* 0: The Unit <OBJECT>
*
* ReturnValue:
* Total blood loss of unit <NUMBER>
*
* Public: No
*/
#include "script_component.hpp"
2015-04-14 18:40:38 +00:00
#define BLOODLOSSRATE_BASIC 0.2
2015-08-22 14:25:10 +00:00
private ["_totalBloodLoss","_tourniquets","_openWounds", "_cardiacOutput", "_internalWounds"];
// 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"];
_totalBloodLoss = 0;
// Advanced medical bloodloss handling
2015-03-06 21:54:44 +00:00
if (GVAR(level) >= 2) then {
2015-04-22 20:36:41 +00:00
_tourniquets = _unit getvariable [QGVAR(tourniquets), [0,0,0,0,0,0]];
_openWounds = _unit getvariable [QGVAR(openWounds), []];
//_cardiacOutput = [_unit] call FUNC(getCardiacOutput);
2015-02-28 18:28:05 +00:00
{
if ((_tourniquets select (_x select 2)) == 0) then {
2015-02-28 18:28:05 +00:00
// total bleeding ratio * percentage of injury left
_totalBloodLoss = _totalBloodLoss + ((_x select 4) * (_x select 3));
2015-02-28 18:28:05 +00:00
// (((BLOODLOSS_SMALL_WOUNDS * (_x select 0))) + ((BLOODLOSS_MEDIUM_WOUNDS * (_x select 1))) + ((BLOODLOSS_LARGE_WOUNDS * (_x select 2))) * (_cardiacOutput / DEFAULT_CARDIAC_OUTPUT));
};
2015-08-22 14:25:10 +00:00
} foreach _openWounds;
2015-04-22 20:36:41 +00:00
_internalWounds = _unit getvariable [QGVAR(internalWounds), []];
2015-02-28 18:28:05 +00:00
{
_totalBloodLoss = _totalBloodLoss + ((_x select 4) * (_x select 3));
2015-08-22 14:25:10 +00:00
} foreach _internalWounds;
2015-02-28 18:28:05 +00:00
// cap the blood loss to be no greater as the current cardiac output
//(_totalBloodLoss min _cardiacOutput);
} else {
2015-09-02 19:56:00 +00:00
{ _totalBloodLoss = _totalBloodLoss + _x } forEach (_unit getvariable [QGVAR(bodyPartStatus), []]);
_totalBloodLoss = (_totalBloodLoss / 6) * BLOODLOSSRATE_BASIC;
};
_totalBloodLoss * ((_unit getVariable [QGVAR(bleedingCoefficient), GVAR(bleedingCoefficient)]) max 0);