2023-09-12 18:58:10 +00:00
|
|
|
#include "..\script_component.hpp"
|
2015-05-28 17:17:29 +00:00
|
|
|
/*
|
|
|
|
* Authors: Ruthberg
|
|
|
|
* Updates the range card data
|
|
|
|
*
|
|
|
|
* Arguments:
|
2016-11-08 13:47:12 +00:00
|
|
|
* 0: zero range <NUMBER>
|
2016-12-01 20:20:51 +00:00
|
|
|
* 1: bore height <NUMBER>
|
|
|
|
* 2: ammo class <STRING>
|
|
|
|
* 3: magazine class <STRING>
|
|
|
|
* 4: weapon class <STRING>
|
2015-05-28 17:17:29 +00:00
|
|
|
*
|
|
|
|
* Return Value:
|
2017-06-08 13:31:51 +00:00
|
|
|
* None
|
2015-05-28 17:17:29 +00:00
|
|
|
*
|
|
|
|
* Example:
|
2020-04-25 06:41:45 +00:00
|
|
|
* [1, 2, "ammo", "magazine", "weapon"] call ace_rangecard_fnc_updateRangeCard
|
2015-05-28 17:17:29 +00:00
|
|
|
*
|
|
|
|
* Public: No
|
|
|
|
*/
|
|
|
|
|
2015-05-28 18:13:22 +00:00
|
|
|
disableSerialization;
|
|
|
|
#define __dsp (uiNamespace getVariable "RangleCard_Display")
|
|
|
|
|
|
|
|
|
2016-12-01 20:20:51 +00:00
|
|
|
params ["_zeroRange", "_boreHeight", "_ammoClass", "_magazineClass", "_weaponClass"];
|
2015-05-28 17:17:29 +00:00
|
|
|
|
2015-05-29 13:07:30 +00:00
|
|
|
if (_ammoClass == "" || _magazineClass == "" || _weaponClass == "") exitWith {};
|
2015-05-28 17:17:29 +00:00
|
|
|
|
2015-05-28 18:13:22 +00:00
|
|
|
{
|
|
|
|
ctrlDelete _x;
|
|
|
|
} forEach GVAR(controls);
|
|
|
|
GVAR(controls) = [];
|
|
|
|
|
|
|
|
for "_row" from 0 to 49 do {
|
2024-02-04 17:50:24 +00:00
|
|
|
private _offset = [0.003, 0] select (_row < 5);
|
2017-10-10 14:39:59 +00:00
|
|
|
private _control = (__dsp ctrlCreate ["RangeCard_RscText", 790000 + _row]);
|
2015-05-28 18:13:22 +00:00
|
|
|
_control ctrlSetPosition [safeZoneX + 0.183, safeZoneY + 0.374 + 0.027 * _row + _offset, 0.062, 0.025];
|
|
|
|
if (_row in [0, 8, 18, 28, 38, 48]) then {
|
|
|
|
_control ctrlSetTextColor [1, 1, 1, 1];
|
|
|
|
} else {
|
|
|
|
_control ctrlSetTextColor [0, 0, 0, 1];
|
|
|
|
};
|
|
|
|
_control ctrlCommit 0;
|
|
|
|
_control ctrlSetText Str(100 + _row * 50);
|
|
|
|
GVAR(controls) pushBack _control;
|
|
|
|
};
|
|
|
|
for "_column" from 0 to 8 do {
|
|
|
|
for "_row" from 0 to 49 do {
|
2024-02-04 17:50:24 +00:00
|
|
|
private _offset = [0.003, 0] select (_row < 5);
|
2017-10-10 14:39:59 +00:00
|
|
|
private _control = (__dsp ctrlCreate ["RangeCard_RscText", 90000 + _column * 100 + _row]);
|
2015-05-28 18:13:22 +00:00
|
|
|
_control ctrlSetPosition [safeZoneX + 0.249 + _column * 0.055, safeZoneY + 0.374 + 0.027 * _row + _offset, 0.052, 0.025];
|
|
|
|
_control ctrlCommit 0;
|
|
|
|
_control ctrlSetText "-0.0";
|
|
|
|
GVAR(controls) pushBack _control;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
for "_column" from 0 to 2 do {
|
|
|
|
for "_row" from 0 to 49 do {
|
2024-02-04 17:50:24 +00:00
|
|
|
private _offset = [0.003, 0] select (_row < 5);
|
2017-10-10 14:39:59 +00:00
|
|
|
private _control = (__dsp ctrlCreate ["RangeCard_RscText", 90000 + (9 +_column) * 100 + _row]);
|
2015-05-28 18:13:22 +00:00
|
|
|
_control ctrlSetPosition [safeZoneX + 0.743 + _column * 0.049, safeZoneY + 0.374 + 0.027 * _row + _offset, 0.047, 0.025];
|
|
|
|
_control ctrlCommit 0;
|
|
|
|
_control ctrlSetText "-0.0";
|
|
|
|
GVAR(controls) pushBack _control;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
for "_column" from 0 to 2 do {
|
|
|
|
for "_row" from 0 to 49 do {
|
2024-02-04 17:50:24 +00:00
|
|
|
private _offset = [0.003, 0] select (_row < 5);
|
2017-10-10 14:39:59 +00:00
|
|
|
private _control = (__dsp ctrlCreate ["RangeCard_RscText", 90000 + (12 +_column) * 100 + _row]);
|
2015-05-28 18:13:22 +00:00
|
|
|
_control ctrlSetPosition [safeZoneX + 0.892 + _column * 0.049, safeZoneY + 0.374 + 0.027 * _row + _offset, 0.047, 0.025];
|
|
|
|
_control ctrlCommit 0;
|
|
|
|
_control ctrlSetText "-0.0";
|
|
|
|
GVAR(controls) pushBack _control;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2015-05-28 17:17:29 +00:00
|
|
|
lnbClear 770100;
|
|
|
|
lnbClear 770200;
|
|
|
|
lnbClear 770300;
|
|
|
|
lnbClear 770400;
|
|
|
|
|
|
|
|
GVAR(rangeCardDataElevation) = [[], [], [], [], [], [], [], [], []];
|
|
|
|
GVAR(rangeCardDataWindage) = [[], [], [], [], [], [], [], [], []];
|
|
|
|
GVAR(rangeCardDataLead) = [[], [], [], [], [], [], [], [], []];
|
2015-05-29 13:07:30 +00:00
|
|
|
GVAR(rangeCardDataMVs) = ["", "", "", "", "", "", "", "", ""];
|
2015-05-28 17:17:29 +00:00
|
|
|
GVAR(lastValidRow) = [];
|
|
|
|
|
|
|
|
GVAR(currentUnit) = 2;
|
|
|
|
GVAR(rangeCardStartRange) = 100;
|
|
|
|
GVAR(rangeCardIncrement) = 50;
|
|
|
|
GVAR(rangeCardEndRange) = GVAR(rangeCardStartRange) + 49 * GVAR(rangeCardIncrement);
|
|
|
|
|
2017-10-10 14:39:59 +00:00
|
|
|
private _ammoConfig = _ammoClass call EFUNC(advanced_ballistics,readAmmoDataFromConfig);
|
|
|
|
private _weaponConfig = _weaponClass call EFUNC(advanced_ballistics,readWeaponDataFromConfig);
|
|
|
|
private _airFriction = _ammoConfig select 0;
|
|
|
|
private _barrelTwist = _weaponConfig select 0;
|
|
|
|
private _barrelLength = _weaponConfig select 2;
|
|
|
|
private _muzzleVelocity = 0;
|
2015-05-30 18:06:55 +00:00
|
|
|
|
2017-10-10 14:39:59 +00:00
|
|
|
private _bc = 0;
|
2024-04-06 18:57:08 +00:00
|
|
|
if ((_ammoConfig select 6) isNotEqualTo []) then {
|
2015-05-30 18:06:55 +00:00
|
|
|
_bc = (_ammoConfig select 6) select 0;
|
|
|
|
};
|
2017-10-10 14:39:59 +00:00
|
|
|
private _transonicStabilityCoef = _ammoConfig select 4;
|
|
|
|
private _dragModel = _ammoConfig select 5;
|
|
|
|
private _atmosphereModel = _ammoConfig select 8;
|
2015-05-30 18:06:55 +00:00
|
|
|
|
2024-01-07 23:13:46 +00:00
|
|
|
private _isABenabled = (missionNamespace getVariable [QEGVAR(advanced_ballistics,enabled), false]) && (_bc != 0);
|
|
|
|
private _useBarrelLengthInfluence = (
|
|
|
|
_isABenabled &&
|
|
|
|
{missionNamespace getVariable [QEGVAR(advanced_ballistics,barrelLengthInfluenceEnabled), false]}
|
|
|
|
);
|
|
|
|
private _useAmmoTemperatureInfluence = (
|
|
|
|
_isABenabled &&
|
|
|
|
{missionNamespace getVariable [QEGVAR(advanced_ballistics,ammoTemperatureEnabled), false]}
|
|
|
|
);
|
|
|
|
|
|
|
|
if (_barrelLength > 0 && _useBarrelLengthInfluence) then {
|
2015-05-29 13:07:30 +00:00
|
|
|
_muzzleVelocity = [_barrelLength, _ammoConfig select 10, _ammoConfig select 11, 0] call EFUNC(advanced_ballistics,calculateBarrelLengthVelocityShift);
|
|
|
|
} else {
|
2017-10-10 14:39:59 +00:00
|
|
|
private _initSpeed = getNumber (configFile >> "CfgMagazines" >> _magazineClass >> "initSpeed");
|
|
|
|
private _initSpeedCoef = getNumber (configFile >> "CfgWeapons" >> _weaponClass >> "initSpeed");
|
2015-05-29 13:07:30 +00:00
|
|
|
if (_initSpeedCoef < 0) then {
|
|
|
|
_initSpeed = _initSpeed * -_initSpeedCoef;
|
|
|
|
};
|
|
|
|
if (_initSpeedCoef > 0) then {
|
|
|
|
_initSpeed = _initSpeedCoef;
|
|
|
|
};
|
|
|
|
_muzzleVelocity = _initSpeed;
|
|
|
|
};
|
2015-05-28 17:17:29 +00:00
|
|
|
|
2017-09-26 14:51:48 +00:00
|
|
|
ctrlSetText [770000, format["%1'' - %2 gr (%3)", round((_ammoConfig select 1) * 39.3700787) / 1000, round((_ammoConfig select 3) * 15.4323584), _ammoClass]];
|
|
|
|
if (_barrelLength > 0) then {
|
2024-01-07 23:13:46 +00:00
|
|
|
if (_useBarrelLengthInfluence && _barrelTwist > 0) then {
|
2015-06-07 08:16:30 +00:00
|
|
|
ctrlSetText [770002, format["Barrel: %1'' 1:%2'' twist", round(2 * _barrelLength * 0.0393700787) / 2, round(_barrelTwist * 0.0393700787)]];
|
2015-05-29 17:39:54 +00:00
|
|
|
} else {
|
2017-09-26 14:51:48 +00:00
|
|
|
ctrlSetText [770002, format["Barrel: %1''", round(2 * _barrelLength * 0.0393700787) / 2]];
|
2015-05-29 17:39:54 +00:00
|
|
|
};
|
2015-05-29 13:07:30 +00:00
|
|
|
};
|
2015-05-28 17:17:29 +00:00
|
|
|
|
2015-05-30 18:06:55 +00:00
|
|
|
lnbAddRow [770100, ["4mps Wind(MRADs)", "1mps LEAD(MRADs)"]];
|
2024-01-07 23:13:46 +00:00
|
|
|
if (_isABenabled) then {
|
2015-05-30 18:06:55 +00:00
|
|
|
lnbAddRow [770100, ["Air/Ammo Temp", "Air/Ammo Temp"]];
|
|
|
|
|
|
|
|
lnbAddRow [770200, ["-15°C", " -5°C", " 5°C", " 10°C", " 15°C", " 20°C", " 25°C", " 30°C", " 35°C"]];
|
|
|
|
lnbAddRow [770300, ["-15°C", " 10°C", " 35°C", "-15°C", " 10°C", " 35°C"]];
|
|
|
|
};
|
2015-05-28 17:17:29 +00:00
|
|
|
|
2016-11-08 13:47:12 +00:00
|
|
|
ctrlSetText [77003, format["%1m ZERO", round(_zeroRange)]];
|
2015-05-28 17:17:29 +00:00
|
|
|
|
2024-01-07 23:13:46 +00:00
|
|
|
if (_isABenabled) then {
|
2016-11-08 13:47:12 +00:00
|
|
|
ctrlSetText [770001, format["Drop Tables for B.P.: %1mb; Corrected for MVV at Air/Ammo Temperatures -15-35 °C", round(EGVAR(scopes,zeroReferenceBarometricPressure) * 100) / 100]];
|
|
|
|
ctrlSetText [77004 , format["B.P.: %1mb", round(EGVAR(scopes,zeroReferenceBarometricPressure) * 100) / 100]];
|
2015-05-29 13:07:30 +00:00
|
|
|
} else {
|
2015-05-30 18:06:55 +00:00
|
|
|
ctrlSetText [770001, ""];
|
2015-05-29 13:07:30 +00:00
|
|
|
ctrlSetText [77004 , ""];
|
|
|
|
};
|
2015-05-28 17:17:29 +00:00
|
|
|
|
2024-01-07 23:13:46 +00:00
|
|
|
private _cacheEntry = missionNamespace getVariable format [QGVAR(%1_%2_%3_%4_%5_%6_%7), _zeroRange, _boreHeight, _ammoClass, _weaponClass, _isABenabled, _useBarrelLengthInfluence, _useAmmoTemperatureInfluence];
|
|
|
|
if (isNil "_cacheEntry") then {
|
|
|
|
private _scopeBaseAngle = if (!_isABenabled) then {
|
2017-11-12 11:11:10 +00:00
|
|
|
private _zeroAngle = "ace_advanced_ballistics" callExtension format ["calcZero:%1:%2:%3:%4", _zeroRange, _muzzleVelocity, _airFriction, _boreHeight];
|
2016-11-09 13:00:25 +00:00
|
|
|
(parseNumber _zeroAngle)
|
|
|
|
} else {
|
2017-11-12 11:11:10 +00:00
|
|
|
private _zeroAngle = "ace_advanced_ballistics" callExtension format ["calcZeroAB:%1:%2:%3:%4:%5:%6:%7:%8:%9", _zeroRange, _muzzleVelocity, _boreHeight, EGVAR(scopes,zeroReferenceTemperature), EGVAR(scopes,zeroReferenceBarometricPressure), EGVAR(scopes,zeroReferenceHumidity), _bc, _dragModel, _atmosphereModel];
|
2016-11-09 13:00:25 +00:00
|
|
|
(parseNumber _zeroAngle)
|
|
|
|
};
|
2024-01-07 23:13:46 +00:00
|
|
|
if (_useAmmoTemperatureInfluence) then {
|
2015-05-29 13:07:30 +00:00
|
|
|
{
|
2016-11-07 11:01:36 +00:00
|
|
|
private _mvShift = [_ammoConfig select 9, _x] call EFUNC(advanced_ballistics,calculateAmmoTemperatureVelocityShift);
|
|
|
|
private _mv = _muzzleVelocity + _mvShift;
|
2016-05-03 00:32:44 +00:00
|
|
|
|
2024-01-07 23:13:46 +00:00
|
|
|
[_scopeBaseAngle,_boreHeight,_airFriction,_mv,_x,EGVAR(scopes,zeroReferenceBarometricPressure),EGVAR(scopes,zeroReferenceHumidity),200,4,1,GVAR(rangeCardEndRange),_bc,_dragModel,_atmosphereModel,_transonicStabilityCoef,_forEachIndex,_isABenabled] call FUNC(calculateRangeCard);
|
2015-05-29 13:07:30 +00:00
|
|
|
} forEach [-15, -5, 5, 10, 15, 20, 25, 30, 35];
|
2016-05-03 00:32:44 +00:00
|
|
|
} else {
|
2024-01-07 23:13:46 +00:00
|
|
|
[_scopeBaseAngle,_boreHeight,_airFriction,_muzzleVelocity,15,EGVAR(scopes,zeroReferenceBarometricPressure),EGVAR(scopes,zeroReferenceHumidity),200,4,1,GVAR(rangeCardEndRange),_bc,_dragModel,_atmosphereModel,_transonicStabilityCoef,3,_isABenabled] call FUNC(calculateRangeCard);
|
2015-05-29 13:07:30 +00:00
|
|
|
};
|
2016-05-03 00:32:44 +00:00
|
|
|
|
2015-05-28 17:17:29 +00:00
|
|
|
for "_i" from 0 to 9 do {
|
|
|
|
GVAR(lastValidRow) pushBack count (GVAR(rangeCardDataElevation) select _i);
|
|
|
|
while {count (GVAR(rangeCardDataElevation) select _i) < 50} do {
|
2024-01-07 23:13:46 +00:00
|
|
|
if (_isABenabled) then {
|
2015-05-29 13:07:30 +00:00
|
|
|
(GVAR(rangeCardDataElevation) select _i) pushBack "###";
|
|
|
|
(GVAR(rangeCardDataWindage) select _i) pushBack "##";
|
|
|
|
(GVAR(rangeCardDataLead) select _i) pushBack "##";
|
|
|
|
} else {
|
|
|
|
(GVAR(rangeCardDataElevation) select _i) pushBack "";
|
|
|
|
(GVAR(rangeCardDataWindage) select _i) pushBack "";
|
|
|
|
(GVAR(rangeCardDataLead) select _i) pushBack "";
|
|
|
|
};
|
2015-05-28 17:17:29 +00:00
|
|
|
};
|
|
|
|
};
|
2016-05-03 00:32:44 +00:00
|
|
|
|
2024-01-07 23:13:46 +00:00
|
|
|
missionNamespace setVariable [format [QGVAR(%1_%2_%3_%4_%5_%6_%7), _zeroRange, _boreHeight, _ammoClass, _weaponClass, _isABenabled, _useBarrelLengthInfluence, _useAmmoTemperatureInfluence], [GVAR(rangeCardDataElevation), GVAR(rangeCardDataWindage), GVAR(rangeCardDataLead), GVAR(rangeCardDataMVs), GVAR(lastValidRow)]];
|
2015-05-28 17:17:29 +00:00
|
|
|
} else {
|
|
|
|
GVAR(rangeCardDataElevation) = _cacheEntry select 0;
|
|
|
|
GVAR(rangeCardDataWindage) = _cacheEntry select 1;
|
|
|
|
GVAR(rangeCardDataLead) = _cacheEntry select 2;
|
|
|
|
GVAR(rangeCardDataMVs) = _cacheEntry select 3;
|
|
|
|
GVAR(lastValidRow) = _cacheEntry select 4;
|
|
|
|
};
|
|
|
|
|
|
|
|
lnbAddRow [770200, GVAR(rangeCardDataMVs)];
|
|
|
|
|
2015-05-28 18:13:22 +00:00
|
|
|
for "_column" from 0 to 8 do {
|
|
|
|
for "_row" from 0 to 49 do {
|
2017-10-10 14:39:59 +00:00
|
|
|
private _control = (__dsp displayCtrl (90000 + _column * 100 + _row));
|
2015-05-28 18:13:22 +00:00
|
|
|
_control ctrlSetText ((GVAR(rangeCardDataElevation) select _column) select _row);
|
2015-05-29 17:39:54 +00:00
|
|
|
if (_row >= (GVAR(lastValidRow) select _column)) then {
|
|
|
|
_control ctrlSetTextColor [0, 0, 0, 0.6];
|
|
|
|
} else {
|
|
|
|
_control ctrlSetTextColor [0, 0, 0, 1.0];
|
|
|
|
};
|
2015-05-28 18:13:22 +00:00
|
|
|
_control ctrlCommit 0;
|
|
|
|
};
|
2015-05-28 17:17:29 +00:00
|
|
|
};
|
|
|
|
{
|
2015-05-28 18:13:22 +00:00
|
|
|
for "_row" from 0 to 49 do {
|
2017-10-10 14:39:59 +00:00
|
|
|
private _control = (__dsp displayCtrl (90000 + (9 + _forEachIndex) * 100 + _row));
|
2015-05-28 18:13:22 +00:00
|
|
|
_control ctrlSetText ((GVAR(rangeCardDataWindage) select _x) select _row);
|
2015-05-29 17:39:54 +00:00
|
|
|
if (_row >= (GVAR(lastValidRow) select _x)) then {
|
|
|
|
_control ctrlSetTextColor [0, 0, 0, 0.6];
|
|
|
|
} else {
|
|
|
|
_control ctrlSetTextColor [0, 0, 0, 1.0];
|
|
|
|
};
|
2015-05-28 18:13:22 +00:00
|
|
|
_control ctrlCommit 0;
|
|
|
|
};
|
|
|
|
} forEach [0, 3, 8];
|
2015-05-28 17:17:29 +00:00
|
|
|
|
|
|
|
{
|
2015-05-28 18:13:22 +00:00
|
|
|
for "_row" from 0 to 49 do {
|
2017-10-10 14:39:59 +00:00
|
|
|
private _control = (__dsp displayCtrl (90000 + (12 + _forEachIndex) * 100 + _row));
|
2015-05-28 18:13:22 +00:00
|
|
|
_control ctrlSetText ((GVAR(rangeCardDataLead) select _x) select _row);
|
2015-05-29 17:39:54 +00:00
|
|
|
if (_row >= (GVAR(lastValidRow) select _x)) then {
|
|
|
|
_control ctrlSetTextColor [0, 0, 0, 0.6];
|
|
|
|
} else {
|
|
|
|
_control ctrlSetTextColor [0, 0, 0, 1.0];
|
|
|
|
};
|
2015-05-28 18:13:22 +00:00
|
|
|
_control ctrlCommit 0;
|
2015-05-28 17:17:29 +00:00
|
|
|
};
|
2015-05-28 18:13:22 +00:00
|
|
|
} forEach [0, 3, 8];
|
2015-05-29 13:07:30 +00:00
|
|
|
|
2017-09-26 14:51:48 +00:00
|
|
|
ctrlSetText [770020, "For best results keep ammunition at ambient air temperature. Tables calculated for the above listed barrel"];
|
|
|
|
ctrlSetText [770021, format["and load with optic mounted %1'' above line of bore.", round((_boreHeight / 2.54) * 10) / 10]];
|