//////////////////////////////////////////// // Start Server-side functions and Create, Display Mission Messages for blckeagls mission system for Arma 3 Epoch // Last Updated 8/14/16 // by Ghostrider-DbD- ////////////////////////////////////////// if (hasInterface) then { //diag_log "[blckeagls] initializing client variables"; blck_MarkerPeristTime = 300; blck_useHint = true; blck_useSystemChat = true; blck_useTitleText = false; blck_useDynamic = false; blck_aiKilluseSystemChat = true; blck_aiKilluseDynamic = false; blck_aiKilluseTitleText = false; blck_processingMsg = -1; blck_processingKill = -1; blck_message = ""; fn_dynamicNotification = { private["_text","_screentime","_xcoord","_ycoord"]; params["_mission","_message"]; waitUntil {blck_processingMsg < 0}; blck_processingMsg = 1; _screentime = 7; _text = format[ "%1

%2
", _mission,_message ]; _ycoord = [safezoneY + safezoneH - 0.8,0.7]; _xcoord = [safezoneX + safezoneW - 0.5,0.35]; [_text,_xcoord,_ycoord,_screentime,0.5] spawn BIS_fnc_dynamicText; uiSleep 3; // 3 second delay before the next message blck_processingMsg = -1; }; //diag_log "[blckeagls] initializing client functions"; fn_missionNotification = { params["_event","_message","_mission"]; if (blck_useSystemChat) then {systemChat format["%1",_message];}; if (blck_useTitleText) then {titleText [_message, "PLAIN DOWN",5];uiSleep 5; titleText ["", "PLAIN DOWN",5]}; if (blck_useHint) then { hint parseText format[ "%1
______________

%2
______________

Any loot you find is yours as payment for eliminating the threat!",_mission,_message ]; }; if (blck_useDynamic) then { [_mission,_message] call fn_dynamicNotification; }; //diag_log format["_fn_missionNotification ====] Paremeters _event %1 _message %2 _mission %3",_event,_message,_mission]; }; fn_reinforcementsNotification = { }; fn_AI_KilledNotification = { private["_message","_text","_screentime","_xcoord","_ycoord"]; _message = _this select 0; //diag_log format["_fn_AI_KilledNotification ====] Paremeters _event %1 _message %2 _mission %3",_message]; if (blck_aiKilluseSystemChat) then {systemChat format["%1",_message];}; if (blck_aiKilluseTitleText) then {titleText [_message, "PLAIN DOWN",5];uiSleep 5; titleText ["", "PLAIN DOWN",5]}; if (blck_aiKilluseDynamic) then { //diag_log format["blckClient.sqf:: dynamic messaging called for mission %2 with message of %1",_message]; waitUntil{blck_processingKill < 0}; blck_processingKill = 1; _text = format["%1",_message]; _xcoord = [safezoneX,0.8]; _ycoord = [safezoneY + safezoneH - 0.5,0.2]; _screentime = 5; [" "+ _text,_xcoord,_ycoord,_screentime] spawn BIS_fnc_dynamicText; uiSleep 3; blck_processingKill = -1; }; }; //"blck_Message" addPublicVariableEventHandler fn_handleMessage = { //private["_event","_msg","_mission"]; diag_log format["blck_Message ====] Paremeters = _this = %1",_this]; params["_event","_message","_mission"]; diag_log format["blck_Message ====] Paremeters _event %1 _message %2 paramter #3 %3",_event,_message,_mission]; switch (_event) do { case "start": { playSound "UAV_05"; diag_log "switch start"; //_mission = _this select 1 select 2; [_event,_message,_mission] spawn fn_missionNotification; }; case "end": { playSound "UAV_03"; diag_log "switch end"; //_mission = _this select 1 select 2; [_event,_message,_mission] spawn fn_missionNotification; }; case "aikilled": { //diag_log "switch aikilled"; [_message] spawn fn_AI_KilledNotification; }; case "DLS": { if ( (player distance _mission) < 1000) then {playsound "AddItemOK"; hint _message;systemChat _message}; }; case "reinforcements": { if ( (player distance _mission) < 1000) then {playsound "AddItemOK"; ["Alert",_message] call fn_dynamicNotification;}; diag_log "---->>>> Reinforcements Spotted"; }; case "IED": { ["IED","Bandits targeted your vehicle with an IED"] call fn_dynamicNotification; for "_i" from 1 to 3 do {playSound "BattlefieldExplosions3_3D";uiSleep 0.3;}; }; }; }; //diag_log "[blckeagls] spawning JIP markers"; if (!isNil "blck_OrangeMarker") then {[blck_OrangeMarker] execVM "debug\spawnMarker.sqf"}; if (!isNil "blck_GreenMarker") then {[blck_GreenMarker] execVM "debug\spawnMarker.sqf"}; if (!isNil "blck_RedMarker") then {[blck_RedMarker] execVM "debug\spawnMarker.sqf"}; if (!isNil "blck_BlueMarker") then {[blck_BlueMarker] execVM "debug\spawnMarker.sqf"}; diag_log "blck client loaded ver 8/14/16 1.0 7:47 AM"; //diag_log "[blckeagls] starting client loop"; private["_start"]; _start = diag_tickTime; while {true} do { if !(blck_Message isEqualTo "") then { diag_log format["[blckClient] blck_Message = %1", blck_message]; private["_message"]; _message = blck_message; _message spawn fn_handleMessage; blck_Message = ""; } else { uiSleep 0.3; }; }; };