mirror of
https://github.com/acemod/ACE3.git
synced 2024-08-30 18:23:18 +00:00
05e4f74e73
* Medical AI - Adjust healing logic for rewrite - move state machine from config to sqf - move all healing logic to seperate func - attempt to handle healing for new system * prioritize unitReady medics * move setting to subcategory under medical * Use faster GET_WOUND_BLEEDING * Update fnc_healingLogic.sqf * Update for wound array changes * Update treatment events changes * Fractures/splint * formating / use GET_OPEN_WOUNDS * Use non-localized medical category
118 lines
4.8 KiB
Plaintext
118 lines
4.8 KiB
Plaintext
#include "script_component.hpp"
|
|
/*
|
|
* Author: BaerMitUmlaut, PabstMirror
|
|
* Applies healing to target
|
|
*
|
|
* Arguments:
|
|
* 0: Healer <OBJECT>
|
|
* 1: Target <OBJECT>
|
|
*
|
|
* Return Value:
|
|
* Nothing
|
|
*
|
|
* Example:
|
|
* [a, b] call ACE_medical_ai_fnc_healingLogic
|
|
*
|
|
* Public: No
|
|
*/
|
|
|
|
params ["_healer", "_target"];
|
|
(_healer getVariable [QGVAR(currentTreatment), [-1]]) params ["_finishTime", "_treatmentTarget", "_treatmentEvent", "_treatmentArgs"];
|
|
|
|
// Treatment in progress, check if finished and apply
|
|
if (_finishTime > 0) exitWith {
|
|
if (CBA_missionTime >= _finishTime) then {
|
|
TRACE_4("treatment finished",_finishTime,_treatmentTarget,_treatmentEvent,_treatmentArgs);
|
|
_healer setVariable [QGVAR(currentTreatment), nil];
|
|
if ((_treatmentTarget == _target) && {(_treatmentEvent select [0, 1]) != "#"}) then {
|
|
[_treatmentEvent, _treatmentArgs, _target] call CBA_fnc_targetEvent;
|
|
#ifdef DEBUG_MODE_FULL
|
|
INFO_4("%1->%2: %3 - %4",_healer,_target,_treatmentEvent,_treatmentArgs);
|
|
systemChat format ["Applying [%1->%2]: %3", _healer, _treatmentTarget, _treatmentEvent];
|
|
#endif
|
|
};
|
|
};
|
|
};
|
|
|
|
private _isMedic = [_healer] call EFUNC(medical_treatment,isMedic);
|
|
private _heartRate = GET_HEART_RATE(_target);
|
|
private _fractures = GET_FRACTURES(_target);
|
|
|
|
private _treatmentEvent = "#none";
|
|
private _treatmentArgs = [];
|
|
private _treatmentTime = 6;
|
|
switch (true) do {
|
|
case (GET_WOUND_BLEEDING(_target) > 0): {
|
|
// Select first bleeding wound and bandage it
|
|
private _openWounds = GET_OPEN_WOUNDS(_target);
|
|
private _selection = "?";
|
|
{
|
|
_x params ["", "_index", "_amount", "_percentage"];
|
|
if ((_amount * _percentage) > 0) exitWith { _selection = ALL_BODY_PARTS select _index; };
|
|
} forEach _openWounds;
|
|
_treatmentEvent = QEGVAR(medical_treatment,bandageLocal);
|
|
_treatmentTime = 5;
|
|
_treatmentArgs = [_target, _selection, "FieldDressing"];
|
|
};
|
|
case (_isMedic && {GET_BLOOD_VOLUME(_target) < BLOOD_VOLUME_CLASS_2_HEMORRHAGE}): {
|
|
private _bloodBags = _target getVariable [QEGVAR(medical,ivBags), []];
|
|
if ((count _bloodBags) >= 2) exitWith {
|
|
_treatmentEvent = "#waitForBlood";
|
|
};
|
|
_treatmentEvent = QEGVAR(medical_treatment,ivBagLocal);
|
|
_treatmentTime = 5;
|
|
_treatmentArgs = [_target, selectRandom ["leftarm", "rightarm", "leftleg", "rightleg"], "SalineIV"];
|
|
};
|
|
case ((count (_target getVariable [VAR_MEDICATIONS, []])) >= 6): {
|
|
_treatmentEvent = "#tooManyMeds";
|
|
};
|
|
case ((_fractures select 4) == 1): {
|
|
_treatmentEvent = QEGVAR(medical_treatment,splintLocal);
|
|
_treatmentTime = 6;
|
|
_treatmentArgs = [_healer, _target, "leftleg"];
|
|
};
|
|
case ((_fractures select 5) == 1): {
|
|
_treatmentEvent = QEGVAR(medical_treatment,splintLocal);
|
|
_treatmentTime = 6;
|
|
_treatmentArgs = [_healer, _target, "rightleg"];
|
|
};
|
|
case (IS_UNCONSCIOUS(_target) || {_heartRate <= 50}): {
|
|
if (CBA_missionTime < (_target getVariable [QGVAR(nextEpinephrine), -1])) exitWith {
|
|
_treatmentEvent = "#waitForEpinephrineToTakeEffect";
|
|
};
|
|
if (_heartRate > 180) exitWith {
|
|
_treatmentEvent = "#waitForSlowerHeart";
|
|
};
|
|
_target setVariable [QGVAR(nextEpinephrine), CBA_missionTime + 10];
|
|
_treatmentEvent = QEGVAR(medical_treatment,medicationLocal);
|
|
_treatmentTime = 2.5;
|
|
_treatmentArgs = [_target, selectRandom ["leftarm", "rightarm", "leftleg", "rightleg"], "Epinephrine"];
|
|
};
|
|
case ((GET_PAIN_PERCEIVED(_target) > 0.25) || {_heartRate >= 180}): {
|
|
if (CBA_missionTime < (_target getVariable [QGVAR(nextMorphine), -1])) exitWith {
|
|
_treatmentEvent = "#waitForMorphineToTakeEffect";
|
|
};
|
|
if (_heartRate < 60) exitWith {
|
|
_treatmentEvent = "#waitForFasterHeart";
|
|
};
|
|
_target setVariable [QGVAR(nextMorphine), CBA_missionTime + 30];
|
|
_treatmentEvent = QEGVAR(medical_treatment,medicationLocal);
|
|
_treatmentTime = 2.5;
|
|
_treatmentArgs = [_target, selectRandom ["leftarm", "rightarm", "leftleg", "rightleg"], "Morphine"];
|
|
};
|
|
};
|
|
|
|
_healer setVariable [QGVAR(currentTreatment), [CBA_missionTime + _treatmentTime, _target, _treatmentEvent, _treatmentArgs]];
|
|
|
|
// Play animation
|
|
if ((_treatmentEvent select [0,1]) != "#") then {
|
|
private _treatmentClassname = _treatmentArgs select 2;
|
|
if (_treatmentEvent == QEGVAR(medical_treatment,splintLocal)) then { _treatmentClassname = "Splint" };
|
|
[_healer, _treatmentClassname, (_healer == _target)] call FUNC(playTreatmentAnim);
|
|
};
|
|
|
|
#ifdef DEBUG_MODE_FULL
|
|
TRACE_4("treatment started",_treatmentTime,_target,_treatmentEvent,_treatmentArgs);
|
|
systemChat format ["Treatment [%1->%2]: %3", _healer, _target, _treatmentEvent];
|
|
#endif
|