mirror of
https://github.com/acemod/ACE3.git
synced 2024-08-30 18:23:18 +00:00
Fix #4523 - fuel nozzle disconnect at maximum hose distance
This commit is contained in:
parent
5d610cf148
commit
b8cc10fecb
@ -16,6 +16,7 @@ PREP(handleDisconnect);
|
|||||||
PREP(handleKilled);
|
PREP(handleKilled);
|
||||||
PREP(handleUnconscious);
|
PREP(handleUnconscious);
|
||||||
PREP(makeJerryCan);
|
PREP(makeJerryCan);
|
||||||
|
PREP(maxDistanceDropNozzle);
|
||||||
PREP(moduleRefuelSettings);
|
PREP(moduleRefuelSettings);
|
||||||
PREP(readFuelCounter);
|
PREP(readFuelCounter);
|
||||||
PREP(refuel);
|
PREP(refuel);
|
||||||
|
54
addons/refuel/functions/fnc_maxDistanceDropNozzle.sqf
Normal file
54
addons/refuel/functions/fnc_maxDistanceDropNozzle.sqf
Normal file
@ -0,0 +1,54 @@
|
|||||||
|
/*
|
||||||
|
* Author: GitHawk, Jonpas
|
||||||
|
* Drops the nozzle at maximum hose distance.
|
||||||
|
*
|
||||||
|
* Arguments:
|
||||||
|
* 0: Unit <OBJECT>
|
||||||
|
* 1: Fuel Truck <OBJECT>
|
||||||
|
* 2: End Pos Offset <ARRAY>
|
||||||
|
* 3: Nozzle <OBJECT> (optional)
|
||||||
|
*
|
||||||
|
* Return Value:
|
||||||
|
* None
|
||||||
|
*
|
||||||
|
* Example:
|
||||||
|
* [player, fuelTruck, [0, 0, 0], nozzle] call ace_refuel_fnc_maxDistanceDropNozzle
|
||||||
|
*
|
||||||
|
* Public: No
|
||||||
|
*/
|
||||||
|
#include "script_component.hpp"
|
||||||
|
|
||||||
|
params ["_unit", "_source", "_endPosOffset", "_nozzle"];
|
||||||
|
|
||||||
|
// Exit if jerry can (no maximum distance there as it's not connected to anything)
|
||||||
|
if (_nozzle getVariable [QGVAR(jerryCan), false]) exitWith {};
|
||||||
|
|
||||||
|
// Check distance periodically to drop it at maximum hose length
|
||||||
|
[{
|
||||||
|
params ["_args", "_pfID"];
|
||||||
|
_args params [
|
||||||
|
["_unit", player, [objNull]],
|
||||||
|
["_source", objNull, [objNull]],
|
||||||
|
["_endPosOffset", [0, 0, 0], [[]], 3],
|
||||||
|
["_nozzle", (_args select 0) getVariable [QGVAR(nozzle), objNull], [objNull]]
|
||||||
|
];
|
||||||
|
|
||||||
|
if (isNull _source || {_unit distance (_source modelToWorld _endPosOffset) > (REFUEL_HOSE_LENGTH - 2)} || {!alive _source}) exitWith {
|
||||||
|
if !(isNull _nozzle) then {
|
||||||
|
[_unit, _nozzle] call FUNC(dropNozzle);
|
||||||
|
REFUEL_UNHOLSTER_WEAPON
|
||||||
|
|
||||||
|
[_unit, "forceWalk", "ACE_refuel", false] call EFUNC(common,statusEffect_set);
|
||||||
|
if (isNull _source || {!alive _source}) then {
|
||||||
|
private _rope = _nozzle getVariable [QGVAR(rope), objNull];
|
||||||
|
if !(isNull _rope) then {
|
||||||
|
ropeDestroy _rope;
|
||||||
|
};
|
||||||
|
deleteVehicle _nozzle;
|
||||||
|
} else {
|
||||||
|
[LSTRING(Hint_TooFar), 2, _unit] call EFUNC(common,displayTextStructured);
|
||||||
|
};
|
||||||
|
};
|
||||||
|
[_pfID] call CBA_fnc_removePerFrameHandler;
|
||||||
|
};
|
||||||
|
}, 0, [_unit, _target, _endPosOffset, _nozzle]] call CBA_fnc_addPerFrameHandler;
|
@ -82,6 +82,9 @@ if (isNull _nozzle) then { // func is called on fuel truck
|
|||||||
'!isNull (_target getVariable [QGVAR(nozzle), objNull])'
|
'!isNull (_target getVariable [QGVAR(nozzle), objNull])'
|
||||||
];
|
];
|
||||||
_unit setVariable [QGVAR(ReleaseActionID), _actionID];
|
_unit setVariable [QGVAR(ReleaseActionID), _actionID];
|
||||||
|
|
||||||
|
// Drop nozzle at maximum hose distance
|
||||||
|
[_unit, _target, _endPosOffset, _nozzle] call FUNC(maxDistanceDropNozzle);
|
||||||
},
|
},
|
||||||
"",
|
"",
|
||||||
localize LSTRING(TakeNozzleAction),
|
localize LSTRING(TakeNozzleAction),
|
||||||
@ -123,43 +126,15 @@ if (isNull _nozzle) then { // func is called on fuel truck
|
|||||||
'!isNull (_target getVariable [QGVAR(nozzle), objNull])'
|
'!isNull (_target getVariable [QGVAR(nozzle), objNull])'
|
||||||
];
|
];
|
||||||
_unit setVariable [QGVAR(ReleaseActionID), _actionID];
|
_unit setVariable [QGVAR(ReleaseActionID), _actionID];
|
||||||
|
|
||||||
|
// Drop nozzle at maximum hose distance
|
||||||
|
private _target = _nozzle getVariable QGVAR(source);
|
||||||
|
private _endPosOffset = _nozzle getVariable QGVAR(attachPos);
|
||||||
|
[_unit, _target, _endPosOffset, _nozzle] call FUNC(maxDistanceDropNozzle);
|
||||||
},
|
},
|
||||||
"",
|
"",
|
||||||
localize LSTRING(TakeNozzleAction),
|
localize LSTRING(TakeNozzleAction),
|
||||||
{true},
|
{true},
|
||||||
["isnotinside"]
|
["isnotinside"]
|
||||||
] call EFUNC(common,progressBar);
|
] call EFUNC(common,progressBar);
|
||||||
|
|
||||||
_target = _nozzle getVariable QGVAR(source);
|
|
||||||
_endPosOffset = _nozzle getVariable QGVAR(attachPos);
|
|
||||||
};
|
|
||||||
if !(_nozzle getVariable [QGVAR(jerryCan), false]) then {
|
|
||||||
[{
|
|
||||||
params ["_args", "_pfID"];
|
|
||||||
_args params [
|
|
||||||
["_unit", player, [objNull]],
|
|
||||||
["_source", objNull, [objNull]],
|
|
||||||
["_endPosOffset", [0, 0, 0], [[]], 3],
|
|
||||||
["_nozzle", _unit getVariable [QGVAR(nozzle), objNull], [objNull]]
|
|
||||||
];
|
|
||||||
|
|
||||||
if (isNull _source || {_unit distance (_source modelToWorld _endPosOffset) > (REFUEL_HOSE_LENGTH - 2)} || {!alive _source}) exitWith {
|
|
||||||
if !(isNull _nozzle) then {
|
|
||||||
[_unit, _nozzle] call FUNC(dropNozzle);
|
|
||||||
REFUEL_UNHOLSTER_WEAPON
|
|
||||||
|
|
||||||
[_unit, "forceWalk", "ACE_refuel", false] call EFUNC(common,statusEffect_set);
|
|
||||||
if (isNull _source || {!alive _source}) then {
|
|
||||||
private _rope = _nozzle getVariable [QGVAR(rope), objNull];
|
|
||||||
if !(isNull _rope) then {
|
|
||||||
ropeDestroy _rope;
|
|
||||||
};
|
|
||||||
deleteVehicle _nozzle;
|
|
||||||
} else {
|
|
||||||
[LSTRING(Hint_TooFar), 2, _unit] call EFUNC(common,displayTextStructured);
|
|
||||||
};
|
|
||||||
};
|
|
||||||
[_pfID] call cba_fnc_removePerFrameHandler;
|
|
||||||
};
|
|
||||||
}, 0, [_unit, _target, _endPosOffset]] call cba_fnc_addPerFrameHandler;
|
|
||||||
};
|
};
|
||||||
|
Loading…
Reference in New Issue
Block a user