-
Notifications
You must be signed in to change notification settings - Fork 739
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
ATragMX - Utilize 'C1 vs. Distance' data in the range card output
- Loading branch information
Showing
4 changed files
with
59 additions
and
31 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
51 changes: 51 additions & 0 deletions
51
addons/atragmx/functions/fnc_lookup_c1_ballistic_coefficient.sqf
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,51 @@ | ||
/* | ||
* Author: Ruthberg | ||
* Lookup the correct C1 ballistic coefficient in the c1 ballistic coefficient vs. distance interpolation table | ||
* | ||
* Arguments: | ||
* Target Range <NUMBER> | ||
* | ||
* Return Value: | ||
* C1 ballistic coefficient <NUMBER | ||
* | ||
* Example: | ||
* call ace_atragmx_fnc_lookup_c1_ballistic_coefficient | ||
* | ||
* Public: No | ||
*/ | ||
#include "script_component.hpp" | ||
|
||
params ["_targetRange"]; | ||
|
||
private _lookupTable = []; | ||
{ | ||
if ((_x select 1) > 0) then { | ||
_lookupTable pushBack _x; | ||
}; | ||
} forEach (GVAR(workingMemory) select 19); | ||
|
||
private _lookupTableSize = count _lookupTable; | ||
if (_lookupTableSize < 2) exitWith { (GVAR(workingMemory) select 15) }; | ||
_lookupTable sort true; | ||
|
||
private _lowerIndex = -1; | ||
private _upperIndex = -1; | ||
|
||
for "_index" from 1 to (_lookupTableSize - 1) do { | ||
_upperIndex = _index; | ||
_lowerIndex = _upperIndex - 1; | ||
if (((_lookupTable select _index) select 0) >= _targetRange) exitWith { (GVAR(workingMemory) select 15) }; | ||
}; | ||
|
||
private _lowerDistance = (_lookupTable select _lowerIndex) select 0; | ||
private _upperDistance = (_lookupTable select _upperIndex) select 0; | ||
private _lowerC1 = (_lookupTable select _lowerIndex) select 1; | ||
private _upperC1 = (_lookupTable select _upperIndex) select 1; | ||
private _c1 = _lowerC1; | ||
if (_lowerDistance != _upperDistance) then { | ||
private _slope = (_upperC1 - _lowerC1) / (_upperDistance - _lowerDistance); | ||
_c1 = _lowerC1 + (_targetRange - _lowerDistance) * _slope; | ||
}; | ||
_c1 = 0.1 max _c1 min 2.0; | ||
|
||
_c1 |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters