ACE3/addons/hitreactions/XEH_postInit.sqf

87 lines
3.4 KiB
Plaintext
Raw Normal View History

Hit Reactions - Add weapon dropping on arm hit (#9539) * 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>
2024-06-06 11:49:15 +00:00
#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;