2024-01-11 20:01:50 +00:00
|
|
|
#include "..\script_component.hpp"
|
2024-01-08 21:22:52 +00:00
|
|
|
/*
|
2024-01-10 06:16:46 +00:00
|
|
|
* Author: Jaynus, NouberNou, Lambda.Tiger
|
2024-02-16 03:03:29 +00:00
|
|
|
* This function returns fragmentation parameters for a specific ammo type.
|
2024-01-13 06:35:22 +00:00
|
|
|
*
|
2024-01-08 21:22:52 +00:00
|
|
|
* Arguments:
|
2024-02-16 03:03:29 +00:00
|
|
|
* 0: Ammo classname <STRING>
|
2024-01-13 06:35:22 +00:00
|
|
|
*
|
2024-01-08 21:22:52 +00:00
|
|
|
* Return Value:
|
|
|
|
* _ammoInfo <ARRAY>
|
2024-02-16 03:03:29 +00:00
|
|
|
* 0: Search range for fragments in meters <NUMBER>
|
|
|
|
* 1: Gurney equation calculated speed <NUMBER>
|
|
|
|
* 2: Array of fragment types <ARRAY>
|
2024-01-08 21:22:52 +00:00
|
|
|
*
|
|
|
|
* Example:
|
2024-03-29 00:33:56 +00:00
|
|
|
* "B_556x45_Ball" call ace_frag_fnc_getFragInfo
|
2024-01-08 21:22:52 +00:00
|
|
|
*
|
|
|
|
* Public: No
|
|
|
|
*/
|
|
|
|
|
|
|
|
params ["_ammo"];
|
|
|
|
|
|
|
|
private _ammoInfo = GVAR(fragInfoCache) get _ammo;
|
|
|
|
|
2024-01-13 06:35:22 +00:00
|
|
|
if (!isNil "_ammoInfo") exitWith {_ammoInfo};
|
2024-01-08 21:22:52 +00:00
|
|
|
|
2024-01-16 00:47:06 +00:00
|
|
|
private _ammoConfig = configFile >> "CfgAmmo" >> _ammo;
|
2024-07-17 06:53:40 +00:00
|
|
|
private _fragTypes = [
|
|
|
|
QGVAR(tiny), QGVAR(tiny), QGVAR(tiny),
|
|
|
|
QGVAR(tiny_HD), QGVAR(tiny_HD), QGVAR(tiny_HD),
|
|
|
|
QGVAR(small), QGVAR(small), QGVAR(small), QGVAR(small),
|
|
|
|
QGVAR(small_HD), QGVAR(small_HD), QGVAR(small_HD), QGVAR(small_HD),
|
|
|
|
QGVAR(medium_HD), QGVAR(medium_HD), QGVAR(medium_HD), QGVAR(medium_HD), QGVAR(medium_HD)
|
|
|
|
];
|
2024-02-16 03:03:29 +00:00
|
|
|
private _notifyMissingEntries = false;
|
2024-02-14 22:50:09 +00:00
|
|
|
if (isArray (_ammoConfig >> QGVAR(classes))) then {
|
|
|
|
_fragTypes = getArray (_ammoConfig >> QGVAR(classes));
|
2024-01-08 21:22:52 +00:00
|
|
|
} else {
|
2024-02-16 03:03:29 +00:00
|
|
|
_notifyMissingEntries = true;
|
2024-01-08 21:22:52 +00:00
|
|
|
};
|
|
|
|
|
2024-01-11 01:02:07 +00:00
|
|
|
/************ Gurney equation notes *****************//*
|
|
|
|
* see https://en.wikipedia.org/wiki/Gurney_equations
|
2024-01-13 06:35:22 +00:00
|
|
|
*
|
2024-02-16 03:03:29 +00:00
|
|
|
* gurney_k is the geometry constant added to _metalMass/_chargeMass
|
|
|
|
* gurney_c = sqrt(2E)
|
2024-01-11 01:02:07 +00:00
|
|
|
*
|
2024-01-15 19:42:45 +00:00
|
|
|
* _chargeMass = 185; - grams of comp-b
|
2024-01-15 20:39:41 +00:00
|
|
|
* _metalMass = 210; - grams of metal are accelerated by explosion
|
2024-01-15 19:42:45 +00:00
|
|
|
* _geometryCoefficient = 3/5; - spherical K factor
|
|
|
|
* _gurneyConstant = 2843; - Gurney constant of comp-b in /ms
|
2024-01-11 01:02:07 +00:00
|
|
|
*
|
2024-01-15 19:42:45 +00:00
|
|
|
* _chargeMass = 429; - grams of tritonal
|
2024-01-15 20:39:41 +00:00
|
|
|
* _metalMass = 496; - grams of metal are accelerated by explosion
|
2024-01-15 19:42:45 +00:00
|
|
|
* _geometryCoefficient = 1/2; - cylindrical K factor
|
|
|
|
* _gurneyConstant = 2320; - Gurney constant of tritonal in m/s
|
2024-01-11 01:02:07 +00:00
|
|
|
* Equation - 0.8 for empirical 80% speed
|
2024-01-15 19:42:45 +00:00
|
|
|
* 0.8 * (((_metalMass / _chargeMass) + _geometryCoefficient) ^ - (1 / 2)) * _gurneyConstant;
|
|
|
|
* or 0.8 * _gurneyConstant * sqrt (_chargeMass /(_metalMass + _chargeMass * _geometryCoefficient)); (slightly faster to compute)
|
2024-01-11 01:02:07 +00:00
|
|
|
*/
|
2024-01-08 21:22:52 +00:00
|
|
|
|
2024-03-01 18:51:21 +00:00
|
|
|
private _chargeMass = getNumber (_ammoConfig >> QGVAR(charge));
|
2024-01-16 00:47:06 +00:00
|
|
|
if (_chargeMass == 0) then {
|
|
|
|
_chargeMass = 1;
|
2024-02-16 03:03:29 +00:00
|
|
|
_notifyMissingEntries = true;
|
2024-01-16 00:47:06 +00:00
|
|
|
};
|
|
|
|
|
2024-03-01 18:51:21 +00:00
|
|
|
private _metalMass = getNumber (_ammoConfig >> QGVAR(metal));
|
2024-01-16 00:47:06 +00:00
|
|
|
if (_metalMass == 0) then {
|
|
|
|
_metalMass = 2;
|
2024-02-16 03:03:29 +00:00
|
|
|
_notifyMissingEntries = true;
|
2024-01-16 00:47:06 +00:00
|
|
|
};
|
|
|
|
|
2024-03-01 18:51:21 +00:00
|
|
|
private _geometryCoefficient = getNumber (_ammoConfig >> QGVAR(gurney_k));
|
2024-01-16 00:47:06 +00:00
|
|
|
if (_geometryCoefficient == 0) then {
|
2024-03-17 22:23:16 +00:00
|
|
|
_geometryCoefficient = 0.5;
|
2024-02-16 03:03:29 +00:00
|
|
|
_notifyMissingEntries = true;
|
2024-01-16 00:47:06 +00:00
|
|
|
};
|
|
|
|
|
2024-03-01 18:51:21 +00:00
|
|
|
private _gurneyConstant = getNumber (_ammoConfig >> QGVAR(gurney_c));
|
2024-01-16 00:47:06 +00:00
|
|
|
if (_gurneyConstant == 0) then {
|
|
|
|
_gurneyConstant = 2440;
|
2024-02-16 03:03:29 +00:00
|
|
|
_notifyMissingEntries = true;
|
2024-01-16 00:47:06 +00:00
|
|
|
};
|
|
|
|
|
2024-02-16 03:03:29 +00:00
|
|
|
if (_notifyMissingEntries) then {
|
2024-01-08 21:22:52 +00:00
|
|
|
INFO_1("Ammo class %1 lacks proper explosive properties definitions for frag!",_ammo);
|
|
|
|
};
|
|
|
|
|
2024-07-17 06:53:40 +00:00
|
|
|
private _indirectHitRange = getNumber(configFile >> "CfgAmmo" >> _shellType >> "indirecthitrange");
|
|
|
|
|
2024-01-11 01:02:07 +00:00
|
|
|
/********************** _ammoInfo format *************************//*
|
2024-07-19 00:19:43 +00:00
|
|
|
* 0: _fragRange - search range for fragments
|
2024-01-15 23:53:12 +00:00
|
|
|
* 1: _fragVelocity - gurney equation calculated velocity
|
2024-01-11 01:02:07 +00:00
|
|
|
* 2: _fragTypes - array of fragment types
|
|
|
|
*/
|
2024-01-08 21:22:52 +00:00
|
|
|
_ammoInfo = [
|
2024-07-17 06:53:40 +00:00
|
|
|
80 * _indirectHitRange,
|
2024-03-17 22:23:16 +00:00
|
|
|
ACE_FRAG_IMPERIC_VELOCITY_CONSTANT * _gurneyConstant * sqrt (_chargeMass / (_metalMass + _chargeMass * _geometryCoefficient)),
|
2024-07-17 06:53:40 +00:00
|
|
|
_fragTypes
|
2024-01-08 21:22:52 +00:00
|
|
|
];
|
|
|
|
|
|
|
|
GVAR(fragInfoCache) set [_ammo, _ammoInfo];
|
2024-01-15 19:42:45 +00:00
|
|
|
_ammoInfo
|