mirror of
https://github.com/acemod/ACE3.git
synced 2024-08-30 18:23:18 +00:00
Merge branch 'master' into release-3.11.0
This commit is contained in:
commit
81e4740b60
@ -139,7 +139,7 @@ while {_TOF < 15 && (_bulletPos select 1) < _targetRange} do {
|
|||||||
_windage1 = - atan(_tx / _trueRange);
|
_windage1 = - atan(_tx / _trueRange);
|
||||||
_windDrift = (_wind2 select 0) * (_TOF - _trueRange / _muzzleVelocity);
|
_windDrift = (_wind2 select 0) * (_TOF - _trueRange / _muzzleVelocity);
|
||||||
_windage2 = - atan(_windDrift / _trueRange);
|
_windage2 = - atan(_windDrift / _trueRange);
|
||||||
_lead = (_targetSpeed * _TOF) / (Tan(3.38 / 60) * _trueRange);
|
_lead = (_targetSpeed * _TOF) / (Tan(MRAD_TO_DEG(1)) * _trueRange);
|
||||||
};
|
};
|
||||||
_kineticEnergy = 0.5 * (_bulletMass / 1000 * (_bulletSpeed ^ 2));
|
_kineticEnergy = 0.5 * (_bulletMass / 1000 * (_bulletSpeed ^ 2));
|
||||||
_kineticEnergy = _kineticEnergy * 0.737562149;
|
_kineticEnergy = _kineticEnergy * 0.737562149;
|
||||||
@ -174,7 +174,7 @@ if (_targetRange != 0) then {
|
|||||||
_windage1 = - atan(_tx / _targetRange);
|
_windage1 = - atan(_tx / _targetRange);
|
||||||
_windDrift = (_wind2 select 0) * (_TOF - _targetRange / _muzzleVelocity);
|
_windDrift = (_wind2 select 0) * (_TOF - _targetRange / _muzzleVelocity);
|
||||||
_windage2 = - atan(_windDrift / _targetRange);
|
_windage2 = - atan(_windDrift / _targetRange);
|
||||||
_lead = (_targetSpeed * _TOF) / (Tan(3.38 / 60) * _targetRange);
|
_lead = (_targetSpeed * _TOF) / (Tan(MRAD_TO_DEG(1)) * _targetRange);
|
||||||
};
|
};
|
||||||
|
|
||||||
_kineticEnergy = 0.5 * (_bulletMass / 1000 * (_bulletSpeed ^ 2));
|
_kineticEnergy = 0.5 * (_bulletMass / 1000 * (_bulletSpeed ^ 2));
|
||||||
|
@ -46,8 +46,8 @@ if (_parseInput) then {
|
|||||||
};
|
};
|
||||||
switch (_dropUnit) do {
|
switch (_dropUnit) do {
|
||||||
case 0: {
|
case 0: {
|
||||||
_transonicDrop = _transonicDrop * 3.38;
|
_transonicDrop = MRAD_TO_MOA(_transonicDrop);
|
||||||
_subsonicDrop = _subsonicDrop * 3.38;
|
_subsonicDrop = MRAD_TO_MOA(_subsonicDrop);
|
||||||
};
|
};
|
||||||
case 2: {
|
case 2: {
|
||||||
_transonicDrop = _transonicDrop / 1.047;
|
_transonicDrop = _transonicDrop / 1.047;
|
||||||
|
@ -47,7 +47,7 @@ if (_resetGunList) then {
|
|||||||
["9.3×64mm" , 862, 100, 0.0627652, -0.00110727, 3.81, 0, 2, 10, 120, 0, 0, 14.90, 9.30, 35.56, 0.368, 1, "ASM" , [[-15,843],[0,850],[10,857],[15,862],[25,876],[30,885],[35,896]] , [[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]], true],
|
["9.3×64mm" , 862, 100, 0.0627652, -0.00110727, 3.81, 0, 2, 10, 120, 0, 0, 14.90, 9.30, 35.56, 0.368, 1, "ASM" , [[-15,843],[0,850],[10,857],[15,862],[25,876],[30,885],[35,896]] , [[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]], true],
|
||||||
|
|
||||||
[".338LM 250gr" , 872, 100, 0.0604821, -0.00060841, 3.81, 0, 2, 10, 120, 0, 0, 16.20, 8.58, 25.40, 0.645, 1, "ICAO", [[-15,853],[0,860],[10,867],[15,872],[25,886],[30,895],[35,906]] , [[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]], true],
|
[".338LM 250gr" , 872, 100, 0.0604821, -0.00060841, 3.81, 0, 2, 10, 120, 0, 0, 16.20, 8.58, 25.40, 0.645, 1, "ICAO", [[-15,853],[0,860],[10,867],[15,872],[25,886],[30,895],[35,906]] , [[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]], true],
|
||||||
[".338LM 300gr" , 792, 100, 0.0685883, -0.00053585, 3.81, 0, 2, 10, 120, 0, 0, 19.44, 8.58, 25.40, 0.759, 1, "ICAO", [[-15,773],[0,780],[10,787],[15,792],[25,806],[30,815],[35,826]] , [[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]], true],
|
[".338LM 300gr" , 792, 100, 0.0685883, -0.00055706, 3.81, 0, 2, 10, 120, 0, 0, 19.44, 8.58, 25.40, 0.759, 1, "ICAO", [[-15,773],[0,780],[10,787],[15,792],[25,806],[30,815],[35,826]] , [[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]], true],
|
||||||
[".338LM API526" , 872, 100, 0.0602535, -0.00069220, 3.81, 0, 2, 10, 120, 0, 0, 16.39, 8.58, 25.40, 0.580, 1, "ICAO", [[-15,853],[0,860],[10,867],[15,872],[25,886],[30,895],[35,906]] , [[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]], true],
|
[".338LM API526" , 872, 100, 0.0602535, -0.00069220, 3.81, 0, 2, 10, 120, 0, 0, 16.39, 8.58, 25.40, 0.580, 1, "ICAO", [[-15,853],[0,860],[10,867],[15,872],[25,886],[30,895],[35,906]] , [[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]], true],
|
||||||
|
|
||||||
[".300WM Mk248 Mod0" , 857, 100, 0.0621425, -0.00072468, 3.81, 0, 2, 10, 120, 0, 0, 12.31, 7.80, 25.40, 0.537, 1, "ICAO", [[-15,838],[0,845],[10,852],[15,857],[25,871],[30,880],[35,891]] , [[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]], true],
|
[".300WM Mk248 Mod0" , 857, 100, 0.0621425, -0.00072468, 3.81, 0, 2, 10, 120, 0, 0, 12.31, 7.80, 25.40, 0.537, 1, "ICAO", [[-15,838],[0,845],[10,852],[15,857],[25,871],[30,880],[35,891]] , [[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]], true],
|
||||||
|
@ -45,9 +45,9 @@ private _speedOfSound = GVAR(temperature) call EFUNC(weather,calculateSpeedOfSou
|
|||||||
|
|
||||||
switch (GVAR(currentScopeUnit)) do {
|
switch (GVAR(currentScopeUnit)) do {
|
||||||
case 0: {
|
case 0: {
|
||||||
_elevation = _elevation / 3.38;
|
_elevation = MRAD_TO_MOA(_elevation);
|
||||||
_windage1 = _windage1 / 3.38;
|
_windage1 = MRAD_TO_MOA(_windage1);
|
||||||
_windage2 = _windage2 / 3.38;
|
_windage2 = MRAD_TO_MOA(_windage2);
|
||||||
};
|
};
|
||||||
case 2: {
|
case 2: {
|
||||||
_elevation = _elevation * 1.047;
|
_elevation = _elevation * 1.047;
|
||||||
@ -55,7 +55,7 @@ private _speedOfSound = GVAR(temperature) call EFUNC(weather,calculateSpeedOfSou
|
|||||||
_windage2 = _windage2 * 1.047;
|
_windage2 = _windage2 * 1.047;
|
||||||
};
|
};
|
||||||
case 3: {
|
case 3: {
|
||||||
private _clickSize = [1, 1 / 1.047, 3.38] select (GVAR(workingMemory) select 7);
|
private _clickSize = [1, 1 / 1.047, MOA_TO_MRAD(1)] select (GVAR(workingMemory) select 7);
|
||||||
private _clickNumber = GVAR(workingMemory) select 8;
|
private _clickNumber = GVAR(workingMemory) select 8;
|
||||||
private _clickInterval = _clickSize / _clickNumber;
|
private _clickInterval = _clickSize / _clickNumber;
|
||||||
|
|
||||||
|
@ -41,16 +41,16 @@ private _lead = GVAR(leadOutput) select GVAR(currentTarget);
|
|||||||
|
|
||||||
switch (GVAR(currentScopeUnit)) do {
|
switch (GVAR(currentScopeUnit)) do {
|
||||||
case 0: {
|
case 0: {
|
||||||
_elevationAbs = _elevationAbs / 3.38;
|
_elevationAbs = MRAD_TO_MOA(_elevationAbs);
|
||||||
_windageAbs = _windageAbs / 3.38;
|
_windageAbs = MRAD_TO_MOA(_windageAbs);
|
||||||
|
|
||||||
_wind2 = _wind2 / 3.38;
|
_wind2 = MRAD_TO_MOA(_wind2);
|
||||||
|
|
||||||
_elevationRel = _elevationRel / 3.38;
|
_elevationRel = MRAD_TO_MOA(_elevationRel);
|
||||||
_windageRel = _windageRel / 3.38;
|
_windageRel = MRAD_TO_MOA(_windageRel);
|
||||||
|
|
||||||
_elevationCur = _elevationCur / 3.38;
|
_elevationCur = MRAD_TO_MOA(_elevationCur);
|
||||||
_windageCur = _windageCur / 3.38;
|
_windageCur = MRAD_TO_MOA(_windageCur);
|
||||||
};
|
};
|
||||||
case 2: {
|
case 2: {
|
||||||
_elevationAbs = _elevationAbs * 1.047;
|
_elevationAbs = _elevationAbs * 1.047;
|
||||||
@ -65,7 +65,7 @@ switch (GVAR(currentScopeUnit)) do {
|
|||||||
_windageCur = _windageCur * 1.047;
|
_windageCur = _windageCur * 1.047;
|
||||||
};
|
};
|
||||||
case 3: {
|
case 3: {
|
||||||
private _clickSize = [1, 1 / 1.047, 3.38] select (GVAR(workingMemory) select 7);
|
private _clickSize = [1, 1 / 1.047, MOA_TO_MRAD(1)] select (GVAR(workingMemory) select 7);
|
||||||
private _clickNumber = GVAR(workingMemory) select 8;
|
private _clickNumber = GVAR(workingMemory) select 8;
|
||||||
private _clickInterval = _clickSize / _clickNumber;
|
private _clickInterval = _clickSize / _clickNumber;
|
||||||
|
|
||||||
|
@ -42,9 +42,9 @@ private _dropData = +GVAR(truingDropDropData);
|
|||||||
|
|
||||||
switch (_dropUnit) do {
|
switch (_dropUnit) do {
|
||||||
case 0: {
|
case 0: {
|
||||||
_dropData set [0, (_dropData select 0) / 3.38];
|
_dropData set [0, MRAD_TO_MOA(_dropData select 0)];
|
||||||
_dropData set [1, (_dropData select 1) / 3.38];
|
_dropData set [1, MRAD_TO_MOA(_dropData select 1)];
|
||||||
_dropData set [2, (_dropData select 2) / 3.38];
|
_dropData set [2, MRAD_TO_MOA(_dropData select 2)];
|
||||||
};
|
};
|
||||||
case 2: {
|
case 2: {
|
||||||
_dropData set [0, (_dropData select 0) * 1.047];
|
_dropData set [0, (_dropData select 0) * 1.047];
|
||||||
|
@ -16,4 +16,11 @@
|
|||||||
|
|
||||||
#include "\z\ace\addons\main\script_macros.hpp"
|
#include "\z\ace\addons\main\script_macros.hpp"
|
||||||
|
|
||||||
|
#define MOA_TO_MRAD(d) (d * 3.43774677) // Conversion factor: 54 / (5 * PI)
|
||||||
|
#define MRAD_TO_MOA(d) (d * 0.29088821) // Conversion factor: (5 * PI) / 54
|
||||||
|
#define DEG_TO_MOA(d) (d * 60) // Conversion factor: 60
|
||||||
|
#define MOA_TO_DEG(d) (d / 60) // Conversion factor: 1 / 60
|
||||||
|
#define DEG_TO_MRAD(d) (d * 17.45329252) // Conversion factor: (50 * PI) / 9
|
||||||
|
#define MRAD_TO_DEG(d) (d / 17.45329252) // Conversion factor: 9 / (50 * PI)
|
||||||
|
|
||||||
#define ATRAGMX_PROFILE_NAMESPACE_VERSION 2.1
|
#define ATRAGMX_PROFILE_NAMESPACE_VERSION 2.1
|
||||||
|
@ -445,7 +445,7 @@ class CfgAmmo {
|
|||||||
};
|
};
|
||||||
class ACE_338_Ball : B_338_Ball {
|
class ACE_338_Ball : B_338_Ball {
|
||||||
timeToLive=10;
|
timeToLive=10;
|
||||||
airFriction=-0.00053585;
|
airFriction=-0.00055706;
|
||||||
typicalSpeed=826;
|
typicalSpeed=826;
|
||||||
ACE_caliber=8.585;
|
ACE_caliber=8.585;
|
||||||
ACE_bulletLength=43.18;
|
ACE_bulletLength=43.18;
|
||||||
|
@ -122,17 +122,17 @@ while {_TOF < 6 && (_bulletPos select 1) < _targetRange} do {
|
|||||||
_tz = (_lastBulletPos select 2) + (_range - (_lastBulletPos select 1)) * ((_bulletPos select 2) - (_lastBulletPos select 2)) / ((_bulletPos select 1) - (_lastBulletPos select 1));
|
_tz = (_lastBulletPos select 2) + (_range - (_lastBulletPos select 1)) * ((_bulletPos select 2) - (_lastBulletPos select 2)) / ((_bulletPos select 1) - (_lastBulletPos select 1));
|
||||||
_elevation = - atan(_tz / _range);
|
_elevation = - atan(_tz / _range);
|
||||||
_windage = - atan(_tx / _range);
|
_windage = - atan(_tx / _range);
|
||||||
_lead = (_targetSpeed * _TOF) / (Tan(3.38 / 60) * _range);
|
_lead = (_targetSpeed * _TOF) / (Tan(MRAD_TO_DEG(1)) * _range);
|
||||||
};
|
};
|
||||||
|
|
||||||
private _elevationString = Str(round(-_elevation * 60 / 3.38 * 10) / 10);
|
private _elevationString = Str(round(-DEG_TO_MRAD(_elevation) * 10) / 10);
|
||||||
if (_elevationString == "0") then {
|
if (_elevationString == "0") then {
|
||||||
_elevationString = "-0.0";
|
_elevationString = "-0.0";
|
||||||
};
|
};
|
||||||
if (_elevationString find "." == -1) then {
|
if (_elevationString find "." == -1) then {
|
||||||
_elevationString = _elevationString + ".0";
|
_elevationString = _elevationString + ".0";
|
||||||
};
|
};
|
||||||
private _windageString = Str(round(_windage * 60 / 3.38 * 10) / 10);
|
private _windageString = Str(round(DEG_TO_MRAD(_windage) * 10) / 10);
|
||||||
if (_windageString find "." == -1) then {
|
if (_windageString find "." == -1) then {
|
||||||
_windageString = _windageString + ".0";
|
_windageString = _windageString + ".0";
|
||||||
};
|
};
|
||||||
|
@ -15,3 +15,10 @@
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
#include "\z\ace\addons\main\script_macros.hpp"
|
#include "\z\ace\addons\main\script_macros.hpp"
|
||||||
|
|
||||||
|
#define MOA_TO_MRAD(d) (d * 3.43774677) // Conversion factor: 54 / (5 * PI)
|
||||||
|
#define MRAD_TO_MOA(d) (d * 0.29088821) // Conversion factor: (5 * PI) / 54
|
||||||
|
#define DEG_TO_MOA(d) (d * 60) // Conversion factor: 60
|
||||||
|
#define MOA_TO_DEG(d) (d / 60) // Conversion factor: 1 / 60
|
||||||
|
#define DEG_TO_MRAD(d) (d * 17.45329252) // Conversion factor: (50 * PI) / 9
|
||||||
|
#define MRAD_TO_DEG(d) (d / 17.45329252) // Conversion factor: 9 / (50 * PI)
|
||||||
|
@ -505,7 +505,7 @@ class CfgAmmo
|
|||||||
ACE_bulletLength=43.18;
|
ACE_bulletLength=43.18;
|
||||||
ACE_bulletMass=19.44;
|
ACE_bulletMass=19.44;
|
||||||
ACE_ammoTempMuzzleVelocityShifts[]={-26.55, -25.47, -22.85, -20.12, -16.98, -12.80, -7.64, -1.53, 5.96, 15.17, 26.19};
|
ACE_ammoTempMuzzleVelocityShifts[]={-26.55, -25.47, -22.85, -20.12, -16.98, -12.80, -7.64, -1.53, 5.96, 15.17, 26.19};
|
||||||
ACE_ballisticCoefficients[]={0.381};
|
ACE_ballisticCoefficients[]={0.368};
|
||||||
ACE_velocityBoundaries[]={};
|
ACE_velocityBoundaries[]={};
|
||||||
ACE_standardAtmosphere="ICAO";
|
ACE_standardAtmosphere="ICAO";
|
||||||
ACE_dragModel=7;
|
ACE_dragModel=7;
|
||||||
|
@ -250,10 +250,10 @@ Optimal airFriction: 0.00053639
|
|||||||
Ammo Class: ACE_338_Ball
|
Ammo Class: ACE_338_Ball
|
||||||
MaxRanges (m): [1200, 1300]
|
MaxRanges (m): [1200, 1300]
|
||||||
MuzzleVelocities (m/s): [800, 830]
|
MuzzleVelocities (m/s): [800, 830]
|
||||||
Max. Velocity diff (m/s): 24.93
|
Max. Velocity diff (m/s): 26.22
|
||||||
Max. Drop diff (cm): 10.92
|
Max. Drop diff (cm): 12.14
|
||||||
Max. Tof diff (ms): 27.0
|
Max. Tof diff (ms): 29.5
|
||||||
Optimal airFriction: 0.00053585
|
Optimal airFriction: 0.00055706
|
||||||
##########################################
|
##########################################
|
||||||
Ammo Class: ACE_338_Ball_API526
|
Ammo Class: ACE_338_Ball_API526
|
||||||
MaxRanges (m): [1200, 1300]
|
MaxRanges (m): [1200, 1300]
|
||||||
|
@ -492,7 +492,7 @@ ammoList = [["B_556x45_Ball", [300, 500, 500], [750, 870, 910], 7, 0.151],
|
|||||||
["ACE_106x83mm_Ball", [1500, 1500], [955, 965], 1, 0.72],
|
["ACE_106x83mm_Ball", [1500, 1500], [955, 965], 1, 0.72],
|
||||||
["B_338_Ball", [1100, 1300], [880, 925], 7, 0.322],
|
["B_338_Ball", [1100, 1300], [880, 925], 7, 0.322],
|
||||||
["B_338_NM_Ball", [1100, 1300], [790, 820], 7, 0.381],
|
["B_338_NM_Ball", [1100, 1300], [790, 820], 7, 0.381],
|
||||||
["ACE_338_Ball", [1200, 1300], [800, 830], 7, 0.381],
|
["ACE_338_Ball", [1200, 1300], [800, 830], 7, 0.368],
|
||||||
["ACE_338_Ball_API526", [1200, 1300], [880, 920], 7, 0.29],
|
["ACE_338_Ball_API526", [1200, 1300], [880, 920], 7, 0.29],
|
||||||
["B_50BW_Ball_F", [300, 400], [510, 596], 1, 0.21],
|
["B_50BW_Ball_F", [300, 400], [510, 596], 1, 0.21],
|
||||||
["B_127x99_Ball", [1300, 1300], [895, 905], 1, 0.67],
|
["B_127x99_Ball", [1300, 1300], [895, 905], 1, 0.67],
|
||||||
|
Loading…
Reference in New Issue
Block a user