Interact Menu - Simplify fnc_renderActionPoints (#8186)

* Simplify fnc_renderActionPoints

* Replace nil-count with forEach
This commit is contained in:
Dystopian 2021-07-24 21:10:49 +04:00 committed by GitHub
parent 46df1bd811
commit 27bd25c4b8
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

View File

@ -35,51 +35,46 @@ private _fnc_renderNearbyActions = {
private _target = _x;
// Quick oclussion test. Skip objects more than 1 m behind the camera plane
private _lambda = ((getPosASL _x) vectorDiff GVAR(cameraPosASL)) vectorDotProduct GVAR(cameraDir);
if ((_lambda > -1) && {!isObjectHidden _target}) then {
private _numInteractions = 0;
private _lambda = getPosASL _target vectorDiff GVAR(cameraPosASL) vectorDotProduct GVAR(cameraDir);
if (
_lambda <= -1
|| {isObjectHidden _target}
// Prevent interacting with yourself or your own vehicle
if (_target != ACE_player && {_target != vehicle ACE_player}) then {
|| {_target in [ACE_player, vehicle ACE_player]}
) then {continue};
private _hasInteractions = false;
// Iterate through object actions, find base level actions and render them if appropiate
GVAR(objectActionList) = _target getVariable [QGVAR(actions), []];
{
// Only render them directly if they are base level actions
if ((_x select 1) isEqualTo []) then {
if (_x select 1 isNotEqualTo []) then {continue};
// Try to render the menu
private _action = _x;
if ([_target, _action] call FUNC(renderBaseMenu)) then {
_numInteractions = _numInteractions + 1;
_hasInteractions = true;
GVAR(foundActions) pushBack [_target, _action, GVAR(objectActionList)];
};
};
nil
} count GVAR(objectActionList);
} forEach GVAR(objectActionList);
// Iterate through base level class actions and render them if appropiate
private _namespace = GVAR(ActNamespace);
private _classActions = _namespace getVariable typeOf _target;
private _classActions = GVAR(ActNamespace) getVariable [typeOf _target, []];
{
private _action = _x;
// Try to render the menu
if ([_target, _action] call FUNC(renderBaseMenu)) then {
_numInteractions = _numInteractions + 1;
_hasInteractions = true;
GVAR(foundActions) pushBack [_target, _action, GVAR(objectActionList)];
};
nil
} count _classActions;
} forEach _classActions;
// Limit the amount of objects the player can interact with
if (_numInteractions > 0) then {
_numInteractObjects = _numInteractObjects + 1;
if (_hasInteractions) then {
INC(_numInteractObjects);
if (_numInteractObjects >= MAXINTERACTOBJECTS) then {break};
};
};
};
if (_numInteractObjects >= MAXINTERACTOBJECTS) exitWith {};
nil
} count _nearestObjects;
} forEach _nearestObjects;
};
private _fnc_renderLastFrameActions = {
@ -88,8 +83,7 @@ private _fnc_renderLastFrameActions = {
GVAR(objectActionList) = _objectActionList;
[_target, _action] call FUNC(renderBaseMenu);
nil
} count GVAR(foundActions);
} forEach GVAR(foundActions);
};
private _fnc_renderSelfActions = {
@ -112,16 +106,14 @@ private _fnc_renderSelfActions = {
{
_action = _x;
[_target, _action, _pos] call FUNC(renderBaseMenu);
nil
} count _classActions;
} forEach _classActions;
};
private _fnc_renderZeusActions = {
{
private _action = _x;
[_this, _action, [0.5, 0.5]] call FUNC(renderBaseMenu);
nil
} count GVAR(ZeusActions);
} forEach GVAR(ZeusActions);
};
@ -178,5 +170,4 @@ if (count GVAR(collectedActionPoints) > 1) then {
{
_x params ["_z", "_sPos", "_activeActionTree"];
[[], _activeActionTree, _sPos, [180,360]] call FUNC(renderMenu);
nil
} count GVAR(collectedActionPoints);
} forEach GVAR(collectedActionPoints);