mirror of
https://github.com/acemod/ACE3.git
synced 2024-08-30 18:23:18 +00:00
Further macros for attach (EFUNC, EQGVAR). Minor fixes
This commit is contained in:
parent
ef2ed3444a
commit
2452884acb
@ -41,7 +41,7 @@ class CfgVehicles {
|
|||||||
class CAManBase: Man {
|
class CAManBase: Man {
|
||||||
class AGM_SelfActions {
|
class AGM_SelfActions {
|
||||||
class AGM_Equipment {
|
class AGM_Equipment {
|
||||||
class ADDON {
|
class GVAR(Attach) {
|
||||||
displayName = "$STR_AGM_Attach_AttachDetach";
|
displayName = "$STR_AGM_Attach_AttachDetach";
|
||||||
condition = QUOTE( [_player, ''] call FUNC(canAttach) );
|
condition = QUOTE( [_player, ''] call FUNC(canAttach) );
|
||||||
statement = QUOTE( [_player] call FUNC(openAttachUI); );
|
statement = QUOTE( [_player] call FUNC(openAttachUI); );
|
||||||
|
@ -29,12 +29,12 @@ switch true do {
|
|||||||
case (_itemName == "AGM_IR_Strobe_Item") : {
|
case (_itemName == "AGM_IR_Strobe_Item") : {
|
||||||
_attachedItem = "AGM_IR_Strobe_Effect" createVehicle [0,0,0];
|
_attachedItem = "AGM_IR_Strobe_Effect" createVehicle [0,0,0];
|
||||||
_attachedItem attachTo [_unit,[0,-0.11,0.16],"pilot"];//makes it attach to the head a bit better, shoulder is not good for visibility - eRazeri
|
_attachedItem attachTo [_unit,[0,-0.11,0.16],"pilot"];//makes it attach to the head a bit better, shoulder is not good for visibility - eRazeri
|
||||||
[localize "STR_AGM_Attach_IrStrobe_Attached"] call AGM_Core_fnc_displayTextStructured;
|
[localize "STR_AGM_Attach_IrStrobe_Attached"] call EFUNC(core,displayTextStructured);
|
||||||
};
|
};
|
||||||
case (_itemName == "B_IR_Grenade") : {
|
case (_itemName == "B_IR_Grenade") : {
|
||||||
_attachedItem = "B_IRStrobe" createVehicle [0,0,0];
|
_attachedItem = "B_IRStrobe" createVehicle [0,0,0];
|
||||||
_attachedItem attachTo [_unit,[-0.05,0,0.12],"rightshoulder"];
|
_attachedItem attachTo [_unit,[-0.05,0,0.12],"rightshoulder"];
|
||||||
[localize "STR_AGM_Attach_IrGrenade_Attached"] call AGM_Core_fnc_displayTextStructured;
|
[localize "STR_AGM_Attach_IrGrenade_Attached"] call EFUNC(core,displayTextStructured);
|
||||||
};
|
};
|
||||||
case (_itemName == "O_IR_Grenade") : {
|
case (_itemName == "O_IR_Grenade") : {
|
||||||
_attachedItem = "O_IRStrobe" createVehicle [0,0,0];
|
_attachedItem = "O_IRStrobe" createVehicle [0,0,0];
|
||||||
@ -59,4 +59,4 @@ switch true do {
|
|||||||
// Remove item
|
// Remove item
|
||||||
_unit removeItem _itemName;
|
_unit removeItem _itemName;
|
||||||
_unit setVariable [QGVAR(ItemName), _itemName, true];
|
_unit setVariable [QGVAR(ItemName), _itemName, true];
|
||||||
_unit setVariable ["AGM_AttachedItem", _attachedItem, true];
|
_unit setVariable [QGVAR(Item), _attachedItem, true];
|
||||||
|
@ -24,7 +24,7 @@ if (_itemName == "") exitWith {};
|
|||||||
_count = (count items _unit) + (count magazines _unit);
|
_count = (count items _unit) + (count magazines _unit);
|
||||||
_unit addItem _itemName;
|
_unit addItem _itemName;
|
||||||
if ((count items _unit) + (count magazines _unit) <= _count) exitWith {
|
if ((count items _unit) + (count magazines _unit) <= _count) exitWith {
|
||||||
[localize "STR_AGM_Attach_Inventory_Full"] call AGM_Core_fnc_displayTextStructured;
|
[localize "STR_AGM_Attach_Inventory_Full"] call EFUNC(core,displayTextStructured);
|
||||||
};
|
};
|
||||||
|
|
||||||
if (_itemName == "B_IR_Grenade" or _itemName == "O_IR_Grenade" or _itemName == "I_IR_Grenade") then {
|
if (_itemName == "B_IR_Grenade" or _itemName == "O_IR_Grenade" or _itemName == "I_IR_Grenade") then {
|
||||||
@ -51,13 +51,13 @@ _unit setVariable [QGVAR(Item),nil, true];
|
|||||||
// Display message
|
// Display message
|
||||||
switch true do {
|
switch true do {
|
||||||
case (_itemName == "AGM_IR_Strobe_Item") : {
|
case (_itemName == "AGM_IR_Strobe_Item") : {
|
||||||
[localize "STR_AGM_Attach_IrStrobe_Detached"] call AGM_Core_fnc_displayTextStructured;
|
[localize "STR_AGM_Attach_IrStrobe_Detached"] call EFUNC(core,displayTextStructured);
|
||||||
};
|
};
|
||||||
case (_itemName == "B_IR_Grenade" or _itemName == "O_IR_Grenade" or _itemName == "I_IR_Grenade") : {
|
case (_itemName == "B_IR_Grenade" or _itemName == "O_IR_Grenade" or _itemName == "I_IR_Grenade") : {
|
||||||
[localize "STR_AGM_Attach_IrGrenade_Detached"] call AGM_Core_fnc_displayTextStructured;
|
[localize "STR_AGM_Attach_IrGrenade_Detached"] call EFUNC(core,displayTextStructured);
|
||||||
};
|
};
|
||||||
case (_itemName == "Chemlight_blue" or {_itemName == "Chemlight_green"} or {_itemName == "Chemlight_red"} or {_itemName == "Chemlight_yellow"}) : {
|
case (_itemName == "Chemlight_blue" or {_itemName == "Chemlight_green"} or {_itemName == "Chemlight_red"} or {_itemName == "Chemlight_yellow"}) : {
|
||||||
[localize "STR_AGM_Attach_Chemlight_Detached"] call AGM_Core_fnc_displayTextStructured;
|
[localize "STR_AGM_Attach_Chemlight_Detached"] call EFUNC(core,displayTextStructured);
|
||||||
};
|
};
|
||||||
default {
|
default {
|
||||||
if (true) exitWith {};
|
if (true) exitWith {};
|
||||||
|
@ -21,7 +21,7 @@ private ["_unit", "_actions", "_attachables", "_item"];
|
|||||||
_unit = _this select 0;
|
_unit = _this select 0;
|
||||||
_listed = [];
|
_listed = [];
|
||||||
_attachables = magazines _unit;
|
_attachables = magazines _unit;
|
||||||
_actions = [localize "STR_AGM_Attach_AttachDetach", localize "STR_AGM_Attach_Attach"] call AGM_Interaction_fnc_prepareSelectMenu;
|
_actions = [localize "STR_AGM_Attach_AttachDetach", localize "STR_AGM_Attach_Attach"] call EFUNC(interaction,prepareSelectMenu);
|
||||||
{
|
{
|
||||||
if !(_x in _listed) then {
|
if !(_x in _listed) then {
|
||||||
_item = ConfigFile >> "CfgMagazines" >> _x;
|
_item = ConfigFile >> "CfgMagazines" >> _x;
|
||||||
@ -31,7 +31,7 @@ _actions = [localize "STR_AGM_Attach_AttachDetach", localize "STR_AGM_Attach_Att
|
|||||||
getText(_item >> "displayName"),
|
getText(_item >> "displayName"),
|
||||||
getText(_item >> "picture"),
|
getText(_item >> "picture"),
|
||||||
_x
|
_x
|
||||||
] call AGM_Interaction_fnc_AddSelectableItem;
|
] call EFUNC(interaction,addSelectableItem);
|
||||||
};
|
};
|
||||||
_listed pushBack _x;
|
_listed pushBack _x;
|
||||||
};
|
};
|
||||||
@ -46,7 +46,7 @@ _attachables = items _unit;
|
|||||||
getText(_item >> "displayName"),
|
getText(_item >> "displayName"),
|
||||||
getText(_item >> "picture"),
|
getText(_item >> "picture"),
|
||||||
_x
|
_x
|
||||||
] call AGM_Interaction_fnc_AddSelectableItem;
|
] call EFUNC(interaction,addSelectableItem);
|
||||||
};
|
};
|
||||||
_listed pushBack _x;
|
_listed pushBack _x;
|
||||||
};
|
};
|
||||||
@ -56,10 +56,10 @@ _attachables = items _unit;
|
|||||||
_actions,
|
_actions,
|
||||||
{
|
{
|
||||||
[AGM_player, _this] call FUNC(attach);
|
[AGM_player, _this] call FUNC(attach);
|
||||||
call AGM_Interaction_fnc_hideMenu;
|
call EFUNC(interaction,hideMenu);
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
call AGM_Interaction_fnc_hideMenu;
|
call EFUNC(interaction,hideMenu);
|
||||||
if !(profileNamespace getVariable ["AGM_Interaction_AutoCloseMenu", false]) then {"Default" call AGM_Interaction_fnc_openMenuSelf};
|
if !(profileNamespace getVariable [EQGVAR(interaction,AutoCloseMenu), false]) then {"Default" call EFUNC(interaction,openMenuSelf)};
|
||||||
}
|
}
|
||||||
] call AGM_Interaction_fnc_openSelectMenu;
|
] call EFUNC(interaction,openSelectMenu);
|
||||||
|
Loading…
Reference in New Issue
Block a user