mirror of
https://github.com/acemod/ACE3.git
synced 2024-08-30 18:23:18 +00:00
Code cleanup 1.54
This commit is contained in:
parent
0bc540305d
commit
e56e18bff3
@ -17,24 +17,17 @@
|
|||||||
params ["_target", "_backpack"];
|
params ["_target", "_backpack"];
|
||||||
|
|
||||||
// do cam shake if the target is the player
|
// do cam shake if the target is the player
|
||||||
if ([_target] call EFUNC(common,isPlayer)) then {
|
if (_target call EFUNC(common,isPlayer)) then {
|
||||||
addCamShake [4, 0.5, 5];
|
addCamShake [4, 0.5, 5];
|
||||||
};
|
};
|
||||||
|
|
||||||
// play a zipper sound effect
|
// play a zipper sound effect
|
||||||
private ["_sounds", "_position"];
|
private _sounds = [
|
||||||
|
|
||||||
_sounds = [
|
|
||||||
/*"a3\sounds_f\characters\ingame\AinvPknlMstpSlayWpstDnon_medic.wss",
|
|
||||||
"a3\sounds_f\characters\ingame\AinvPknlMstpSlayWrflDnon_medic.wss",
|
|
||||||
"a3\sounds_f\characters\ingame\AinvPpneMstpSlayWpstDnon_medic.wss",
|
|
||||||
"a3\sounds_f\characters\ingame\AinvPpneMstpSlayWrflDnon_medic.wss"*/
|
|
||||||
|
|
||||||
QUOTE(PATHTO_R(sounds\zip_in.wav)),
|
QUOTE(PATHTO_R(sounds\zip_in.wav)),
|
||||||
QUOTE(PATHTO_R(sounds\zip_out.wav))
|
QUOTE(PATHTO_R(sounds\zip_out.wav))
|
||||||
];
|
];
|
||||||
|
|
||||||
_position = AGLToASL (_target modelToWorldVisual (_target selectionPosition "Spine3"));
|
private _position = AGLToASL (_target modelToWorldVisual (_target selectionPosition "Spine3"));
|
||||||
|
|
||||||
playSound3D [
|
playSound3D [
|
||||||
_sounds select floor random count _sounds,
|
_sounds select floor random count _sounds,
|
||||||
|
@ -12,13 +12,12 @@
|
|||||||
*/
|
*/
|
||||||
#include "script_component.hpp"
|
#include "script_component.hpp"
|
||||||
|
|
||||||
params ["_backpack"];
|
params [["_backpack", objNull, [objNull]]];
|
||||||
|
|
||||||
if (_backpack isEqualType objNull) then {
|
if (_backpack isEqualType objNull) then {
|
||||||
_backpack = typeOf _backpack;
|
_backpack = typeOf _backpack;
|
||||||
};
|
};
|
||||||
|
|
||||||
private "_config";
|
private _config = configFile >> "CfgVehicles" >> _backpack;
|
||||||
_config = configFile >> "CfgVehicles" >> _backpack;
|
|
||||||
|
|
||||||
getText (_config >> "vehicleClass") == "backpacks" && {getNumber (_config >> "maximumLoad") > 0} // return
|
getText (_config >> "vehicleClass") == "backpacks" && {getNumber (_config >> "maximumLoad") > 0} // return
|
||||||
|
@ -16,11 +16,10 @@
|
|||||||
params ["_unit", "_backpack"];
|
params ["_unit", "_backpack"];
|
||||||
|
|
||||||
// exit if the target is not a real backpack, i.e. parachute, static weapon bag etc.
|
// exit if the target is not a real backpack, i.e. parachute, static weapon bag etc.
|
||||||
if !([_backpack] call FUNC(isBackpack)) exitWith {false};
|
if !(_backpack call FUNC(isBackpack)) exitWith {false};
|
||||||
|
|
||||||
// get the unit that wears the backpack object
|
// get the unit that wears the backpack object
|
||||||
private "_target";
|
private _target = objectParent _backpack;
|
||||||
_target = objectParent _backpack;
|
|
||||||
|
|
||||||
if (isNull _target) exitWith {false};
|
if (isNull _target) exitWith {false};
|
||||||
|
|
||||||
|
@ -24,15 +24,13 @@
|
|||||||
params ["_unit", "_weapon", "", "", "", "", "_projectile"];
|
params ["_unit", "_weapon", "", "", "", "", "_projectile"];
|
||||||
TRACE_3("params",_unit,_weapon,_projectile);
|
TRACE_3("params",_unit,_weapon,_projectile);
|
||||||
|
|
||||||
if ((!local _unit) || {_weapon != (secondaryWeapon _unit)}) exitWith {};
|
if (!local _unit || {_weapon != secondaryWeapon _unit}) exitWith {};
|
||||||
|
|
||||||
private ["_replacementTube", "_items"];
|
private _replacementTube = getText (configFile >> "CfgWeapons" >> _weapon >> "ACE_UsedTube");
|
||||||
_replacementTube = getText (configFile >> "CfgWeapons" >> _weapon >> "ACE_UsedTube");
|
|
||||||
if (_replacementTube == "") exitWith {}; //If no replacement defined just exit
|
if (_replacementTube == "") exitWith {}; //If no replacement defined just exit
|
||||||
|
|
||||||
|
|
||||||
//Save array of items attached to launcher
|
//Save array of items attached to launcher
|
||||||
_items = secondaryWeaponItems _unit;
|
private _items = secondaryWeaponItems _unit;
|
||||||
//Replace the orginal weapon with the 'usedTube' weapon
|
//Replace the orginal weapon with the 'usedTube' weapon
|
||||||
_unit addWeapon _replacementTube;
|
_unit addWeapon _replacementTube;
|
||||||
//Makes sure the used tube is still equiped
|
//Makes sure the used tube is still equiped
|
||||||
@ -55,12 +53,10 @@ if !([_unit] call EFUNC(common,isPlayer)) then {
|
|||||||
[_idPFH] call CBA_fnc_removePerFrameHandler;
|
[_idPFH] call CBA_fnc_removePerFrameHandler;
|
||||||
|
|
||||||
//If (tube is dropped) OR (is dead) OR (is player) just exit
|
//If (tube is dropped) OR (is dead) OR (is player) just exit
|
||||||
if (((secondaryWeapon _unit) != _tube) || {!alive _unit} || {([_unit] call EFUNC(common,isPlayer))}) exitWith {};
|
if (secondaryWeapon _unit != _tube || {!alive _unit} || {[_unit] call EFUNC(common,isPlayer)}) exitWith {};
|
||||||
|
|
||||||
private ["_items", "_container"];
|
//private _items = secondaryWeaponItems _unit;
|
||||||
|
private _container = createVehicle ["GroundWeaponHolder", position _unit, [], 0, "CAN_COLLIDE"];
|
||||||
// _items = secondaryWeaponItems _unit;
|
|
||||||
_container = createVehicle ["GroundWeaponHolder", position _unit, [], 0, "CAN_COLLIDE"];
|
|
||||||
_container setPosAsl (getPosAsl _unit);
|
_container setPosAsl (getPosAsl _unit);
|
||||||
_container addWeaponCargoGlobal [_tube, 1];
|
_container addWeaponCargoGlobal [_tube, 1];
|
||||||
|
|
||||||
|
@ -20,17 +20,12 @@ TRACE_1("params",_unit);
|
|||||||
|
|
||||||
if (!local _unit) exitWith {};
|
if (!local _unit) exitWith {};
|
||||||
|
|
||||||
private ["_launcher", "_config"];
|
private _launcher = secondaryWeapon _unit;
|
||||||
|
private _config = configFile >> "CfgWeapons" >> _launcher;
|
||||||
_launcher = secondaryWeapon _unit;
|
|
||||||
_config = configFile >> "CfgWeapons" >> _launcher;
|
|
||||||
|
|
||||||
if (isClass _config && {getText (_config >> "ACE_UsedTube") != ""} && {getNumber (_config >> "ACE_isUsedLauncher") != 1} && {count secondaryWeaponMagazine _unit == 0}) then {
|
if (isClass _config && {getText (_config >> "ACE_UsedTube") != ""} && {getNumber (_config >> "ACE_isUsedLauncher") != 1} && {count secondaryWeaponMagazine _unit == 0}) then {
|
||||||
private ["_magazine", "_isLauncherSelected", "_didAdd"];
|
private _magazine = getArray (_config >> "magazines") select 0;
|
||||||
|
private _isLauncherSelected = currentWeapon _unit == _launcher;
|
||||||
_magazine = getArray (_config >> "magazines") select 0;
|
|
||||||
|
|
||||||
_isLauncherSelected = currentWeapon _unit == _launcher;
|
|
||||||
|
|
||||||
_unit removeMagazines _magazine;
|
_unit removeMagazines _magazine;
|
||||||
|
|
||||||
@ -38,8 +33,9 @@ if (isClass _config && {getText (_config >> "ACE_UsedTube") != ""} && {getNumber
|
|||||||
_unit addBackpack "ACE_FakeBackpack";
|
_unit addBackpack "ACE_FakeBackpack";
|
||||||
_unit removeWeapon _launcher;
|
_unit removeWeapon _launcher;
|
||||||
_unit addMagazine _magazine;
|
_unit addMagazine _magazine;
|
||||||
_didAdd = _magazine in (magazines _unit);
|
private _didAdd = _magazine in magazines _unit;
|
||||||
_unit addWeapon _launcher;
|
_unit addWeapon _launcher;
|
||||||
|
|
||||||
if (!_didAdd) then {
|
if (!_didAdd) then {
|
||||||
TRACE_1("Failed To Add Disposable Magazine Normally, doing backup method (no backpack)",_unit);
|
TRACE_1("Failed To Add Disposable Magazine Normally, doing backup method (no backpack)",_unit);
|
||||||
_unit addSecondaryWeaponItem _magazine;
|
_unit addSecondaryWeaponItem _magazine;
|
||||||
@ -48,8 +44,9 @@ if (isClass _config && {getText (_config >> "ACE_UsedTube") != ""} && {getNumber
|
|||||||
} else {
|
} else {
|
||||||
_unit removeWeapon _launcher;
|
_unit removeWeapon _launcher;
|
||||||
_unit addMagazine _magazine;
|
_unit addMagazine _magazine;
|
||||||
_didAdd = _magazine in (magazines _unit);
|
private _didAdd = _magazine in magazines _unit;
|
||||||
_unit addWeapon _launcher;
|
_unit addWeapon _launcher;
|
||||||
|
|
||||||
if (!_didAdd) then {
|
if (!_didAdd) then {
|
||||||
TRACE_2("Failed To Add Disposable Magazine Normally, doing backup method",_unit,(backpack _unit));
|
TRACE_2("Failed To Add Disposable Magazine Normally, doing backup method",_unit,(backpack _unit));
|
||||||
_unit addSecondaryWeaponItem _magazine;
|
_unit addSecondaryWeaponItem _magazine;
|
||||||
|
@ -24,13 +24,11 @@ _player removeMagazines "ACE_FiredMissileDummy";
|
|||||||
|
|
||||||
if (isNull _display) exitWith {};
|
if (isNull _display) exitWith {};
|
||||||
|
|
||||||
private ["_launcher", "_control", "_config"];
|
private _launcher = secondaryWeapon _player;
|
||||||
|
|
||||||
_launcher = secondaryWeapon _player;
|
|
||||||
|
|
||||||
if (_launcher == "" || {getText (configFile >> "CfgWeapons" >> _launcher >> "ACE_UsedTube") == ""}) then {
|
if (_launcher == "" || {getText (configFile >> "CfgWeapons" >> _launcher >> "ACE_UsedTube") == ""}) then {
|
||||||
_control = _display displayCtrl 627;
|
private _control = _display displayCtrl 627;
|
||||||
_config = configFile >> "RscDisplayInventory" >> "controls" >> "SlotSecondaryMagazine";
|
private _config = configFile >> "RscDisplayInventory" >> "controls" >> "SlotSecondaryMagazine";
|
||||||
_control ctrlSetPosition [getNumber (_config >> "x"), getNumber (_config >> "y"), getNumber (_config >> "w"), getNumber (_config >> "h")];
|
_control ctrlSetPosition [getNumber (_config >> "x"), getNumber (_config >> "y"), getNumber (_config >> "w"), getNumber (_config >> "h")];
|
||||||
_control ctrlCommit 0;
|
_control ctrlCommit 0;
|
||||||
|
|
||||||
@ -39,7 +37,7 @@ if (_launcher == "" || {getText (configFile >> "CfgWeapons" >> _launcher >> "ACE
|
|||||||
_control ctrlSetPosition [getNumber (_config >> "x"), getNumber (_config >> "y"), getNumber (_config >> "w"), getNumber (_config >> "h")];
|
_control ctrlSetPosition [getNumber (_config >> "x"), getNumber (_config >> "y"), getNumber (_config >> "w"), getNumber (_config >> "h")];
|
||||||
_control ctrlCommit 0;
|
_control ctrlCommit 0;
|
||||||
} else {
|
} else {
|
||||||
_control = _display displayCtrl 627;
|
private _control = _display displayCtrl 627;
|
||||||
_control ctrlSetPosition [0, 0, 0, 0];
|
_control ctrlSetPosition [0, 0, 0, 0];
|
||||||
_control ctrlCommit 0;
|
_control ctrlCommit 0;
|
||||||
|
|
||||||
|
@ -20,8 +20,7 @@
|
|||||||
|
|
||||||
params ["_projectile", "_color", "_intensity", "_timeToLive"];
|
params ["_projectile", "_color", "_intensity", "_timeToLive"];
|
||||||
|
|
||||||
private "_light";
|
private _light = "#lightpoint" createVehicleLocal position _projectile;
|
||||||
_light = "#lightpoint" createVehicleLocal position _projectile;
|
|
||||||
|
|
||||||
_light setLightColor _color;
|
_light setLightColor _color;
|
||||||
_light setLightAmbient _color;
|
_light setLightAmbient _color;
|
||||||
|
@ -17,14 +17,12 @@
|
|||||||
|
|
||||||
params ["_grenade"];
|
params ["_grenade"];
|
||||||
|
|
||||||
private ["_affected", "_strength", "_posGrenade", "_eyePos", "_losCount", "_eyeDir", "_dirToUnitVector", "_angleDiff", "_light"];
|
private _affected = _grenade nearEntities ["CAManBase", 20];
|
||||||
|
|
||||||
_affected = _grenade nearEntities ["CAManBase", 20];
|
|
||||||
|
|
||||||
{
|
{
|
||||||
if (local _x && {alive _x}) then {
|
if (local _x && {alive _x}) then {
|
||||||
|
|
||||||
_strength = 1 - ((_x distance _grenade) min 15) / 15;
|
private _strength = 1 - ((_x distance _grenade) min 15) / 15;
|
||||||
|
|
||||||
TRACE_3("FlashBangEffect Start",_x,(_x distance _grenade),_strength);
|
TRACE_3("FlashBangEffect Start",_x,(_x distance _grenade),_strength);
|
||||||
|
|
||||||
@ -47,12 +45,12 @@ _affected = _grenade nearEntities ["CAManBase", 20];
|
|||||||
} else {
|
} else {
|
||||||
//Do effects for player
|
//Do effects for player
|
||||||
// is there line of sight to the grenade?
|
// is there line of sight to the grenade?
|
||||||
_posGrenade = getPosASL _grenade;
|
private _posGrenade = getPosASL _grenade;
|
||||||
_eyePos = eyePos ACE_player; //PositionASL
|
private _eyePos = eyePos ACE_player; //PositionASL
|
||||||
_posGrenade set [2, (_posGrenade select 2) + 0.2]; // compensate for grenade glitching into ground
|
_posGrenade set [2, (_posGrenade select 2) + 0.2]; // compensate for grenade glitching into ground
|
||||||
|
|
||||||
//Check for line of sight (check 4 points in case grenade is stuck in an object or underground)
|
//Check for line of sight (check 4 points in case grenade is stuck in an object or underground)
|
||||||
_losCount = {
|
private _losCount = {
|
||||||
!lineIntersects [_posGrenade vectorAdd _x, _eyePos, _grenade, ACE_player]
|
!lineIntersects [_posGrenade vectorAdd _x, _eyePos, _grenade, ACE_player]
|
||||||
} count [[0,0,0], [0,0,0.2], [0.1, 0.1, 0.1], [-0.1, -0.1, 0.1]];
|
} count [[0,0,0], [0,0,0.2], [0.1, 0.1, 0.1], [-0.1, -0.1, 0.1]];
|
||||||
|
|
||||||
@ -68,9 +66,9 @@ _affected = _grenade nearEntities ["CAManBase", 20];
|
|||||||
|
|
||||||
// account for people looking away by slightly
|
// account for people looking away by slightly
|
||||||
// reducing the effect for visual effects.
|
// reducing the effect for visual effects.
|
||||||
_eyeDir = (positionCameraToWorld [0,0,1] vectorDiff positionCameraToWorld [0,0,0]);
|
private _eyeDir = (positionCameraToWorld [0,0,1] vectorDiff positionCameraToWorld [0,0,0]);
|
||||||
_dirToUnitVector = _eyePos vectorFromTo _posGrenade;
|
private _dirToUnitVector = _eyePos vectorFromTo _posGrenade;
|
||||||
_angleDiff = acos (_eyeDir vectorDotProduct _dirToUnitVector);
|
private _angleDiff = acos (_eyeDir vectorDotProduct _dirToUnitVector);
|
||||||
|
|
||||||
// from 0-45deg, full effect
|
// from 0-45deg, full effect
|
||||||
if (_angleDiff > 45) then {
|
if (_angleDiff > 45) then {
|
||||||
@ -85,7 +83,8 @@ _affected = _grenade nearEntities ["CAManBase", 20];
|
|||||||
};
|
};
|
||||||
|
|
||||||
// create flash to illuminate environment
|
// create flash to illuminate environment
|
||||||
_light = "#lightpoint" createVehicleLocal (getPos _grenade);
|
private _light = "#lightpoint" createVehicleLocal getPos _grenade;
|
||||||
|
|
||||||
_light setLightBrightness 200;
|
_light setLightBrightness 200;
|
||||||
_light setLightAmbient [1,1,1];
|
_light setLightAmbient [1,1,1];
|
||||||
_light setLightColor [1,1,1];
|
_light setLightColor [1,1,1];
|
||||||
|
@ -20,7 +20,7 @@ params ["_projectile"];
|
|||||||
if (alive _projectile) then {
|
if (alive _projectile) then {
|
||||||
playSound3D ["A3\Sounds_F\weapons\Explosion\explosion_mine_1.wss", _projectile, false, getPosASL _projectile, 5, 1.2, 400];
|
playSound3D ["A3\Sounds_F\weapons\Explosion\explosion_mine_1.wss", _projectile, false, getPosASL _projectile, 5, 1.2, 400];
|
||||||
|
|
||||||
private _affected = _projectile nearEntities ["CAManBase", 20];
|
private _affected = _projectile nearEntities ["CAManBase", 50];
|
||||||
|
|
||||||
["flashbangExplosion", _affected, [_projectile]] call EFUNC(common,targetEvent);
|
["flashbangExplosion", _affected, [_projectile]] call EFUNC(common,targetEvent);
|
||||||
};
|
};
|
||||||
|
@ -15,9 +15,7 @@
|
|||||||
*/
|
*/
|
||||||
#include "script_component.hpp"
|
#include "script_component.hpp"
|
||||||
|
|
||||||
private ["_mode", "_hint"];
|
private _mode = missionNamespace getVariable [QGVAR(currentThrowMode), 0];
|
||||||
|
|
||||||
_mode = missionNamespace getVariable [QGVAR(currentThrowMode), 0];
|
|
||||||
|
|
||||||
if (_mode == 4) then {
|
if (_mode == 4) then {
|
||||||
_mode = 0;
|
_mode = 0;
|
||||||
@ -30,13 +28,13 @@ if (_mode == 3) then {
|
|||||||
_mode = 4;
|
_mode = 4;
|
||||||
};
|
};
|
||||||
|
|
||||||
_hint = [
|
private _hint = localize ([
|
||||||
localize LSTRING(NormalThrow),
|
LSTRING(NormalThrow),
|
||||||
localize LSTRING(HighThrow),
|
LSTRING(HighThrow),
|
||||||
localize LSTRING(PreciseThrow),
|
LSTRING(PreciseThrow),
|
||||||
localize LSTRING(RollGrenade),
|
LSTRING(RollGrenade),
|
||||||
localize LSTRING(DropGrenade)
|
LSTRING(DropGrenade)
|
||||||
] select _mode;
|
] select _mode);
|
||||||
|
|
||||||
[_hint] call EFUNC(common,displayTextStructured);
|
[_hint] call EFUNC(common,displayTextStructured);
|
||||||
|
|
||||||
|
@ -30,24 +30,22 @@ if (isNull _projectile) then {
|
|||||||
_projectile = nearestObject [_unit, _ammo];
|
_projectile = nearestObject [_unit, _ammo];
|
||||||
};
|
};
|
||||||
|
|
||||||
|
private _config = configFile >> "CfgAmmo" >> _ammo;
|
||||||
|
|
||||||
// handle special grenades
|
// handle special grenades
|
||||||
if (local _unit) then {
|
if (local _unit) then {
|
||||||
if (getNumber (configFile >> "CfgAmmo" >> _ammo >> QGVAR(flashbang)) == 1) then {
|
if (getNumber (_config >> QGVAR(flashbang)) == 1) then {
|
||||||
private "_fuzeTime";
|
private _fuzeTime = getNumber (_config >> "explosionTime");
|
||||||
_fuzeTime = getNumber (configFile >> "CfgAmmo" >> _ammo >> "explosionTime");
|
|
||||||
|
|
||||||
[FUNC(flashbangThrownFuze), [_projectile], _fuzeTime, 0] call EFUNC(common,waitAndExecute);
|
[FUNC(flashbangThrownFuze), [_projectile], _fuzeTime, 0] call EFUNC(common,waitAndExecute);
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
if (getNumber (configFile >> "CfgAmmo" >> _ammo >> QGVAR(flare)) == 1) then {
|
if (getNumber (_config >> QGVAR(flare)) == 1) then {
|
||||||
private ["_fuzeTime", "_timeToLive", "_color", "_intensity"];
|
private _fuzeTime = getNumber (_config >> "explosionTime");
|
||||||
|
private _timeToLive = getNumber (_config >> "timeToLive");
|
||||||
_fuzeTime = getNumber (configFile >> "CfgAmmo" >> _ammo >> "explosionTime");
|
private _color = getArray (_config >> QGVAR(color));
|
||||||
_timeToLive = getNumber (configFile >> "CfgAmmo" >> _ammo >> "timeToLive");
|
private _intensity = _color deleteAt 3;
|
||||||
_color = getArray (configFile >> "CfgAmmo" >> _ammo >> QGVAR(color));
|
|
||||||
_intensity = _color select 3;
|
|
||||||
_color resize 3;
|
|
||||||
|
|
||||||
[FUNC(flare), [_projectile, _color, _intensity, _timeToLive], _fuzeTime, 0] call EFUNC(common,waitAndExecute);
|
[FUNC(flare), [_projectile, _color, _intensity, _timeToLive], _fuzeTime, 0] call EFUNC(common,waitAndExecute);
|
||||||
};
|
};
|
||||||
@ -55,12 +53,10 @@ if (getNumber (configFile >> "CfgAmmo" >> _ammo >> QGVAR(flare)) == 1) then {
|
|||||||
// handle throw modes
|
// handle throw modes
|
||||||
if (_unit != ACE_player) exitWith {};
|
if (_unit != ACE_player) exitWith {};
|
||||||
|
|
||||||
private "_mode";
|
private _mode = missionNamespace getVariable [QGVAR(currentThrowMode), 0];
|
||||||
_mode = missionNamespace getVariable [QGVAR(currentThrowMode), 0];
|
|
||||||
|
|
||||||
if (_mode != 0) then {
|
if (_mode != 0) then {
|
||||||
private "_velocity";
|
private _velocity = velocity _projectile;
|
||||||
_velocity = velocity _projectile;
|
|
||||||
|
|
||||||
switch (_mode) do {
|
switch (_mode) do {
|
||||||
//high throw
|
//high throw
|
||||||
|
@ -3,5 +3,6 @@
|
|||||||
ADDON = false;
|
ADDON = false;
|
||||||
|
|
||||||
PREP(fallDown);
|
PREP(fallDown);
|
||||||
|
PREP(getRandomAnimation);
|
||||||
|
|
||||||
ADDON = true;
|
ADDON = true;
|
||||||
|
@ -35,8 +35,7 @@ if (!isNil QUOTE(EFUNC(medical,playInjuredSound))) then {
|
|||||||
[_unit] call EFUNC(medical,playInjuredSound);
|
[_unit] call EFUNC(medical,playInjuredSound);
|
||||||
};
|
};
|
||||||
|
|
||||||
private "_vehicle";
|
private _vehicle = vehicle _unit;
|
||||||
_vehicle = vehicle _unit;
|
|
||||||
|
|
||||||
// handle static weapons
|
// handle static weapons
|
||||||
if (_vehicle isKindOf "StaticWeapon") exitWith {
|
if (_vehicle isKindOf "StaticWeapon") exitWith {
|
||||||
@ -53,61 +52,20 @@ if (_vehicle != _unit) exitWith {};
|
|||||||
if !([_unit, _vehicle] call EFUNC(common,canInteractWith)) exitWith {};
|
if !([_unit, _vehicle] call EFUNC(common,canInteractWith)) exitWith {};
|
||||||
|
|
||||||
// handle ladders
|
// handle ladders
|
||||||
if (getNumber (configFile >> "CfgMovesMaleSdr" >> "States" >> animationState _unit >> "AGM_isLadder") == 1) exitWith {
|
if (getNumber (configFile >> "CfgMovesMaleSdr" >> "States" >> animationState _unit >> "ACE_isLadder") == 1) exitWith {
|
||||||
_unit action ["LadderOff", nearestObject [position _unit, "House"]];
|
_unit action ["LadderOff", nearestObject [position _unit, "House"]];
|
||||||
};
|
};
|
||||||
|
|
||||||
// only play animation when standing due to lack of animations, sry
|
// only play animation when standing due to lack of animations, sry
|
||||||
if !(stance _unit in ["CROUCH", "STAND"]) exitWith {};
|
if !(stance _unit in ["CROUCH", "STAND"]) exitWith {};
|
||||||
|
|
||||||
private "_velocity";
|
private _velocity = vectorMagnitude velocity _unit;
|
||||||
_velocity = vectorMagnitude velocity _unit;
|
|
||||||
|
|
||||||
// only fall when moving
|
// only fall when moving
|
||||||
if (_velocity < 2) exitWith {};
|
if (_velocity < 2) exitWith {};
|
||||||
|
|
||||||
// get correct animation by weapon
|
// get correct animation by weapon
|
||||||
private "_anim";
|
private _anim = _unit call FUNC(getRandomAnimation);
|
||||||
|
|
||||||
call {
|
|
||||||
private "_weapon";
|
|
||||||
_weapon = currentWeapon _unit;
|
|
||||||
|
|
||||||
if (_weapon == "") exitWith {
|
|
||||||
_anim = "AmovPercMsprSnonWnonDf_AmovPpneMstpSnonWnonDnon"
|
|
||||||
};
|
|
||||||
|
|
||||||
if (_weapon == primaryWeapon _unit) exitWith {
|
|
||||||
if ([_unit] call EFUNC(common,isPlayer)) then {
|
|
||||||
private "_isRunning";
|
|
||||||
_isRunning = _velocity > 4;
|
|
||||||
|
|
||||||
_anim = [
|
|
||||||
["AmovPercMsprSlowWrfldf_AmovPpneMstpSrasWrflDnon_2", "AmovPercMsprSlowWrfldf_AmovPpneMstpSrasWrflDnon"] select _isRunning,
|
|
||||||
["AmovPercMsprSlowWrfldf_AmovPpneMstpSrasWrflDnon_2", "AmovPercMsprSlowWrfldf_AmovPpneMstpSrasWrflDnon"] select _isRunning,
|
|
||||||
"AmovPercMstpSrasWrflDnon_AadjPpneMstpSrasWrflDleft",
|
|
||||||
"AmovPercMstpSrasWrflDnon_AadjPpneMstpSrasWrflDright"
|
|
||||||
] select floor random 4;
|
|
||||||
} else {
|
|
||||||
_anim = "AmovPercMsprSlowWrfldf_AmovPpneMstpSrasWrflDnon";
|
|
||||||
};
|
|
||||||
};
|
|
||||||
|
|
||||||
if (_weapon == handgunWeapon _unit) exitWith {
|
|
||||||
if ([_unit] call EFUNC(common,isPlayer)) then {
|
|
||||||
_anim = [
|
|
||||||
"AmovPercMsprSlowWpstDf_AmovPpneMstpSrasWpstDnon",
|
|
||||||
"AmovPercMsprSlowWpstDf_AmovPpneMstpSrasWpstDnon",
|
|
||||||
"AmovPercMstpSrasWpstDnon_AadjPpneMstpSrasWpstDleft",
|
|
||||||
"AmovPercMstpSrasWpstDnon_AadjPpneMstpSrasWpstDright"
|
|
||||||
] select floor random 4;
|
|
||||||
} else {
|
|
||||||
_anim = "AmovPercMsprSlowWpstDf_AmovPpneMstpSrasWpstDnon";
|
|
||||||
};
|
|
||||||
};
|
|
||||||
|
|
||||||
_anim = "";
|
|
||||||
};
|
|
||||||
|
|
||||||
// exit if no animation for this weapon exists, i.e. binocular or rocket launcher
|
// exit if no animation for this weapon exists, i.e. binocular or rocket launcher
|
||||||
if (_anim == "") exitWith {};
|
if (_anim == "") exitWith {};
|
||||||
|
51
addons/hitreactions/functions/fnc_getRandomAnimation.sqf
Normal file
51
addons/hitreactions/functions/fnc_getRandomAnimation.sqf
Normal file
@ -0,0 +1,51 @@
|
|||||||
|
/*
|
||||||
|
* Author: commy2
|
||||||
|
* Get a random fall animation for the unit.
|
||||||
|
*
|
||||||
|
* Arguments:
|
||||||
|
* 0: unit <OBJECT>
|
||||||
|
*
|
||||||
|
* Return Value:
|
||||||
|
* Fall animation <STRING>
|
||||||
|
*
|
||||||
|
* Public: No
|
||||||
|
*/
|
||||||
|
#include "script_component.hpp"
|
||||||
|
|
||||||
|
params ["_unit"];
|
||||||
|
|
||||||
|
private _weapon = currentWeapon _unit;
|
||||||
|
|
||||||
|
if (_weapon == "") exitWith {
|
||||||
|
"AmovPercMsprSnonWnonDf_AmovPpneMstpSnonWnonDnon"
|
||||||
|
};
|
||||||
|
|
||||||
|
if (_weapon == primaryWeapon _unit) exitWith {
|
||||||
|
if (_unit call EFUNC(common,isPlayer)) then {
|
||||||
|
private _isRunning = _velocity > 4;
|
||||||
|
|
||||||
|
[
|
||||||
|
["AmovPercMsprSlowWrfldf_AmovPpneMstpSrasWrflDnon_2", "AmovPercMsprSlowWrfldf_AmovPpneMstpSrasWrflDnon"] select _isRunning,
|
||||||
|
["AmovPercMsprSlowWrfldf_AmovPpneMstpSrasWrflDnon_2", "AmovPercMsprSlowWrfldf_AmovPpneMstpSrasWrflDnon"] select _isRunning,
|
||||||
|
"AmovPercMstpSrasWrflDnon_AadjPpneMstpSrasWrflDleft",
|
||||||
|
"AmovPercMstpSrasWrflDnon_AadjPpneMstpSrasWrflDright"
|
||||||
|
] select floor random 4
|
||||||
|
} else {
|
||||||
|
"AmovPercMsprSlowWrfldf_AmovPpneMstpSrasWrflDnon"
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
if (_weapon == handgunWeapon _unit) exitWith {
|
||||||
|
if (_unit call EFUNC(common,isPlayer)) then {
|
||||||
|
[
|
||||||
|
"AmovPercMsprSlowWpstDf_AmovPpneMstpSrasWpstDnon",
|
||||||
|
"AmovPercMsprSlowWpstDf_AmovPpneMstpSrasWpstDnon",
|
||||||
|
"AmovPercMstpSrasWpstDnon_AadjPpneMstpSrasWpstDleft",
|
||||||
|
"AmovPercMstpSrasWpstDnon_AadjPpneMstpSrasWpstDright"
|
||||||
|
] select floor random 4
|
||||||
|
} else {
|
||||||
|
"AmovPercMsprSlowWpstDf_AmovPpneMstpSrasWpstDnon"
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
""
|
@ -6,9 +6,8 @@ if (!hasInterface) exitWith {};
|
|||||||
["inventoryDisplayLoaded", {
|
["inventoryDisplayLoaded", {
|
||||||
|
|
||||||
[{
|
[{
|
||||||
private "_dialog";
|
disableSerialization;
|
||||||
|
params ["_dialog"];
|
||||||
_dialog = _this select 0;
|
|
||||||
|
|
||||||
if (isNull _dialog) exitWith {
|
if (isNull _dialog) exitWith {
|
||||||
[_this select 1] call CBA_fnc_removePerFrameHandler;
|
[_this select 1] call CBA_fnc_removePerFrameHandler;
|
||||||
|
@ -15,33 +15,30 @@
|
|||||||
*/
|
*/
|
||||||
#include "script_component.hpp"
|
#include "script_component.hpp"
|
||||||
|
|
||||||
private ["_pos", "_dir"];
|
params ["_unit"];
|
||||||
|
|
||||||
PARAMS_1(_unit);
|
private _pos = getPosASL _unit;
|
||||||
|
private _dir = getDir _unit;
|
||||||
|
|
||||||
_pos = getPosASL _unit;
|
|
||||||
_dir = getDir _unit;
|
|
||||||
_dir = [sin _dir, cos _dir, 0];
|
_dir = [sin _dir, cos _dir, 0];
|
||||||
|
|
||||||
private ["_checkPos0beg", "_checkPos0end", "_checkPos1beg", "_checkPos1end"];
|
private _checkPos0beg = _pos vectorAdd [0, 0, 0.9];
|
||||||
|
private _checkPos0end = _checkPos0beg vectorAdd (_dir vectorMultiply 1.3);
|
||||||
|
|
||||||
_checkPos0beg = _pos vectorAdd [0, 0, 0.9];
|
private _checkPos1beg = _pos vectorAdd [0, 0, 1.75];
|
||||||
_checkPos0end = _checkPos0beg vectorAdd (_dir vectorMultiply 1.3);
|
private _checkPos1end = _checkPos1beg vectorAdd (_dir vectorMultiply 1.3);
|
||||||
|
|
||||||
_checkPos1beg = _pos vectorAdd [0, 0, 1.75];
|
private _checkPos2beg = _pos vectorAdd [0.3 * (_dir select 1), 0.3 * -(_dir select 0), 2.0];
|
||||||
_checkPos1end = _checkPos1beg vectorAdd (_dir vectorMultiply 1.3);
|
private _checkPos2end = _checkPos2beg vectorAdd (_dir vectorMultiply 1.3);
|
||||||
|
|
||||||
_checkPos2beg = _pos vectorAdd [0.3 * (_dir select 1), 0.3 * -(_dir select 0), 2.0];
|
private _checkPos3beg = _pos vectorAdd [-0.2 * (_dir select 1), -0.2 * -(_dir select 0), 2.0];
|
||||||
_checkPos2end = _checkPos2beg vectorAdd (_dir vectorMultiply 1.3);
|
private _checkPos3end = _checkPos3beg vectorAdd (_dir vectorMultiply 1.3);
|
||||||
|
|
||||||
_checkPos3beg = _pos vectorAdd [-0.2 * (_dir select 1), -0.2 * -(_dir select 0), 2.0];
|
private _checkPos4beg = _pos vectorAdd [0.3 * (_dir select 1), 0.3 * -(_dir select 0), 1.5];
|
||||||
_checkPos3end = _checkPos3beg vectorAdd (_dir vectorMultiply 1.3);
|
private _checkPos4end = _checkPos4beg vectorAdd (_dir vectorMultiply 1.3);
|
||||||
|
|
||||||
_checkPos4beg = _pos vectorAdd [0.3 * (_dir select 1), 0.3 * -(_dir select 0), 1.5];
|
private _checkPos5beg = _pos vectorAdd [-0.2 * (_dir select 1), -0.2 * -(_dir select 0), 1.5];
|
||||||
_checkPos4end = _checkPos4beg vectorAdd (_dir vectorMultiply 1.3);
|
private _checkPos5end = _checkPos5beg vectorAdd (_dir vectorMultiply 1.3);
|
||||||
|
|
||||||
_checkPos5beg = _pos vectorAdd [-0.2 * (_dir select 1), -0.2 * -(_dir select 0), 1.5];
|
|
||||||
_checkPos5end = _checkPos5beg vectorAdd (_dir vectorMultiply 1.3);
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
drawLine3D [ASLToATL _checkPos0beg, ASLToATL _checkPos0end, [0,1,0,1]];
|
drawLine3D [ASLToATL _checkPos0beg, ASLToATL _checkPos0end, [0,1,0,1]];
|
||||||
|
@ -15,9 +15,7 @@
|
|||||||
*/
|
*/
|
||||||
#include "script_component.hpp"
|
#include "script_component.hpp"
|
||||||
|
|
||||||
private "_unit";
|
params ["_unit"];
|
||||||
|
|
||||||
_unit = _this select 0;
|
|
||||||
|
|
||||||
if !([_unit] call FUNC(canClimb)) exitWith {
|
if !([_unit] call FUNC(canClimb)) exitWith {
|
||||||
[localize LSTRING(CanNotClimb)] call EFUNC(common,displayTextStructured);
|
[localize LSTRING(CanNotClimb)] call EFUNC(common,displayTextStructured);
|
||||||
|
@ -15,11 +15,9 @@
|
|||||||
*/
|
*/
|
||||||
#include "script_component.hpp"
|
#include "script_component.hpp"
|
||||||
|
|
||||||
private ["_unit", "_weight"];
|
params ["_unit"];
|
||||||
|
|
||||||
_unit = _this select 0;
|
private _weight = loadAbs _unit * 0.1;
|
||||||
|
|
||||||
_weight = loadAbs _unit * 0.1;
|
|
||||||
|
|
||||||
if (GVAR(useImperial)) then {
|
if (GVAR(useImperial)) then {
|
||||||
_weight = format ["%1lb", (round (_weight * 100)) / 100];
|
_weight = format ["%1lb", (round (_weight * 100)) / 100];
|
||||||
|
@ -16,12 +16,10 @@
|
|||||||
*/
|
*/
|
||||||
#include "script_component.hpp"
|
#include "script_component.hpp"
|
||||||
|
|
||||||
private ["_unit", "_anim", "_pos"];
|
params ["_unit", "_anim"];
|
||||||
|
|
||||||
_unit = _this select 0;
|
private _pos = _unit modelToWorldVisual (_unit selectionPosition "camera");
|
||||||
_anim = _this select 1;
|
|
||||||
|
|
||||||
_pos = _unit modelToWorldVisual (_unit selectionPosition "camera");
|
|
||||||
[_unit, "AmovPknlMstpSnonWnonDnon", 2] call EFUNC(common,doAnimation);
|
[_unit, "AmovPknlMstpSnonWnonDnon", 2] call EFUNC(common,doAnimation);
|
||||||
|
|
||||||
_pos = _pos vectorDiff (_unit selectionPosition "camera");
|
_pos = _pos vectorDiff (_unit selectionPosition "camera");
|
||||||
|
@ -1,7 +1,21 @@
|
|||||||
// TMR: Small Arms - Recoil initialization and functions
|
/*
|
||||||
// (C) 2013 Ryan Schultz. See LICENSE.
|
* Author: Orginal by Ryan Schultz, edited by KoffeinFlummi, commy2
|
||||||
// Edited prefixes for compatability in AGM_Realism by KoffeinFlummi
|
* Adds camera shake when firing
|
||||||
// Edited by commy2
|
* From TMR: Small Arms
|
||||||
|
*
|
||||||
|
* Arguments:
|
||||||
|
* 0: Unit <OBJECT>
|
||||||
|
* 1: Weapon <STRING>
|
||||||
|
* 3: Muzzle <STRING>
|
||||||
|
*
|
||||||
|
* Return Value:
|
||||||
|
* Nothing
|
||||||
|
*
|
||||||
|
* Example:
|
||||||
|
* [player, (currentWeapon player), (currentMuzzle player)] call ace_recoil_fnc_camShake;
|
||||||
|
*
|
||||||
|
* Public: No
|
||||||
|
*/
|
||||||
#include "script_component.hpp"
|
#include "script_component.hpp"
|
||||||
|
|
||||||
#define BASE_POWER 0.40
|
#define BASE_POWER 0.40
|
||||||
@ -9,28 +23,22 @@
|
|||||||
#define BASE_FREQ 13
|
#define BASE_FREQ 13
|
||||||
#define RECOIL_COEF 40
|
#define RECOIL_COEF 40
|
||||||
|
|
||||||
private ["_unit", "_weapon", "_muzzle"];
|
params ["_unit", "_weapon", "_muzzle"];
|
||||||
|
|
||||||
_unit = _this select 0;
|
|
||||||
_weapon = _this select 1;
|
|
||||||
_muzzle = _this select 2;
|
|
||||||
|
|
||||||
if (toLower _weapon in ["throw", "put"]) exitWith {};
|
if (toLower _weapon in ["throw", "put"]) exitWith {};
|
||||||
|
|
||||||
private ["_powerMod", "_timeMod", "_freqMod"];
|
private _powerMod = ([0, -0.1, -0.1, 0, -0.2] select (["STAND", "CROUCH", "PRONE", "UNDEFINED", ""] find stance _unit)) + ([0, -1, 0, -1] select (["INTERNAL", "EXTERNAL", "GUNNER", "GROUP"] find cameraView));
|
||||||
|
|
||||||
_powerMod = ([0, -0.1, -0.1, 0, -0.2] select (["STAND", "CROUCH", "PRONE", "UNDEFINED", ""] find stance _unit)) + ([0, -1, 0, -1] select (["INTERNAL", "EXTERNAL", "GUNNER", "GROUP"] find cameraView));
|
|
||||||
_timeMod = 0;
|
|
||||||
_freqMod = 0;
|
|
||||||
|
|
||||||
// to get camshake read kickback
|
// to get camshake read kickback
|
||||||
private ["_config", "_recoil"];
|
private _recoil = missionNamespace getVariable format [QGVAR(%1-%2), _weapon, _muzzle];
|
||||||
|
|
||||||
_config = configFile >> "CfgWeapons" >> _weapon;
|
if (isNil "_recoil") then {
|
||||||
_recoil = if (_muzzle == _weapon) then {
|
private _config = configFile >> "CfgWeapons" >> _weapon;
|
||||||
getText (_config >> "recoil")
|
|
||||||
|
if (_muzzle == _weapon) then {
|
||||||
|
_recoil = getText (_config >> "recoil")
|
||||||
} else {
|
} else {
|
||||||
getText (_config >> _muzzle >> "recoil")
|
_recoil = getText (_config >> _muzzle >> "recoil")
|
||||||
};
|
};
|
||||||
|
|
||||||
if (isClass (configFile >> "CfgRecoils" >> _recoil)) then {
|
if (isClass (configFile >> "CfgRecoils" >> _recoil)) then {
|
||||||
@ -42,26 +50,26 @@ if (isClass (configFile >> "CfgRecoils" >> _recoil)) then {
|
|||||||
_recoil = [0, 0];
|
_recoil = [0, 0];
|
||||||
};
|
};
|
||||||
|
|
||||||
|
TRACE_3("Caching Recoil config",_weapon,_muzzle,_recoil);
|
||||||
|
|
||||||
// parse numbers
|
// parse numbers
|
||||||
_recoil set [0, call compile format ["%1", _recoil select 0]];
|
_recoil set [0, call compile format ["%1", _recoil select 0]];
|
||||||
_recoil set [1, call compile format ["%1", _recoil select 1]];
|
_recoil set [1, call compile format ["%1", _recoil select 1]];
|
||||||
|
|
||||||
private "_powerCoef";
|
missionNamespace setVariable [format [QGVAR(%1-%2), _weapon, _muzzle], _recoil];
|
||||||
_powerCoef = RECOIL_COEF * linearConversion [0, 1, random 1, _recoil select 0, _recoil select 1, false];
|
};
|
||||||
|
|
||||||
|
private _powerCoef = RECOIL_COEF * linearConversion [0, 1, random 1, _recoil select 0, _recoil select 1, false];
|
||||||
|
|
||||||
if (isWeaponRested _unit) then {_powerMod = _powerMod - 0.07};
|
if (isWeaponRested _unit) then {_powerMod = _powerMod - 0.07};
|
||||||
if (isWeaponDeployed _unit) then {_powerMod = _powerMod - 0.11};
|
if (isWeaponDeployed _unit) then {_powerMod = _powerMod - 0.11};
|
||||||
|
|
||||||
private "_camshake";
|
private _camshake = [
|
||||||
_camshake = [
|
|
||||||
_powerCoef * (BASE_POWER + _powerMod) max 0,
|
_powerCoef * (BASE_POWER + _powerMod) max 0,
|
||||||
BASE_TIME + _timeMod max 0,
|
BASE_TIME,
|
||||||
BASE_FREQ + _freqMod max 0
|
BASE_FREQ
|
||||||
];
|
];
|
||||||
|
|
||||||
/*
|
TRACE_4("addCamShake",_recoil,_powerCoef,_powerMod,_camshake);\
|
||||||
systemChat str _camshake;
|
|
||||||
copyToClipboard format ["addCamShake %1;", _camshake];
|
|
||||||
*/
|
|
||||||
|
|
||||||
addCamShake _camshake;
|
addCamShake _camshake;
|
||||||
|
@ -7,9 +7,9 @@ if (!hasInterface) exitWith {};
|
|||||||
["ACE3 Weapons", QGVAR(checkAmmo), localize LSTRING(checkAmmo),
|
["ACE3 Weapons", QGVAR(checkAmmo), localize LSTRING(checkAmmo),
|
||||||
{
|
{
|
||||||
// Conditions: canInteract
|
// Conditions: canInteract
|
||||||
if !([ACE_player, (vehicle ACE_player), ["isNotInside", "isNotSitting"]] call EFUNC(common,canInteractWith)) exitWith {false};
|
if !([ACE_player, vehicle ACE_player, ["isNotInside", "isNotSitting"]] call EFUNC(common,canInteractWith)) exitWith {false};
|
||||||
// Conditions: specific
|
// Conditions: specific
|
||||||
if !([ACE_player] call EFUNC(common,canUseWeapon) || {(vehicle ACE_player) isKindOf "StaticWeapon"}) exitWith {false};
|
if !(ACE_player call EFUNC(common,canUseWeapon) || {(vehicle ACE_player) isKindOf "StaticWeapon"}) exitWith {false};
|
||||||
|
|
||||||
// Statement
|
// Statement
|
||||||
[ACE_player] call FUNC(checkAmmo);
|
[ACE_player] call FUNC(checkAmmo);
|
||||||
@ -20,26 +20,26 @@ if (!hasInterface) exitWith {};
|
|||||||
|
|
||||||
["setAmmoSync", {
|
["setAmmoSync", {
|
||||||
//To propagate the setAmmo change, do it on all clients
|
//To propagate the setAmmo change, do it on all clients
|
||||||
PARAMS_3(_unit,_weapon,_ammo);
|
params ["_unit", "_weapon", "_ammo"];
|
||||||
|
TRACE_3("setAmmoSync EH",_unit,_weapon,_ammo);
|
||||||
|
|
||||||
_unit setAmmo [_weapon, _ammo];
|
_unit setAmmo [_weapon, _ammo];
|
||||||
}] call EFUNC(common,addEventhandler);
|
}] call EFUNC(common,addEventhandler);
|
||||||
|
|
||||||
// Listen for attempts to link ammo
|
// Listen for attempts to link ammo
|
||||||
["linkedAmmo", {
|
["linkedAmmo", {
|
||||||
EXPLODE_3_PVT(_this,_receiver,_giver,_magazine);
|
params ["_receiver", "_giver", "_magazine"];
|
||||||
|
|
||||||
private ["_magazineCfg","_magazineType"];
|
private _magazineType = currentMagazine _receiver;
|
||||||
_magazineType = currentMagazine _receiver;
|
private _magazineCfg = configFile >> "CfgMagazines" >> _magazineType;
|
||||||
_magazineCfg = configFile >> "CfgMagazines" >> _magazineType;
|
|
||||||
|
|
||||||
// Return the magazine if it's the wrong type
|
// Return the magazine if it's the wrong type
|
||||||
if (_magazineType != (_magazine select 0)) exitWith {
|
if (_magazineType != (_magazine select 0)) exitWith {
|
||||||
["returnedAmmo", [_giver], [_giver,_receiver,_magazine]] call EFUNC(common,targetEvent);
|
["returnedAmmo", [_giver], [_giver,_receiver,_magazine]] call EFUNC(common,targetEvent);
|
||||||
};
|
};
|
||||||
|
|
||||||
private ["_ammoCount","_ammoMissing","_ammoAdded","_ammoRemaining"];
|
private _ammoCount = _receiver ammo currentWeapon _receiver;
|
||||||
_ammoCount = _receiver ammo currentWeapon _receiver;
|
private _ammoMissing = getNumber (_magazineCfg >> "count") - _ammoCount;
|
||||||
_ammoMissing = getNumber (_magazineCfg >> "count") - _ammoCount;
|
|
||||||
|
|
||||||
// Return the magazine if the belt is full or empty
|
// Return the magazine if the belt is full or empty
|
||||||
if ((_ammoCount == 0) || _ammoMissing == 0) exitWith {
|
if ((_ammoCount == 0) || _ammoMissing == 0) exitWith {
|
||||||
@ -47,19 +47,18 @@ if (!hasInterface) exitWith {};
|
|||||||
};
|
};
|
||||||
|
|
||||||
// Add the ammo
|
// Add the ammo
|
||||||
_ammoAdded = _ammoMissing min (_magazine select 1);
|
private _ammoAdded = _ammoMissing min (_magazine select 1);
|
||||||
["setAmmoSync", [_receiver, (currentWeapon _receiver), (_ammoCount + _ammoAdded)]] call EFUNC(common,globalEvent);
|
["setAmmoSync", [_receiver, currentWeapon _receiver, _ammoCount + _ammoAdded]] call EFUNC(common,globalEvent);
|
||||||
|
|
||||||
if ((_magazine select 1) - _ammoAdded > 0) then {
|
if ((_magazine select 1) - _ammoAdded > 0) then {
|
||||||
["returnedAmmo", [_giver], [_giver, _receiver, [_magazineType, (_magazine select 1) - _ammoAdded]]] call EFUNC(common,targetEvent);
|
["returnedAmmo", [_giver], [_giver, _receiver, [_magazineType, (_magazine select 1) - _ammoAdded]]] call EFUNC(common,targetEvent);
|
||||||
};
|
};
|
||||||
|
|
||||||
}] call EFUNC(common,addEventhandler);
|
}] call EFUNC(common,addEventhandler);
|
||||||
|
|
||||||
|
|
||||||
// Listen for returned magazines
|
// Listen for returned magazines
|
||||||
["returnedAmmo", {
|
["returnedAmmo", {
|
||||||
EXPLODE_3_PVT(_this,_receiver,_giver,_magazine);
|
params ["_receiver", "", "_magazine"];
|
||||||
|
TRACE_2("returnedAmmo EH",_receiver,_magazine);
|
||||||
|
|
||||||
_receiver addMagazine _magazine;
|
_receiver addMagazine _magazine;
|
||||||
}] call EFUNC(common,addEventhandler);
|
}] call EFUNC(common,addEventhandler);
|
||||||
|
@ -11,26 +11,24 @@
|
|||||||
*/
|
*/
|
||||||
#include "script_component.hpp"
|
#include "script_component.hpp"
|
||||||
|
|
||||||
EXPLODE_2_PVT(_this,_player,_target);
|
params ["_player", "_target"];
|
||||||
|
|
||||||
if (vehicle _target != _target) exitWith {false};
|
if (vehicle _target != _target) exitWith {false};
|
||||||
|
|
||||||
private ["_magazineCfg","_magazineType"];
|
private _magazineType = currentMagazine _target;
|
||||||
_magazineType = currentMagazine _target;
|
private _magazineCfg = configFile >> "CfgMagazines" >> _magazineType;
|
||||||
_magazineCfg = configFile >> "CfgMagazines" >> _magazineType;
|
|
||||||
if (getNumber (_magazineCfg >> "ACE_isBelt") == 0) exitWith {false};
|
if (getNumber (_magazineCfg >> "ACE_isBelt") == 0) exitWith {false};
|
||||||
|
|
||||||
// Check if the ammo is not empty or full
|
// Check if the ammo is not empty or full
|
||||||
private "_ammoCount";
|
private _ammoCount = _target ammo currentWeapon _target;
|
||||||
_ammoCount = _target ammo currentWeapon _target;
|
|
||||||
|
|
||||||
// Exit if the belt is full or empty
|
// Exit if the belt is full or empty
|
||||||
if ((_ammoCount == 0) || (getNumber (_magazineCfg >> "count") - _ammoCount) == 0) exitWith {false};
|
if (_ammoCount == 0 || getNumber (_magazineCfg >> "count") - _ammoCount == 0) exitWith {false};
|
||||||
|
|
||||||
// Check if the player has any of the same magazines
|
// Check if the player has any of the same magazines
|
||||||
// Calculate max ammo
|
// Calculate max ammo
|
||||||
private "_maxAmmo";
|
private _maxAmmo = 0;
|
||||||
_maxAmmo = 0;
|
|
||||||
|
|
||||||
{
|
{
|
||||||
_maxAmmo = _maxAmmo max (_x select 1);
|
_maxAmmo = _maxAmmo max (_x select 1);
|
||||||
|
@ -13,10 +13,9 @@
|
|||||||
|
|
||||||
#define COUNT_BARS 12
|
#define COUNT_BARS 12
|
||||||
|
|
||||||
EXPLODE_1_PVT(_this,_unit);
|
params ["_unit"];
|
||||||
|
|
||||||
private ["_target"];
|
private _target = vehicle _unit;
|
||||||
_target = vehicle _unit;
|
|
||||||
|
|
||||||
if (count _this > 1) then {
|
if (count _this > 1) then {
|
||||||
_target = _this select 1;
|
_target = _this select 1;
|
||||||
|
@ -14,11 +14,9 @@
|
|||||||
|
|
||||||
EXPLODE_1_PVT(_this,_target);
|
EXPLODE_1_PVT(_this,_target);
|
||||||
|
|
||||||
private ["_weapon","_muzzle","_magazine","_showNumber","_ammo","_maxRounds","_count","_text","_color","_picture","_ammoBarsStructuredText", "_a", "_loadedName", "_string"];
|
private _weapon = currentWeapon _target;
|
||||||
|
private _muzzle = currentMuzzle _target;
|
||||||
_weapon = currentWeapon _target;
|
private _magazine = currentMagazine _target;
|
||||||
_muzzle = currentMuzzle _target;
|
|
||||||
_magazine = currentMagazine _target;
|
|
||||||
|
|
||||||
// currentWeapon returns "" for static weapons before they are shot once
|
// currentWeapon returns "" for static weapons before they are shot once
|
||||||
if (_target isKindOf "StaticWeapon") then {
|
if (_target isKindOf "StaticWeapon") then {
|
||||||
@ -31,8 +29,8 @@ if (_target isKindOf "StaticWeapon") then {
|
|||||||
|
|
||||||
if (_magazine == "") then {
|
if (_magazine == "") then {
|
||||||
// Try to get magazine using magazinesAmmoFull
|
// Try to get magazine using magazinesAmmoFull
|
||||||
private ["_magazines"];
|
private _magazines = magazinesAmmoFull _target;
|
||||||
_magazines = magazinesAmmoFull _target;
|
|
||||||
{
|
{
|
||||||
if (_x select 2) exitWith {
|
if (_x select 2) exitWith {
|
||||||
_magazine = _x select 0;
|
_magazine = _x select 0;
|
||||||
@ -45,10 +43,10 @@ if (_magazine == "") exitWith {};
|
|||||||
if (_weapon == "") exitWith {};
|
if (_weapon == "") exitWith {};
|
||||||
if (!( _muzzle isEqualType "")) then {_muzzle = _weapon};
|
if (!( _muzzle isEqualType "")) then {_muzzle = _weapon};
|
||||||
|
|
||||||
_showNumber = false;
|
private _showNumber = false;
|
||||||
_ammo = 0;
|
private _ammo = 0;
|
||||||
_maxRounds = 1;
|
private _maxRounds = 1;
|
||||||
_count = 0;
|
private _count = 0;
|
||||||
|
|
||||||
// not grenade launcher
|
// not grenade launcher
|
||||||
if (_muzzle == _weapon) then {
|
if (_muzzle == _weapon) then {
|
||||||
@ -75,16 +73,16 @@ if (_muzzle == _weapon) then {
|
|||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
_ammoBarsStructuredText = if (_showNumber) then {
|
private _ammoBarsStructuredText = if (_showNumber) then {
|
||||||
parseText format ["<t align='center' >%1x</t>", _count]
|
parseText format ["<t align='center' >%1x</t>", _count]
|
||||||
} else {
|
} else {
|
||||||
_color = [((2 * (1 - _ammo / _maxRounds)) min 1), ((2 * _ammo / _maxRounds) min 1), 0];
|
private _color = [((2 * (1 - _ammo / _maxRounds)) min 1), ((2 * _ammo / _maxRounds) min 1), 0];
|
||||||
|
|
||||||
_string = "";
|
private _string = "";
|
||||||
for "_a" from 1 to _count do {
|
for "_a" from 1 to _count do {
|
||||||
_string = _string + "|";
|
_string = _string + "|";
|
||||||
};
|
};
|
||||||
_text = [_string, _color] call EFUNC(common,stringToColoredText);
|
private _text = [_string, _color] call EFUNC(common,stringToColoredText);
|
||||||
|
|
||||||
_string = "";
|
_string = "";
|
||||||
for "_a" from (_count + 1) to (_maxRounds min COUNT_BARS) do {
|
for "_a" from (_count + 1) to (_maxRounds min COUNT_BARS) do {
|
||||||
@ -97,11 +95,11 @@ _ammoBarsStructuredText = if (_showNumber) then {
|
|||||||
|
|
||||||
if (_target isKindOf "StaticWeapon") then {
|
if (_target isKindOf "StaticWeapon") then {
|
||||||
//Vehicle mags (usualy) don't have pictures, so just show the text above ammo count
|
//Vehicle mags (usualy) don't have pictures, so just show the text above ammo count
|
||||||
_loadedName = getText (configFile >> "CfgMagazines" >> _magazine >> "displaynameshort");
|
private _loadedName = getText (configFile >> "CfgMagazines" >> _magazine >> "displaynameshort");
|
||||||
_loadedName = parseText format ["<t align='center' >%1</t>", _loadedName];
|
_loadedName = parseText format ["<t align='center' >%1</t>", _loadedName];
|
||||||
_text = composeText [_loadedName, linebreak, _ammoBarsStructuredText];
|
private _text = composeText [_loadedName, linebreak, _ammoBarsStructuredText];
|
||||||
[_text] call EFUNC(common,displayTextStructured);
|
[_text] call EFUNC(common,displayTextStructured);
|
||||||
} else {
|
} else {
|
||||||
_picture = getText (configFile >> "CfgMagazines" >> _magazine >> "picture");
|
private _picture = getText (configFile >> "CfgMagazines" >> _magazine >> "picture");
|
||||||
[_ammoBarsStructuredText, _picture] call EFUNC(common,displayTextPicture);
|
[_ammoBarsStructuredText, _picture] call EFUNC(common,displayTextPicture);
|
||||||
};
|
};
|
||||||
|
@ -11,26 +11,24 @@
|
|||||||
*/
|
*/
|
||||||
#include "script_component.hpp"
|
#include "script_component.hpp"
|
||||||
|
|
||||||
EXPLODE_2_PVT(_this,_player,_target);
|
params ["_player", "_target"];
|
||||||
|
|
||||||
if (vehicle _target != _target) exitWith {false};
|
if (vehicle _target != _target) exitWith {false};
|
||||||
|
|
||||||
private ["_magazineCfg","_magazineType", "_condition", "_onFailure", "_onFinish"];
|
private _magazineType = currentMagazine _target;
|
||||||
_magazineType = currentMagazine _target;
|
private _magazineCfg = configFile >> "CfgMagazines" >> _magazineType;
|
||||||
_magazineCfg = configFile >> "CfgMagazines" >> _magazineType;
|
|
||||||
if (getNumber (_magazineCfg >> "ACE_isBelt") == 0) exitWith {false};
|
if (getNumber (_magazineCfg >> "ACE_isBelt") == 0) exitWith {false};
|
||||||
|
|
||||||
// Check if the ammo is not empty or full
|
// Check if the ammo is not empty or full
|
||||||
private "_ammoCount";
|
private _ammoCount = _target ammo currentWeapon _target;
|
||||||
_ammoCount = _target ammo currentWeapon _target;
|
|
||||||
|
|
||||||
// Exit if the belt is full or empty
|
// Exit if the belt is full or empty
|
||||||
if ((_ammoCount == 0) || (getNumber (_magazineCfg >> "count") - _ammoCount) == 0) exitWith {false};
|
if ((_ammoCount == 0) || (getNumber (_magazineCfg >> "count") - _ammoCount) == 0) exitWith {false};
|
||||||
|
|
||||||
// Check if the player has any of the same same magazines
|
// Check if the player has any of the same same magazines
|
||||||
// Calculate max ammo it can link
|
// Calculate max ammo it can link
|
||||||
private "_maxAmmo";
|
private _maxAmmo = 0;
|
||||||
_maxAmmo = 0;
|
|
||||||
|
|
||||||
{
|
{
|
||||||
_maxAmmo = _maxAmmo max (_x select 1);
|
_maxAmmo = _maxAmmo max (_x select 1);
|
||||||
@ -38,21 +36,20 @@ _maxAmmo = 0;
|
|||||||
|
|
||||||
if (_maxAmmo == 0) exitWith {};
|
if (_maxAmmo == 0) exitWith {};
|
||||||
|
|
||||||
|
|
||||||
// Condition to call each frame
|
// Condition to call each frame
|
||||||
_condition = {
|
private _condition = {
|
||||||
EXPLODE_2_PVT((_this select 0),_player,_target);
|
(_this select 0) params ["_player", "_target"];
|
||||||
([_player, _target, []] call EFUNC(common,canInteractWith)) && ((_player distance _target) < 3) && ((speed _target) < 1)
|
([_player, _target, []] call EFUNC(common,canInteractWith)) && ((_player distance _target) < 3) && ((speed _target) < 1)
|
||||||
};
|
};
|
||||||
|
|
||||||
_onFinish = {
|
private _onFinish = {
|
||||||
EXPLODE_3_PVT((_this select 0),_player,_target,_magazine);
|
(_this select 0) params ["_player", "_target", "_magazine"];
|
||||||
|
|
||||||
// Raise event on remote unit
|
// Raise event on remote unit
|
||||||
["linkedAmmo", [_target], [_target, _player, _magazine]] call EFUNC(common,targetEvent);
|
["linkedAmmo", [_target], [_target, _player, _magazine]] call EFUNC(common,targetEvent);
|
||||||
};
|
};
|
||||||
|
|
||||||
_onFailure = {
|
private _onFailure = {
|
||||||
EXPLODE_3_PVT((_this select 0),_player,_target,_magazine);
|
EXPLODE_3_PVT((_this select 0),_player,_target,_magazine);
|
||||||
[_player, "AmovPknlMstpSrasWrflDnon", 1] call EFUNC(common,doAnimation);
|
[_player, "AmovPknlMstpSrasWrflDnon", 1] call EFUNC(common,doAnimation);
|
||||||
|
|
||||||
|
@ -16,8 +16,6 @@
|
|||||||
*/
|
*/
|
||||||
#include "script_component.hpp"
|
#include "script_component.hpp"
|
||||||
|
|
||||||
private "_maxSpeed";
|
|
||||||
|
|
||||||
params ["_driver", "_vehicle"];
|
params ["_driver", "_vehicle"];
|
||||||
|
|
||||||
if (GVAR(isSpeedLimiter)) exitWith {
|
if (GVAR(isSpeedLimiter)) exitWith {
|
||||||
@ -30,7 +28,7 @@ if (GVAR(isSpeedLimiter)) exitWith {
|
|||||||
playSound "ACE_Sound_Click";
|
playSound "ACE_Sound_Click";
|
||||||
GVAR(isSpeedLimiter) = true;
|
GVAR(isSpeedLimiter) = true;
|
||||||
|
|
||||||
_maxSpeed = speed _vehicle max 10;
|
private _maxSpeed = speed _vehicle max 10;
|
||||||
|
|
||||||
[{
|
[{
|
||||||
params ["_args", "_idPFH"];
|
params ["_args", "_idPFH"];
|
||||||
@ -51,8 +49,7 @@ _maxSpeed = speed _vehicle max 10;
|
|||||||
[_idPFH] call CBA_fnc_removePerFrameHandler;
|
[_idPFH] call CBA_fnc_removePerFrameHandler;
|
||||||
};
|
};
|
||||||
|
|
||||||
private "_speed";
|
private _speed = speed _vehicle;
|
||||||
_speed = speed _vehicle;
|
|
||||||
|
|
||||||
if (_speed > _maxSpeed) then {
|
if (_speed > _maxSpeed) then {
|
||||||
_vehicle setVelocity ((velocity _vehicle) vectorMultiply ((_maxSpeed / _speed) - 0.00001)); // fix 1.42-hotfix PhysX libraries applying force in previous direction when turning
|
_vehicle setVelocity ((velocity _vehicle) vectorMultiply ((_maxSpeed / _speed) - 0.00001)); // fix 1.42-hotfix PhysX libraries applying force in previous direction when turning
|
||||||
|
@ -105,8 +105,7 @@ if (!hasInterface) exitWith {};
|
|||||||
if ((currentWeapon ACE_player) != "") then {
|
if ((currentWeapon ACE_player) != "") then {
|
||||||
[ACE_player] call FUNC(putWeaponAway);
|
[ACE_player] call FUNC(putWeaponAway);
|
||||||
} else {
|
} else {
|
||||||
private ["_weapon"];
|
private _weapon = switch (true) do {
|
||||||
_weapon = switch (true) do {
|
|
||||||
case ((primaryWeapon ACE_player) != ""): {primaryWeapon ACE_player};
|
case ((primaryWeapon ACE_player) != ""): {primaryWeapon ACE_player};
|
||||||
case ((handgunWeapon ACE_player) != ""): {handgunWeapon ACE_player};
|
case ((handgunWeapon ACE_player) != ""): {handgunWeapon ACE_player};
|
||||||
case ((secondaryWeapon ACE_player) != ""): {secondaryWeapon ACE_player};
|
case ((secondaryWeapon ACE_player) != ""): {secondaryWeapon ACE_player};
|
||||||
|
@ -17,16 +17,14 @@ GVAR(GrenadesAll) = [];
|
|||||||
GVAR(GrenadesFrag) = [];
|
GVAR(GrenadesFrag) = [];
|
||||||
GVAR(GrenadesNonFrag) = [];
|
GVAR(GrenadesNonFrag) = [];
|
||||||
|
|
||||||
private ["_magazines", "_ammo", "_explosive"];
|
|
||||||
|
|
||||||
{
|
{
|
||||||
_magazines = getArray (configFile >> "CfgWeapons" >> "Throw" >> _x >> "magazines");
|
private _magazines = getArray (configFile >> "CfgWeapons" >> "Throw" >> _x >> "magazines");
|
||||||
|
|
||||||
GVAR(GrenadesAll) append _magazines;
|
GVAR(GrenadesAll) append _magazines;
|
||||||
|
|
||||||
{
|
{
|
||||||
_ammo = getText (configFile >> "CfgMagazines" >> _x >> "ammo");
|
private _ammo = getText (configFile >> "CfgMagazines" >> _x >> "ammo");
|
||||||
_explosive = getNumber (configFile >> "CfgAmmo" >> _ammo >> "explosive");
|
private _explosive = getNumber (configFile >> "CfgAmmo" >> _ammo >> "explosive");
|
||||||
|
|
||||||
([GVAR(GrenadesFrag), GVAR(GrenadesNonFrag)] select (_explosive == 0)) pushBack _x;
|
([GVAR(GrenadesFrag), GVAR(GrenadesNonFrag)] select (_explosive == 0)) pushBack _x;
|
||||||
false
|
false
|
||||||
|
@ -20,12 +20,10 @@ if !(GVAR(DisplayText)) exitWith {};
|
|||||||
|
|
||||||
params ["_magazine", "_numberofGrenades"];
|
params ["_magazine", "_numberofGrenades"];
|
||||||
|
|
||||||
private ["_color", "_name", "_text", "_picture"];
|
private _color = [[1, 0, 0], [1, 1, 1]] select (_numberofGrenades > 0);
|
||||||
|
private _name = getText (configFile >> "CfgMagazines" >> _magazine >> "displayNameShort");
|
||||||
|
|
||||||
_color = [[1, 0, 0], [1, 1, 1]] select (_numberofGrenades > 0);
|
private _text = [format ["%1 x%2", _name, _numberofGrenades], _color] call EFUNC(common,stringToColoredText);
|
||||||
_name = getText (configFile >> "CfgMagazines" >> _magazine >> "displayNameShort");
|
private _picture = getText (configFile >> "CfgMagazines" >> _magazine >> "picture");
|
||||||
|
|
||||||
_text = [format ["%1 x%2", _name, _numberofGrenades], _color] call EFUNC(common,stringToColoredText);
|
|
||||||
_picture = getText (configFile >> "CfgMagazines" >> _magazine >> "picture");
|
|
||||||
|
|
||||||
["displayTextPicture", [_text, _picture]] call EFUNC(common,localEvent);
|
["displayTextPicture", [_text, _picture]] call EFUNC(common,localEvent);
|
||||||
|
@ -17,11 +17,8 @@
|
|||||||
|
|
||||||
params ["_vehicle"];
|
params ["_vehicle"];
|
||||||
|
|
||||||
private ["_turret", "_weapons"];
|
private _turret = _vehicle call EFUNC(common,getTurretCommander);
|
||||||
|
private _weapons = _vehicle weaponsTurret _turret;
|
||||||
_turret = [_vehicle] call EFUNC(common,getTurretCommander);
|
|
||||||
|
|
||||||
_weapons = _vehicle weaponsTurret _turret;
|
|
||||||
|
|
||||||
if (
|
if (
|
||||||
count _weapons > 1
|
count _weapons > 1
|
||||||
@ -32,8 +29,8 @@ if (
|
|||||||
// avoid infinite loop
|
// avoid infinite loop
|
||||||
if !("SmokeLauncher" in _weapons) exitWith {};
|
if !("SmokeLauncher" in _weapons) exitWith {};
|
||||||
|
|
||||||
private "_index";
|
private _index = 0;
|
||||||
_index = 0;
|
|
||||||
while {
|
while {
|
||||||
_vehicle currentWeaponTurret _turret != "SmokeLauncher"
|
_vehicle currentWeaponTurret _turret != "SmokeLauncher"
|
||||||
} do {
|
} do {
|
||||||
@ -44,8 +41,7 @@ if (
|
|||||||
} else {
|
} else {
|
||||||
// fire away!
|
// fire away!
|
||||||
|
|
||||||
private "_logic";
|
private _logic = createGroup sideLogic createUnit ["Logic", [0,0,0], [], 0, "NONE"];
|
||||||
_logic = createGroup sideLogic createUnit ["Logic", [0,0,0], [], 0, "NONE"];
|
|
||||||
|
|
||||||
_logic action ["useWeapon", _vehicle, commander _vehicle, 0];
|
_logic action ["useWeapon", _vehicle, commander _vehicle, 0];
|
||||||
|
|
||||||
|
@ -18,14 +18,12 @@
|
|||||||
|
|
||||||
params ["_unit", "_weapon"];
|
params ["_unit", "_weapon"];
|
||||||
|
|
||||||
private ["_sound", "_position"];
|
private _sound = getArray (configFile >> "CfgWeapons" >> _weapon >> "changeFiremodeSound");
|
||||||
|
|
||||||
_sound = getArray (configFile >> "CfgWeapons" >> _weapon >> "changeFiremodeSound");
|
|
||||||
|
|
||||||
if (_sound isEqualTo []) exitWith {};
|
if (_sound isEqualTo []) exitWith {};
|
||||||
|
|
||||||
// get position where to play the sound (position of the weapon)
|
// get position where to play the sound (position of the weapon)
|
||||||
_position = AGLToASL (_unit modelToWorldVisual (_unit selectionPosition "RightHand"));
|
private _position = AGLToASL (_unit modelToWorldVisual (_unit selectionPosition "RightHand"));
|
||||||
|
|
||||||
_sound params ["_filename", ["_volume", 1], ["_soundPitch", 1], ["_distance", 0]];
|
_sound params ["_filename", ["_volume", 1], ["_soundPitch", 1], ["_distance", 0]];
|
||||||
|
|
||||||
|
@ -17,6 +17,6 @@
|
|||||||
|
|
||||||
params ["_unit"];
|
params ["_unit"];
|
||||||
|
|
||||||
[_unit] call EFUNC(common,fixLoweredRifleAnimation);
|
_unit call EFUNC(common,fixLoweredRifleAnimation);
|
||||||
|
|
||||||
_unit action ["SwitchWeapon", _unit, _unit, 99];
|
_unit action ["SwitchWeapon", _unit, _unit, 99];
|
||||||
|
@ -18,10 +18,8 @@
|
|||||||
|
|
||||||
params ["_unit", ["_type", 0]];
|
params ["_unit", ["_type", 0]];
|
||||||
|
|
||||||
private ["_currentGrenade", "_magazines", "_grenades", "_nextGrenadeIndex", "_nextGrenade", "_uniformGrenades", "_vestGrenades", "_backpackGrenades"];
|
|
||||||
|
|
||||||
// get currently selected grenade
|
// get currently selected grenade
|
||||||
_currentGrenade = currentThrowable _unit;
|
private _currentGrenade = currentThrowable _unit;
|
||||||
|
|
||||||
// get correct array format if no grenade is selected
|
// get correct array format if no grenade is selected
|
||||||
if (_currentGrenade isEqualTo []) then {
|
if (_currentGrenade isEqualTo []) then {
|
||||||
@ -31,9 +29,9 @@ if (_currentGrenade isEqualTo []) then {
|
|||||||
_currentGrenade = _currentGrenade select 0;
|
_currentGrenade = _currentGrenade select 0;
|
||||||
|
|
||||||
// get available magazines for that unit
|
// get available magazines for that unit
|
||||||
_magazines = magazines _unit;
|
private _magazines = magazines _unit;
|
||||||
|
|
||||||
_grenades = [];
|
private _grenades = [];
|
||||||
|
|
||||||
{
|
{
|
||||||
if (_x in _magazines) then {
|
if (_x in _magazines) then {
|
||||||
@ -46,22 +44,22 @@ _grenades = [];
|
|||||||
if (_grenades isEqualTo []) exitWith {false};
|
if (_grenades isEqualTo []) exitWith {false};
|
||||||
|
|
||||||
// get next grenade muzzle
|
// get next grenade muzzle
|
||||||
_nextGrenadeIndex = (_grenades find _currentGrenade) + 1;
|
private _nextGrenadeIndex = (_grenades find _currentGrenade) + 1;
|
||||||
|
|
||||||
// roll over if the last grenade was selected
|
// roll over if the last grenade was selected
|
||||||
if (_nextGrenadeIndex >= count _grenades) then {
|
if (_nextGrenadeIndex >= count _grenades) then {
|
||||||
_nextGrenadeIndex = 0;
|
_nextGrenadeIndex = 0;
|
||||||
};
|
};
|
||||||
|
|
||||||
_nextGrenade = _grenades select _nextGrenadeIndex;
|
private _nextGrenade = _grenades select _nextGrenadeIndex;
|
||||||
|
|
||||||
// abort if the same grenade would be selected
|
// abort if the same grenade would be selected
|
||||||
if (_currentGrenade == _nextGrenade) exitWith {false};
|
if (_currentGrenade == _nextGrenade) exitWith {false};
|
||||||
|
|
||||||
// current best method to select a grenade: remove all grenades except the one you want to select, then add them back
|
// current best method to select a grenade: remove all grenades except the one you want to select, then add them back
|
||||||
_uniformGrenades = [uniformItems _unit, {_x in GVAR(GrenadesAll) && {_x != _nextGrenade}}] call EFUNC(common,filter);
|
private _uniformGrenades = [uniformItems _unit, {_x in GVAR(GrenadesAll) && {_x != _nextGrenade}}] call EFUNC(common,filter);
|
||||||
_vestGrenades = [vestItems _unit, {_x in GVAR(GrenadesAll) && {_x != _nextGrenade}}] call EFUNC(common,filter);
|
private _vestGrenades = [vestItems _unit, {_x in GVAR(GrenadesAll) && {_x != _nextGrenade}}] call EFUNC(common,filter);
|
||||||
_backpackGrenades = [backpackItems _unit, {_x in GVAR(GrenadesAll) && {_x != _nextGrenade}}] call EFUNC(common,filter);
|
private _backpackGrenades = [backpackItems _unit, {_x in GVAR(GrenadesAll) && {_x != _nextGrenade}}] call EFUNC(common,filter);
|
||||||
|
|
||||||
// remove all grenades except those we are switching to --> this breaks the selector
|
// remove all grenades except those we are switching to --> this breaks the selector
|
||||||
{_unit removeItemFromUniform _x; false} count _uniformGrenades;
|
{_unit removeItemFromUniform _x; false} count _uniformGrenades;
|
||||||
|
@ -29,20 +29,18 @@ if (_weapon in (_unit getVariable [QEGVAR(safemode,safedWeapons), []])) exitWith
|
|||||||
[_unit, _weapon, _weapon] call EFUNC(safemode,unlockSafety);
|
[_unit, _weapon, _weapon] call EFUNC(safemode,unlockSafety);
|
||||||
};
|
};
|
||||||
|
|
||||||
private ["_muzzles", "_modes"];
|
private _muzzles = [_weapon] call EFUNC(common,getWeaponMuzzles);
|
||||||
|
private _modes = [_weapon] call EFUNC(common,getWeaponModes);
|
||||||
|
|
||||||
_muzzles = [_weapon] call EFUNC(common,getWeaponMuzzles);
|
private _index = (_modes find currentWeaponMode _unit) + 1;
|
||||||
_modes = [_weapon] call EFUNC(common,getWeaponModes);
|
|
||||||
|
|
||||||
private ["_index", "_muzzle", "_mode"];
|
|
||||||
|
|
||||||
_index = (_modes find currentWeaponMode _unit) + 1;
|
|
||||||
if (_index > count _modes - 1) then {_index = 0};
|
if (_index > count _modes - 1) then {_index = 0};
|
||||||
|
|
||||||
_muzzle = _muzzles select 0;
|
private _muzzle = _muzzles select 0;
|
||||||
_mode = _modes select _index;
|
private _mode = _modes select _index;
|
||||||
|
|
||||||
_index = 0;
|
_index = 0;
|
||||||
|
|
||||||
while {
|
while {
|
||||||
_index < 100 && {currentMuzzle _unit != _muzzle || {currentWeaponMode _unit != _mode}}
|
_index < 100 && {currentMuzzle _unit != _muzzle || {currentWeaponMode _unit != _mode}}
|
||||||
} do {
|
} do {
|
||||||
|
@ -20,8 +20,7 @@ params ["_unit", "_weapon"];
|
|||||||
|
|
||||||
if (_weapon == "") exitWith {};
|
if (_weapon == "") exitWith {};
|
||||||
|
|
||||||
private "_muzzles";
|
private _muzzles = _weapon call EFUNC(common,getWeaponMuzzles);
|
||||||
_muzzles = [_weapon] call EFUNC(common,getWeaponMuzzles);
|
|
||||||
|
|
||||||
if (currentWeapon _unit != _weapon) exitWith {
|
if (currentWeapon _unit != _weapon) exitWith {
|
||||||
if (count _muzzles > 1) then {
|
if (count _muzzles > 1) then {
|
||||||
@ -35,12 +34,11 @@ if (currentWeapon _unit != _weapon) exitWith {
|
|||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
private ["_index", "_muzzle"];
|
private _index = (_muzzles find currentMuzzle _unit) + 1;
|
||||||
|
|
||||||
_index = (_muzzles find currentMuzzle _unit) + 1;
|
|
||||||
if (_index > count _muzzles - 1) then {_index = 1};
|
if (_index > count _muzzles - 1) then {_index = 1};
|
||||||
|
|
||||||
_muzzle = _muzzles select _index;
|
private _muzzle = _muzzles select _index;
|
||||||
|
|
||||||
_index = 0;
|
_index = 0;
|
||||||
while {
|
while {
|
||||||
|
@ -19,39 +19,36 @@
|
|||||||
|
|
||||||
params ["_unit", "_vehicle", "_index"];
|
params ["_unit", "_vehicle", "_index"];
|
||||||
|
|
||||||
private "_turret";
|
private _turret = _unit call EFUNC(common,getTurretIndex);
|
||||||
_turret = [_unit] call EFUNC(common,getTurretIndex);
|
|
||||||
|
|
||||||
if (_turret isEqualTo [] && {_unit == driver _vehicle}) then {
|
if (_turret isEqualTo [] && {_unit == driver _vehicle}) then {
|
||||||
private ["_weapons", "_weapon"];
|
private _weapons = weapons _vehicle;
|
||||||
|
|
||||||
_weapons = weapons _vehicle;
|
|
||||||
if (_index > count _weapons - 1) exitWith {};
|
if (_index > count _weapons - 1) exitWith {};
|
||||||
|
|
||||||
_weapon = _weapons select _index;
|
private _weapon = _weapons select _index;
|
||||||
|
|
||||||
_index = 0;
|
_index = 0;
|
||||||
|
|
||||||
while {
|
while {
|
||||||
_index < 100 && {currentWeapon _vehicle != _weapon}
|
_index < 100 && {currentWeapon _vehicle != _weapon}
|
||||||
} do {
|
} do {
|
||||||
_unit action ["SwitchWeapon", _vehicle, _unit, _index];
|
_unit action ["SwitchWeapon", _vehicle, _unit, _index];
|
||||||
_index = _index + 1;
|
_index = _index + 1;
|
||||||
};
|
};
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
private ["_weapons", "_weapon"];
|
private _weapons = _vehicle weaponsTurret _turret;
|
||||||
|
|
||||||
_weapons = _vehicle weaponsTurret _turret;
|
|
||||||
if (_index > count _weapons - 1) exitWith {};
|
if (_index > count _weapons - 1) exitWith {};
|
||||||
|
|
||||||
_weapon = _weapons select _index;
|
private _weapon = _weapons select _index;
|
||||||
|
|
||||||
_index = 0;
|
_index = 0;
|
||||||
|
|
||||||
while {
|
while {
|
||||||
_index < 100 && {_vehicle currentWeaponTurret _turret != _weapon}
|
_index < 100 && {_vehicle currentWeaponTurret _turret != _weapon}
|
||||||
} do {
|
} do {
|
||||||
_unit action ["SwitchWeapon", _vehicle, _unit, _index];
|
_unit action ["SwitchWeapon", _vehicle, _unit, _index];
|
||||||
_index = _index + 1;
|
_index = _index + 1;
|
||||||
};
|
};
|
||||||
|
|
||||||
};
|
};
|
||||||
|
@ -25,8 +25,7 @@ params ["_unit", "_weapon", "", "", "", "_magazine"];
|
|||||||
|
|
||||||
if (_weapon != "Throw") exitWith {};
|
if (_weapon != "Throw") exitWith {};
|
||||||
|
|
||||||
private "_count";
|
private _count = {_x == _magazine} count magazines _unit;
|
||||||
_count = {_x == _magazine} count magazines _unit;
|
|
||||||
|
|
||||||
[_magazine, _count] call FUNC(displayGrenadeTypeAndNumber);
|
[_magazine, _count] call FUNC(displayGrenadeTypeAndNumber);
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user