ACE3/addons/dagr/functions/fnc_outputVector.sqf

99 lines
2.8 KiB
Plaintext
Raw Normal View History

2015-06-07 15:53:37 +00:00
/*
* Author: Rosuto
* DAGR vector output loop
*
* Arguments:
* Nothing
*
* Return Value:
* Nothing
*
* Example:
*
* Public: No
*/
#include "script_component.hpp"
2015-06-08 12:32:42 +00:00
private ["_pos", "_xGrid", "_yGrid", "_dagrGrid", "_bearing", "_dagrDist", "_dagrElevation", "_dagrTime", "_elevation", "_xCoord", "_yCoord"];
2015-06-07 15:53:37 +00:00
135471 cutRsc ["DAGR_DISPLAY", "plain down"];
2015-06-08 10:57:16 +00:00
#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 {};
2015-06-08 10:57:16 +00:00
2015-06-08 12:32:42 +00:00
_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];};
2015-06-08 10:57:16 +00:00
// Find laser position
2015-06-08 12:32:42 +00:00
_xGrid = toArray Str(round(_pos select 0));
2015-06-08 10:57:16 +00:00
while {count _xGrid < 5} do {
_xGrid = [48] + _xGrid;
};
_xGrid resize 4;
_xGrid = toString _xGrid;
_xGrid = parseNumber _xGrid;
2015-06-08 12:32:42 +00:00
_yGrid = toArray Str(round(_pos select 1));
2015-06-08 10:57:16 +00:00
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) };
2015-06-07 15:53:37 +00:00
};
2015-06-08 10:57:16 +00:00
_dagrGrid = _xCoord + " " + _yCoord;
// Find target elevation
_elevation = floor ((GVAR(LAZPOS) select 2) + EGVAR(weather,altitude));
2015-06-07 15:53:37 +00:00
_dagrElevation = str _elevation + "m";
2015-06-08 10:57:16 +00:00
// Time
2015-06-07 15:53:37 +00:00
_dagrTime = [daytime, "HH:MM"] call bis_fnc_timeToString;
2015-06-08 10:57:16 +00:00
// Bearing
_bearing = GVAR(LAZHEADING);
2015-06-07 15:53:37 +00:00
if (_bearing >= 360) then {_bearing = _bearing - 360;};
if (!GVAR(useDegrees)) then {_bearing = DEG_TO_MIL(_bearing)};
2015-06-07 15:53:37 +00:00
_bearing = floor (_bearing);
2015-06-08 10:57:16 +00:00
// Distance
_dagrDist = str GVAR(LAZDIST) + "m";
2015-06-07 15:53:37 +00:00
// Put grid into variable so DAGR menu can access it
GVAR(vectorGrid) = _dagrGrid;
2015-06-07 15:53:37 +00:00
2015-06-08 10:57:16 +00:00
// 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] });
2015-06-08 10:57:16 +00:00
__timeControl ctrlSetText format ["%1", _dagrTime];