mirror of
https://github.com/acemod/ACE3.git
synced 2024-08-30 18:23:18 +00:00
3f4564605b
* Muzzle Velocity vs. Temperature Interpolation * C1 Ballistic Coefficient vs. Distance Interpolation * Coriolis and Spin drift output * Options menu * Truing Drop --------------------------------- * Overworked default gun profiles --------------------------------- * Fixed the Cancel buttons on the gun-, atmosphere- and target columns. * Fixed some muzzle velocity entries in the default gun list. * Fixed divide by zero error in the target range estimator
181 lines
5.0 KiB
Plaintext
181 lines
5.0 KiB
Plaintext
/*
|
|
* Author: Ruthberg
|
|
* Updates the result input and output fields
|
|
*
|
|
* Arguments:
|
|
* Nothing
|
|
*
|
|
* Return Value:
|
|
* Nothing
|
|
*
|
|
* Example:
|
|
* call ace_atragmx_fnc_update_result
|
|
*
|
|
* Public: No
|
|
*/
|
|
#include "script_component.hpp"
|
|
|
|
private ["_elevationAbs", "_elevationRel", "_elevationCur", "_windageAbs", "_windageRel", "_windageCur", "_wind2", "_lead", "_clickSize", "_clickNumber", "_clickInterval"];
|
|
_elevationAbs = GVAR(elevationOutput) select GVAR(currentTarget);
|
|
_elevationRel = 0;
|
|
_elevationCur = 0;
|
|
_windageAbs = GVAR(windage1Output) select GVAR(currentTarget);
|
|
_windageRel = 0;
|
|
_windageCur = 0;
|
|
|
|
_wind2 = GVAR(windage2Output) select GVAR(currentTarget);
|
|
|
|
if (GVAR(showCoriolis)) then {
|
|
_elevationRel = GVAR(verticalCoriolisOutput) select GVAR(currentTarget);
|
|
_windageRel = GVAR(horizontalCoriolisOutput) select GVAR(currentTarget);
|
|
|
|
_windageCur = GVAR(spinDriftOutput) select GVAR(currentTarget);
|
|
} else {
|
|
_elevationCur = GVAR(workingMemory) select 10;
|
|
_windageCur = GVAR(workingMemory) select 11;
|
|
|
|
_elevationRel = _elevationAbs - _elevationCur;
|
|
_windageRel = _windageAbs - _windageCur;
|
|
};
|
|
|
|
_lead = GVAR(leadOutput) select GVAR(currentTarget);
|
|
|
|
switch (GVAR(currentScopeUnit)) do {
|
|
case 0: {
|
|
_elevationAbs = _elevationAbs / 3.38;
|
|
_windageAbs = _windageAbs / 3.38;
|
|
|
|
_wind2 = _wind2 / 3.38;
|
|
|
|
_elevationRel = _elevationRel / 3.38;
|
|
_windageRel = _windageRel / 3.38;
|
|
|
|
_elevationCur = _elevationCur / 3.38;
|
|
_windageCur = _windageCur / 3.38;
|
|
};
|
|
case 2: {
|
|
_elevationAbs = _elevationAbs * 1.047;
|
|
_windageAbs = _windageAbs * 1.047;
|
|
|
|
_wind2 = _wind2 / 1.047;
|
|
|
|
_elevationRel = _elevationRel * 1.047;
|
|
_windageRel = _windageRel * 1.047;
|
|
|
|
_elevationCur = _elevationCur * 1.047;
|
|
_windageCur = _windageCur * 1.047;
|
|
};
|
|
case 3: {
|
|
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;
|
|
|
|
_elevationAbs = Round(_elevationAbs / _clickInterval);
|
|
_windageAbs = Round(_windageAbs / _clickInterval);
|
|
|
|
_wind2 = Round(_wind2 / _clickInterval);
|
|
|
|
_elevationRel = Round(_elevationRel / _clickInterval);
|
|
_windageRel = Round(_windageRel / _clickInterval);
|
|
|
|
_elevationCur = Round(_elevationCur / _clickInterval);
|
|
_windageCur = Round(_windageCur / _clickInterval);
|
|
};
|
|
};
|
|
|
|
if (GVAR(showWind2)) then {
|
|
ctrlSetText [42, "Wind2"];
|
|
} else {
|
|
ctrlSetText [42, "Lead"];
|
|
};
|
|
|
|
_elevationAbs = Round(_elevationAbs * 100) / 100;
|
|
if (_elevationAbs > 0) then {
|
|
ctrlSetText [400, format["%1", abs(_elevationAbs)]];
|
|
} else {
|
|
if (_elevationAbs < 0) then {
|
|
ctrlSetText [400, format["%1D", abs(_elevationAbs)]];
|
|
} else {
|
|
ctrlSetText [400, "0.0"];
|
|
};
|
|
};
|
|
_elevationRel = Round(_elevationRel * 100) / 100;
|
|
if (_elevationRel > 0) then {
|
|
ctrlSetText [401, format["%1", abs(_elevationRel)]];
|
|
} else {
|
|
if (_elevationRel < 0) then {
|
|
ctrlSetText [401, format["%1D", abs(_elevationRel)]];
|
|
} else {
|
|
ctrlSetText [401, "0.0"];
|
|
};
|
|
};
|
|
_elevationCur = Round(_elevationCur * 100) / 100;
|
|
if (_elevationCur > 0) then {
|
|
ctrlSetText [402, format["%1", abs(_elevationCur)]];
|
|
} else {
|
|
if (_elevationCur < 0) then {
|
|
ctrlSetText [402, format["%1D", abs(_elevationCur)]];
|
|
} else {
|
|
ctrlSetText [402, "0.0"];
|
|
};
|
|
};
|
|
|
|
_windageAbs = Round(_windageAbs * 100) / 100;
|
|
if (_windageAbs > 0) then {
|
|
ctrlSetText [410, format["%1R", abs(_windageAbs)]];
|
|
} else {
|
|
if (_windageAbs < 0) then {
|
|
ctrlSetText [410, format["%1L", abs(_windageAbs)]];
|
|
} else {
|
|
ctrlSetText [410, "0.0"];
|
|
};
|
|
};
|
|
_windageRel = Round(_windageRel * 100) / 100;
|
|
if (_windageRel > 0) then {
|
|
ctrlSetText [411, format["%1R", abs(_windageRel)]];
|
|
} else {
|
|
if (_windageRel < 0) then {
|
|
ctrlSetText [411, format["%1L", abs(_windageRel)]];
|
|
} else {
|
|
ctrlSetText [411, "0.0"];
|
|
};
|
|
};
|
|
_windageCur = Round(_windageCur * 100) / 100;
|
|
if (_windageCur > 0) then {
|
|
ctrlSetText [412, format["%1R", abs(_windageCur)]];
|
|
} else {
|
|
if (_windageCur < 0) then {
|
|
ctrlSetText [412, format["%1L", abs(_windageCur)]];
|
|
} else {
|
|
ctrlSetText [412, "0.0"];
|
|
};
|
|
};
|
|
|
|
if (GVAR(showWind2)) then {
|
|
_wind2 = Round(_wind2 * 100) / 100;
|
|
if (_wind2 > 0) then {
|
|
ctrlSetText [420, format["%1R", abs(_wind2)]];
|
|
} else {
|
|
if (_wind2 < 0) then {
|
|
ctrlSetText [420, format["%1L", abs(_wind2)]];
|
|
} else {
|
|
ctrlSetText [420, "0.0"];
|
|
};
|
|
};
|
|
} else {
|
|
_lead = Round(_lead * 100) / 100;
|
|
if (_lead > 0) then {
|
|
if ((GVAR(targetSpeedDirection) select GVAR(currentTarget)) == 1) then {
|
|
ctrlSetText [420, format["%1R", abs(_lead)]];
|
|
} else {
|
|
ctrlSetText [420, format["%1L", abs(_lead)]];
|
|
};
|
|
} else {
|
|
ctrlSetText [420, "0.0"];
|
|
};
|
|
};
|