ACE3/addons/common/functions/fnc_showHud.sqf

70 lines
2.4 KiB
Plaintext
Raw Permalink Normal View History

#include "..\script_component.hpp"
2015-10-16 03:33:05 +00:00
/*
* Author: PabstMirror
* Allows multiple sources to not overwrite showHud command.
* Bitwise AND Logic (a single false in a mask will make it false).
2015-10-16 03:33:05 +00:00
*
* Arguments:
* 0: Source ID <STRING> (default: "")
* 1: Show Hud Bool Array (8 to set, empty to remove) <ARRAY> (default: [])
2015-10-16 13:28:54 +00:00
* - [hud, info, radar, compass, direction, menu, group, cursors]
2015-11-25 17:07:56 +00:00
* - hud: Boolean - show scripted HUD (same as normal showHUD true/false)
* - info: Boolean - show vehicle + soldier info (hides weapon info from the HUD as well)
* - radar: Boolean - show vehicle radar
* - compass: Boolean - show vehicle compass
* - direction: Boolean - show tank direction indicator (not present in vanilla Arma 3)
* - menu: Boolean - show commanding menu (hides HC related menus)
* - group: Boolean - show group info bar (hides squad leader info bar)
* - cursors: Boolean - show HUD weapon cursors (connected with scripted HUD)
* - panels: Boolean - show vehicle panels / GPS
* - ???: Boolean - Possibly related to changelog entry `Added: A new showKillConfirmations parameter for the showHud command`
2015-10-16 03:33:05 +00:00
*
* Return Value:
* Resulting ShowHud Array <ARRAY>
*
* Example:
* ["hideHud", [false, true, true, true, true, true, true, false, true, true]] call ace_common_fnc_showHud; //This is equivalent to the old showHud false
2015-11-25 17:07:56 +00:00
* [] call ace_common_fnc_showHud; //sets `showHud` and returns the result array used
2015-10-16 03:33:05 +00:00
*
* Public: Yes
*/
if (!hasInterface) exitWith {[-1]};
params [["_reason", "", [""]], ["_mask", [], [[]]]];
2015-10-16 03:33:05 +00:00
if (isArray (missionConfigFile >> "showHUD")) then {
//(showHud = 0;) is fine - the array is the problem
WARNING("showHUD[] in Description.ext breaks the showHud command");
2015-10-16 03:33:05 +00:00
};
if (_reason != "") then {
_reason = toLower _reason;
if (_mask isEqualTo []) then {
TRACE_2("Removing",_reason,_mask);
GVAR(showHudHash) deleteAt _reason;
2015-10-16 03:33:05 +00:00
} else {
while {(count _mask) < 10} do { _mask pushBack true; };
TRACE_2("Setting",_reason,_mask);
GVAR(showHudHash) set [_reason, _mask];
2015-10-16 03:33:05 +00:00
};
};
private _masks = values GVAR(showHudHash);
2015-11-17 19:56:55 +00:00
private _resultMask = [];
2015-10-16 03:33:05 +00:00
for "_index" from 0 to 9 do {
2015-11-17 19:56:55 +00:00
private _set = true; //Default to true
2015-10-16 03:33:05 +00:00
{
if (!(_x select _index)) exitWith {
_set = false; //Any false will make it false
};
} forEach _masks;
_resultMask pushBack _set;
};
TRACE_2("showHud",_resultMask,keys GVAR(showHudHash));
2015-10-16 03:33:05 +00:00
showHud _resultMask;
_resultMask