2015-02-08 09:01:32 +00:00
|
|
|
/*
|
|
|
|
* Author: Glowbal
|
|
|
|
* Updates the vitals. Is expected to be called every second.
|
2015-02-07 22:55:48 +00:00
|
|
|
*
|
2015-02-08 09:01:32 +00:00
|
|
|
* Arguments:
|
|
|
|
* 0: The Unit <OBJECT>
|
|
|
|
*
|
|
|
|
* ReturnValue:
|
|
|
|
* <NIL>
|
|
|
|
*
|
|
|
|
* Public: No
|
2015-02-07 22:55:48 +00:00
|
|
|
*/
|
|
|
|
#include "script_component.hpp"
|
|
|
|
|
2016-12-05 20:34:20 +00:00
|
|
|
params ["_unit"];
|
2016-10-12 19:59:32 +00:00
|
|
|
|
2016-12-05 20:34:20 +00:00
|
|
|
private _lastTimeUpdated = _unit getVariable [QGVAR(lastTimeUpdated), CBA_missionTime];
|
|
|
|
private _deltaT = CBA_missionTime - _lastTimeUpdated;
|
|
|
|
_unit setVariable [QGVAR(lastTimeUpdated), CBA_missionTime];
|
|
|
|
|
|
|
|
TRACE_2("ACE_DEBUG",_unit,_deltaT);
|
|
|
|
|
|
|
|
if (_deltaT == 0) exitWith {};
|
2015-03-15 00:48:50 +00:00
|
|
|
|
2016-06-13 00:11:21 +00:00
|
|
|
private _lastTimeValuesSynced = _unit getVariable [QGVAR(lastMomentValuesSynced), 0];
|
2016-12-05 20:34:20 +00:00
|
|
|
private _syncValues = (CBA_missionTime - _lastTimeValuesSynced) >= (10 + floor(random(10)));
|
2016-10-12 19:59:32 +00:00
|
|
|
|
2015-03-08 12:56:24 +00:00
|
|
|
if (_syncValues) then {
|
2016-03-02 10:01:39 +00:00
|
|
|
_unit setVariable [QGVAR(lastMomentValuesSynced), CBA_missionTime];
|
2015-03-08 12:56:24 +00:00
|
|
|
};
|
|
|
|
|
2016-12-05 20:34:20 +00:00
|
|
|
private _bloodVolume = (_unit getVariable [QGVAR(bloodVolume), DEFAULT_BLOOD_VOLUME]) + ([_unit, _deltaT, _syncValues] call FUNC(getBloodVolumeChange));
|
|
|
|
_bloodVolume = 0 max _bloodVolume min DEFAULT_BLOOD_VOLUME;
|
2015-04-14 18:40:38 +00:00
|
|
|
|
2016-12-05 20:34:20 +00:00
|
|
|
// @todo: replace this and the rest of the setVariable with EFUNC(common,setApproximateVariablePublic)
|
2015-11-30 16:27:09 +00:00
|
|
|
_unit setVariable [QGVAR(bloodVolume), _bloodVolume, _syncValues];
|
2015-02-07 22:55:48 +00:00
|
|
|
|
2015-09-03 15:18:37 +00:00
|
|
|
TRACE_3("ACE_DEBUG",_bloodVolume,_syncValues,_unit);
|
2015-02-07 22:55:48 +00:00
|
|
|
// Set variables for synchronizing information across the net
|
2016-12-05 20:34:20 +00:00
|
|
|
if (_bloodVolume < BLOOD_VOLUME_CLASS_1_HEMORRHAGE) then {
|
|
|
|
if (_bloodVolume < BLOOD_VOLUME_CLASS_3_HEMORRHAGE) then {
|
2015-11-30 16:27:09 +00:00
|
|
|
if (_unit getVariable [QGVAR(hasLostBlood), 0] != 2) then {
|
|
|
|
_unit setVariable [QGVAR(hasLostBlood), 2, true];
|
2015-04-28 18:47:11 +00:00
|
|
|
};
|
|
|
|
} else {
|
2015-11-30 16:27:09 +00:00
|
|
|
if (_unit getVariable [QGVAR(hasLostBlood), 0] != 1) then {
|
|
|
|
_unit setVariable [QGVAR(hasLostBlood), 1, true];
|
2015-04-28 18:47:11 +00:00
|
|
|
};
|
2016-06-13 10:18:56 +00:00
|
|
|
};
|
2015-02-07 22:55:48 +00:00
|
|
|
} else {
|
2015-11-30 16:27:09 +00:00
|
|
|
if (_unit getVariable [QGVAR(hasLostBlood), 0] != 0) then {
|
|
|
|
_unit setVariable [QGVAR(hasLostBlood), 0, true];
|
2015-02-07 22:55:48 +00:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2016-10-12 19:59:32 +00:00
|
|
|
private _bloodLoss = _unit call FUNC(getBloodLoss);
|
|
|
|
TRACE_3("ACE_DEBUG",_bloodLoss,_unit getVariable QGVAR(isBleeding),_unit);
|
2016-09-18 17:48:49 +00:00
|
|
|
if (_bloodLoss > 0) then {
|
|
|
|
_unit setVariable [QGVAR(bloodloss), _bloodLoss, _syncValues];
|
|
|
|
|
2016-12-05 20:34:20 +00:00
|
|
|
[QGVAR(Injury), _unit] call CBA_fnc_localEvent;
|
2016-10-12 19:59:32 +00:00
|
|
|
|
2015-11-30 16:27:09 +00:00
|
|
|
if !(_unit getVariable [QGVAR(isBleeding), false]) then {
|
|
|
|
_unit setVariable [QGVAR(isBleeding), true, true];
|
2015-02-07 22:55:48 +00:00
|
|
|
};
|
|
|
|
} else {
|
2015-11-30 16:27:09 +00:00
|
|
|
if (_unit getVariable [QGVAR(isBleeding), false]) then {
|
|
|
|
_unit setVariable [QGVAR(isBleeding), false, true];
|
2015-02-07 22:55:48 +00:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2016-06-13 00:11:21 +00:00
|
|
|
private _painStatus = _unit getVariable [QGVAR(pain), 0];
|
2015-09-04 14:37:20 +00:00
|
|
|
TRACE_4("ACE_DEBUG",_painStatus,_unit getVariable QGVAR(hasPain),_unit getVariable QGVAR(painSuppress),_unit);
|
2015-11-30 16:27:09 +00:00
|
|
|
if (_painStatus > (_unit getVariable [QGVAR(painSuppress), 0])) then {
|
|
|
|
if !(_unit getVariable [QGVAR(hasPain), false]) then {
|
|
|
|
_unit setVariable [QGVAR(hasPain), true, true];
|
2015-02-07 22:55:48 +00:00
|
|
|
};
|
|
|
|
} else {
|
2015-11-30 16:27:09 +00:00
|
|
|
if (_unit getVariable [QGVAR(hasPain), false]) then {
|
|
|
|
_unit setVariable [QGVAR(hasPain), false, true];
|
2015-02-07 22:55:48 +00:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2016-12-05 20:34:20 +00:00
|
|
|
TRACE_6("ACE_DEBUG_ADVANCED_VITALS",_painStatus,_bloodVolume,_unit getVariable QGVAR(hasPain),_unit getVariable QGVAR(morphine),_syncValues,_unit);
|
2016-06-13 10:18:56 +00:00
|
|
|
|
2016-12-05 20:34:20 +00:00
|
|
|
// Handle pain due tourniquets, that have been applied more than 120 s ago
|
|
|
|
private _oldTourniquets = (_unit getVariable [QGVAR(tourniquets), []]) select {_x > 0 && {CBA_missionTime - _x > 120}};
|
|
|
|
// Increase pain at a rate of 0.001 units/s per old tourniquet
|
|
|
|
_painStatus = _painStatus + (count _oldTourniquets) * 0.001 * _deltaT;
|
2016-06-13 10:18:56 +00:00
|
|
|
|
2016-12-05 20:34:20 +00:00
|
|
|
private _heartRate = (_unit getVariable [QGVAR(heartRate), 80]) + _deltaT * ([_unit] call FUNC(getHeartRateChange));
|
|
|
|
_unit setVariable [QGVAR(heartRate), 0 max _heartRate, _syncValues];
|
2015-02-07 22:55:48 +00:00
|
|
|
|
2016-12-05 20:34:20 +00:00
|
|
|
private _bloodPressure = [_unit] call FUNC(getBloodPressure);
|
|
|
|
_unit setVariable [QGVAR(bloodPressure), _bloodPressure, _syncValues];
|
2016-02-28 23:50:28 +00:00
|
|
|
|
2016-12-05 20:34:20 +00:00
|
|
|
private _cardiacOutput = [_unit] call FUNC(getCardiacOutput);
|
|
|
|
if (_bloodLoss > BLOOD_LOSS_KNOCK_OUT_THRESHOLD * _cardiacOutput) then {
|
|
|
|
[QGVAR(CriticalVitals), _unit] call CBA_fnc_localEvent;
|
|
|
|
};
|
2016-02-29 01:08:59 +00:00
|
|
|
|
2016-12-05 20:34:20 +00:00
|
|
|
#ifdef DEBUG_MODE_FULL
|
|
|
|
if (!isPlayer _unit) then {
|
|
|
|
private _cardiacArrest = _unit getVariable [QGVAR(inCardiacArrest), false];
|
|
|
|
hintSilent format["blood volume: %1, blood loss: [%2, %3]\nhr: %4, bp: %5, pain: %6", round(_bloodVolume * 100) / 100, round(_bloodLoss * 1000) / 1000, round((_bloodLoss / _cardiacOutput) * 100) / 100, round(_heartRate), _bloodPressure, round(_painStatus * 100) / 100];
|
|
|
|
};
|
|
|
|
#endif
|
2015-02-07 22:55:48 +00:00
|
|
|
|
2016-12-05 20:34:20 +00:00
|
|
|
_unit setVariable [QGVAR(pain), 0 max (_painStatus - _deltaT * PAIN_REDUCTION_SPEED), _syncValues];
|
2015-02-07 22:55:48 +00:00
|
|
|
|
2016-12-05 20:34:20 +00:00
|
|
|
TRACE_8("ACE_DEBUG_ADVANCED_VITALS",_painStatus,PAIN_REDUCTION_SPEED,_heartRate,_bloodVolume,_bloodPressure,_deltaT,_syncValues,_unit);
|
2015-02-07 22:55:48 +00:00
|
|
|
|
2016-12-05 20:34:20 +00:00
|
|
|
_bloodPressure params ["_bloodPressureL", "_bloodPressureH"];
|
|
|
|
if (_bloodPressureL < 40) then {
|
|
|
|
[QGVAR(CriticalVitals), _unit] call CBA_fnc_localEvent;
|
|
|
|
};
|
|
|
|
if ((_heartRate < 20) || {_heartRate > 220} || {_bloodPressureH < 50}) then {
|
|
|
|
[QGVAR(FatalVitals), _unit] call CBA_fnc_localEvent;
|
|
|
|
};
|
2016-06-13 00:11:21 +00:00
|
|
|
|
2016-12-05 20:34:20 +00:00
|
|
|
// Handle spontaneous wakeup from unconsciousness
|
|
|
|
if (_unit getVariable [QGVAR(isUnconscious), false]) then {
|
|
|
|
if (_unit call FUNC(hasStableVitals)) then {
|
|
|
|
private _lastWakeUpCheck = _unit getVariable [QGVAR(lastWakeUpCheck), CBA_missionTime];
|
|
|
|
if (CBA_missionTime - _lastWakeUpCheck > SPONTANEOUS_WAKE_UP_INTERVAL) then {
|
|
|
|
_unit setVariable [QGVAR(lastWakeUpCheck), CBA_missionTime];
|
|
|
|
if ((random 1) < SPONTANEOUS_WAKE_UP_CHANCE) then {
|
|
|
|
[QGVAR(WakeUp), _unit] call CBA_fnc_localEvent;
|
2015-02-07 22:55:48 +00:00
|
|
|
};
|
|
|
|
};
|
2016-12-05 20:34:20 +00:00
|
|
|
} else {
|
|
|
|
// Unstable vitals, procrastinate the next wakeup check
|
|
|
|
_unit setVariable [QGVAR(lastWakeUpCheck), CBA_missionTime];
|
2015-02-07 23:08:36 +00:00
|
|
|
};
|
2015-02-07 22:55:48 +00:00
|
|
|
};
|