mirror of
https://github.com/acemod/ACE3.git
synced 2024-08-30 18:23:18 +00:00
Add getInteractionDistance and fix VTOL refuel/arm (#4882)
This commit is contained in:
parent
d2ee1e987a
commit
3ce0865913
@ -2,6 +2,7 @@
|
||||
// interaction menu
|
||||
PREP(addPassengerActions);
|
||||
PREP(addPassengersActions);
|
||||
PREP(getInteractionDistance);
|
||||
PREP(getVehiclePos);
|
||||
PREP(getVehiclePosComplex);
|
||||
PREP(getWeaponPos);
|
||||
|
33
addons/interaction/functions/fnc_getInteractionDistance.sqf
Normal file
33
addons/interaction/functions/fnc_getInteractionDistance.sqf
Normal file
@ -0,0 +1,33 @@
|
||||
/*
|
||||
* Author: PabstMirror
|
||||
* Gets effective interaction distance (handles very large vehicles)
|
||||
*
|
||||
* Arguments:
|
||||
* 0: Player <OBJECT>
|
||||
* 0: Target Vehicle <OBJECT>
|
||||
*
|
||||
* Return value:
|
||||
* Distance to interaction point <NUMBER>
|
||||
*
|
||||
* Example:
|
||||
* [player, cursorObject] call ace_interaction_fnc_getInteractionDistance
|
||||
*
|
||||
* Public: No
|
||||
*/
|
||||
#include "script_component.hpp"
|
||||
|
||||
params ["_unit", "_target"];
|
||||
TRACE_3("getInteractionDistance",_unit,_target,typeOf _target);
|
||||
|
||||
// Handle Man, Crate
|
||||
if (!((_target isKindOf "Car") || {_target isKindOf "Tank"} || {_target isKindOf "Helicopter"} || {_target isKindOf "Plane"} || {_target isKindOf "Ship_F"})) exitWith {
|
||||
_unit distance _target
|
||||
};
|
||||
|
||||
private _unitEyeASL = eyePos _unit;
|
||||
private _targetModelPos = [_target, _unitEyeASL] call FUNC(getVehiclePosComplex);
|
||||
private _distance = _unitEyeASL distance (AGLtoASL (_target modelToWorld _targetModelPos));
|
||||
|
||||
TRACE_2("",_targetModelPos,_distance);
|
||||
|
||||
_distance
|
@ -19,7 +19,7 @@
|
||||
private ["_dummy","_magazineClass"];
|
||||
params [["_target", objNull, [objNull]], ["_unit", objNull, [objNull]]];
|
||||
|
||||
if (GVAR(level) == 0 || {isNull _unit} || {!(_unit isKindOf "CAManBase")} || {!local _unit} || {_target distance _unit > REARM_ACTION_DISTANCE} || {_target getVariable [QGVAR(disabled), false]}) exitWith {false};
|
||||
if (GVAR(level) == 0 || {isNull _unit} || {!(_unit isKindOf "CAManBase")} || {!local _unit} || {([_unit, _target] call EFUNC(interaction,getInteractionDistance)) > REARM_ACTION_DISTANCE} || {_target getVariable [QGVAR(disabled), false]}) exitWith {false};
|
||||
|
||||
_dummy = _unit getVariable [QGVAR(dummy), objNull];
|
||||
if (isNull _dummy) exitwith {false};
|
||||
|
@ -22,5 +22,5 @@ params [["_unit", objNull, [objNull]], ["_target", objNull, [objNull]]];
|
||||
{!(_unit isKindOf "CAManBase")} ||
|
||||
{!local _unit} ||
|
||||
{!alive _target} ||
|
||||
{(_target distance _unit) > REFUEL_ACTION_DISTANCE} ||
|
||||
{([_unit, _target] call EFUNC(interaction,getInteractionDistance)) > REFUEL_ACTION_DISTANCE} ||
|
||||
{(_target call FUNC(getFuel) == REFUEL_INFINITE_FUEL)})
|
||||
|
@ -27,5 +27,5 @@ if (_target isKindOf "AllVehicles") then {
|
||||
|
||||
!(isNull _nozzle ||
|
||||
{_engine} ||
|
||||
{(_target distance _unit) > REFUEL_ACTION_DISTANCE} ||
|
||||
{([_unit, _target] call EFUNC(interaction,getInteractionDistance)) > REFUEL_ACTION_DISTANCE} ||
|
||||
{!isNull (_target getVariable [QGVAR(nozzle), objNull])})
|
||||
|
@ -21,5 +21,5 @@ params [["_unit", objNull, [objNull]], ["_target", objNull, [objNull]]];
|
||||
private _nozzle = _unit getVariable [QGVAR(nozzle), objNull];
|
||||
|
||||
(!isNull _nozzle) &&
|
||||
{_target distance _unit < REFUEL_ACTION_DISTANCE} &&
|
||||
{([_unit, _target] call EFUNC(interaction,getInteractionDistance)) < REFUEL_ACTION_DISTANCE} &&
|
||||
{_target == (_nozzle getVariable [QGVAR(source), objNull])}
|
||||
|
@ -23,6 +23,6 @@ if (isNull _unit ||
|
||||
{!local _unit} ||
|
||||
{!alive _target} ||
|
||||
{!isNull (_unit getVariable [QGVAR(nozzle), objNull])} ||
|
||||
{(_target distance _unit) > REFUEL_ACTION_DISTANCE}) exitWith {false};
|
||||
{([_unit, _target] call EFUNC(interaction,getInteractionDistance)) > REFUEL_ACTION_DISTANCE}) exitWith {false};
|
||||
|
||||
!(_target getVariable [QGVAR(isConnected), false]) && {!(_unit getVariable [QGVAR(isRefueling), false])}
|
||||
|
Loading…
Reference in New Issue
Block a user