mirror of
https://github.com/acemod/ACE3.git
synced 2024-08-30 18:23:18 +00:00
94 lines
3.4 KiB
Plaintext
94 lines
3.4 KiB
Plaintext
|
/*
|
||
|
* Author: Norrin, Rocko, Ruthberg
|
||
|
*
|
||
|
* HuntIR monitor system
|
||
|
*
|
||
|
* Arguments:
|
||
|
* Nothing
|
||
|
*
|
||
|
* Return Value:
|
||
|
* Nothing
|
||
|
*
|
||
|
* Public: No
|
||
|
*/
|
||
|
#include "script_component.hpp"
|
||
|
|
||
|
#define __TYPE_WRITER_DELAY 0.05
|
||
|
|
||
|
if ((ACE_player call CBA_fnc_getUnitAnim) select 0 == "stand") then {
|
||
|
ACE_player playMove "AmovPercMstpSrasWrflDnon_diary";
|
||
|
};
|
||
|
|
||
|
13521 cutText ["", "BLACK", 0];
|
||
|
createDialog "ace_huntir_cam_dialog_off";
|
||
|
|
||
|
[{
|
||
|
if (!dialog) exitWith {
|
||
|
13521 cutText ["", "PLAIN", 0];
|
||
|
};
|
||
|
closeDialog 0;
|
||
|
createDialog "ace_huntir_cam_dialog_inactive";
|
||
|
uiNameSpace setVariable ["ace_huntir_monitor", findDisplay 18881];
|
||
|
[{
|
||
|
GVAR(startTime) = ACE_time;
|
||
|
GVAR(done) = false;
|
||
|
GVAR(connectionDelay) = 5;
|
||
|
GVAR(state) = "searching";
|
||
|
GVAR(message) = [];
|
||
|
GVAR(messageSearching) = toArray "Searching.....";
|
||
|
GVAR(messageConnecting) = toArray "Connecting.....";
|
||
|
[{
|
||
|
private ["_elapsedTime", "_nearestHuntIRs"];
|
||
|
_elapsedTime = ACE_time - GVAR(startTime);
|
||
|
_nearestHuntIRs = ACE_player nearEntities ["ACE_HuntIR", 2000];
|
||
|
|
||
|
if ((!dialog) || GVAR(done)) exitWith {
|
||
|
[_this select 1] call cba_fnc_removePerFrameHandler;
|
||
|
|
||
|
if (dialog && GVAR(state) == "connected") then {
|
||
|
[_nearestHuntIRs select 0] call FUNC(cam);
|
||
|
} else {
|
||
|
13521 cutText ["", "PLAIN"];
|
||
|
};
|
||
|
};
|
||
|
switch (GVAR(state)) do {
|
||
|
case "searching": {
|
||
|
if (count GVAR(message) < count GVAR(messageSearching)) then {
|
||
|
GVAR(message) pushBack (GVAR(messageSearching) select (count GVAR(message)));
|
||
|
ctrlSetText [1, toString GVAR(message)];
|
||
|
} else {
|
||
|
GVAR(message) = [];
|
||
|
if (_elapsedTime > 10) then {
|
||
|
GVAR(state) = "noGDS";
|
||
|
};
|
||
|
if (_elapsedTime > 5 && {count _nearestHuntIRs > 0}) then {
|
||
|
GVAR(state) = "connecting";
|
||
|
};
|
||
|
};
|
||
|
};
|
||
|
case "connecting": {
|
||
|
if (count GVAR(message) < count GVAR(messageConnecting)) then {
|
||
|
GVAR(message) pushBack (GVAR(messageConnecting) select (count GVAR(message)));
|
||
|
ctrlSetText [1, toString GVAR(message)];
|
||
|
} else {
|
||
|
GVAR(message) = [];
|
||
|
GVAR(connectionDelay) = GVAR(connectionDelay) - 1;
|
||
|
if (GVAR(connectionDelay) <= 0) then {
|
||
|
GVAR(done) = true;
|
||
|
GVAR(state) = "connected";
|
||
|
};
|
||
|
};
|
||
|
};
|
||
|
case "noGDS": {
|
||
|
ctrlSetText [1, "No GDS System detected"];
|
||
|
[{
|
||
|
GVAR(done) = true;
|
||
|
closedialog 0;
|
||
|
13521 cutText ["", "PLAIN"];
|
||
|
}, [], 3, 0] call EFUNC(common,waitAndExecute);
|
||
|
};
|
||
|
};
|
||
|
}, __TYPE_WRITER_DELAY, []] call CBA_fnc_addPerFrameHandler;
|
||
|
}, [], 0.5, 0] call EFUNC(common,waitAndExecute);
|
||
|
}, [], 1, 0] call EFUNC(common,waitAndExecute);
|