2017-03-23 13:12:08 +00:00
|
|
|
/*
|
|
|
|
* Author: Zakant
|
|
|
|
* Calculate the blood loost and blood volume for a unit. Used from CPR to simulate a heart rate while in cardiac arrest
|
|
|
|
*
|
|
|
|
* Arguments:
|
2017-03-23 16:23:18 +00:00
|
|
|
* 0: Unit <OBJECT>
|
2017-03-23 13:12:08 +00:00
|
|
|
*
|
|
|
|
* Return Value:
|
|
|
|
* NONE
|
|
|
|
*
|
|
|
|
* Public: No
|
|
|
|
*/
|
|
|
|
#include "script_component.hpp"
|
|
|
|
|
|
|
|
params["_unit"];
|
|
|
|
|
|
|
|
// We will just simulate blood flow for now!
|
|
|
|
private _lastTimeUpdated = _unit getVariable [QEGVAR(medical,lastTimeUpdated), CBA_missionTime];
|
|
|
|
private _deltaT = CBA_missionTime - _lastTimeUpdated;
|
|
|
|
|
|
|
|
private _lastTimeValuesSynced = _unit getVariable [QEGVAR(medical,lastMomentValuesSynced), 0];
|
|
|
|
private _syncValues = (CBA_missionTime - _lastTimeValuesSynced) >= (10 + floor(random(10)));
|
|
|
|
|
|
|
|
_unit setVariable [QEGVAR(medical,lastTimeUpdated), CBA_missionTime];
|
|
|
|
if (_deltaT != 0) then {
|
|
|
|
private _change = ([_unit, _deltaT, _syncValues] call EFUNC(medical,getBloodVolumeChange));
|
|
|
|
private _bloodVolume = (_unit getVariable [QEGVAR(medical,bloodVolume), DEFAULT_BLOOD_VOLUME]) + _change ;
|
|
|
|
_bloodVolume = 0 max _bloodVolume min DEFAULT_BLOOD_VOLUME;
|
|
|
|
_unit setVariable [QEGVAR(medical,bloodVolume), _bloodVolume, _syncValues];
|
|
|
|
};
|