mirror of
https://github.com/acemod/ACE3.git
synced 2024-08-30 18:23:18 +00:00
5ad8b3c6bc
* Fix incorrect muzzle velocity displayed on magazine * Apply suggestions from code review Co-Authored-By: dedmen <dedmen@users.noreply.github.com> * Remove garbage file * Script header updates * Update addons/ballistics/functions/fnc_statTextStatement_magazineMuzzleVelocity.sqf Co-Authored-By: dedmen <dedmen@users.noreply.github.com>
70 lines
3.6 KiB
C++
70 lines
3.6 KiB
C++
class EGVAR(arsenal,stats) {
|
|
class statBase;
|
|
class ACE_barrelTwist: statBase {
|
|
scope = 2;
|
|
priority = 1;
|
|
stats[] = {"ACE_barrelTwist"};
|
|
displayName= CSTRING(statBarrelTwist);
|
|
showText = 1;
|
|
textStatement = QUOTE(params [ARR_2('_stat', '_config')]; private _barrelTwist = getNumber (_config >> _stat select 0); format [ARR_3('%1mm (%2in)',_barrelTwist toFixed 0, (_barrelTwist / 25.4) toFixed 1)]);
|
|
tabs[] = {{0,1}, {}};
|
|
};
|
|
class ACE_barrelLength: statBase {
|
|
scope = 2;
|
|
priority = 0;
|
|
stats[] = {"ACE_barrelLength"};
|
|
displayName = CSTRING(statBarrelLength);
|
|
showText = 1;
|
|
textStatement = QUOTE(params [ARR_2('_stat', '_config')]; private _barrelLength = getNumber (_config >> _stat select 0); format [ARR_3('%1mm (%2in)',_barrelLength toFixed 0, (_barrelLength / 25.4) toFixed 1)]);
|
|
tabs[] = {{0,1}, {}};
|
|
};
|
|
class ACE_ammo: statBase {
|
|
scope = 2;
|
|
priority = 5;
|
|
stats[] = {"ammo", "displayName"};
|
|
displayName = "$STR_dn_ammo";
|
|
showText = 1;
|
|
textStatement = QUOTE(params [ARR_2('_stat', '_config')]; private _ammoDisplayName = getText (configFile >> 'CfgAmmo' >> (getText (_config >> 'ammo')) >> _stat select 1); [ARR_2(_ammoDisplayName, getText (_config >> _stat select 0))] select (_ammoDisplayName == ''));
|
|
tabs[] = {{}, {4}};
|
|
};
|
|
class ACE_ballisticCoef: statBase {
|
|
scope = 2;
|
|
priority = 4;
|
|
stats[] = {"ACE_dragModel","ACE_ballisticCoefficients", "ACE_standardAtmosphere"};
|
|
displayName= CSTRING(statBallisticCoef);
|
|
showText= 1;
|
|
textStatement = QUOTE(params[ARR_2('_stat', '_config')]; private _ammoCfg = (configFile >> 'CfgAmmo' >> (getText (_config >> 'ammo'))); private _ballisticCoef = getArray (_ammoCfg >> _stat select 1); _ballisticCoef sort false; format [ARR_4('%1 G%2 (%3)', _ballisticCoef select 0 ,getNumber (_ammoCfg >> _stat select 0), getText (_ammoCfg >> _stat select 2))]);
|
|
condition = QUOTE(params[ARR_2('_stat', '_config')]; private _ammoCfg = (configFile >> 'CfgAmmo' >> (getText (_config >> 'ammo'))); !(getArray (_ammoCfg >> _stat select 1) isEqualTo []));
|
|
tabs[] ={{}, {4}};
|
|
};
|
|
class ACE_bulletMass: statBase {
|
|
scope = 2;
|
|
priority = 3;
|
|
stats[] = {"ACE_bulletMass"};
|
|
displayName = CSTRING(statBulletMass);
|
|
showText = 1;
|
|
textStatement = QUOTE(params[ARR_2('_stat', '_config')]; private _ammoWeight = getNumber (configFile >> 'CfgAmmo' >> (getText (_config >> 'ammo')) >> _stat select 0); format [ARR_3('%1g (%2gr)', _ammoWeight toFixed 1, (_ammoWeight * 15.43) toFixed 1)]);
|
|
condition = QUOTE(params[ARR_2('_stat', '_config')]; getNumber (configFile >> 'CfgAmmo' >> (getText (_config >> 'ammo')) >> _stat select 0) > 0);
|
|
tabs[] = {{}, {4}};
|
|
};
|
|
class ACE_magMuzzleVelocity: statBase {
|
|
scope = 2;
|
|
priority = 3;
|
|
stats[] = {"initSpeed"};
|
|
displayName= CSTRING(statMuzzleVelocity);
|
|
showText= 1;
|
|
textStatement = QUOTE([ARR_2(_this select 0, _this select 1)] call FUNC(statTextStatement_magazineMuzzleVelocity));
|
|
condition = QUOTE(getNumber (_this select 1 >> (_this select 0) select 0) > 0);
|
|
tabs[] = {{}, {4}};
|
|
};
|
|
class ACE_weaponMuzzleVelocity: statBase {
|
|
scope = 2;
|
|
priority = 3;
|
|
stats[] = {"initSpeed"};
|
|
displayName= CSTRING(statMuzzleVelocity);
|
|
showText = 1;
|
|
textStatement = QUOTE([ARR_2(_this select 0, _this select 1)] call FUNC(statTextStatement_weaponMuzzleVelocity));
|
|
tabs[] = {{0,1}, {}};
|
|
};
|
|
};
|