ACE3/addons/atragmx/functions/fnc_update_range_card.sqf

106 lines
3.1 KiB
Plaintext
Raw Normal View History

/*
* Author: Ruthberg
* Updates the range card listbox content
*
* Arguments:
* Nothing
*
* Return Value:
* Nothing
*
* Example:
* call ace_atragmx_fnc_update_range_card
*
* Public: No
*/
#include "script_component.hpp"
private ["_range", "_elevation", "_windage1", "_windage2", "_clickSize", "_clickNumber", "_clickInterval", "_lead", "_TOF", "_velocity", "_kineticEnergy", "_rangeOutput", "_elevationOutput", "_windageOutput", "_lastColumnOutput", "_speedOfSound"];
_lastColumnOutput = "";
if (GVAR(showWind2) && GVAR(rangeCardCurrentColumn) == 0) then {
ctrlSetText [5006, "Wind2"];
} else {
ctrlSetText [5006, (GVAR(rangeCardLastColumns) select GVAR(rangeCardCurrentColumn))];
};
if (GVAR(currentUnit) == 1) then {
2015-04-07 20:44:26 +00:00
ctrlSetText [5003, "Yards"];
} else {
2015-04-07 20:44:26 +00:00
ctrlSetText [5003, "Meters"];
};
lnbClear 5007;
_speedOfSound = GVAR(temperature) call EFUNC(weather,calculateSpeedOfSound);
{
2015-04-07 20:44:26 +00:00
_range = _x select 0;
_elevation = _x select 1;
_windage1 = (_x select 2) select 0;
_windage2 = (_x select 2) select 1;
2015-04-07 20:44:26 +00:00
_lead = _x select 3;
_TOF = _x select 4;
_velocity = _x select 5;
_kineticEnergy = _x select 6;
switch (GVAR(currentScopeUnit)) do {
case 0: {
2015-04-07 20:44:26 +00:00
_elevation = _elevation / 3.38;
_windage1 = _windage1 / 3.38;
_windage2 = _windage2 / 3.38;
};
case 2: {
2015-04-07 20:44:26 +00:00
_elevation = _elevation * 1.047;
_windage1 = _windage1 * 1.047;
_windage2 = _windage2 * 1.047;
2015-04-07 20:44:26 +00:00
};
case 3: {
2015-04-21 13:01:23 +00:00
switch (GVAR(workingMemory) select 7) do {
case 0: { _clickSize = 1; };
case 1: { _clickSize = 1 / 1.047; };
case 2: { _clickSize = 3.38; };
};
_clickNumber = GVAR(workingMemory) select 8;
_clickInterval = _clickSize / _clickNumber;
2015-04-07 20:44:26 +00:00
2015-04-21 13:01:23 +00:00
_elevation = Round(_elevation / _clickInterval);
_windage1 = Round(_windage1 / _clickInterval);
_windage2 = Round(_windage2 / _clickInterval);
2015-04-07 20:44:26 +00:00
};
};
_elevationOutput = Str(Round(_elevation * 100) / 100);
_windageOutput = Str(Round(_windage1 * 100) / 100);
2015-04-07 20:44:26 +00:00
_rangeOutput = Str(_range);
if (_velocity < _speedOfSound) then {
2015-04-07 20:44:26 +00:00
_rangeOutput = _rangeOutput + "*";
};
if (GVAR(currentUnit) == 1) then {
2015-04-07 20:44:26 +00:00
_velocity = _velocity * 3.2808399;
};
switch (GVAR(rangeCardCurrentColumn)) do {
case 0: {
if (GVAR(showWind2)) then {
_lastColumnOutput = Str(Round(_windage2 * 100) / 100);
} else {
_lastColumnOutput = Str(Round(_lead * 100) / 100);
};
2015-04-07 20:44:26 +00:00
};
case 1: {
2015-04-07 20:44:26 +00:00
_lastColumnOutput = Str(Round(_velocity));
};
case 2: {
2015-04-07 20:44:26 +00:00
_lastColumnOutput = Str(Round(_kineticEnergy));
};
case 3: {
2015-04-07 20:44:26 +00:00
_lastColumnOutput = Str(Round(_TOF * 100) / 100);
}
};
lnbAddRow [5007, [_rangeOutput, _elevationOutput, _windageOutput, _lastColumnOutput]];
2015-04-08 09:05:28 +00:00
} forEach GVAR(rangeCardData);