CfgRecoils – Arma 3
Category: Arma 3: Weapon & Magazine Configuration
| Lou Montana (talk | contribs) m (Text replacement - "\[\[[Cc]ategory:ArmA:[ _]?([^|]+)\]\]" to "{{GameCategory|arma1|$1}}") | Lou Montana (talk | contribs)  m (Fix category) | ||
| (5 intermediate revisions by the same user not shown) | |||
| Line 1: | Line 1: | ||
| {{TOC|none}} | |||
| {{Feature|informative|For earlier recoil versions, see {{Link|ArmA: Armed Assault: CfgRecoils}}.}} | |||
| == Samples == | |||
| === Recoil === | |||
| * Parameter ''muzzleOuter'' defines the possible area where the recoil would like to move the weapon's muzzle randomly at each shot. It is defined as ellipse with variables defining the (x = horizontal axis position, y = vertical axis position, a = horizontal magnitude, b = vertical magnitude); or, translated to the weapon's recoil movement behavior (how far to the right, how high up, how much horizontal deviation, how much vertical deviation). | * Parameter ''muzzleOuter'' defines the possible area where the recoil would like to move the weapon's muzzle randomly at each shot. It is defined as ellipse with variables defining the (x = horizontal axis position, y = vertical axis position, a = horizontal magnitude, b = vertical magnitude); or, translated to the weapon's recoil movement behavior (how far to the right, how high up, how much horizontal deviation, how much vertical deviation). | ||
| * Parameter ''kickBack'' defines the minimum and maximum of random interval for backward force applied over the arms and torso for each fired shot. | * Parameter ''kickBack'' defines the minimum and maximum of random interval for backward force applied over the arms and torso for each fired shot. | ||
| Line 43: | Line 13: | ||
| Camera shakes are derived from the overall magnitude of each recoil impulse forces. | Camera shakes are derived from the overall magnitude of each recoil impulse forces. | ||
| <syntaxhighlight lang="cpp"> | |||
| class CfgRecoils | |||
| { | |||
| 	class my_awesome_recoil | |||
| 	{ | |||
| 		muzzleOuter[]	= { 0.3, 1.0, 0.3, 0.2 }; // x, y, a, b | |||
| 		kickBack[]	= { 0.03, 0.06 }; | |||
| 		permanent	= 0.1; | |||
| 		temporary	= 0.01; | |||
| 	}; | |||
| }; | |||
| </syntaxhighlight> | |||
| ==  | === Weapon === | ||
| <syntaxhighlight lang="cpp"> | |||
| class CfgWeapons | |||
| { | |||
| 	class MyRifle | |||
| 	{ | |||
| 		recoil = "my_awesome_recoil"; | |||
| 	}; | |||
| }; | |||
| </syntaxhighlight> | |||
| === Config === | |||
| Recoil  | <syntaxhighlight lang="cpp"> | ||
| class CfgWeaponHandling | |||
| { | |||
| 	class Recoil | |||
| 	{ | |||
| 		kickVisual	= 0.3;	// multiplier for extra camera-only movement for weapon kickback | |||
| 		impulseCoef	= 1;	// common coefficient for weapon-based recoil configuration values, increase to make all recoils stronger, decrease to make them all weaker | |||
| 		prone		= 1.25;	// coefficient of recoil forces while in prone (this is further multiplied by weapon resting coefficients) | |||
| 	}; | |||
| }; | |||
| </syntaxhighlight> | |||
| '''Basic suggestions''' | |||
| * would you like your weapon to kick more to the right? Increase Horizontal Axis Position value of ''muzzleOuter''. | |||
| * would you like your weapon to kick more upwards? Increase Vertical Axis Position value of ''muzzleOuter''. | |||
| * would you like your weapon to jump left and right more randomly? Increase Horizontal Magnitude value of ''muzzleOuter''. | |||
| * would you like your weapon to jump up and down more randomly? Increase Vertical Magnitude value of ''muzzleOuter''. | |||
| * would you like your weapon to climb up more? Increase ''permanent''. | |||
| * would you like your weapon to shake more in your hands? Increase ''temporary''. | |||
| * would you like your weapon to kick back more? Increase ''kickBack''. | |||
| * and vice versa. | |||
| {{GameCategory| | {{GameCategory|arma3|Weapon & Magazine Configuration}} | ||
Latest revision as of 12:33, 31 March 2025
Samples
Recoil
- Parameter muzzleOuter defines the possible area where the recoil would like to move the weapon's muzzle randomly at each shot. It is defined as ellipse with variables defining the (x = horizontal axis position, y = vertical axis position, a = horizontal magnitude, b = vertical magnitude); or, translated to the weapon's recoil movement behavior (how far to the right, how high up, how much horizontal deviation, how much vertical deviation).
- Parameter kickBack defines the minimum and maximum of random interval for backward force applied over the arms and torso for each fired shot.
- Remaining parameters define how much of the random muzzle displacement within the defined ellipse space is permanent (causing muzzle rise you should compensate for) and how much is temporary (causing temporal weapon rise up and down, thus causing the weapon to shake in your hands).
Camera shakes are derived from the overall magnitude of each recoil impulse forces.
class CfgRecoils
{
	class my_awesome_recoil
	{
		muzzleOuter[]	= { 0.3, 1.0, 0.3, 0.2 }; // x, y, a, b
		kickBack[]	= { 0.03, 0.06 };
		permanent	= 0.1;
		temporary	= 0.01;
	};
};
Weapon
class CfgWeapons
{
	class MyRifle
	{
		recoil = "my_awesome_recoil";
	};
};
Config
class CfgWeaponHandling
{
	class Recoil
	{
		kickVisual	= 0.3;	// multiplier for extra camera-only movement for weapon kickback
		impulseCoef	= 1;	// common coefficient for weapon-based recoil configuration values, increase to make all recoils stronger, decrease to make them all weaker
		prone		= 1.25;	// coefficient of recoil forces while in prone (this is further multiplied by weapon resting coefficients)
	};
};
Basic suggestions
- would you like your weapon to kick more to the right? Increase Horizontal Axis Position value of muzzleOuter.
- would you like your weapon to kick more upwards? Increase Vertical Axis Position value of muzzleOuter.
- would you like your weapon to jump left and right more randomly? Increase Horizontal Magnitude value of muzzleOuter.
- would you like your weapon to jump up and down more randomly? Increase Vertical Magnitude value of muzzleOuter.
- would you like your weapon to climb up more? Increase permanent.
- would you like your weapon to shake more in your hands? Increase temporary.
- would you like your weapon to kick back more? Increase kickBack.
- and vice versa.
