CfgAmmo Config Reference
Introduction
CfgAmmo, cfgMagazines, cfgWeapons and cfgVehicles are root classes defined in the engine's config.bin.
These classes can be subsequently added to by addons inherit in the game or provided by oem.
CfgAmmo defines the missile characterstics for ammunition held in a cfgMagazine which, in turn, is used by a cfgWeapon, which, in turn, is selected for use in a (series of) cfgVehicles. The same ammunition can be, and generally is, used by multiple magazines. The same magazine, can be, and generally is, used by multiple weapons. And so on.
The default value is shown in the legend.
Note that engines accept integer values where a float would normally be expected.
TokenNames marked ArmA were introduced from Xbox Elite and beyond.
Arma Enhancement
Arma introduced a new root class, cfgMagazines.
In contrast, OFP uses a rather tedious construct in it's cfgWeapons class to distinguish between weapon and magazine paramaters.
Regardless, there is no change in effect or construct or meaning to the cfgAmmo class in any engine.
Modifications
access=1;
- Ammunition classes can be added.
- Existing classes can (sometimes) be altered.
The default class for cfgAmmo specifies access=3; Almost all subsequent classes inherit this value, which means they cannot be altered in any way.
To allow YOUR addon to subsequently modify YOUR ammunition (should you wish to with other addons), you must change the access= in YOUR ammunition.
A
airFriction
ArmA
Float
Description: As implied, how much the air friction slows down the projectile. Negative values.
animated
audibleFire
Float
Description: How much can AI hear when given weapon is fired.
audibleFire=5.0;
airLock
Boolean
Description: Declares if ammo can lock on air targets. Also makes AI to decide whether to engage air units with the particular ammo.
C
canLock
Integer
Description: Declares if ammo is able to lock (necessary for airLock, irLock & laserLock)
Possible values:
- 0 = false
- 1 = cadet mode only
- 2 = always.
canLock=0;
cartridge
String
Description: Declares the path to the cartridge P3D model, which may be ejected on each shot. Like all model specifications, .p3d is inferred.
cartridge="FxCartridge[.p3d]";
cost
Integer
Description: Cost-gain evaluation is performed to choose an appropriate weapon. Gain includes self-preservation,
cost includes time required to complete the attack.
As a result, weapons with high cost are unlikely to be used again common targets, esp. when low cost weapons are available. Still, there may be situation where AI may decide to use high cost weapon, esp. when it thinks it has little chance of survival and needs to attempt destroying enemy quickly.
cost=5000;
CraterEffects
ArmA
String
Description: Declares which crater effect to spawn on hit on ground.
Possible values: BombCrater, ExploAmmoCrater, GrenadeCrater, ImpactEffectsBig, MissileCrater, ShellCrater
CraterEffects="ExploAmmoCrater";
D
deflecting
ArmA
Integer
Description: Declares if ammo is deflecting and thus deflection angle.
deflecting=10;
E
effectsFire
effectsMissile
effectsSmoke
explosionEffects
ArmA
String
Description: Declares which explosion effect to spawn on hit.
Possible values:
- BombExplosion
- ExploAmmoExplosion
- ExplosionEffects
- GrenadeExplosion
explosionTime
ArmA
Integer
Description: Declares after how many seconds ammo will explode (e.g. used on timed hand grenades).
explosionTime=5;
explosive
Float
Description: Declares if ammo is explosive, and if it is, how much (What part of the damage is done using explosion, the rest is assumed to be caused by kinetic impact, given as a ratio - 1 means fully explosive, 0 means fully kinetic)
F
fuseDistance
ArmA
Float
Description: The minimum distance any explosive projectile has to travel, before it becomes "armed" and thus explodes on impact. Missiles hitting below the given range still visually explode, causing no damage or shockwave effects. Grenades will stick into the ground for X amount of time and then disappear causing no damage, or (in case 'explosionTime=' is set) explode after X seconds, causing damage.
H
hit
Float
Description: Damage on hit. In OFP total damage is calculated as: Total damage = Hit damage - Indirect damage (while hit value bigger then Indirecthit)
hit=8;
HitEffects
class HitEffects { vehicle = "ImpactMetal"; object = "ImpactConcrete"; };
hit...[]
Description: All array values are defaulted to
hitBuilding[] = {"soundHit",1};
hitArmor[]
hitBuilding[]
hitConcrete[]
hitDefault[]
hitFoliage[]
hitGlass[]
hitGlassArmored[]
hitGround[]
ofp only
hitGroundHard[]
hitGroundSoft[]
hitIron[]
hitMan[]
hitMetal[]
hitMetalplate[]
hitPlastic[]
hitRubber[]
hitWood[]
I
indirectHit
Float
Description: Damage in indirectHitRange.
indirectHit=8;
indirectHitRange
Float
Description: Radius in metres where indirectHit damage is caused.
indirectHitRange=75;
initTime
Float
Description: How long (in seconds) the projectile waits before starting it's motor.
initTime=0.2;
irLock
Boolean
Description: Declares if ammo can lock on IR-targets.
L
laserLock
Boolean
Description: Declares if ammo can lock on laser designator.
lightColor[]
Array
Description: Declares color of light (e.g. on flares).
lightColor[]={1,1,1,0};
M
maneuvrability
Float
Description: Declares maneuvrability of guided missiles.
Higher values than 30-33 cause the Missile (when locked on) to spin wildly and rarely hit the target; tweaking sideairfriction and simulationstep makes the missile track and hit it's target, but esp. in Multiplayer from other Players fov, the missile will spin out of control, whilst from the shooters own pov, it will still fly straight and hit it's target.
manueuvrability=30;
manualControl
Boolean
Description: Declares if ammo can be controlled by the player during flight (?).
manualControl=0;
maxControlRange
Float
Description: Declares in which distance to player ammo can be controlled during flight.
Using this on handheld Launchers causes the Missile to 'time-out' after approximately 1.5km, loosing all control of the warhead, which causes the Missile to spin around/take off into random directions (until it self-destructs, 'timetolive'), making higher Values useless.
Using this on any VEHICLE mounted Launchers (like the TOW, Hellfire or Maverick) allows the warhead to track AND turn/follow it's target even if said target is behind the player vehicle (and possibly AI-controlled ones too), which requires a high maneuverability value on the missile. That way, one can simply lock on, then pass the locked Target and shoot a missile, which will follow the target even without direct line of sight. NOTE that the missile follows the target regardless of obstacles, init-time or initspeed, meaning the missile might crash into the ground, esp. at lower heights.
maxControlRange=5000;
maxSpeed
Float
Description: Declares the maximum speed (m/s).
maxSpeed=241;
model
String
Description: Declares path to model.
model="\ca\weapons\bullet[.p3d]"
min/MaxRange...
Description: These tokens are present in ofp only. They were badly classed in ofp, causing all weapons using this specific 'bullet' to exhibit this behaviour rather than the behaviour of the 'rifle'. As such they were transferred to ArmA's cfgWeapons.
Above statement is not (!!!!) true; EVEN IN ARMA 2 and OA, these values STILL exist AND affect the AI (AND ONLY THE AI!!!) in the following ways:
(The tokens are found/put on each weapons "firing modes", or on the gun itself, if it has no seperate firing modes)
minRange
Float
Description: Minimum engagement range for the AI. Below given values, the AI WON'T engage but just "stare them down", even if they get shot at, and -most likely- killed.
Minrange = 5;
minRangeProbab
Float
Description:Probability declaring how high the chance is that the AI will engage a target at "MINRANGE" using this (current) firing mode. Values are 0.0 - 1.0 [NO chance -> 100% chance].
minRangeProbab=0.02;
midRange
Float
Description: Mid-Range engagement range for AI's using this (current) firing mode.
midRange=150;
midRangeProbab
Float
Description:Probability declaring how high the chance is that the AI will engage a target at "MIDRANGE". Values 0.0 - 1.0
midRangeProbab=0.7;
maxRange
Float
Description:MAXIMUM range possible for the AI. Although AI's MAY engage targets slightly beyond MAXRANGE, this is how far the AI will try to shoot at targets.
maxRange=500;
maxRangeProbab
Float
Description:How high the chance is that the AI will engage targets at MAXRANGE or slightly below. Targets definetly beyond MAXRANGE are ignored. 0.0 - 1.0
maxRangeProbab=0.51;
P
proxyShape
String
Description: Declares the model of this weapon used in proxies on vehicles. Note that proxies can be used only with air units.
proxyShape="\ca\air\sidewinder_proxy";
S
sideAirFriction
Float
Description: Adjusts the drag of a projectile. Lower values decrease drag, higher values increase drag. When used with guided projectiles, higher values make it easier for the projectile to turn while lower values make it more difficult to turn.
sideAirFriction=0.5;
simulation
String
Description: Declares simulation type.
Also affects the behavior the projectile causes to the shooter/object hit;
changing "shotShell" to "shotBullet" makes a tank shell pass through more trees rather than being stopped by them, and also removes the recoil which usually affects the tank/vehicle the cannon is mounted to. Changing "shotBullet" to "shotSpread" (OA only) causes the changed ammo to behave like it is buckshot (again, OA only).
Possible values: refer to Models & Classnames: Simulation Types for a list of all supported simulation types.
simulation="shotShell";
simulationStep
Float
Description: ?
shadow
sound...[]
soundFly[]
soundEngine[]
soundHit[]
supersonicCrackNear[]
ArmA
Array
Description: Declares sound and volume of the supersonic crack (near the player). Supersonic crack will only occur if ammo is flying with supersonic speed.
supersonicCrackNear[]={"\ca\Weapons\Data\Sound\supersonic_crack_close.wss",1,1};
supersonicCrackFar[]
ArmA
Array
Description: Declares sound and volume of the supersonic crack (far). Supersonic crack will only occur if ammo is flying with supersonic speed.
supersonicCrackFar[]={"\ca\Weapons\Data\Sound\supersonic_crack_50meters.wss",1,1};
T
thrust
Float
Description: Engine power for missiles and rockets.
thrustTime
Float
Description: Engine burn time for missiles and rockets.
thrustTime=0.200000;
timeToLive
ArmAInteger
Description: Time before the ammo vanishes, used as optimization to avoid having to simulate stray bullets. Note that this parameter has no effect in OFP where timeToLive is predefined by simulation.
timeToLive=4;
tracerColor[]
Array
Description: Declares tracer colour with "easy" settings (tracers enabled), format is {Red, Green, Blue, Transparency}.
tracerColorR[]
Array
Description: Declares tracer colour with "realistic" settings (tracers disabled), format is {Red, Green, Blue, Transparency}.
trackLead
ArmA
Float
Description: The amount of lead a guided weapon will use when tracking a target.
trackOversteer
ArmA
Float
Description: The factor at which a guided weapon will steer to meet TrackLead.
typicalSpeed
ArmA
Integer
Description: hit value is valid when projectile moves at this speed. With lower speed the hit caused by the ammo is lower as well.
V
visibleFire
Float
Description: how much does AI see a unit firing this weapon
visibleFire=18;
visibleFireTime
Integer
Description: How long is one shot assumed to be noticeable by the AI. Values under 5 should be avoided, as AI can performs is cycles with 5s of no testing in between.
visibleFireTime=18;