Event Handlers/Reloaded – Arma 3

From Bohemia Interactive Community
Revision as of 21:02, 1 March 2016 by Killzone Kid (talk | contribs) (Created page with "__TOC__ ==Overview== In short, Reloaded Event Handler (EH) triggers every time a new magazine is added to a weapon. <br><br> <code>pla...")
(diff) ← Older revision | Latest revision (diff) | Newer revision → (diff)
Jump to navigation Jump to search

Overview

In short, Reloaded Event Handler (EH) triggers every time a new magazine is added to a weapon.

player addEventHandler ["Reloaded", {hint str _this}];

Example Return

[
	B Alpha 1-1:1 (KK),
	"arifle_MXC_Holo_pointer_F",
	"arifle_MXC_Holo_pointer_F",
	[
		"30Rnd_65x39_caseless_mag",
		30,
		1e+007,
		0
	],
	[
		"30Rnd_65x39_caseless_mag",
		12,
		1e+007,
		0
	]
]

Return Format

The EH returns array in _this variable of the following format [entity, weapon, muzzle, newMagazine, (oldMagazine)], where:

  • entity: Object - unit or vehicle to which EH is assigned
  • weapon: String - weapon that got reloaded
  • muzzle: String - weapons muzzle that got reloaded
  • newMagazine: Array - new magazine info in format [magazineClass, ammoCount, magazineID, magazineCreator], where:
    • magazineClass: String - class name of the magazine
    • ammoCount: Number - amount of ammo in magazine
    • magazineID: Number - global magazine id
    • magazineCreator: Number - owner of the magazine creator
  • (oldMagazine): Array - old magazine that was in the muzzle before. Could be Nothing if muzzle was empty prior to reload event. Format is the same as for the newMagazine.

Magazine ID

The EH can be assigned to both person and transport. It triggers only when new magazine is loaded into a weapon. The magazine ID number is normally > 10,000,000, so due to the number to string conversion limitation it would always show as 1e+007 in hint. In order to be able to see the changing ID number, subtract this amount from the return ID.

Example

Here is a little demo to play with: player addEventHandler ["Reloaded", { params ["", "_weapon", "_muzzle", "_newmag", ["_oldmag", ["","","",""]]]; hint format [" Weapon: %1\n Muzzle: %2\n\n - New Magazine -\n Name: %3\n Ammo: %4\n ID: %5\n Creator: %6\n\n - Old Magazine -\n Name: %7\n Ammo: %8\n ID: %9\n Creator: %10 ", _weapon, _muzzle, _newmag select 0, _newmag select 1, (_newmag select 2) - 1e+007, _newmag select 3, _oldmag select 0, _oldmag select 1, if (_oldmag select 2 isEqualType "") then {""} else {(_oldmag select 2) - 1e+007}, _oldmag select 3 ]; }];


Some explanation about "Throw" and "Put" weapons

The "Throw" weapon has multiple muzzles for different types of currentThrowables. Normally the muzzles are already loaded. However, if you have "Reloaded" EH attached and a spare hand grenade in inventory, when you throw 1st grenade the EH will trigger immediately. This might be a little bit confusing at first, but it is the correct behaviour. As 1st grenade leaves its muzzle, spare grenade is auto reloaded immediately, which explains the EH firing.

The "Put" weapon also has multiple muzzles for different type of mines, but unlike "Throw" weapon, it seems to have its muzzles empty, so it loads and fires them pretty much at the same time. This behaviour could also raise eyebrow at first. But if you assign both "Reloaded" and "Fired" EH to player, when he puts down a mine, both EH fire almost immediately, with "Reloaded" always firing first. This means that "Put" muzzles are reloaded and fired immediately only when requested and this is why old mag information will be non-existent.