From ed15d99915bb4773e661a69b2f50267fc9b296a7 Mon Sep 17 00:00:00 2001 From: jonpas Date: Sat, 18 Jun 2016 11:32:56 +0200 Subject: [PATCH] Fix basic UI being overwritten on RscDiary unload (#3920) * Display disabled message when basic config set by mission showHud * Set showHud on RscDiary unload - fix #3907, Remove redundant force parameter from basic setElements * Log forced source to RPT * Add source to scripted element setter --- addons/ui/CfgEventHandlers.hpp | 7 ++++ addons/ui/XEH_PREP.hpp | 1 + addons/ui/XEH_clientInit.sqf | 4 +-- addons/ui/functions/fnc_findSetElement.sqf | 25 +++++++++++++ .../ui/functions/fnc_setAdvancedElement.sqf | 18 +++++----- .../ui/functions/fnc_setElementVisibility.sqf | 35 +++++++++++-------- addons/ui/functions/fnc_setElements.sqf | 10 ++++-- 7 files changed, 71 insertions(+), 29 deletions(-) create mode 100644 addons/ui/functions/fnc_findSetElement.sqf diff --git a/addons/ui/CfgEventHandlers.hpp b/addons/ui/CfgEventHandlers.hpp index 36c0fca8a3..89c91283ed 100644 --- a/addons/ui/CfgEventHandlers.hpp +++ b/addons/ui/CfgEventHandlers.hpp @@ -15,3 +15,10 @@ class Extended_PostInit_EventHandlers { clientInit = QUOTE(call COMPILE_FILE(XEH_clientInit)); }; }; + +// Closing diary resets showHUD +class Extended_DisplayUnload_EventHandlers { + class RscDiary { + ADDON = QUOTE([{[false] call FUNC(setElements)}] call CBA_fnc_execNextFrame); + }; +}; diff --git a/addons/ui/XEH_PREP.hpp b/addons/ui/XEH_PREP.hpp index 8a6b4d2ce1..5c01ea1c3e 100644 --- a/addons/ui/XEH_PREP.hpp +++ b/addons/ui/XEH_PREP.hpp @@ -1,3 +1,4 @@ +PREP(findSetElement); PREP(moduleInit); PREP(setAdvancedElement); PREP(setElements); diff --git a/addons/ui/XEH_clientInit.sqf b/addons/ui/XEH_clientInit.sqf index 8ab7f35ab2..450ea0904f 100644 --- a/addons/ui/XEH_clientInit.sqf +++ b/addons/ui/XEH_clientInit.sqf @@ -5,7 +5,7 @@ if (!hasInterface) exitWith {}; ["ace_settingsInitialized", { // Initial settings - [true] call FUNC(setElements); + [false] call FUNC(setElements); // On load and entering/exiting a vehicle ["ace_infoDisplayChanged", { @@ -30,7 +30,7 @@ if (!hasInterface) exitWith {}; params ["_name"]; if (_name in ELEMENTS_BASIC) then { - [false] call FUNC(setElements); + [true] call FUNC(setElements); } else { if (isClass (configFile >> "ACE_UI" >> _name select [7])) then { [_name select [7], missionNamespace getVariable _name, true] call FUNC(setAdvancedElement); diff --git a/addons/ui/functions/fnc_findSetElement.sqf b/addons/ui/functions/fnc_findSetElement.sqf new file mode 100644 index 0000000000..939d371c04 --- /dev/null +++ b/addons/ui/functions/fnc_findSetElement.sqf @@ -0,0 +1,25 @@ +/* + * Author: Jonpas + * Finds set element by element name and returns index, source of the set element and state. + * + * Arguments: + * 0: Element Name + * + * Return Value: + * None + * + * Example: + * ["ace_ui_ammoCount"] call ace_ui_fnc_findSetElement + * + * Public: No + */ +#include "script_component.hpp" + +params ["_element"]; + +{ + if (_element in _x) exitWith { + [_forEachIndex, _x select 0, _x select 2] + }; + [-1, "", false] +} forEach GVAR(elementsSet); diff --git a/addons/ui/functions/fnc_setAdvancedElement.sqf b/addons/ui/functions/fnc_setAdvancedElement.sqf index 956dc3db5b..f068c48ed0 100644 --- a/addons/ui/functions/fnc_setAdvancedElement.sqf +++ b/addons/ui/functions/fnc_setAdvancedElement.sqf @@ -39,10 +39,10 @@ private _elements = getArray (_config >> "elements"); { private _condition = call compile (getText _x); if !(_condition) exitWith { - TRACE_2("Condition False",_element,_x); // Display and print info which component forced the element except for default vehicle check if (_showHint) then { [LSTRING(Disabled), 2] call EFUNC(common,displayTextStructured); + ACE_LOGINFO_2("Attempted modification of a forced User Interface element '%1' by '%2'",_element,configName _x); }; _show = false; }; @@ -50,15 +50,15 @@ private _elements = getArray (_config >> "elements"); // Get setting from scripted API if (!_force) then { - private _index = GVAR(elementsSet) find [_element, _show]; - if (_index == -1) then { - _index = GVAR(elementsSet) find [_element, !_show]; - if (_index != -1) then { - if (_showHint) then { - [LSTRING(Disabled), 2] call EFUNC(common,displayTextStructured); - }; - _show = ((GVAR(elementsSet)) select _index) select 1; + private _setElement = [_element] call FUNC(findSetElement); + _setElement params ["_indexSet", "_sourceSet", "_showSet"]; + + if (_indexSet != -1) then { + if (_showHint) then { + [LSTRING(Disabled), 2] call EFUNC(common,displayTextStructured); + ACE_LOGINFO_2("Attempted modification of a forced User Interface element '%1' by '%2'",_element,_sourceSet); }; + _show = _showSet; }; }; diff --git a/addons/ui/functions/fnc_setElementVisibility.sqf b/addons/ui/functions/fnc_setElementVisibility.sqf index 8fbe4cf294..f8ed74c4ad 100644 --- a/addons/ui/functions/fnc_setElementVisibility.sqf +++ b/addons/ui/functions/fnc_setElementVisibility.sqf @@ -3,21 +3,23 @@ * Setter for toggling advanced element visibility. * * Arguments: - * 0: Set/Unset - * 1: Element Name - * 2: Show/Hide Element (default: false) + * 0: Source + * 1: Set/Unset + * 2: Element Name + * 3: Show/Hide Element (default: false) * * Return Value: * None * * Example: - * [true, "ace_ui_ammoCount", false] call ace_ui_fnc_setElementVisibility + * ["ace_reload", true, "ace_ui_ammoCount", false] call ace_ui_fnc_setElementVisibility * * Public: Yes */ #include "script_component.hpp" params [ + ["_source", "", [""]], ["_set", true, [true]], ["_element", "", [""]], ["_show", false, [true]] @@ -28,32 +30,35 @@ if (!isClass (configFile >> "ACE_UI" >> _element)) exitWith { ACE_LOGWARNING_1("Element '%1' does not exist",_element); }; +if (_source == "" || {_element == ""}) exitWith { + ACE_LOGWARNING("Source or Element may not be empty strings!"); +}; + private _return = false; +private _setElement = [_element] call FUNC(findSetElement); +_setElement params ["_indexSet", "_sourceSet"]; + if (_set) then { // Exit if element has been set from another component, print warning if after interface initialization - if ([_element, _show] in GVAR(elementsSet) || {[_element, !_show] in GVAR(elementsSet)}) exitWith { + if (_indexSet != -1) exitWith { if (GVAR(interfaceInitialized)) then { - ACE_LOGWARNING_2("Element '%1' already set in %2",_element,GVAR(elementsSet)); + ACE_LOGWARNING_2("Element '%1' already set by %2",_element,_sourceSet); }; }; - TRACE_3("Setting element",_element,_show,GVAR(elementsSet)); + TRACE_4("Setting element",_source,_element,_show,GVAR(elementsSet)); private _success = [_element, _show, false, true] call FUNC(setAdvancedElement); if (_success) then { - GVAR(elementsSet) pushBack [_element, _show]; + GVAR(elementsSet) pushBack [_source, _element, _show]; _return = true; }; } else { - if ([_element, _show] in GVAR(elementsSet) || {[_element, !_show] in GVAR(elementsSet)}) then { - TRACE_3("Unsetting element",_element,_show,GVAR(elementsSet)); + if (_indexSet != -1) then { + TRACE_4("Unsetting element",_sourceSet,_element,_show,GVAR(elementsSet)); - private _index = GVAR(elementsSet) find [_element, _show]; - if (_index == -1) then { - _index = GVAR(elementsSet) find [_element, !_show]; - }; - GVAR(elementsSet) deleteAt _index; + GVAR(elementsSet) deleteAt _indexSet; [_element, _show, false, true] call FUNC(setAdvancedElement); _return = true; diff --git a/addons/ui/functions/fnc_setElements.sqf b/addons/ui/functions/fnc_setElements.sqf index 877489aba4..f029a9f5ae 100644 --- a/addons/ui/functions/fnc_setElements.sqf +++ b/addons/ui/functions/fnc_setElements.sqf @@ -3,7 +3,7 @@ * Sets basic visible elements of the UI using showHUD setter. * * Arguments: - * 0: Force change even when disallowed (default: false) + * 0: Show Hint (default: false) * * Return Value: * None @@ -15,9 +15,13 @@ */ #include "script_component.hpp" -if (isArray (missionConfigFile >> "showHUD")) exitWith {}; +params [["_showHint", false]]; -params [ ["_force", false, [true]] ]; +if (isArray (missionConfigFile >> "showHUD")) exitWith { + if (_showHint) then { + [LSTRING(Disabled)] call EFUNC(common,displayTextStructured); + }; +}; ["ui", [ true,