2015-03-16 18:25:29 +00:00
|
|
|
// by PabstMirror, commy2
|
|
|
|
#include "script_component.hpp"
|
|
|
|
|
2024-07-01 16:36:37 +00:00
|
|
|
[QGVAR(moveCorpse), {
|
|
|
|
params ["_corpse", "_dir", "_posATL"];
|
|
|
|
_posATL params ["_xPos", "_yPos", "_zPos"];
|
|
|
|
|
|
|
|
if (isNull _corpse) exitWith {};
|
|
|
|
|
|
|
|
private _currentPos = getPosATL _corpse;
|
|
|
|
|
|
|
|
// Check if the corpse is already close to the target
|
|
|
|
// If so, don't teleport
|
|
|
|
if !(
|
2024-07-01 17:13:01 +00:00
|
|
|
_currentPos distance _posATL > 0.25
|
2024-07-01 16:36:37 +00:00
|
|
|
) then {
|
|
|
|
// Set direction before position
|
|
|
|
_corpse setDir _dir;
|
|
|
|
|
|
|
|
// Bring corpse back to clone's position
|
|
|
|
_corpse setPosATL _posATL;
|
|
|
|
};
|
|
|
|
|
|
|
|
// Sync the corpse with its position
|
|
|
|
[{
|
|
|
|
_this awake true;
|
|
|
|
|
|
|
|
[{
|
|
|
|
_this awake false;
|
|
|
|
}, _this] call CBA_fnc_execNextFrame;
|
|
|
|
}, _corpse] call CBA_fnc_execNextFrame;
|
|
|
|
|
|
|
|
// Allow the corpse to be synced for JIP players
|
|
|
|
if (isServer) exitWith {
|
|
|
|
GVAR(movedCorpses) pushBackUnique _corpse;
|
|
|
|
};
|
|
|
|
}] call CBA_fnc_addEventHandler;
|
|
|
|
|
2015-09-26 01:16:55 +00:00
|
|
|
if (isServer) then {
|
2023-09-11 12:29:56 +00:00
|
|
|
// Release object on disconnection. Function is identical to killed
|
|
|
|
addMissionEventHandler ["HandleDisconnect", LINKFUNC(handleKilled)];
|
2024-07-01 16:36:37 +00:00
|
|
|
|
|
|
|
GVAR(movedCorpses) = [];
|
|
|
|
|
|
|
|
["CAManBase", "Deleted", {
|
|
|
|
GVAR(movedCorpses) deleteAt (GVAR(movedCorpses) find (_this select 0));
|
|
|
|
}, true, [], true] call CBA_fnc_addClassEventHandler;
|
|
|
|
|
|
|
|
[QGVAR(disableSyncMovedCorpseOnJIP), {
|
|
|
|
params ["_corpse"];
|
|
|
|
|
|
|
|
GVAR(movedCorpses) deleteAt (GVAR(movedCorpses) find _corpse);
|
|
|
|
}] call CBA_fnc_addEventHandler;
|
|
|
|
|
|
|
|
// Sync position of dead corpse for JIP unit (prevents weird invisible hitboxes on corpses)
|
|
|
|
[QGVAR(requestSyncMovedCorpsesJIP), {
|
|
|
|
params ["_clientOwner"];
|
|
|
|
|
|
|
|
{
|
|
|
|
[QGVAR(moveCorpse), [_x, getDir _x, getPosATL _x], _clientOwner] call CBA_fnc_ownerEvent;
|
|
|
|
} forEach GVAR(movedCorpses);
|
|
|
|
}] call CBA_fnc_addEventHandler;
|
|
|
|
} else {
|
|
|
|
[QGVAR(requestSyncMovedCorpsesJIP), clientOwner] call CBA_fnc_serverEvent;
|
2015-09-26 01:16:55 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
if (!hasInterface) exitWith {};
|
|
|
|
|
2015-03-18 13:14:16 +00:00
|
|
|
if (isNil "ACE_maxWeightDrag") then {
|
|
|
|
ACE_maxWeightDrag = 800;
|
|
|
|
};
|
|
|
|
|
|
|
|
if (isNil "ACE_maxWeightCarry") then {
|
|
|
|
ACE_maxWeightCarry = 600;
|
2015-03-16 18:25:29 +00:00
|
|
|
};
|
2023-07-23 23:07:37 +00:00
|
|
|
|
2023-06-28 11:43:10 +00:00
|
|
|
if (isNil QGVAR(maxWeightCarryRun)) then {
|
|
|
|
GVAR(maxWeightCarryRun) = 50;
|
|
|
|
};
|
2015-03-16 18:25:29 +00:00
|
|
|
|
2023-07-21 17:24:25 +00:00
|
|
|
// Extended EH doesn't fire for dead units, so add interactions manually
|
|
|
|
{
|
|
|
|
_x call FUNC(initPerson);
|
|
|
|
} forEach allDeadMen;
|
|
|
|
|
2015-03-16 18:25:29 +00:00
|
|
|
["isNotDragging", {!((_this select 0) getVariable [QGVAR(isDragging), false])}] call EFUNC(common,addCanInteractWithCondition);
|
2015-03-17 14:42:25 +00:00
|
|
|
["isNotCarrying", {!((_this select 0) getVariable [QGVAR(isCarrying), false])}] call EFUNC(common,addCanInteractWithCondition);
|
2015-03-17 12:47:07 +00:00
|
|
|
|
2023-07-23 23:07:37 +00:00
|
|
|
// Release object on player change. This does work when returning to lobby, but not when hard disconnecting.
|
|
|
|
["unit", LINKFUNC(handlePlayerChanged)] call CBA_fnc_addPlayerEventHandler;
|
2016-08-03 20:26:36 +00:00
|
|
|
["vehicle", {[ACE_player, objNull] call FUNC(handlePlayerChanged)}] call CBA_fnc_addPlayerEventHandler;
|
2023-07-23 23:07:37 +00:00
|
|
|
["weapon", LINKFUNC(handlePlayerWeaponChanged)] call CBA_fnc_addPlayerEventHandler;
|
2015-03-24 18:07:39 +00:00
|
|
|
|
2023-11-21 20:18:19 +00:00
|
|
|
// When changing cameras, drop carried and dragged objects
|
|
|
|
["featureCamera", {
|
|
|
|
params ["_unit", "_camera"];
|
|
|
|
|
|
|
|
// Unit can either drag or carry, functions themselves handle which ones are executed
|
|
|
|
switch (_camera) do {
|
|
|
|
// Default camera
|
|
|
|
case "": {
|
|
|
|
_unit call FUNC(resumeDrag);
|
|
|
|
_unit call FUNC(resumeCarry);
|
|
|
|
};
|
|
|
|
// Arsenals make the unit change animations, which makes the unit drop dragged/carried objects regardless
|
|
|
|
case "arsenal";
|
|
|
|
case "ace_arsenal": {
|
|
|
|
_unit call FUNC(handleKilled);
|
|
|
|
};
|
|
|
|
default {
|
|
|
|
_unit call FUNC(pauseDrag);
|
|
|
|
_unit call FUNC(pauseCarry);
|
|
|
|
};
|
|
|
|
};
|
|
|
|
}] call CBA_fnc_addPlayerEventHandler;
|
|
|
|
|
2023-07-23 23:07:37 +00:00
|
|
|
// Handle waking up dragged unit and falling unconscious while dragging
|
|
|
|
["ace_unconscious", LINKFUNC(handleUnconscious)] call CBA_fnc_addEventHandler;
|
2015-03-24 18:07:39 +00:00
|
|
|
|
2024-07-01 16:36:37 +00:00
|
|
|
// Display event handler
|
|
|
|
["MouseZChanged", {(_this select 1) call FUNC(handleScrollWheel)}] call CBA_fnc_addDisplayHandler;
|
|
|
|
|
2023-07-20 17:44:49 +00:00
|
|
|
// Handle local effect commands for clones
|
2024-07-01 16:36:37 +00:00
|
|
|
[QGVAR(setCloneFace), {
|
|
|
|
params ["_clone", "_corpse"];
|
2020-10-04 20:39:52 +00:00
|
|
|
|
2024-07-01 16:36:37 +00:00
|
|
|
_clone setFace face _corpse;
|
2020-10-04 20:39:52 +00:00
|
|
|
_clone setMimic "unconscious";
|
|
|
|
}] call CBA_fnc_addEventHandler;
|
2024-02-02 17:19:43 +00:00
|
|
|
|
2023-11-21 20:18:19 +00:00
|
|
|
// Handle surrendering and handcuffing
|
|
|
|
["ace_captiveStatusChanged", {
|
|
|
|
params ["_unit", "_state"];
|
|
|
|
|
|
|
|
// If surrended or handcuffed, drop dragged/carried object
|
|
|
|
if (_state && {local _unit}) then {
|
|
|
|
_unit call FUNC(handleKilled);
|
|
|
|
};
|
|
|
|
}] call CBA_fnc_addEventHandler;
|
|
|
|
|
2024-01-13 16:39:39 +00:00
|
|
|
[QGVAR(startCarry), LINKFUNC(startCarryLocal)] call CBA_fnc_addEventHandler;
|
|
|
|
[QGVAR(startDrag), LINKFUNC(startDragLocal)] call CBA_fnc_addEventHandler;
|
|
|
|
|
2023-07-22 03:30:40 +00:00
|
|
|
[QGVAR(carryingContainerClosed), {
|
|
|
|
params ["_container", "_owner"];
|
|
|
|
TRACE_2("carryingContainerClosed EH",_container,_owner);
|
|
|
|
if !(_owner getVariable [QGVAR(isCarrying), false]) exitWith { ERROR_1("not carrying - %1",_this) };
|
|
|
|
|
|
|
|
private _weight = 0;
|
|
|
|
if !(_container getVariable [QGVAR(ignoreWeightCarry), false]) then {
|
|
|
|
_weight = [_container] call FUNC(getWeight);
|
|
|
|
};
|
|
|
|
|
2023-07-23 23:07:37 +00:00
|
|
|
// Drop the object if overweight
|
2023-07-22 03:30:40 +00:00
|
|
|
if (_weight > ACE_maxWeightCarry) exitWith {
|
|
|
|
[_owner, _container] call FUNC(dropObject_carry);
|
|
|
|
};
|
|
|
|
private _canRun = [_weight] call FUNC(canRun_carry);
|
|
|
|
|
2023-07-23 23:07:37 +00:00
|
|
|
// Force walking based on weight
|
2023-07-22 03:30:40 +00:00
|
|
|
[_owner, "forceWalk", QUOTE(ADDON), !_canRun] call EFUNC(common,statusEffect_set);
|
|
|
|
[_owner, "blockSprint", QUOTE(ADDON), _canRun] call EFUNC(common,statusEffect_set);
|
|
|
|
}] call CBA_fnc_addEventHandler;
|
|
|
|
|
|
|
|
[QGVAR(draggingContainerClosed), {
|
|
|
|
params ["_container", "_owner"];
|
|
|
|
TRACE_2("draggingContainerClosed EH",_container,_owner);
|
|
|
|
if !(_owner getVariable [QGVAR(isDragging), false]) exitWith { ERROR_1("not dragging - %1",_this) };
|
|
|
|
|
|
|
|
private _weight = 0;
|
|
|
|
if !(_container getVariable [QGVAR(ignoreWeightDrag), false]) then {
|
|
|
|
_weight = [_container] call FUNC(getWeight);
|
|
|
|
};
|
|
|
|
|
2023-07-23 23:07:37 +00:00
|
|
|
// Drop the object if overweight
|
2023-07-22 03:30:40 +00:00
|
|
|
if (_weight > ACE_maxWeightDrag) exitWith {
|
|
|
|
[_owner, _container] call FUNC(dropObject);
|
|
|
|
};
|
|
|
|
}] call CBA_fnc_addEventHandler;
|
|
|
|
|
2023-12-07 03:20:47 +00:00
|
|
|
#include "initKeybinds.inc.sqf"
|