/* * Author: Rosuto * DAGR vector output loop * * Arguments: * Nothing * * Return Value: * Nothing * * Example: * * Public: No */ #include "script_component.hpp" private ["_pos", "_xGrid", "_yGrid", "_dagrGrid", "_bearing", "_dagrDist", "_dagrElevation", "_dagrTime", "_elevation", "_xCoord", "_yCoord"]; 135471 cutRsc ["DAGR_DISPLAY", "plain down"]; #define __display (uiNameSpace getVariable "DAGR_DISPLAY") #define __gridControl (__display displayCtrl 266851) #define __speedControl (__display displayCtrl 266858) #define __elevationControl (__display displayCtrl 266853) #define __headingControl (__display displayCtrl 266854) #define __timeControl (__display displayCtrl 266855) #define __background (__display displayCtrl 266856) __background ctrlSetText QUOTE(PATHTOF(UI\dagr_vector.paa)); if (GVAR(noVectorData)) exitwith {}; _pos = [GVAR(LAZPOS) select 0, GVAR(LAZPOS) select 1]; // Incase grids go neg due to 99-00 boundry if (_pos select 0 < 0) then {_pos set [0, (_pos select 0) + 99999];}; if (_pos select 1 < 0) then {_pos set [1, (_pos select 1) + 99999];}; // Find laser position _xGrid = toArray Str(round(_pos select 0)); while {count _xGrid < 5} do { _xGrid = [48] + _xGrid; }; _xGrid resize 4; _xGrid = toString _xGrid; _xGrid = parseNumber _xGrid; _yGrid = toArray Str(round(_pos select 1)); while {count _yGrid < 5} do { _yGrid = [48] + _yGrid; }; _yGrid resize 4; _yGrid = toString _yGrid; _yGrid = parseNumber _yGrid; _xCoord = switch true do { case (_xGrid >= 1000): { "" + Str(_xGrid) }; case (_xGrid >= 100): { "0" + Str(_xGrid) }; case (_xGrid >= 10): { "00" + Str(_xGrid) }; default { "000" + Str(_xGrid) }; }; _yCoord = switch true do { case (_yGrid >= 1000): { "" + Str(_yGrid) }; case (_yGrid >= 100): { "0" + Str(_yGrid) }; case (_yGrid >= 10): { "00" + Str(_yGrid) }; default { "000" + Str(_yGrid) }; }; _dagrGrid = _xCoord + " " + _yCoord; // Find target elevation _elevation = floor ((GVAR(LAZPOS) select 2) + EGVAR(common,mapAltitude)); _dagrElevation = str _elevation + "m"; // Time _dagrTime = [daytime, "HH:MM"] call bis_fnc_timeToString; // Bearing _bearing = GVAR(LAZHEADING); if (_bearing >= 360) then {_bearing = _bearing - 360;}; if (!GVAR(useDegrees)) then {_bearing = DEG_TO_MIL(_bearing)}; _bearing = floor (_bearing); // Distance _dagrDist = str GVAR(LAZDIST) + "m"; // Put grid into variable so DAGR menu can access it GVAR(vectorGrid) = _dagrGrid; // OUTPUT __gridControl ctrlSetText format ["%1", _dagrGrid]; __speedControl ctrlSetText format ["%1", _dagrDist]; __elevationControl ctrlSetText format ["%1", _dagrElevation]; __headingControl ctrlSetText (if (!GVAR(useDegrees)) then { format ["%1", _bearing] } else { format ["%1°", _bearing] }); __timeControl ctrlSetText format ["%1", _dagrTime];