mirror of
https://github.com/acemod/ACE3.git
synced 2024-08-30 18:23:18 +00:00
33dc7e3dbd
* Create fnc_checkWeaponDrop.sqf * Update fnc_checkWeaponDrop.sqf * Create XEH_postInit.sqf * Update XEH_postInit.sqf * Update XEH_postInit.sqf * Update fnc_checkWeaponDrop.sqf * fix spelling issue * Update initSettings.sqf Add weaponDropEnabled setting * Update stringtable.xml * Update fnc_checkWeaponDrop.sqf * Update initSettings.sqf Forgot a bracket * Add weapon drop chance setting * Update XEH_postInit.sqf * Update CfgEventHandlers.hpp actually make it run postinit * Update XEH_PREP.hpp * Update stringtable.xml * Update initSettings.sqf No need, set chance to 0 * Update XEH_postInit.sqf already comparing against chance, can just set to 0 * Update initSettings.sqf * Update stringtable.xml * Update XEH_postInit.sqf * add arm hit chance fix weapon thing too * Update stringtable.xml * Update addons/hitreactions/functions/fnc_checkWeaponDrop.sqf Co-authored-by: Grim <69561145+LinkIsGrim@users.noreply.github.com> * Update addons/hitreactions/functions/fnc_checkWeaponDrop.sqf Co-authored-by: Grim <69561145+LinkIsGrim@users.noreply.github.com> * appearance stuff * Update addons/hitreactions/initSettings.sqf Co-authored-by: Grim <69561145+LinkIsGrim@users.noreply.github.com> * Update addons/hitreactions/functions/fnc_checkWeaponDrop.sqf Co-authored-by: Jouni Järvinen <rautamiekka@users.noreply.github.com> * kjw's poor arithmetic * Update fnc_checkWeaponDrop.sqf wrong check * remove systemchat debug whoops * Update fnc_checkWeaponDrop.sqf * Update XEH_postInit.sqf * Update fnc_checkWeaponDrop.sqf * Early exit, wait for clear * Make default setting 0 * Update script_component.hpp * Update XEH_postInit.sqf * Update script_component.hpp * Update XEH_postInit.sqf * Update XEH_postInit.sqf * Update addons/hitreactions/functions/fnc_checkWeaponDrop.sqf * Update XEH_postInit.sqf Unsure if exitWith in postInit is proper? Seems better than nesting all of that in another scope imo * Update XEH_preInit.sqf * Update fnc_checkWeaponDrop.sqf * Update addons/hitreactions/XEH_preInit.sqf Co-authored-by: Grim <69561145+LinkIsGrim@users.noreply.github.com> * Update hitreactions.md * Update hitreactions.md * Update addons/hitreactions/functions/fnc_checkWeaponDrop.sqf Co-authored-by: johnb432 <58661205+johnb432@users.noreply.github.com> * Update addons/hitreactions/functions/fnc_checkWeaponDrop.sqf Co-authored-by: johnb432 <58661205+johnb432@users.noreply.github.com> * Update addons/hitreactions/initSettings.sqf * Update XEH_postInit.sqf * Update addons/hitreactions/XEH_postInit.sqf Co-authored-by: johnb432 <58661205+johnb432@users.noreply.github.com> * Update addons/hitreactions/XEH_postInit.sqf Co-authored-by: johnb432 <58661205+johnb432@users.noreply.github.com> * Update addons/hitreactions/functions/fnc_checkWeaponDrop.sqf Co-authored-by: johnb432 <58661205+johnb432@users.noreply.github.com> * Update addons/hitreactions/functions/fnc_checkWeaponDrop.sqf Co-authored-by: johnb432 <58661205+johnb432@users.noreply.github.com> * Update XEH_postInit.sqf * Update XEH_postInit.sqf * Update fnc_checkWeaponDrop.sqf * Spacing fixes * Update addons/hitreactions/XEH_postInit.sqf Co-authored-by: johnb432 <58661205+johnb432@users.noreply.github.com> * Take _hitEntity into account if exists * Update fnc_checkWeaponDrop.sqf _didHitGun will no longer ever be true * Minor component cleanup * Removed gun hits, added double hit detection * Decouple AI and player probabilities * Tweaks and fixes * Update XEH_PREP.hpp * Add missing param * Fixed bugged state AI are in after using TakeWeapon * Fixes and cleanup * Made API clear, moved undroppable to config entry * Update fnc_checkWeaponDrop.sqf * Check for Zeus RC and avoid `setUnitLoadout` * Expand `addWeapon`'s capabilities * Cleaned up `addWeapon` * Removed weapon replacement as it's apparently not necessary * Defined undefined variable --------- Co-authored-by: Grim <69561145+LinkIsGrim@users.noreply.github.com> Co-authored-by: Jouni Järvinen <rautamiekka@users.noreply.github.com> Co-authored-by: johnb432 <58661205+johnb432@users.noreply.github.com>
87 lines
3.4 KiB
Plaintext
87 lines
3.4 KiB
Plaintext
#include "script_component.hpp"
|
|
|
|
["ace_firedNonPlayer", {
|
|
if (GVAR(weaponDropChanceArmHitPlayer) + GVAR(weaponDropChanceArmHitAI) == 0) exitWith {};
|
|
|
|
(_this select 6) addEventHandler ["HitPart", {
|
|
params ["", "_entity", "", "", "", "", "_selections"];
|
|
|
|
[_entity, _selections] call FUNC(checkWeaponDrop);
|
|
}];
|
|
}] call CBA_fnc_addEventHandler;
|
|
|
|
["ace_firedPlayer", {
|
|
if (GVAR(weaponDropChanceArmHitPlayer) + GVAR(weaponDropChanceArmHitAI) == 0) exitWith {};
|
|
|
|
(_this select 6) addEventHandler ["HitPart", {
|
|
params ["", "_entity", "", "", "", "", "_selections"];
|
|
|
|
[_entity, _selections] call FUNC(checkWeaponDrop);
|
|
}];
|
|
}] call CBA_fnc_addEventHandler;
|
|
|
|
[QGVAR(dropWeapon), {
|
|
params ["_unit"];
|
|
|
|
if !(_unit getVariable [QGVAR(canDropWeapon), true]) exitWith {};
|
|
|
|
// Prevents AI from losing both primary and pistol when being shot with their pistol out
|
|
_unit setVariable [QGVAR(canDropWeapon), false];
|
|
|
|
private _weapon = currentWeapon _unit;
|
|
private _thrownWeapon = _unit call EFUNC(common,throwWeapon);
|
|
|
|
[{
|
|
params ["_unit"];
|
|
|
|
_unit setVariable [QGVAR(canDropWeapon), nil];
|
|
}, _unit, 0.5] call CBA_fnc_waitAndExecute;
|
|
|
|
if (_unit call EFUNC(common,isPlayer)) exitWith {}; // Don't make players pick their own weapons up
|
|
|
|
// Wait before executing, as otherwise the unit would pick up the weapon immediately
|
|
[{
|
|
[{
|
|
(_this select 0) params ["_unit", "_weapon", "_thrownWeapon", "_timeout"];
|
|
|
|
// If the unit has been deleted or dead, if the weapon doesn't exist anymore or if it's been too long, stop
|
|
if (!alive _unit || {!local _unit} || {isNull _thrownWeapon} || {CBA_missionTime >= _timeout}) exitWith {
|
|
(_this select 1) call CBA_fnc_removePerFrameHandler;
|
|
};
|
|
|
|
// Don't pick up weapon when unit is unconscious
|
|
if (lifeState _unit == "INCAPACITATED") exitWith {};
|
|
|
|
// If the unit has no essential weapons, force them to get their weapon, otherwise wait until no enemies are present
|
|
if !(
|
|
(primaryWeapon _unit == "" && {handgunWeapon _unit == ""}) ||
|
|
{(_unit distance (_unit findNearestEnemy _unit)) > missionNamespace getVariable [QGVAR(safePickupDistance), DEFAULT_PICKUP_DISTANCE]}
|
|
) exitWith {};
|
|
|
|
// If the unit is too far away, make them move closer
|
|
if (_unit distance _thrownWeapon >= 4) exitWith {
|
|
private _pos = getPosATL _thrownWeapon;
|
|
|
|
_unit setDestination [_pos, "LEADER PLANNED", true];
|
|
_unit doMove _pos;
|
|
};
|
|
|
|
(_this select 1) call CBA_fnc_removePerFrameHandler;
|
|
|
|
_unit action ["TakeWeapon", _thrownWeapon, _weapon];
|
|
|
|
// Make the unit switch weapons
|
|
[{
|
|
(_this select 0) hasWeapon (_this select 1)
|
|
}, {
|
|
params ["_unit", "_weapon"];
|
|
|
|
if (!alive _unit || {!local _unit} || {primaryWeapon _unit != _weapon}) exitWith {};
|
|
|
|
// Switch to the primary weapon, if it was picked up
|
|
_unit selectWeapon _weapon;
|
|
}, [_unit, _weapon], 5] call CBA_fnc_waitUntilAndExecute;
|
|
}, 5, _this] call CBA_fnc_addPerFrameHandler;
|
|
}, [_unit, _weapon, _thrownWeapon, CBA_missionTime + 300], random [2, 3, 4]] call CBA_fnc_waitAndExecute;
|
|
}] call CBA_fnc_addEventHandler;
|