From a420865b5b65a0eec8429d404e8c65477195c022 Mon Sep 17 00:00:00 2001 From: Vdauphin Date: Thu, 5 Nov 2020 22:47:13 +0100 Subject: [PATCH] Add: Unloading and fix full vehicle --- addons/cargo/functions/fnc_loadItem.sqf | 24 +++++++++++++++-------- addons/cargo/functions/fnc_unloadItem.sqf | 17 ++++++++++++---- 2 files changed, 29 insertions(+), 12 deletions(-) diff --git a/addons/cargo/functions/fnc_loadItem.sqf b/addons/cargo/functions/fnc_loadItem.sqf index 84497b1b6a..50ce64ae7b 100644 --- a/addons/cargo/functions/fnc_loadItem.sqf +++ b/addons/cargo/functions/fnc_loadItem.sqf @@ -40,24 +40,32 @@ if (_item isEqualType objNull) then { if ( (_vehicle canVehicleCargo _item) isEqualTo [false, true] && // Could be loaded if _vehicle was empty {_vehicleCargo findIf { - !(_x in _loaded) && + !(_x in _loaded) && // Don't use ViV if ViV was used outside of ACE Cargo !(typeOf _x isEqualTo "CargoNet_01_box_F") - } isEqualTo -1} // Don't use ViV if ViV was used outside of ACE Cargo + } isEqualTo -1} ) then { - private _cargoBox = createVehicle ["CargoNet_01_box_F", [0, 0, 0], [], 0, "CAN_COLLIDE"]; - if ((_vehicle canVehicleCargo _cargoBox) select 1) then { - while {!(_vehicle setVehicleCargo _cargoBox)} do { // Move ViV cargo to ACE Cargo + private _cargoNet = createVehicle ["CargoNet_01_box_F", [0, 0, 0], [], 0, "CAN_COLLIDE"]; + if ((_vehicle canVehicleCargo _cargoNet) select 1) then { + while {!(_vehicle setVehicleCargo _cargoNet)} do { // Move ViV cargo to ACE Cargo private _itemViV = _vehicleCargo deleteAt 0; - if !(objNull setVehicleCargo _itemViV) exitWith {deleteVehicle _cargoBox;}; + if (typeOf _itemViV isEqualTo "CargoNet_01_box_F") exitWith { // The vehicle is already full of "CargoNet_01_box_F") + deleteVehicle _cargoNet; + _item setVariable [QGVAR(cargoNet), _itemViV, true]; + }; + if !(objNull setVehicleCargo _itemViV) exitWith {deleteVehicle _cargoNet;}; - _itemViV attachTo [_vehicle,[0,0,-100]]; + _itemViV setVariable [QGVAR(cargoNet), _cargoNet, true]; + _itemViV attachTo [_vehicle, [0,0,-100]]; [QEGVAR(common,hideObjectGlobal), [_itemViV, true]] call CBA_fnc_serverEvent; // Some objects below water will take damage over time and eventualy become "water logged" and unfixable (because of negative z attach) [_itemViV, "blockDamage", "ACE_cargo", true] call EFUNC(common,statusEffect_set); }; + if !(isNull _cargoNet) then { + _item setVariable [QGVAR(cargoNet), _cargoNet, true]; + }; } else { - deleteVehicle _cargoBox; + deleteVehicle _cargoNet; }; }; _item attachTo [_vehicle, [0,0,-100]]; diff --git a/addons/cargo/functions/fnc_unloadItem.sqf b/addons/cargo/functions/fnc_unloadItem.sqf index f95fec144c..087ada290b 100644 --- a/addons/cargo/functions/fnc_unloadItem.sqf +++ b/addons/cargo/functions/fnc_unloadItem.sqf @@ -48,14 +48,23 @@ private _itemSize = [_item] call FUNC(getSizeItem); _vehicle setVariable [QGVAR(space), (_space + _itemSize), true]; if (_item isEqualType objNull) then { - if (isVehicleCargo _item) then { - objNull setVehicleCargo _item; - _item setPosASL (AGLtoASL _emptyPosAGL); - } else { + if (isNull isVehicleCargo _item) then { detach _item; // hideObjectGlobal must be executed before setPos to ensure light objects are rendered correctly // do both on server to ensure they are executed in the correct order [QGVAR(serverUnload), [_item, _emptyPosAGL]] call CBA_fnc_serverEvent; + + private _cargoNet = _item getVariable [QGVAR(cargoNet), objNull]; + if !(isNull _cargoNet) then { + private _itemsRemaining = _loaded select {_x getVariable [QGVAR(cargoNet), objNull] isEqualTo _cargoNet}; + if (_itemsRemaining isEqualTo []) then { + objNull setVehicleCargo _cargoNet; + deleteVehicle _cargoNet; + }; + }; + } else { + objNull setVehicleCargo _item; + _item setPosASL (AGLtoASL _emptyPosAGL); }; } else { private _newItem = createVehicle [_item, _emptyPosAGL, [], 0, "NONE"];