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"
|
|
|
|
|
2015-08-22 14:25:10 +00:00
|
|
|
private ["_heartRate","_bloodPressure","_bloodVolume","_painStatus", "_lastTimeValuesSynced", "_syncValues", "_airwayStatus", "_blood"];
|
|
|
|
params ["_unit", "_interval"];
|
2015-09-03 15:18:37 +00:00
|
|
|
TRACE_3("ACE_DEBUG",_unit,_interval,_unit);
|
2015-03-15 00:48:50 +00:00
|
|
|
if (_interval == 0) exitWith {};
|
|
|
|
|
2015-11-30 16:27:09 +00:00
|
|
|
_lastTimeValuesSynced = _unit getVariable [QGVAR(lastMomentValuesSynced), 0];
|
2015-05-21 16:42:44 +00:00
|
|
|
_syncValues = (ACE_time - _lastTimeValuesSynced >= (10 + floor(random(10))) && GVAR(keepLocalSettingsSynced));
|
2015-03-08 12:56:24 +00:00
|
|
|
if (_syncValues) then {
|
2015-11-30 16:27:09 +00:00
|
|
|
_unit setVariable [QGVAR(lastMomentValuesSynced), ACE_time];
|
2015-03-08 12:56:24 +00:00
|
|
|
};
|
|
|
|
|
2015-11-30 16:27:09 +00:00
|
|
|
_bloodVolume = (_unit getVariable [QGVAR(bloodVolume), 100]) + ([_unit] call FUNC(getBloodVolumeChange));
|
2015-04-14 18:40:38 +00:00
|
|
|
_bloodVolume = _bloodVolume max 0;
|
|
|
|
|
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
|
2015-04-28 18:47:11 +00:00
|
|
|
if (_bloodVolume < 100) then {
|
2015-04-28 20:19:30 +00:00
|
|
|
if ((_bloodVolume < 90 && (GVAR(level) == 2)) || _bloodVolume <= 45) then {
|
2015-09-03 15:18:37 +00:00
|
|
|
TRACE_4("ACE_DEBUG_ADVANCED",_bloodVolume,_unit getVariable QGVAR(hasLostBlood),_syncValues,_unit);
|
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-09-03 15:18:37 +00:00
|
|
|
TRACE_4("ACE_DEBUG", _bloodVolume,_unit getVariable QGVAR(hasLostBlood),_syncValues,_unit);
|
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
|
|
|
};
|
|
|
|
}
|
2015-02-07 22:55:48 +00:00
|
|
|
} else {
|
2015-09-03 20:17:59 +00:00
|
|
|
TRACE_4("ACE_DEBUG",_bloodVolume,_unit getVariable QGVAR(hasLostBlood),_syncValues,_unit);
|
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
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2015-09-03 15:18:37 +00:00
|
|
|
TRACE_3("ACE_DEBUG",[_unit] call FUNC(getBloodLoss),_unit getVariable QGVAR(isBleeding),_unit);
|
2015-04-22 20:36:41 +00:00
|
|
|
if (([_unit] call FUNC(getBloodLoss)) > 0) then {
|
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
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2015-11-30 16:27:09 +00:00
|
|
|
_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
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2015-03-12 06:33:44 +00:00
|
|
|
if (GVAR(level) == 1) then {
|
2015-09-04 17:21:10 +00:00
|
|
|
TRACE_5("ACE_DEBUG_BASIC_VITALS",_painStatus,_unit getVariable QGVAR(hasPain),_unit getVariable QGVAR(morphine),_syncValues,_unit);
|
2015-03-12 06:33:44 +00:00
|
|
|
// reduce pain
|
2015-04-28 17:30:35 +00:00
|
|
|
if (_painStatus > 0) then {
|
|
|
|
_unit setVariable [QGVAR(pain), (_painStatus - 0.001 * _interval) max 0, _syncValues];
|
2015-03-12 06:33:44 +00:00
|
|
|
};
|
2015-02-07 22:55:48 +00:00
|
|
|
|
2015-03-12 06:33:44 +00:00
|
|
|
// reduce painkillers
|
|
|
|
if (_unit getVariable [QGVAR(morphine), 0] > 0) then {
|
2015-04-28 17:30:35 +00:00
|
|
|
_unit setVariable [QGVAR(morphine), ((_unit getVariable [QGVAR(morphine), 0]) - 0.0015 * _interval) max 0, _syncValues];
|
2015-03-12 06:33:44 +00:00
|
|
|
};
|
2015-02-07 22:55:48 +00:00
|
|
|
|
2015-03-15 02:26:00 +00:00
|
|
|
// bleeding
|
|
|
|
_blood = _unit getVariable [QGVAR(bloodVolume), 100];
|
2015-04-14 18:40:38 +00:00
|
|
|
if (_blood <= 35 and !(_unit getVariable ["ACE_isUnconscious", false])) then {
|
|
|
|
[_unit, true] call FUNC(setUnconscious);
|
|
|
|
};
|
|
|
|
if (_blood == 0) then {
|
|
|
|
[_unit] call FUNC(setDead);
|
2015-02-07 22:55:48 +00:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
// handle advanced medical, with vitals
|
2015-03-08 12:56:24 +00:00
|
|
|
if (GVAR(level) >= 2) then {
|
2015-09-04 14:37:20 +00:00
|
|
|
TRACE_6("ACE_DEBUG_ADVANCED_VITALS",_painStatus,_bloodVolume, _unit getVariable QGVAR(hasPain),_unit getVariable QGVAR(morphine),_syncValues,_unit);
|
2015-11-30 16:14:05 +00:00
|
|
|
if (_bloodVolume < 30) exitWith {
|
2015-03-15 02:26:10 +00:00
|
|
|
[_unit] call FUNC(setDead);
|
|
|
|
};
|
|
|
|
|
|
|
|
if ([_unit] call EFUNC(common,isAwake)) then {
|
|
|
|
if (_bloodVolume < 60) then {
|
|
|
|
if (random(1) > 0.9) then {
|
2015-04-17 18:40:24 +00:00
|
|
|
[_unit, true, 15 + random(20)] call FUNC(setUnconscious);
|
2015-03-15 02:26:10 +00:00
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
2015-02-07 22:55:48 +00:00
|
|
|
|
2016-02-29 01:08:59 +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 * _interval;
|
2016-02-28 23:50:28 +00:00
|
|
|
|
2015-02-07 22:55:48 +00:00
|
|
|
// Set the vitals
|
2015-11-30 16:27:09 +00:00
|
|
|
_heartRate = (_unit getVariable [QGVAR(heartRate), 80]) + (([_unit] call FUNC(getHeartRateChange)) * _interval);
|
|
|
|
_unit setVariable [QGVAR(heartRate), _heartRate max 0, _syncValues];
|
2015-02-07 22:55:48 +00:00
|
|
|
|
|
|
|
_bloodPressure = [_unit] call FUNC(getBloodPressure);
|
2015-11-30 16:27:09 +00:00
|
|
|
_unit setVariable [QGVAR(bloodPressure), _bloodPressure, _syncValues];
|
2015-02-07 22:55:48 +00:00
|
|
|
|
2016-02-29 01:08:59 +00:00
|
|
|
_painReduce = if (_painStatus > 5) then {0.002} else {0.001};
|
|
|
|
|
|
|
|
// @todo: replace this and the rest of the setVariable with EFUNC(common,setApproximateVariablePublic)
|
|
|
|
_unit setVariable [QGVAR(pain), (_painStatus - _painReduce * _interval) max 0, _syncValues];
|
|
|
|
|
2015-09-03 15:18:37 +00:00
|
|
|
TRACE_8("ACE_DEBUG_ADVANCED_VITALS",_painStatus,_painReduce,_heartRate,_bloodVolume,_bloodPressure,_interval,_syncValues,_unit);
|
2015-03-21 09:55:40 +00:00
|
|
|
// TODO Disabled until implemented fully
|
2015-02-07 22:55:48 +00:00
|
|
|
// Handle airway
|
2015-03-21 09:55:40 +00:00
|
|
|
/*if (GVAR(setting_allowAirwayInjuries)) then {
|
2015-11-30 16:27:09 +00:00
|
|
|
_airwayStatus = _unit getVariable [QGVAR(airwayStatus), 100];
|
|
|
|
if (((_unit getVariable [QGVAR(airwayOccluded), false]) || (_unit getVariable [QGVAR(airwayCollapsed), false])) && !((_unit getVariable [QGVAR(airwaySecured), false]))) then {
|
2015-02-07 22:55:48 +00:00
|
|
|
if (_airwayStatus >= 0.5) then {
|
2015-11-30 16:27:09 +00:00
|
|
|
_unit setVariable [QGVAR(airwayStatus), _airwayStatus - 0.5 * _interval, _syncValues];
|
2015-02-07 22:55:48 +00:00
|
|
|
};
|
|
|
|
} else {
|
2015-11-30 16:27:09 +00:00
|
|
|
if !((_unit getVariable [QGVAR(airwayOccluded), false]) || (_unit getVariable [QGVAR(airwayCollapsed), false])) then {
|
2015-03-08 14:58:35 +00:00
|
|
|
if (_airwayStatus < 100) then {
|
2015-11-30 16:27:09 +00:00
|
|
|
_unit setVariable [QGVAR(airwayStatus), (_airwayStatus + 1.5 * _interval) min 100, _syncValues];
|
2015-02-07 22:55:48 +00:00
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
2015-03-08 14:58:35 +00:00
|
|
|
if (_airwayStatus < 80) then {
|
|
|
|
[_unit] call FUNC(setUnconscious);
|
|
|
|
if (_airwayStatus <= 0) then {
|
|
|
|
[_unit, true] call FUNC(setDead);
|
|
|
|
};
|
|
|
|
};
|
2015-03-21 09:55:40 +00:00
|
|
|
};*/
|
2015-02-07 22:55:48 +00:00
|
|
|
|
|
|
|
// Check vitals for medical status
|
|
|
|
// TODO check for in revive state instead of variable
|
2015-08-22 14:25:10 +00:00
|
|
|
_bloodPressure params ["_bloodPressureL", "_bloodPressureH"];
|
2015-02-07 22:55:48 +00:00
|
|
|
|
2015-11-30 16:27:09 +00:00
|
|
|
if (!(_unit getVariable [QGVAR(inCardiacArrest),false])) then {
|
2015-02-07 22:55:48 +00:00
|
|
|
if (_heartRate < 10 || _bloodPressureH < 30 || _bloodVolume < 20) then {
|
2015-04-17 18:40:24 +00:00
|
|
|
[_unit, true, 10+ random(20)] call FUNC(setUnconscious); // safety check to ensure unconsciousness for units if they are not dead already.
|
2015-02-07 22:55:48 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
if (_bloodPressureH > 260) then {
|
|
|
|
if (random(1) > 0.7) then {
|
|
|
|
[_unit] call FUNC(setCardiacArrest);
|
|
|
|
};
|
|
|
|
};
|
|
|
|
if (_bloodPressureL < 40 && _heartRate > 190) then {
|
|
|
|
if (random(1) > 0.7) then {
|
|
|
|
[_unit] call FUNC(setCardiacArrest);
|
|
|
|
};
|
|
|
|
};
|
|
|
|
if (_bloodPressureH > 145 && _heartRate > 150) then {
|
|
|
|
if (random(1) > 0.7) then {
|
|
|
|
[_unit] call FUNC(setCardiacArrest);
|
|
|
|
};
|
|
|
|
};
|
|
|
|
if (_heartRate > 200) then {
|
|
|
|
[_unit] call FUNC(setCardiacArrest);
|
|
|
|
};
|
|
|
|
|
|
|
|
if (_heartRate < 20) then {
|
|
|
|
[_unit] call FUNC(setCardiacArrest);
|
|
|
|
};
|
2015-02-07 23:08:36 +00:00
|
|
|
};
|
2015-04-05 18:11:54 +00:00
|
|
|
|
|
|
|
// syncing any remaining values
|
|
|
|
if (_syncValues) then {
|
2015-09-03 15:18:37 +00:00
|
|
|
TRACE_3("ACE_DEBUG_IVBAGS_SYNC",GVAR(IVBags),_syncValues,_unit);
|
2015-04-05 18:11:54 +00:00
|
|
|
{
|
|
|
|
private "_value";
|
2015-11-30 16:27:09 +00:00
|
|
|
_value = _unit getVariable _x;
|
2015-11-30 16:22:16 +00:00
|
|
|
if !(isNil "_value") then {
|
2015-11-30 16:27:09 +00:00
|
|
|
_unit setVariable [_x,(_unit getVariable [_x, 0]), true];
|
2015-04-05 18:11:54 +00:00
|
|
|
};
|
2015-11-30 16:23:48 +00:00
|
|
|
} forEach GVAR(IVBags);
|
2015-04-05 18:11:54 +00:00
|
|
|
};
|
2015-02-07 22:55:48 +00:00
|
|
|
};
|