diff --git a/TO_MERGE/agm/Goggles/CfgFunctions.hpp b/TO_MERGE/agm/Goggles/CfgFunctions.hpp deleted file mode 100644 index 4ff3eb37cd..0000000000 --- a/TO_MERGE/agm/Goggles/CfgFunctions.hpp +++ /dev/null @@ -1,25 +0,0 @@ -class CfgFunctions{ - class AGM_Goggles{ - class AGM_Goggles{ - file="AGM_Goggles\functions"; - class Init{postInit = 1;}; - class ApplyGlassesEffect; - class RemoveGlassesEffect; - class ApplyDirtEffect; - class RemoveDirtEffect; - class isGogglesVisible; - class isDivingGoggles; - class ClearGlasses; - class CheckGoggles; - class GetExplosionIndex; - class RainEffect; - class RemoveRainEffect; - class DustHandler; - class ExternalCamera; - class isInRotorWash; - class OnEachFrame; - class ApplyDust; - class RemoveDustEffect; - }; - }; -}; \ No newline at end of file diff --git a/TO_MERGE/agm/Goggles/config.cpp b/TO_MERGE/agm/Goggles/config.cpp deleted file mode 100644 index 8bc8ffa9b5..0000000000 --- a/TO_MERGE/agm/Goggles/config.cpp +++ /dev/null @@ -1,295 +0,0 @@ -#define COLOUR 8.0 -class CfgPatches { - class AGM_Goggles { - units[] = {}; - weapons[] = {}; - requiredVersion = 0.60; - requiredAddons[] = {AGM_Core}; - version = "0.95"; - versionStr = "0.95"; - versionAr[] = {0,95,0}; - author[] = {"Garth 'L-H' de Wet"}; - authorUrl = "https://github.com/CorruptedHeart"; - }; -}; - -#include "CfgFunctions.hpp" -#define COMBAT_GOGGLES AGM_Overlay="AGM_Goggles\textures\HUD\CombatGoggles.paa"; \ - AGM_OverlayCracked = "AGM_Goggles\textures\HUD\CombatGogglesCracked.paa"; \ - AGM_Resistance = 2; \ - AGM_Protection = 1; - -class CfgGlasses { - class None { - AGM_Color[] = {0,0,0}; - AGM_TintAmount=0; - AGM_Overlay = ""; - AGM_OverlayDirt = "A3\Ui_f\data\igui\rsctitles\HealthTextures\dust_upper_ca.paa"; - AGM_OverlayCracked = "AGM_Goggles\textures\HUD\Cracked.paa"; - AGM_Resistance = 0; - AGM_Protection = 0; - AGM_DustPath = "AGM_Goggles\textures\fx\dust\%1.paa"; - }; - - class G_Combat:None { - COMBAT_GOGGLES - }; - - class G_Diving { - AGM_Overlay="AGM_Goggles\textures\HUD\DivingGoggles.paa"; - AGM_OverlayCracked = "AGM_Goggles\textures\HUD\DivingGogglesCracked.paa"; - AGM_Resistance = 2; - AGM_Protection = 1; - }; - - class G_Lowprofile:None { - AGM_TintAmount=COLOUR*2; - AGM_Resistance = 2; - AGM_Protection = 1; - }; - - class G_Shades_Black:None { - AGM_TintAmount=COLOUR*2; - AGM_Resistance = 1; - }; - - class G_Shades_Blue:None{ - AGM_Color[] = {0,0,1}; - AGM_TintAmount=COLOUR; - AGM_Resistance = 1; - }; - - class G_Shades_Green:None{ - AGM_Color[] = {0,1,0}; - AGM_TintAmount=COLOUR; - AGM_Resistance = 1; - }; - - class G_Shades_Red:None{ - AGM_Color[] = {1,0,0}; - AGM_TintAmount=COLOUR; - AGM_Resistance = 1; - }; - - class G_Spectacles:None{ - AGM_TintAmount=COLOUR; - AGM_Resistance = 1; - }; - - class G_Spectacles_Tinted:None{ - AGM_TintAmount=COLOUR*2; - AGM_Resistance = 1; - }; - - class G_Sport_Blackred:None{ - AGM_Color[] = {1,0,0}; - AGM_TintAmount=COLOUR; - AGM_Resistance = 1; - }; - - class G_Sport_BlackWhite:None{ - AGM_Color[] = {0,0,1}; - AGM_TintAmount=COLOUR; - AGM_Resistance = 1; - }; - - class G_Sport_Blackyellow:None{ - AGM_TintAmount=COLOUR*2; - AGM_Resistance = 1; - }; - - class G_Sport_Checkered:None{ - AGM_TintAmount=COLOUR*2; - AGM_Resistance = 1; - }; - - class G_Sport_Greenblack:None{ - AGM_TintAmount=COLOUR*2; - AGM_Resistance = 1; - }; - - class G_Sport_Red:None{ - AGM_TintAmount=COLOUR*2; - AGM_Color[] = {0,0,0}; - AGM_Resistance = 1; - }; - - class G_Squares:None{ - AGM_TintAmount=COLOUR; - AGM_Resistance = 1; - }; - - class G_Squares_Tinted:None{ - AGM_TintAmount=COLOUR; - AGM_Resistance = 1; - }; - - class G_Tactical_Black:None{ - AGM_TintAmount=COLOUR; - AGM_Color[] = {0,0,-1.5}; - AGM_Resistance = 1; - }; - - class G_Tactical_Clear:None{ - AGM_TintAmount=COLOUR; - AGM_Color[] = {0,0,-1}; - AGM_Resistance = 1; - }; - - class G_Aviator:None{ - AGM_Color[] = {0,0,-1}; - AGM_TintAmount=COLOUR; - AGM_Resistance = 1; - }; - - class G_Lady_Blue:None{ - AGM_Color[] = {0,0,1}; - AGM_TintAmount=COLOUR; - AGM_Resistance = 1; - }; - - class G_Lady_Red:None{ - AGM_Color[] = {1,0,0}; - AGM_TintAmount=COLOUR; - AGM_Resistance = 1; - }; - - class G_Lady_Dark:None{ - AGM_TintAmount=COLOUR*2; - AGM_Resistance = 1; - }; - - class G_Lady_Mirror:None{ - AGM_TintAmount=COLOUR; - AGM_Resistance = 1; - }; - - class AV_ESS_blk:None{ - COMBAT_GOGGLES - }; - - class G_Balaclava_blk; - - class G_Balaclava_combat:G_Balaclava_blk { - COMBAT_GOGGLES - }; - - class G_Balaclava_lowprofile:G_Balaclava_blk { - AGM_TintAmount=COLOUR*2; - AGM_Resistance = 2; - AGM_Protection = 1; - }; - - class G_Bandanna_blk; - class G_Bandanna_shades:G_Bandanna_blk { - AGM_TintAmount=COLOUR*2; - AGM_Resistance = 1; - AGM_Protection = 1; - }; - class G_Bandanna_sport:G_Bandanna_blk { - AGM_Color[] = {1,0,0}; - AGM_TintAmount=COLOUR; - AGM_Resistance = 1; - AGM_Protection = 1; - }; - class G_Bandanna_aviator:G_Bandanna_blk { - AGM_Color[] = {0,0,-1}; - AGM_TintAmount=COLOUR; - AGM_Resistance = 1; - AGM_Protection = 1; - }; -}; - -#include "RscTitles.hpp" - -class CfgMovesBasic -{ - class ManActions - { - GestureWipeFace[] = {"GestureWipeFace", "gesture"}; - }; -}; - -class CfgGesturesMale -{ - class States - { - class GestureFreezeStand; - class GestureWipeFace: GestureFreezeStand - { - file = "\AGM_Goggles\anim\WipeGlasses.rtm"; - canPullTrigger = 0; - }; - }; -}; - -class CfgWeapons{ - class H_HelmetB; - - class H_CrewHelmetHeli_B:H_HelmetB { - AGM_Protection = 1; - }; - class H_PilotHelmetHeli_B:H_HelmetB { - AGM_Protection = 1; - }; - class H_PilotHelmetFighter_B:H_HelmetB { - AGM_Protection = 1; - }; -}; - -class RifleAssaultCloud { - AGM_Goggles_BulletCount = 4; -}; -class MachineGunCloud { - AGM_Goggles_BulletCount = 3; -}; -class SniperCloud { - AGM_Goggles_BulletCount = 1; -}; - -class AGM_Core_Default_Keys { - class wipeGlasses { - displayName = $STR_AGM_Goggles_WipeGlasses; - condition = "!(player getVariable['AGM_isUnconscious', false])"; - statement = "call AGM_Goggles_fnc_ClearGlasses;"; - key = 20; // T - shift = 1; - control = 1; - alt = 0; - }; -}; - -class AGM_Core_Options { - class showInThirdPerson { - displayName = $STR_AGM_Goggles_ShowInThirdPerson; - default = 0; - }; -}; - -class CfgCloudlets { - class Default; - class AGMRainEffect:Default { - interval = 0.001; - particleShape = "\A3\data_f\ParticleEffects\Universal\Refract"; - particleFSNtieth = 1; - particleFSIndex = 0; - particleFSFrameCount = 1; - particleFSLoop = 1; - - particleType = "Billboard"; - lifeTime = 0.5; - rotationVelocity = 1; - weight = 100; - volume = 0.000; - rubbing = 1.7; - size[] = {0.1}; - color[] = {{1,1,1,1}}; - animationSpeed[] = {0,1}; - randomDirectionPeriod = 0.2; - randomDirectionIntensity = 1.2; - positionVar[] = {2, 2, 2.5}; - sizeVar = 0.01; - colorVar[] = {0, 0, 0, 0.1}; - destroyOnWaterSurface = 1; - }; -}; diff --git a/TO_MERGE/agm/Goggles/define.hpp b/TO_MERGE/agm/Goggles/define.hpp deleted file mode 100644 index 3e7666bfaa..0000000000 --- a/TO_MERGE/agm/Goggles/define.hpp +++ /dev/null @@ -1,27 +0,0 @@ -// Control types -#define CT_STATIC 0 -#define ST_PICTURE 0x30 - -//////////////// -//Base Classes// -//////////////// - -class RscPicture -{ - access = 0; - idc = -1; - type = CT_STATIC; - style = ST_PICTURE; - colorBackground[] = {0,0,0,0}; - colorText[] = {1,1,1,1}; - font = "puristaMedium"; - sizeEx = 0; - lineSpacing = 0; - fixedWidth = 0; - shadow = 0; - text = ""; - x = safezoneX; - y = safezoneY; - w = safezoneW; - h = safezoneH; -}; diff --git a/TO_MERGE/agm/Goggles/functions/fn_ApplyDirtEffect.sqf b/TO_MERGE/agm/Goggles/functions/fn_ApplyDirtEffect.sqf deleted file mode 100644 index eea86c295e..0000000000 --- a/TO_MERGE/agm/Goggles/functions/fn_ApplyDirtEffect.sqf +++ /dev/null @@ -1,32 +0,0 @@ -/* - Name: AGM_Goggles_fnc_ApplyDirtEffect - - Author: Garth de Wet (LH) - - Description: - Adds dirt effect to the glasses. - - Parameters: - Nothing - - Returns: - BOOLEAN - True if succeeded false if not - - Example: - call AGM_Goggles_fnc_ApplyDirtEffect; -*/ -#include "\AGM_Goggles\script.sqf" - -if (cameraOn != player || call AGM_Goggles_fnc_ExternalCamera) exitWith{false}; -private "_dirtImage"; -AGM_Goggles_Effects set [DIRT, true]; - -if (player call AGM_Goggles_fnc_isGogglesVisible) then{ - _dirtImage = getText(ConfigFile >> "CfgGlasses" >> goggles player >> "AGM_OverlayDirt"); - if (_dirtImage != "") then { - 100 cutRsc["RscAGM_GogglesEffects", "PLAIN",0.1, false]; - (uiNamespace getVariable ["AGM_Goggles_DisplayEffects", displayNull] displayCtrl 10660) ctrlSetText _dirtImage; - }; -}; - -true \ No newline at end of file diff --git a/TO_MERGE/agm/Goggles/functions/fn_ApplyDust.sqf b/TO_MERGE/agm/Goggles/functions/fn_ApplyDust.sqf deleted file mode 100644 index b01408ed7b..0000000000 --- a/TO_MERGE/agm/Goggles/functions/fn_ApplyDust.sqf +++ /dev/null @@ -1,69 +0,0 @@ -/* - Name: AGM_Goggles_fnc_ApplyDust - - Author: Garth de Wet (LH) - - Description: - Applies dust to screen. - - Parameters: - Nothing - - Returns: - Nothing - - Example 1: - call AGM_Goggles_fnc_ApplyDust; -*/ -#include "\AGM_Goggles\script.sqf" -if (call AGM_Goggles_fnc_ExternalCamera) exitWith {}; -if (player call AGM_Goggles_fnc_isGogglesVisible) exitWith { - 100 cutRsc["RscAGM_GogglesEffects", "PLAIN",2,false]; - (uiNamespace getVariable ["AGM_Goggles_DisplayEffects", displayNull] displayCtrl 10662) ctrlSetText format[getText(ConfigFile >> "CfgGlasses" >> AGM_Goggles_Current >> "AGM_DustPath"), GETDUSTT(DAMOUNT)+1]; - SETDUST(DAMOUNT,CLAMP(GETDUSTT(DAMOUNT)+1,0,1)); - SETDUST(DBULLETS,0); -}; - -if (player getVariable ["AGM_EyesDamaged", false]) exitWith {SETDUST(DACTIVE,false);SETDUST(DBULLETS,0);SETDUST(DAMOUNT,0);}; -SETDUST(DAMOUNT,CLAMP(GETDUSTT(DAMOUNT)+1,0,2)); - -private "_amount"; -_amount = 1 - (GETDUSTT(DAMOUNT) * 0.125); - -AGM_Goggles_PostProcessEyes ppEffectAdjust[1, 1, 0, [0,0,0,0], [_amount,_amount,_amount,_amount],[1,1,1,0]]; -AGM_Goggles_PostProcessEyes ppEffectCommit 1; -AGM_Goggles_PostProcessEyes ppEffectEnable true; -if !(scriptDone AGM_Goggles_DustHandler) then { - terminate AGM_Goggles_DustHandler; -}; -SETDUST(DBULLETS,0); -AGM_Goggles_DustHandler = [3] spawn { - private ["_loop", "_timeToSleep"]; - _timeToSleep = _this select 0; - _loop = true; - while {_loop} do { - sleep _timeToSleep; - _timeToSleep = GETDUSTT(DTIME); - - if(_timeToSleep >= (time - 2.5)) then { - _timeToSleep = time - _timeToSleep; - } else { - SETDUST(DAMOUNT,CLAMP(GETDUSTT(DAMOUNT)-1,0,2)); - private "_amount"; - _amount = 1 - (GETDUSTT(DAMOUNT) * 0.125); - if !(player getVariable ["AGM_EyesDamaged", false]) then { - AGM_Goggles_PostProcessEyes ppEffectAdjust[1, 1, 0, [0,0,0,0], [_amount,_amount,_amount,_amount],[1,1,1,0]]; - AGM_Goggles_PostProcessEyes ppEffectCommit 1; - sleep 1; - }; - if (GETDUSTT(DAMOUNT) <= 0) then { - AGM_Goggles_PostProcessEyes ppEffectEnable false; - SETDUST(DACTIVE,false); - SETDUST(DBULLETS,0); - _loop = false; - }; - SETDUST(DTIME,time); - _timeToSleep = 3; - }; - }; -}; \ No newline at end of file diff --git a/TO_MERGE/agm/Goggles/functions/fn_CheckGoggles.sqf b/TO_MERGE/agm/Goggles/functions/fn_CheckGoggles.sqf deleted file mode 100644 index e03bbc6069..0000000000 --- a/TO_MERGE/agm/Goggles/functions/fn_CheckGoggles.sqf +++ /dev/null @@ -1,52 +0,0 @@ -/* - Author: Garth de Wet (LH) - - Description: - Performs rain checks and checks to see whether glasses effects have been applied or not. - Checks for external camera and removes effects. - - Parameters: - Nothing - - Returns: - Nothing - - Example: - [] execVM "AGM_Goggles\functions\fn_CheckGoggles.sqf"; -*/ -#include "\AGM_Goggles\script.sqf" -waitUntil {sleep 0.46;alive player}; -call AGM_Goggles_fnc_CheckGlasses; -["AGM_Goggles_RotorWash", "OnEachFrame", {call AGM_Goggles_fnc_OnEachFrame;}] call BIS_fnc_addStackedEventHandler; -[] spawn AGM_Goggles_fnc_RainEffect; -while {alive player} do { - sleep 1; - if (true) then { - // Detect if curator interface is open and disable effects - if (!isNull(findDisplay 312)) exitWith { - if (AGM_Goggles_EffectsActive) then { - call AGM_Goggles_fnc_RemoveGlassesEffect; - }; - }; - call AGM_Goggles_fnc_CheckGlasses; - if !(player call AGM_Goggles_fnc_isGogglesVisible) exitWith { - if (AGM_Goggles_EffectsActive) then { - call AGM_Goggles_fnc_RemoveGlassesEffect; - }; - }; - if (call AGM_Goggles_fnc_ExternalCamera) exitWith { - if (AGM_Goggles_EffectsActive) then { - call AGM_Goggles_fnc_RemoveGlassesEffect; - }; - }; - if !(AGM_Goggles_EffectsActive) then { - (goggles player) call AGM_Goggles_fnc_ApplyGlassesEffect; - } else { - if ((goggles player) call AGM_Goggles_fnc_isDivingGoggles && {underwater player}) then { - call AGM_Goggles_fnc_RemoveRainEffect; - call AGM_Goggles_fnc_RemoveDirtEffect; - call AGM_Goggles_fnc_RemoveDustEffect; - }; - }; - }; -}; \ No newline at end of file diff --git a/TO_MERGE/agm/Goggles/functions/fn_ClearGlasses.sqf b/TO_MERGE/agm/Goggles/functions/fn_ClearGlasses.sqf deleted file mode 100644 index ab85238818..0000000000 --- a/TO_MERGE/agm/Goggles/functions/fn_ClearGlasses.sqf +++ /dev/null @@ -1,39 +0,0 @@ -/* - Name: AGM_Goggles_fnc_ClearGlasses - - Author: Garth de Wet (LH) - - Description: - Clears all dirt, rain, dust from glasses. - Removes glasses effect (PP, overlay) and then puts it back. - - Parameters: - Nothing - - Returns: - Nothing - - Example: - call AGM_Goggles_fnc_ClearGlasses; -*/ -#include "\AGM_Goggles\script.sqf" - -private "_broken"; -_broken = GETBROKEN; -AGM_Goggles_Effects = GLASSESDEFAULT; -AGM_Goggles_Effects set [BROKEN, _broken]; - -if ((stance player) != "PRONE") then { - player playActionNow "gestureWipeFace"; -}; - -null = [] spawn { - sleep 0.3; - if (cameraView == "INTERNAL") then { - addCamShake [5, 1.75, 2]; - }; -}; - -call AGM_Goggles_fnc_RemoveDirtEffect; -call AGM_Goggles_fnc_RemoveRainEffect; -call AGM_Goggles_fnc_RemoveDustEffect; diff --git a/TO_MERGE/agm/Goggles/functions/fn_GetExplosionIndex.sqf b/TO_MERGE/agm/Goggles/functions/fn_GetExplosionIndex.sqf deleted file mode 100644 index e7ac8b04f6..0000000000 --- a/TO_MERGE/agm/Goggles/functions/fn_GetExplosionIndex.sqf +++ /dev/null @@ -1,28 +0,0 @@ -/* - Name: AGM_Goggles_fnc_GetExplosionIndex - - Author: Garth de Wet (LH) - - Description: - Turns 0-1 damage into a rating system of 0-3 - - Parameters: - 0: NUMBER - The amount of damage - - Returns: - NUMBER (the rating) [0-3] - - Example: - _rating = 0.05 call AGM_Goggles_fnc_GetExplosionIndex -*/ -private ["_effect", "_effectIndex"]; -_effect = _this; - -_effectIndex = switch true do { - case (_effect <= 0.04): {0}; - case (_effect <= 0.06): {1}; - case (_effect <= 0.09): {2}; - default {3}; -}; - -_effectIndex diff --git a/TO_MERGE/agm/Goggles/functions/fn_Init.sqf b/TO_MERGE/agm/Goggles/functions/fn_Init.sqf deleted file mode 100644 index 7a8710c7f7..0000000000 --- a/TO_MERGE/agm/Goggles/functions/fn_Init.sqf +++ /dev/null @@ -1,111 +0,0 @@ -/* - Name: AGM_Goggles_fnc_Init - - Author: Garth de Wet (LH) - - Description: - Sets up the glasses mod for usage. Initialises variables and event handlers. - Shouldn't be called by a user/modder ever. Done by the engine. - - Parameters: - Nothing - - Returns: - Nothing - - Example: - call AGM_Goggles_fnc_Init; -*/ -if (!hasInterface) exitWith {}; -#include "\AGM_Goggles\script.sqf" - -if isNil("AGM_Goggles_UsePP") then { - AGM_Goggles_UsePP = true; -}; - -AGM_Goggles_PostProcess = ppEffectCreate ["ColorCorrections", 1995]; -AGM_Goggles_PostProcessEyes = ppEffectCreate ["ColorCorrections", 1992]; -AGM_Goggles_PostProcessEyes ppEffectAdjust[1, 1, 0, [0,0,0,0], [0,0,0,1],[1,1,1,0]]; -AGM_Goggles_PostProcessEyes ppEffectCommit 0; -AGM_Goggles_PostProcessEyes ppEffectEnable false; -AGM_Goggles_EffectsActive = false; -AGM_Goggles_Effects = GLASSESDEFAULT; -AGM_Goggles_Current = "None"; -AGM_Goggles_EyesDamageScript = 0 spawn {}; -AGM_Goggles_FrameEvent = [false, [false,20]]; -AGM_Goggles_PostProcessEyes_Enabled = false; -AGM_Goggles_DustHandler = 0 spawn {}; -AGM_Goggles_RainDrops = objNull; - -AGM_Goggles_fnc_CheckGlasses = { - if (AGM_Goggles_Current != (goggles player)) then { - AGM_Goggles_Current = (goggles player); - ["GlassesChanged",[AGM_Goggles_Current]] call CBA_fnc_localEvent; - }; -}; - -player addEventHandler ["Explosion", { - if (alive player) then { - call AGM_Goggles_fnc_ApplyDirtEffect; - if (GETBROKEN) exitWith {}; - if (((_this select 1) call AGM_Goggles_fnc_GetExplosionIndex) < getNumber(ConfigFile >> "CfgGlasses" >> AGM_Goggles_Current >> "AGM_Resistance")) exitWith {}; - if !(player call AGM_Goggles_fnc_isGogglesVisible) exitWith {["GlassesCracked",[player]] call CBA_fnc_localEvent;}; - AGM_Goggles_Effects set [BROKEN, true]; - if (getText(ConfigFile >> "CfgGlasses" >> AGM_Goggles_Current >> "AGM_OverlayCracked") != "" && {cameraOn == player}) then { - if (call AGM_Goggles_fnc_ExternalCamera) exitWith {}; - if (isNull(GLASSDISPLAY)) then { - 150 cutRsc["RscAGM_Goggles", "PLAIN",1, false]; - }; - (GLASSDISPLAY displayCtrl 10650) ctrlSetText getText(ConfigFile >> "CfgGlasses" >> AGM_Goggles_Current >> "AGM_OverlayCracked"); - }; - ["GlassesCracked",[player]] call CBA_fnc_localEvent; - }; -}]; -player addEventHandler ["Killed",{ - [] spawn { - sleep 2; - AGM_Goggles_PostProcessEyes ppEffectEnable false; - AGM_Goggles_Effects = GLASSESDEFAULT; - call AGM_Goggles_fnc_RemoveGlassesEffect; - AGM_Goggles_EffectsActive=false; - player setVariable ["AGM_EyesDamaged", false]; - terminate AGM_Goggles_EyesDamageScript; - terminate AGM_Goggles_MainLoop; - terminate AGM_Goggles_DustHandler; - AGM_Goggles_MainLoop = [] spawn AGM_Goggles_fnc_CheckGoggles; - }; -}]; -player addEventHandler ["Fired",{[_this select 0, _this select 1] call AGM_Goggles_fnc_DustHandler;}]; -player AddEventHandler ["Take",{call AGM_Goggles_fnc_CheckGlasses;}]; -player AddEventHandler ["Put", {call AGM_Goggles_fnc_CheckGlasses;}]; - -["GlassesChanged",{ - AGM_Goggles_Effects = GLASSESDEFAULT; - - if (call AGM_Goggles_fnc_ExternalCamera) exitWith {call AGM_Goggles_fnc_RemoveGlassesEffect}; - - if (player call AGM_Goggles_fnc_isGogglesVisible) then { - (_this select 0) call AGM_Goggles_fnc_ApplyGlassesEffect; - } else { - call AGM_Goggles_fnc_RemoveGlassesEffect; - }; -}] call CBA_fnc_addEventHandler; -["GlassesCracked",{ - if (_this select 0 != player) exitWith {}; - player setVariable ["AGM_EyesDamaged", true]; - if !(scriptDone AGM_Goggles_EyesDamageScript) then { - terminate AGM_Goggles_EyesDamageScript; - }; - AGM_Goggles_PostProcessEyes ppEffectAdjust[1, 1, 0, [0,0,0,0], [0.5,0.5,0.5,0.5],[1,1,1,0]]; - AGM_Goggles_PostProcessEyes ppEffectCommit 0; - AGM_Goggles_PostProcessEyes ppEffectEnable true; - AGM_Goggles_EyesDamageScript = [] spawn { - sleep 25; - AGM_Goggles_PostProcessEyes ppEffectAdjust[1, 1, 0, [0,0,0,0], [1,1,1,1],[1,1,1,0]]; - AGM_Goggles_PostProcessEyes ppEffectCommit 5; - sleep 5; - AGM_Goggles_PostProcessEyes ppEffectEnable false; - player setVariable ["AGM_EyesDamaged", false]; - }; -}] call CBA_fnc_addEventHandler; -AGM_Goggles_MainLoop = [] spawn AGM_Goggles_fnc_CheckGoggles; diff --git a/TO_MERGE/agm/Goggles/functions/fn_OnEachFrame.sqf b/TO_MERGE/agm/Goggles/functions/fn_OnEachFrame.sqf deleted file mode 100644 index 660c3d7afa..0000000000 --- a/TO_MERGE/agm/Goggles/functions/fn_OnEachFrame.sqf +++ /dev/null @@ -1,80 +0,0 @@ -/* - Name: AGM_Goggles_fnc_OnEachFrame - - Author: Garth de Wet (LH) - - Description: - Runs every frame checking for helicopters. - - Parameters: - Nothing - - Returns: - Nothing - - Example: - ["AGM_Goggles_RotorWash", "OnEachFrame", "call AGM_Goggles_fnc_OnEachFrame;"] call BIS_fnc_addStackedEventHandler; -*/ -#include "\AGM_Goggles\script.sqf" -if (isNull(player)) then { - ["AGM_Goggles_RotorWash", "OnEachFrame"] call BIS_fnc_removeStackedEventHandler; -}; -AGM_Goggles_FrameEvent set [0, !(AGM_Goggles_FrameEvent select 0)]; -if (AGM_Goggles_FrameEvent select 0) exitWith { - if (vehicle player != player && {!([player] call AGM_Core_fnc_isTurnedOut)}) exitWith {(AGM_Goggles_FrameEvent select 1) set [0, false]; }; - AGM_Goggles_FrameEvent set [1, ([player] call AGM_Goggles_fnc_isInRotorWash)]; -}; -private ["_rotorWash","_safe"]; -_rotorWash = AGM_Goggles_FrameEvent select 1; -_safe = false; -if !(_rotorWash select 0) exitWith { - if (AGM_Goggles_PostProcessEyes_Enabled) then { - AGM_Goggles_PostProcessEyes_Enabled = false; - if (!scriptDone (AGM_Goggles_DustHandler)) then { - terminate AGM_Goggles_DustHandler; - }; - AGM_Goggles_DustHandler = [] spawn { - AGM_Goggles_PostProcessEyes ppEffectAdjust [1, 1, 0, [0,0,0,0], [0,0,0,1],[1,1,1,0]]; - AGM_Goggles_PostProcessEyes ppEffectCommit 2; - sleep 2; - AGM_Goggles_PostProcessEyes ppEffectEnable false; - }; - }; -}; -if ((headgear player) != "") then { - _safe = (getNumber (ConfigFile >> "CfgWeapons" >> (headgear player) >> "AGM_Protection") == 1); -}; -if !(_safe) then { - if !(player call AGM_Goggles_fnc_isGogglesVisible) exitWith{}; - if (GETDUSTT(DAMOUNT) < 2) then { - if (!GETDUSTT(DACTIVE)) then { - SETDUST(DACTIVE,true); - call AGM_Goggles_fnc_ApplyDust; - } else { - if ((_rotorWash select 1) > 0.5) then { - call AGM_Goggles_fnc_ApplyDust; - }; - }; - }; - _safe = (getNumber (ConfigFile >> "CfgGlasses" >> AGM_Goggles_Current >> "AGM_Protection") == 1); -}; -if (_safe) exitWith {}; -if ((_rotorWash select 1) <= 15) then { - private "_scale"; - _scale = 0.7; - if ((_rotorWash select 1) != 0) then { - _scale = CLAMP(0.3*(_rotorWash select 1),0.1,0.3); - } else { - _scale = 0.1; - }; - _scale = 1 - _scale; - if (!scriptDone (AGM_Goggles_DustHandler)) then { - terminate AGM_Goggles_DustHandler; - }; - if !(player getVariable ["AGM_EyesDamaged", false]) then { - AGM_Goggles_PostProcessEyes_Enabled = true; - AGM_Goggles_PostProcessEyes ppEffectAdjust [1, 1, 0, [0,0,0,0], [_scale,_scale,_scale,_scale],[1,1,1,0]]; - AGM_Goggles_PostProcessEyes ppEffectCommit 0.5; - AGM_Goggles_PostProcessEyes ppEffectEnable true; - }; -}; diff --git a/TO_MERGE/agm/Goggles/functions/fn_RainEffect.sqf b/TO_MERGE/agm/Goggles/functions/fn_RainEffect.sqf deleted file mode 100644 index a52862a20e..0000000000 --- a/TO_MERGE/agm/Goggles/functions/fn_RainEffect.sqf +++ /dev/null @@ -1,61 +0,0 @@ -/* - Name: AGM_Goggles_fnc_RainEffect - - Author: Garth de Wet (LH) - - Description: - - - Parameters: - Nothing - - Returns: - Nothing - - Example: - [] spawn AGM_Goggles_fnc_RainEffect; -*/ -#include "\AGM_Goggles\script.sqf" -AGM_Goggles_RainDrops = objNull; -AGM_Goggles_Rain_Active = false; -_fnc_underCover = { - private ["_pos", "_unit"]; - _unit = (_this select 0); - if (vehicle _unit != _unit && {!([_unit] call AGM_Core_fnc_isTurnedOut)}) exitWith {true}; - _pos = eyePos _unit; - ((positionCameraToWorld [0,0,1] select 2) < ((positionCameraToWorld [0,0,0] select 2) - 0.4)) || {(lineIntersects [_pos, _pos vectorAdd [0,0,15], _unit])} -}; -private ["_lastRain"]; -_lastRain = 0; -while {alive player} do { - sleep 0.5; - if (isNull(findDisplay 312)) then { - // Ignore if player is under water - if (!AGM_Goggles_EffectsActive || {underwater player}) exitWith{call AGM_Goggles_fnc_RemoveRainEffect;}; - if (_lastRain != rain) then { - call AGM_Goggles_fnc_RemoveRainEffect; - _lastRain = rain; - // Rain is happening - if (_lastRain > 0.05 && {!([player] call _fnc_underCover)}) then { - AGM_Goggles_Rain_Active = true; - AGM_Goggles_RainDrops = "#particlesource" createVehicleLocal GetPos player; - AGM_Goggles_RainDrops setParticleClass "AGMRainEffect"; - AGM_Goggles_RainDrops setDropInterval (0.07 * (1.1 - _lastRain)); - AGM_Goggles_RainDrops attachTo [vehicle player,[0,0,0]]; - }; - }else{ - if (_lastRain > 0.05) then { - if (AGM_Goggles_Rain_Active && {[player] call _fnc_underCover}) exitWith { - call AGM_Goggles_fnc_RemoveRainEffect; - }; - if (!AGM_Goggles_Rain_Active) then { - _lastRain = -1; - }; - }; - }; - }else{ - if (AGM_Goggles_Rain_Active) then { - call AGM_Goggles_fnc_RemoveRainEffect; - }; - }; -}; \ No newline at end of file diff --git a/TO_MERGE/agm/Goggles/functions/fn_RemoveDirtEffect.sqf b/TO_MERGE/agm/Goggles/functions/fn_RemoveDirtEffect.sqf deleted file mode 100644 index 0d63dec827..0000000000 --- a/TO_MERGE/agm/Goggles/functions/fn_RemoveDirtEffect.sqf +++ /dev/null @@ -1,20 +0,0 @@ -/* - Name: AGM_Goggles_fnc_RemoveDirtEffect - - Author: Garth de Wet (LH) - - Description: - Removes dirt from the glasses. - - Parameters: - Nothing - - Returns: - Nothing - - Example: - call AGM_Goggles_fnc_RemoveDirtEffect; -*/ -if (!isNull(uiNamespace getVariable ["AGM_Goggles_DisplayEffects", displayNull])) then { - (uiNamespace getVariable ["AGM_Goggles_DisplayEffects", displayNull] displayCtrl 10660) ctrlSetText ""; -}; diff --git a/TO_MERGE/agm/Goggles/functions/fn_RemoveDustEffect.sqf b/TO_MERGE/agm/Goggles/functions/fn_RemoveDustEffect.sqf deleted file mode 100644 index a895583e02..0000000000 --- a/TO_MERGE/agm/Goggles/functions/fn_RemoveDustEffect.sqf +++ /dev/null @@ -1,20 +0,0 @@ -/* - Name: AGM_Goggles_fnc_RemoveDustEffect - - Author: Garth de Wet (LH) - - Description: - Removes dust from the glasses. - - Parameters: - Nothing - - Returns: - Nothing - - Example: - call AGM_Goggles_fnc_RemoveDustEffect; -*/ -if (!isNull(uiNamespace getVariable ["AGM_Goggles_DisplayEffects", displayNull])) then { - (uiNamespace getVariable ["AGM_Goggles_DisplayEffects", displayNull] displayCtrl 10662) ctrlSetText ""; -}; diff --git a/TO_MERGE/agm/Goggles/functions/fn_RemoveGlassesEffect.sqf b/TO_MERGE/agm/Goggles/functions/fn_RemoveGlassesEffect.sqf deleted file mode 100644 index b80f79a028..0000000000 --- a/TO_MERGE/agm/Goggles/functions/fn_RemoveGlassesEffect.sqf +++ /dev/null @@ -1,29 +0,0 @@ -/* - Name: AGM_Goggles_fnc_RemoveGlassesEffect - - Author: Garth de Wet (LH) - - Description: - Removes the glasses effect from the screen, removes dirt effect, removes rain effect, - removes dust effect. Does not reset array (glasses will still be broken, dirty, ect.) - - Parameters: - Nothing - - Returns: - Nothing - - Example: - call AGM_Goggles_fnc_RemoveGlassesEffect; -*/ -#include "\AGM_Goggles\script.sqf" -AGM_Goggles_EffectsActive = false; -AGM_Goggles_PostProcess ppEffectEnable false; - -if (!isNull(GLASSDISPLAY)) then { - GLASSDISPLAY closeDisplay 0; -}; - -call AGM_Goggles_fnc_RemoveDirtEffect; -call AGM_Goggles_fnc_RemoveRainEffect; -call AGM_Goggles_fnc_RemoveDustEffect; diff --git a/TO_MERGE/agm/Goggles/functions/fn_RemoveRainEffect.sqf b/TO_MERGE/agm/Goggles/functions/fn_RemoveRainEffect.sqf deleted file mode 100644 index a3e3629bb1..0000000000 --- a/TO_MERGE/agm/Goggles/functions/fn_RemoveRainEffect.sqf +++ /dev/null @@ -1,21 +0,0 @@ -/* - Name: AGM_Goggles_fnc_RemoveRainEffect - - Author: Garth de Wet (LH) - - Description: - Removes rain effects from the screen. Resets the rain array. - - Parameters: - Nothing - - Returns: - Nothing - - Example: - call AGM_Goggles_fnc_RemoveRainEffect; -*/ -if (!isNull (AGM_Goggles_RainDrops)) then { - deleteVehicle (AGM_Goggles_RainDrops); -}; -AGM_Goggles_Rain_Active = false; \ No newline at end of file diff --git a/TO_MERGE/agm/Goggles/script.sqf b/TO_MERGE/agm/Goggles/script.sqf deleted file mode 100644 index 92f681915e..0000000000 --- a/TO_MERGE/agm/Goggles/script.sqf +++ /dev/null @@ -1,21 +0,0 @@ -#define GLASSESDEFAULT [false,[false,0,0,0],false] - -#define DIRT 0 -#define DUST 1 -#define BROKEN 2 - -#define GETDIRT (AGM_Goggles_Effects select DIRT) -#define GETDUST (AGM_Goggles_Effects select DUST) -#define GETBROKEN (AGM_Goggles_Effects select BROKEN) -#define GETDUSTT(type) ((AGM_Goggles_Effects select DUST) select type) - -#define SETDUST(type,value) (AGM_Goggles_Effects select DUST) set [type, value] - -#define DACTIVE 0 -#define DTIME 1 -#define DBULLETS 2 -#define DAMOUNT 3 - -#define GLASSDISPLAY (uiNamespace getVariable ["AGM_Goggles_Display", displayNull]) - -#define CLAMP(x,low,high) (if(x > high)then{high}else{if(x < low)then{low}else{x}}) diff --git a/TO_MERGE/agm/Markers/InsertMarker.hpp b/TO_MERGE/agm/Markers/InsertMarker.hpp deleted file mode 100644 index 07366a1f4b..0000000000 --- a/TO_MERGE/agm/Markers/InsertMarker.hpp +++ /dev/null @@ -1,136 +0,0 @@ - -class RscDisplayInsertMarker { - onLoad = "_this call compile preprocessFileLineNumbers 'AGM_Markers\scripts\initInsertMarker.sqf'"; - onUnload = "_this call compile preprocessFileLineNumbers 'AGM_Markers\scripts\placeMarker.sqf'"; - idd = 54; - movingEnable = 1; - class controlsBackground { - class RscText_1000: RscText { - idc = 1000; - /*x = "0 * GUI_GRID_INSERTMARKER_W + GUI_GRID_INSERTMARKER_X"; - y = "0 * GUI_GRID_INSERTMARKER_H + GUI_GRID_INSERTMARKER_Y"; - w = "8 * GUI_GRID_INSERTMARKER_W"; - h = "2.5 * GUI_GRID_INSERTMARKER_H"; - colorBackground[] = {0,0,0,0.5};*/ - }; - class Description: RscStructuredText { - colorBackground[] = {0,0,0,0.7}; - idc = 1100; - x = "14 * ( ((safezoneW / safezoneH) min 1.2) / 40) + (safezoneX)"; - y = "9.5 * ( ( ((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + safezoneH - ( ((safezoneW / safezoneH) min 1.2) / 1.2))"; - w = "10 * ( ((safezoneW / safezoneH) min 1.2) / 40)"; - h = "1 * ( ( ((safezoneW / safezoneH) min 1.2) / 1.2) / 25)"; - }; - }; - class controls { - //delete ButtonOK; - class ButtonMenuOK: RscButtonMenuOK { - x = "14 * ( ((safezoneW / safezoneH) min 1.2) / 40) + (safezoneX)"; - y = "15.5 * ( ( ((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + safezoneH - ( ((safezoneW / safezoneH) min 1.2) / 1.2))"; - w = "8.9 * ( ((safezoneW / safezoneH) min 1.2) / 40)"; - h = "1 * ( ( ((safezoneW / safezoneH) min 1.2) / 1.2) / 25)"; - // size = "0.85 * ( ( ( ((safezoneW / safezoneH) min 1.2) / 1.2) / 25) * 1)"; - // sizeEx = "0.85 * ( ( ( ((safezoneW / safezoneH) min 1.2) / 1.2) / 25) * 1)"; - text = ""; - }; - class ButtonMenuCancel: RscButtonMenuCancel { - x = "23 * ( ((safezoneW / safezoneH) min 1.2) / 40) + (safezoneX)"; - y = "15.5 * ( ( ((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + safezoneH - ( ((safezoneW / safezoneH) min 1.2) / 1.2))"; - w = "1.1 * ( ((safezoneW / safezoneH) min 1.2) / 40)"; - h = "1 * ( ( ((safezoneW / safezoneH) min 1.2) / 1.2) / 25)"; - - text = "X"; - colorBackground[] = {0.75,0,0,0.5}; - colorBackgroundFocused[] = {0.75,0,0,0.5}; - colorBackground2[] = {1,0,0,0.5}; - }; - /*class ButtonMenuInfo: RscButtonMenu { - idc = 2400; - text = "$STR_A3_RscDisplayInsertMarker_ButtonMenuInfo"; - x = "14 * ( ((safezoneW / safezoneH) min 1.2) / 40) + (safezoneX)"; - y = "13.5 * ( ( ((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + safezoneH - ( ((safezoneW / safezoneH) min 1.2) / 1.2))"; - w = "10 * ( ((safezoneW / safezoneH) min 1.2) / 40)"; - h = "1 * ( ( ((safezoneW / safezoneH) min 1.2) / 1.2) / 25)"; - };*/ - delete ButtonMenuInfo; - class Title: RscText { - moving = 1; - colorBackground[] = {"(profilenamespace getvariable ['GUI_BCG_RGB_R',0.69])","(profilenamespace getvariable ['GUI_BCG_RGB_G',0.75])","(profilenamespace getvariable ['GUI_BCG_RGB_B',0.5])","(profilenamespace getvariable ['GUI_BCG_RGB_A',0.8])"}; - idc = 1001; - text = "$STR_A3_RscDisplayInsertMarker_Title"; - x = "14 * ( ((safezoneW / safezoneH) min 1.2) / 40) + (safezoneX)"; - y = "8.5 * ( ( ((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + safezoneH - ( ((safezoneW / safezoneH) min 1.2) / 1.2))"; - w = "10 * ( ((safezoneW / safezoneH) min 1.2) / 40)"; - h = "1 * ( ( ((safezoneW / safezoneH) min 1.2) / 1.2) / 25)"; - }; - delete Description; - /*class Info: RscStructuredText { - colorBackground[] = {0,0,0,0.7}; - idc = 1101; - x = "14 * ( ((safezoneW / safezoneH) min 1.2) / 40) + (safezoneX)"; - y = "11.5 * ( ( ((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + safezoneH - ( ((safezoneW / safezoneH) min 1.2) / 1.2))"; - w = "10 * ( ((safezoneW / safezoneH) min 1.2) / 40)"; - h = "1 * ( ( ((safezoneW / safezoneH) min 1.2) / 1.2) / 25)"; - };*/ - delete Info; - class Picture: RscPicture { - idc = 102; - x = 0.259984; - y = 0.4; - w = 0.05; - h = 0.0666667; - }; - class Text: RscEdit { - idc = 101; - x = "14 * ( ((safezoneW / safezoneH) min 1.2) / 40) + (safezoneX)"; - y = "10.5 * ( ( ((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + safezoneH - ( ((safezoneW / safezoneH) min 1.2) / 1.2))"; - w = "10 * ( ((safezoneW / safezoneH) min 1.2) / 40)"; - h = "1 * ( ( ((safezoneW / safezoneH) min 1.2) / 1.2) / 25)"; - }; - /*class SizeX: RscEdit { - idc = 1200; - text = "10"; - x = "14 * ( ((safezoneW / safezoneH) min 1.2) / 40) + (safezoneX)"; - y = "12.5 * ( ( ((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + safezoneH - ( ((safezoneW / safezoneH) min 1.2) / 1.2))"; - w = "5 * ( ((safezoneW / safezoneH) min 1.2) / 40)"; - h = "1 * ( ( ((safezoneW / safezoneH) min 1.2) / 1.2) / 25)"; - }; - class SizeY: RscEdit { - idc = 1201; - text = "10"; - x = "19 * ( ((safezoneW / safezoneH) min 1.2) / 40) + (safezoneX)"; - y = "12.5 * ( ( ((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + safezoneH - ( ((safezoneW / safezoneH) min 1.2) / 1.2))"; - w = "5 * ( ((safezoneW / safezoneH) min 1.2) / 40)"; - h = "1 * ( ( ((safezoneW / safezoneH) min 1.2) / 1.2) / 25)"; - };*/ - class MarkerShape: RscCombo { - idc = 1210; - x = "14 * ( ((safezoneW / safezoneH) min 1.2) / 40) + (safezoneX)"; - y = "11.5 * ( ( ((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + safezoneH - ( ((safezoneW / safezoneH) min 1.2) / 1.2))"; - w = "10 * ( ((safezoneW / safezoneH) min 1.2) / 40)"; - h = "1 * ( ( ((safezoneW / safezoneH) min 1.2) / 1.2) / 25)"; - }; - class MarkerColor: RscCombo { - idc = 1211; - x = "14 * ( ((safezoneW / safezoneH) min 1.2) / 40) + (safezoneX)"; - y = "12.5 * ( ( ((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + safezoneH - ( ((safezoneW / safezoneH) min 1.2) / 1.2))"; - w = "10 * ( ((safezoneW / safezoneH) min 1.2) / 40)"; - h = "1 * ( ( ((safezoneW / safezoneH) min 1.2) / 1.2) / 25)"; - }; - class MarkerAngle: RscXSliderH { - idc = 1220; - text = "10"; - x = "14 * ( ((safezoneW / safezoneH) min 1.2) / 40) + (safezoneX)"; - y = "13.5 * ( ( ((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + safezoneH - ( ((safezoneW / safezoneH) min 1.2) / 1.2))"; - w = "10 * ( ((safezoneW / safezoneH) min 1.2) / 40)"; - h = "1 * ( ( ((safezoneW / safezoneH) min 1.2) / 1.2) / 25)"; - }; - class MarkerAngleText: RscText { - idc = 1221; - x = "14 * ( ((safezoneW / safezoneH) min 1.2) / 40) + (safezoneX)"; - y = "14.5 * ( ( ((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + safezoneH - ( ((safezoneW / safezoneH) min 1.2) / 1.2))"; - w = "10 * ( ((safezoneW / safezoneH) min 1.2) / 40)"; - h = "1 * ( ( ((safezoneW / safezoneH) min 1.2) / 1.2) / 25)"; - }; - }; -}; diff --git a/TO_MERGE/agm/Markers/clientInit.sqf b/TO_MERGE/agm/Markers/clientInit.sqf deleted file mode 100644 index e5dc72e804..0000000000 --- a/TO_MERGE/agm/Markers/clientInit.sqf +++ /dev/null @@ -1,7 +0,0 @@ -// by commy2 - -// request marker data for JIP -if (isMultiplayer && {!isServer}) then { - _logic = createGroup sideLogic createUnit ["Logic", [0,0,0], [], 0, "NONE"]; - [_logic, "AGM_Markers_fnc_sendMarkersJIP", 1] call AGM_Core_fnc_execRemoteFnc; -}; diff --git a/TO_MERGE/agm/Markers/config.cpp b/TO_MERGE/agm/Markers/config.cpp deleted file mode 100644 index 3811f1f685..0000000000 --- a/TO_MERGE/agm/Markers/config.cpp +++ /dev/null @@ -1,47 +0,0 @@ -class CfgPatches { - class AGM_Markers { - units[] = {}; - weapons[] = {}; - requiredVersion = 0.60; - requiredAddons[] = {AGM_Core}; - version = "0.95"; - versionStr = "0.95"; - versionAr[] = {0,95,0}; - author[] = {"commy2"}; - authorUrl = "https://github.com/commy2/"; - }; -}; - -class CfgFunctions { - class AGM_Markers { - class AGM_Markers { - file = "AGM_Markers\functions"; - class onLBSelChangedColor; - class onLBSelChangedShape; - class onSliderPosChangedAngle; - class sendMarkersJIP; - class setMarker; - class setMarkerJIP; - class setMarkerNetwork; - }; - }; -}; - -class Extended_PostInit_EventHandlers { - class AGM_Markers { - clientInit = "call compile preprocessFileLineNumbers 'AGM_Markers\clientInit.sqf'"; - }; -}; - -class RscPicture; -class RscText; -class RscStructuredText; -class RscButtonMenuOK; -class RscButtonMenuCancel; -class RscButtonMenu; -class RscEdit; -class RscCombo; -class RscSlider; -class RscXSliderH; - -#include diff --git a/TO_MERGE/agm/Markers/functions/fn_sendMarkersJIP.sqf b/TO_MERGE/agm/Markers/functions/fn_sendMarkersJIP.sqf deleted file mode 100644 index dd95a68d50..0000000000 --- a/TO_MERGE/agm/Markers/functions/fn_sendMarkersJIP.sqf +++ /dev/null @@ -1,15 +0,0 @@ -// by commy2 - -private "_logic"; - -_logic = _this; - -[ - [ - missionNamespace getVariable ["AGM_allMapMarkers", []], - missionNamespace getVariable ["AGM_allMapMarkersProperties", []], - _logic - ], - "AGM_Markers_fnc_setMarkerJIP", - _logic -] call AGM_Core_fnc_execRemoteFnc; diff --git a/TO_MERGE/agm/Markers/functions/fn_setMarker.sqf b/TO_MERGE/agm/Markers/functions/fn_setMarker.sqf deleted file mode 100644 index 63df5bfe11..0000000000 --- a/TO_MERGE/agm/Markers/functions/fn_setMarker.sqf +++ /dev/null @@ -1,15 +0,0 @@ -// by commy2 - -private ["_marker", "_data", "_config"]; - -_marker = _this select 0; -_data = _this select 1; - -_config = (configfile >> "CfgMarkers") select (_data select 0); -[[_marker, configName _config], "{if ((_this select 0) in allMapMarkers) then {(_this select 0) setMarkerTypeLocal (_this select 1)};}", 2] call AGM_Core_fnc_execRemoteFnc; - -_config = (configfile >> "CfgMarkerColors") select (_data select 1); -[[_marker, configName _config], "{if ((_this select 0) in allMapMarkers) then {(_this select 0) setMarkerColorLocal (_this select 1)};}", 2] call AGM_Core_fnc_execRemoteFnc; - -[[_marker, _data select 2], "{if ((_this select 0) in allMapMarkers) then {(_this select 0) setMarkerPosLocal (_this select 1)};}", 2] call AGM_Core_fnc_execRemoteFnc; -[[_marker, _data select 3], "{if ((_this select 0) in allMapMarkers) then {(_this select 0) setMarkerDirLocal (_this select 1)};}", 2] call AGM_Core_fnc_execRemoteFnc; diff --git a/TO_MERGE/agm/Markers/functions/fn_setMarkerJIP.sqf b/TO_MERGE/agm/Markers/functions/fn_setMarkerJIP.sqf deleted file mode 100644 index 9ede4d492e..0000000000 --- a/TO_MERGE/agm/Markers/functions/fn_setMarkerJIP.sqf +++ /dev/null @@ -1,26 +0,0 @@ -// by commy2 - -private ["_allMapMarkers", "_allMapMarkersProperties", "_index", "_data", "_config"]; - -_allMapMarkers = _this select 0; -_allMapMarkersProperties = _this select 1; -_logic = _this select 2; - -{ - _index = _allMapMarkers find _x; - - if (_index != -1) then { - _data = _allMapMarkersProperties select _index; - - _config = (configfile >> "CfgMarkers") select (_data select 0); - _x setMarkerTypeLocal configName _config; - - _config = (configfile >> "CfgMarkerColors") select (_data select 1); - _x setMarkerColorLocal configName _config; - - _x setMarkerPosLocal (_data select 2); - _x setMarkerDirLocal (_data select 3); - }; -} forEach allMapMarkers; - -deleteVehicle _logic; diff --git a/TO_MERGE/agm/Markers/functions/fn_setMarkerNetwork.sqf b/TO_MERGE/agm/Markers/functions/fn_setMarkerNetwork.sqf deleted file mode 100644 index e655c7171f..0000000000 --- a/TO_MERGE/agm/Markers/functions/fn_setMarkerNetwork.sqf +++ /dev/null @@ -1,36 +0,0 @@ -// by commy2 - -private ["_marker", "_data", "_config"]; - -_marker = _this select 0; -_data = _this select 1; - -_config = (configfile >> "CfgMarkers") select (_data select 0); -_marker setMarkerTypeLocal configName _config; - -_config = (configfile >> "CfgMarkerColors") select (_data select 1); -_marker setMarkerColorLocal configName _config; - -_marker setMarkerPosLocal (_data select 2); -_marker setMarkerDirLocal (_data select 3); - -// save properties on server machine for JIP, marker editing ready -if (isMultiplayer && {isServer}) then { - private ["_allMapMarkers", "_allMapMarkersProperties", "_index"]; - - _allMapMarkers = missionNamespace getVariable ["AGM_allMapMarkers", []]; - _allMapMarkersProperties = missionNamespace getVariable ["AGM_allMapMarkersProperties", []]; - - _index = _allMapMarkers find _marker; - - if (_index == -1) then { - _allMapMarkers pushBack _marker; - _allMapMarkersProperties pushBack _data; - } else { - _allMapMarkers set [_index, _marker]; - _allMapMarkersProperties set [_index, _data]; - }; - - AGM_allMapMarkers = _allMapMarkers; - AGM_allMapMarkersProperties = _allMapMarkersProperties; -}; diff --git a/TO_MERGE/agm/Markers/scripts/placeMarker.sqf b/TO_MERGE/agm/Markers/scripts/placeMarker.sqf deleted file mode 100644 index 248190435a..0000000000 --- a/TO_MERGE/agm/Markers/scripts/placeMarker.sqf +++ /dev/null @@ -1,51 +0,0 @@ -// by commy2 - -if (_this select 1 == 1) then { - disableserialization; - _display = _this select 0; - - _pos = ctrlPosition (_display displayCtrl 102); - _pos = [ - (_pos select 0) + (_pos select 2) / 2, - (_pos select 1) + (_pos select 3) / 2 - ]; - - switch (true) do { - case (!isNull findDisplay 12) : { - _pos = (findDisplay 12 displayCtrl 51) ctrlMapScreenToWorld _pos; - }; - case (!isNull findDisplay 37) : { - _pos = (findDisplay 37 displayCtrl 51) ctrlMapScreenToWorld _pos; - }; - case (!isNull findDisplay 52) : { - _pos = (findDisplay 52 displayCtrl 51) ctrlMapScreenToWorld _pos; - }; - case (!isNull findDisplay 53) : { - _pos = (findDisplay 53 displayCtrl 51) ctrlMapScreenToWorld _pos; - }; - }; - - _pos spawn { - /*[ - allMapMarkers select (count allMapMarkers - 1), - [ - uiNamespace getVariable ['AGM_Markers_currentMarkerShape', 0], - uiNamespace getVariable ['AGM_Markers_currentMarkerColor', 0], - _this, - uiNamespace getVariable ['AGM_Markers_currentMarkerAngle', 0] - ] - ] call AGM_Markers_fnc_setMarker;*/ - - [ - [ - allMapMarkers select (count allMapMarkers - 1), - [ - uiNamespace getVariable ['AGM_Markers_currentMarkerShape', 0], - uiNamespace getVariable ['AGM_Markers_currentMarkerColor', 0], - _this, - uiNamespace getVariable ['AGM_Markers_currentMarkerAngle', 0] - ] - ], "AGM_Markers_fnc_setMarkerNetwork", 2 - ] call AGM_Core_fnc_execRemoteFnc; - }; -}; diff --git a/TO_MERGE/cse/f_eh/CfgFunctions.h b/TO_MERGE/cse/f_eh/CfgFunctions.h deleted file mode 100644 index 36054c411f..0000000000 --- a/TO_MERGE/cse/f_eh/CfgFunctions.h +++ /dev/null @@ -1,20 +0,0 @@ -class CfgFunctions { - class CSE { - class eventhandlers { - file = "cse\cse_f_eh\functions"; - class initialization_f { - preInit = 1; - postInit = 1; - recompile = 1; - }; - class eventHandler_f { recompile = 1; }; - class HandleHeal_EH_F { recompile = 1; }; - class HandleDamage_EH_F { recompile = 1; }; - class customEventHandler_F { recompile = 1; }; - class getCustomResults_F { recompile = 1; }; - class setEventhandler_f { recompile = 1; }; - class removeEventHandler_f { recompile = 1; }; - class addModuleEventHandlers_f { recompile = 1; }; - }; - }; -}; \ No newline at end of file diff --git a/TO_MERGE/cse/f_eh/CfgVehicles.h b/TO_MERGE/cse/f_eh/CfgVehicles.h deleted file mode 100644 index 15511631e1..0000000000 --- a/TO_MERGE/cse/f_eh/CfgVehicles.h +++ /dev/null @@ -1,180 +0,0 @@ -class CfgVehicles { - class All; - class AllVehicles : All { - class EventHandlers { - handleDamage = "[_this,'handleDamage'] call CSE_fnc_HandleDamage_EH_F;"; - HandleHeal = "[_this,'handleHeal'] call CSE_fnc_HandleHeal_EH_F;"; - local = "_this call cse_eh_cba_compat_local;"; - killed = "_this call cse_eh_cba_compat_Killed"; - firedNear = "_this call cse_eh_cba_compat_FiredNear"; - fired = "_this call cse_eh_cba_compat_Fired"; - respawn = "_this call cse_eh_cba_compat_Respawn"; - Take = "_this call cse_eh_cba_compat_Take"; - Put = "_this call cse_eh_cba_compat_Put"; - GetIn = "_this call cse_eh_cba_compat_GetIn"; - GetOut = "_this call cse_eh_cba_compat_GetOut"; - }; - }; - - class Man; - class CAManBase: Man { - class EventHandlers { - handleDamage = "[_this,'handleDamage'] call CSE_fnc_HandleDamage_EH_F;"; - HandleHeal = "[_this,'handleHeal'] call CSE_fnc_HandleHeal_EH_F;"; - local = "_this call cse_eh_cba_compat_local;"; - killed = "_this call cse_eh_cba_compat_Killed"; - firedNear = "_this call cse_eh_cba_compat_FiredNear"; - fired = "_this call cse_eh_cba_compat_Fired"; - respawn = "_this call cse_eh_cba_compat_Respawn"; - Take = "_this call cse_eh_cba_compat_Take"; - Put = "_this call cse_eh_cba_compat_Put"; - GetIn = "_this call cse_eh_cba_compat_GetIn"; - GetOut = "_this call cse_eh_cba_compat_GetOut"; - }; - }; - - class SoldierGB : CAManBase{ - class EventHandlers { - handleDamage = "[_this,'handleDamage'] call CSE_fnc_HandleDamage_EH_F;"; - HandleHeal = "[_this,'handleHeal'] call CSE_fnc_HandleHeal_EH_F;"; - local = "_this call cse_eh_cba_compat_local;"; - killed = "_this call cse_eh_cba_compat_Killed"; - firedNear = "_this call cse_eh_cba_compat_FiredNear"; - fired = "_this call cse_eh_cba_compat_Fired"; - respawn = "_this call cse_eh_cba_compat_Respawn"; - Take = "_this call cse_eh_cba_compat_Take"; - Put = "_this call cse_eh_cba_compat_Put"; - GetIn = "_this call cse_eh_cba_compat_GetIn"; - GetOut = "_this call cse_eh_cba_compat_GetOut"; - }; - }; - class SoldierWB : CAManBase { - class EventHandlers { - handleDamage = "[_this,'handleDamage'] call CSE_fnc_HandleDamage_EH_F;"; - HandleHeal = "[_this,'handleHeal'] call CSE_fnc_HandleHeal_EH_F;"; - local = "_this call cse_eh_cba_compat_local;"; - killed = "_this call cse_eh_cba_compat_Killed"; - firedNear = "_this call cse_eh_cba_compat_FiredNear"; - fired = "_this call cse_eh_cba_compat_Fired"; - respawn = "_this call cse_eh_cba_compat_Respawn"; - Take = "_this call cse_eh_cba_compat_Take"; - Put = "_this call cse_eh_cba_compat_Put"; - GetIn = "_this call cse_eh_cba_compat_GetIn"; - GetOut = "_this call cse_eh_cba_compat_GetOut"; - }; - }; - class SoldierEB : CAManBase{ - class EventHandlers { - handleDamage = "[_this,'handleDamage'] call CSE_fnc_HandleDamage_EH_F;"; - HandleHeal = "[_this,'handleHeal'] call CSE_fnc_HandleHeal_EH_F;"; - local = "_this call cse_eh_cba_compat_local;"; - killed = "_this call cse_eh_cba_compat_Killed"; - firedNear = "_this call cse_eh_cba_compat_FiredNear"; - fired = "_this call cse_eh_cba_compat_Fired"; - respawn = "_this call cse_eh_cba_compat_Respawn"; - Take = "_this call cse_eh_cba_compat_Take"; - Put = "_this call cse_eh_cba_compat_Put"; - GetIn = "_this call cse_eh_cba_compat_GetIn"; - GetOut = "_this call cse_eh_cba_compat_GetOut"; - }; - }; - class B_Soldier_base_F: SoldierWB { - class EventHandlers { - handleDamage = "[_this,'handleDamage'] call CSE_fnc_HandleDamage_EH_F;"; - HandleHeal = "[_this,'handleHeal'] call CSE_fnc_HandleHeal_EH_F;"; - local = "_this call cse_eh_cba_compat_local;"; - killed = "_this call cse_eh_cba_compat_Killed"; - firedNear = "_this call cse_eh_cba_compat_FiredNear"; - fired = "_this call cse_eh_cba_compat_Fired"; - respawn = "_this call cse_eh_cba_compat_Respawn"; - Take = "_this call cse_eh_cba_compat_Take"; - Put = "_this call cse_eh_cba_compat_Put"; - GetIn = "_this call cse_eh_cba_compat_GetIn"; - GetOut = "_this call cse_eh_cba_compat_GetOut"; - }; - }; - class B_Soldier_03_f: B_Soldier_base_F { - class EventHandlers { - handleDamage = "[_this,'handleDamage'] call CSE_fnc_HandleDamage_EH_F;"; - HandleHeal = "[_this,'handleHeal'] call CSE_fnc_HandleHeal_EH_F;"; - local = "_this call cse_eh_cba_compat_local;"; - killed = "_this call cse_eh_cba_compat_Killed"; - firedNear = "_this call cse_eh_cba_compat_FiredNear"; - fired = "_this call cse_eh_cba_compat_Fired"; - respawn = "_this call cse_eh_cba_compat_Respawn"; - Take = "_this call cse_eh_cba_compat_Take"; - Put = "_this call cse_eh_cba_compat_Put"; - GetIn = "_this call cse_eh_cba_compat_GetIn"; - GetOut = "_this call cse_eh_cba_compat_GetOut"; - }; - }; - - class LandVehicle; - class Car: LandVehicle { - class EventHandlers { - local = "_this call cse_eh_cba_compat_local;"; - killed = "_this call cse_eh_cba_compat_Killed"; - firedNear = "_this call cse_eh_cba_compat_FiredNear"; - fired = "_this call cse_eh_cba_compat_Fired"; - respawn = "_this call cse_eh_cba_compat_Respawn"; - Take = "_this call cse_eh_cba_compat_Take"; - Put = "_this call cse_eh_cba_compat_Put"; - GetIn = "_this call cse_eh_cba_compat_GetIn"; - GetOut = "_this call cse_eh_cba_compat_GetOut"; - }; - }; - class Tank: LandVehicle { - class EventHandlers { - local = "_this call cse_eh_cba_compat_local;"; - killed = "_this call cse_eh_cba_compat_Killed"; - firedNear = "_this call cse_eh_cba_compat_FiredNear"; - fired = "_this call cse_eh_cba_compat_Fired"; - respawn = "_this call cse_eh_cba_compat_Respawn"; - Take = "_this call cse_eh_cba_compat_Take"; - Put = "_this call cse_eh_cba_compat_Put"; - GetIn = "_this call cse_eh_cba_compat_GetIn"; - GetOut = "_this call cse_eh_cba_compat_GetOut"; - }; - }; - - class Air; - class Helicopter: Air { - class EventHandlers { - local = "_this call cse_eh_cba_compat_local;"; - killed = "_this call cse_eh_cba_compat_Killed"; - firedNear = "_this call cse_eh_cba_compat_FiredNear"; - fired = "_this call cse_eh_cba_compat_Fired"; - respawn = "_this call cse_eh_cba_compat_Respawn"; - Take = "_this call cse_eh_cba_compat_Take"; - Put = "_this call cse_eh_cba_compat_Put"; - GetIn = "_this call cse_eh_cba_compat_GetIn"; - GetOut = "_this call cse_eh_cba_compat_GetOut"; - }; - }; - class Plane: Air { - class EventHandlers { - local = "_this call cse_eh_cba_compat_local;"; - killed = "_this call cse_eh_cba_compat_Killed"; - firedNear = "_this call cse_eh_cba_compat_FiredNear"; - fired = "_this call cse_eh_cba_compat_Fired"; - respawn = "_this call cse_eh_cba_compat_Respawn"; - Take = "_this call cse_eh_cba_compat_Take"; - Put = "_this call cse_eh_cba_compat_Put"; - GetIn = "_this call cse_eh_cba_compat_GetIn"; - GetOut = "_this call cse_eh_cba_compat_GetOut"; - }; - }; - class Ship: AllVehicles { - class EventHandlers { - local = "_this call cse_eh_cba_compat_local;"; - killed = "_this call cse_eh_cba_compat_Killed"; - firedNear = "_this call cse_eh_cba_compat_FiredNear"; - fired = "_this call cse_eh_cba_compat_Fired"; - respawn = "_this call cse_eh_cba_compat_Respawn"; - Take = "_this call cse_eh_cba_compat_Take"; - Put = "_this call cse_eh_cba_compat_Put"; - GetIn = "_this call cse_eh_cba_compat_GetIn"; - GetOut = "_this call cse_eh_cba_compat_GetOut"; - }; - }; -}; \ No newline at end of file diff --git a/TO_MERGE/cse/f_eh/Combat_Space_Enhancement.h b/TO_MERGE/cse/f_eh/Combat_Space_Enhancement.h deleted file mode 100644 index f44a5fac89..0000000000 --- a/TO_MERGE/cse/f_eh/Combat_Space_Enhancement.h +++ /dev/null @@ -1,13 +0,0 @@ - -class Combat_Space_Enhancement { - class EventHandlers { - class PreInit_EventHandlers { - class cse_xeh_fired_eventHandler_Compat { - init = "call compile preprocessFile 'cse\cse_f_eh\cba_compat_init.sqf';"; - }; - }; - }; - - class CustomResults {}; - class CustomEventHandlers {}; -}; \ No newline at end of file diff --git a/TO_MERGE/cse/f_eh/Extended_Init_EventHandlers.h b/TO_MERGE/cse/f_eh/Extended_Init_EventHandlers.h deleted file mode 100644 index 953aa28c44..0000000000 --- a/TO_MERGE/cse/f_eh/Extended_Init_EventHandlers.h +++ /dev/null @@ -1,103 +0,0 @@ -class Extended_Fired_Eventhandlers -{ - class AllVehicles - { - class cse_CBA_COMPAT_XEH - { - Fired = "[_this,'fired'] call cse_fnc_eventHandler_F;"; - }; - }; -}; - -class Extended_HandleDamage_Eventhandlers -{ - class AllVehicles - { - class cse_CBA_COMPAT_XEH - { - handleDamage = "[_this,'handleDamage'] call CSE_fnc_HandleDamage_EH_F;"; - }; - }; -}; - -class Extended_FiredNear_Eventhandlers -{ - class AllVehicles - { - class cse_CBA_COMPAT_XEH - { - FiredNear = "[_this,'firedNear'] call cse_fnc_eventHandler_F;"; - }; - }; -}; - -class Extended_Killed_Eventhandlers -{ - class AllVehicles - { - class cse_CBA_COMPAT_XEH - { - Killed = "[_this,'killed'] call cse_fnc_eventHandler_F;"; - }; - }; -}; - -class Extended_Local_Eventhandlers -{ - class AllVehicles - { - class cse_CBA_COMPAT_XEH - { - Local = "[_this,'local'] call cse_fnc_eventHandler_F;"; - }; - }; -}; - -class Extended_Respawn_Eventhandlers -{ - class AllVehicles - { - class cse_CBA_COMPAT_XEH { - Respawn = "[_this,'respawn'] call cse_fnc_eventHandler_F;"; - }; - }; -}; - -class Extended_Take_Eventhandlers -{ - class AllVehicles - { - class cse_CBA_COMPAT_XEH { - Take = "[_this,'take'] call cse_fnc_eventHandler_F;"; - }; - }; -}; - -class Extended_Put_Eventhandlers -{ - class AllVehicles - { - class cse_CBA_COMPAT_XEH { - Put = "[_this,'put'] call cse_fnc_eventHandler_F;"; - }; - }; -}; - -class Extended_GetIn_Eventhandlers -{ - class AllVehicles - { - class cse_CBA_COMPAT_XEH { - GetIn = "[_this,'getIn'] call cse_fnc_eventHandler_F;"; - }; - }; -}; -class Extended_GetOut_EventHandlers -{ - class AllVehicles - { - class cse_CBA_COMPAT_XEH { - GetOut = "[_this,'getOut'] call cse_fnc_eventHandler_F;"; - }; - }; -}; \ No newline at end of file diff --git a/TO_MERGE/cse/f_eh/cba_compat_init.sqf b/TO_MERGE/cse/f_eh/cba_compat_init.sqf deleted file mode 100644 index 129c8d9c4e..0000000000 --- a/TO_MERGE/cse/f_eh/cba_compat_init.sqf +++ /dev/null @@ -1,19 +0,0 @@ -/** - * cba_compat_init.sqf - * @Descr: CBA compatability wrapper. - * @Author: Glowbal - * - * @Arguments: [] - * @Return: void - * @PublicAPI: false - */ - -cse_eh_cba_compat_local = if (!isClass (configFile >> 'CfgPatches' >> 'CBA_main')) then { {[_this,'local'] call cse_fnc_eventHandler_F;} } else {{}}; -cse_eh_cba_compat_Respawn = if (!isClass (configFile >> 'CfgPatches' >> 'CBA_main')) then { {[_this,'respawn'] call cse_fnc_eventHandler_F;} } else {{}}; -cse_eh_cba_compat_Killed = if (!isClass (configFile >> 'CfgPatches' >> 'CBA_main')) then { {[_this,'killed'] call cse_fnc_eventHandler_F;} } else {{}}; -cse_eh_cba_compat_FiredNear = if (!isClass (configFile >> 'CfgPatches' >> 'CBA_main')) then { {[_this,'firedNear'] call cse_fnc_eventHandler_F;} } else {{}}; -cse_eh_cba_compat_Fired = if (!isClass (configFile >> 'CfgPatches' >> 'CBA_main')) then { {[_this,'fired'] call cse_fnc_eventHandler_F;} } else {{}}; -cse_eh_cba_compat_Take = if (!isClass (configFile >> 'CfgPatches' >> 'CBA_main')) then { {[_this,'Take'] call cse_fnc_eventHandler_F;} } else {{}}; -cse_eh_cba_compat_Put = if (!isClass (configFile >> 'CfgPatches' >> 'CBA_main')) then { {[_this,'Put'] call cse_fnc_eventHandler_F;} } else {{}}; -cse_eh_cba_compat_GetIn = if (!isClass (configFile >> 'CfgPatches' >> 'CBA_main')) then { {[_this,'GetIn'] call cse_fnc_eventHandler_F;} } else {{}}; -cse_eh_cba_compat_GetOut = if (!isClass (configFile >> 'CfgPatches' >> 'CBA_main')) then { {[_this,'GetOut'] call cse_fnc_eventHandler_F;} } else {{}}; diff --git a/TO_MERGE/cse/f_eh/config.cpp b/TO_MERGE/cse/f_eh/config.cpp deleted file mode 100644 index eab6a20d7d..0000000000 --- a/TO_MERGE/cse/f_eh/config.cpp +++ /dev/null @@ -1,31 +0,0 @@ -class CfgPatches -{ - class cse_f_eh - { - units[] = {}; - weapons[] = {}; - requiredVersion = 0.1; - requiredAddons[] = {/*"cba_extended_eventhandlers", "cba_xeh", "extended_eventhandlers"*/ "A3_Characters_F","A3_Boat_F","A3_animals_f","A3_air_f","A3_soft_f","A3_static_f","A3_weapons_f","a3_structures_f"}; - version = "0.10.0_rc"; - author[] = {"Combat Space Enhancement"}; - authorUrl = "http://csemod.com"; - }; -}; -class CfgAddons { - class PreloadAddons { - class cse_f_eh { - list[] = {"cse_f_eh"}; - }; - }; -}; -/* Event handlers */ -#include "CfgVehicles.h" - -/* For CBA Compatability */ -#include "Extended_Init_EventHandlers.h" - - /* Ensures that the functions are being compiled */ -#include "CfgFunctions.h" - -/* To ensure that the custom eventhandler classes exist */ -#include "Combat_Space_Enhancement.h" \ No newline at end of file diff --git a/TO_MERGE/cse/f_eh/functions/fn_HandleHeal_eh_f.sqf b/TO_MERGE/cse/f_eh/functions/fn_HandleHeal_eh_f.sqf deleted file mode 100644 index c59c985771..0000000000 --- a/TO_MERGE/cse/f_eh/functions/fn_HandleHeal_eh_f.sqf +++ /dev/null @@ -1,54 +0,0 @@ -/** - * fn_HandleHeal_eh_f.sqf - * @Descr: Execute the handleHeal Eventhandlers. Is currently bugged due to Arma Engine problem? - * @Author: Glowbal - * - * @Arguments: [] - * @Return: BOOL Returns true if handleHeal has been fully handled - * @PublicAPI: false - */ - -private ["_vehicle","_allPreInitHandlers","_handle","_totalValue","_cfg","_amountOfHandlers", "_newCfg","_returnValue","_ehCfg"]; -_vehicle = (_this select 0) select 1; -_handle = _this select 1; -_allPreInitHandlers = []; - -if (!local _vehicle) exitwith {}; -if (isnil "CSE_fnc_HandleHeal_EH_F") then { - CSE_fnc_HandleHeal_EH_F = compile preProcessFileLineNumbers '\cse\cse_f_eh\fn_HandleHeal_EH_F.sqf'; -}; - -if (isnil "CSE_F_MODULE_OBJ_EH") then { - CSE_F_MODULE_OBJ_EH = []; -}; -{ - - _cfg = (ConfigFile >> "Combat_Space_Enhancement" >> "CfgModules" >> _x); - if (isClass _cfg) then { - if (isClass (_cfg >> "EventHandlers")) then { - _numberOfEH = count (_cfg >> "EventHandlers"); - for "_j" from 0 to (_numberOfEH -1) /* step +1 */ do { - //for [{_j=0}, {_j< _numberOfEH}, {_j=_j+1}] do { - _ehCfg = ((_cfg >> "EventHandlers") select _j); - if (isClass _ehCfg) then { - if (_vehicle isKindOf (ConfigName _ehCfg)) then { - _allPreInitHandlers pushback compile getText(_ehCfg >> _handle); - }; - }; - }; - }; - }; -}foreach CSE_F_MODULE_OBJ_EH; -{ - private ["_returnValue"]; - _returnValue = (_this select 0) call _x; -}foreach _allPreInitHandlers; -[_allPreInitHandlers] call cse_fnc_debug; - -AISFinishHeal [(_this select 0) select 0, (_this select 0) select 1, (_this select 0) select 2]; - -if (count _allPreInitHandlers > 0) then { - true; -} else { - false; -}; \ No newline at end of file diff --git a/TO_MERGE/cse/f_eh/functions/fn_addModuleEventhandlers_f.sqf b/TO_MERGE/cse/f_eh/functions/fn_addModuleEventhandlers_f.sqf deleted file mode 100644 index 3830605364..0000000000 --- a/TO_MERGE/cse/f_eh/functions/fn_addModuleEventhandlers_f.sqf +++ /dev/null @@ -1,64 +0,0 @@ -/** - * fn_addModuleEventhandlers_f.sqf - * @Descr: N/A - * @Author: Glowbal - * - * @Arguments: [] - * @Return: - * @PublicAPI: false - */ - -private ["_entity", "_handle", "_eventHandlerName", "_eventHandlerCollection", "_cfg", "_numberOfEH", "_ehCfg", "_classType", "_text", "_code", "_eventHandlerCollection","_collectedEHIDs", "_collectedID_VarName"]; -_entity = _this select 0; -_handle = _this select 1; - -_eventHandlerName = ("cse_f_eventhandler_" + _handle); - -_eventHandlerCollection = missionNamespace getvariable _eventHandlerName; -if (isnil "_eventHandlerCollection") then { - _eventHandlerCollection = []; - { - _cfg = (ConfigFile >> "Combat_Space_Enhancement" >> "CfgModules" >> _x >> "EventHandlers"); - if (isClass (_cfg)) then { - _numberOfEH = count (_cfg); - - for "_EHiterator" from 0 to (_numberOfEH -1) do { - _ehCfg = ((_cfg) select _EHiterator); - if (isClass _ehCfg) then { - _classType = (ConfigName _ehCfg); - _text = getText(_ehCfg >> _handle); - if (_text != "") then { - _code = (compile _text); - _eventHandlerCollection pushBack [_classType, _code, _x]; - true; - }; - }; - }; - }; - }count CSE_F_MODULE_OBJ_EH; - missionNamespace setvariable [_eventHandlerName, _eventHandlerCollection]; - if (isnil "cse_f_eventhandlers_collection") then { - cse_f_eventhandlers_collection = []; - }; - cse_f_eventhandlers_collection pushBack _eventHandlerName; -}; - -_collectedID_VarName = format["cse_addModuleEventHandlers_f_%1_ids", _handle]; - -// clear all module eventhandlers first -_collectedEHIDs = _entity getvariable [_collectedID_VarName, []]; -{ - [_entity, _handle, _x] call cse_fnc_removeEventHandler_F; -}foreach _collectedEHIDs; - -// now we add the new ones -_collectedEHIDs = []; -{ - if (_entity isKindOf (_x select 0)) then { - _collectedEHIDs pushback (format["cse_moduleEventhandlerID_", _foreachIndex]); - [_entity, _handle, format["cse_moduleEventhandlerID_", _foreachIndex], _x select 1] call cse_fnc_setEventhandler_f; - }; -}foreach _eventHandlerCollection; - -// Store the new IDs -_entity setvariable [_collectedID_VarName, _collectedEHIDs]; \ No newline at end of file diff --git a/TO_MERGE/cse/f_eh/functions/fn_customEventHandler_f.sqf b/TO_MERGE/cse/f_eh/functions/fn_customEventHandler_f.sqf deleted file mode 100644 index 00f7fa50dc..0000000000 --- a/TO_MERGE/cse/f_eh/functions/fn_customEventHandler_f.sqf +++ /dev/null @@ -1,61 +0,0 @@ -/** - * fn_customEventHandler_f.sqf - * @Descr: Execute a custom defined eventhandler. - * @Author: Glowbal - * - * @Arguments: [arguments ANY, handle STRING (The name of the eventhandler)] - * @Return: ARRAY Array containing the results of the called eventhandlers. - * @PublicAPI: true - */ - - -private ["_arguments","_handle","_ehCfg","_eventHandlerCollection","_eventHandlerName","_cfg","_code","_classType", "_return"]; -_arguments = _this select 0; -_handle = _this select 1; - -_eventHandlerName = ("cse_f_custom_eventhandler_" + _handle); -_eventHandlerCollection = missionNamespace getvariable _eventHandlerName; -if (isnil "_eventHandlerCollection") then { - _eventHandlerCollection = []; - [format["caching Custom Eventhandler: %1",_handle]] call cse_fnc_debug; - _cfg = (ConfigFile >> "Combat_Space_Enhancement" >> "CustomEventHandlers" >> _handle); - if (isClass _cfg) then { - _numberOfEH = count _cfg; - - for "_EHiterator" from 0 to (_numberOfEH -1) /* step +1 */ do { - //for [{_EHiterator=0}, {(_EHiterator< _numberOfEH)}, {_EHiterator=_EHiterator+1}] do { - _ehCfg = _cfg select _EHiterator; - if (isClass _ehCfg) then { - _classType = (ConfigName _ehCfg); - _code = (compile getText(_ehCfg >> "onCall")); - _eventHandlerCollection pushback [_classType, _code]; - true; - }; - }; - }; - - _cfg = (MissionConfigFile >> "Combat_Space_Enhancement" >> "CustomEventHandlers" >> _handle); - if (isClass _cfg) then { - _numberOfEH = count _cfg; - for "_EHiterator" from 0 to (_numberOfEH -1) /* step +1 */ do { - //for [{_EHiterator=0}, {(_EHiterator< _numberOfEH)}, {_EHiterator=_EHiterator+1}] do { - _ehCfg = _cfg select _EHiterator; - if (isClass _ehCfg) then { - _classType = (ConfigName _ehCfg); - _code = (compile getText(_ehCfg >> "onCall")); - _eventHandlerCollection pushback [_classType, _code]; - true; - }; - }; - }; - - missionNamespace setvariable [_eventHandlerName, _eventHandlerCollection]; - [format["Custom Eventhandler: %1 cache: %2",_handle, _eventHandlerCollection]] call cse_fnc_debug; -}; - -_return = []; -{ - _return pushback (_arguments call (_x select 1)); -}foreach _eventHandlerCollection; - -_return \ No newline at end of file diff --git a/TO_MERGE/cse/f_eh/functions/fn_eventHandler_f.sqf b/TO_MERGE/cse/f_eh/functions/fn_eventHandler_f.sqf deleted file mode 100644 index beada7ec82..0000000000 --- a/TO_MERGE/cse/f_eh/functions/fn_eventHandler_f.sqf +++ /dev/null @@ -1,65 +0,0 @@ -/** - * fn_eventHandler_f.sqf - * @Descr: Execute eventhandlers - * @Author: Glowbal - * - * @Arguments: [] - * @Return: void - * @PublicAPI: false - */ - -private ["_args","_handle","_entity","_cfgFile","_cfg","_numberOfEH","_ehCfg","_value", "_code", "_eventHandlerCollection", "_classType", "_eventHandlerName"]; -_args = _this select 0; -_handle = _this select 1; -_entity = _args select 0; - -if (isnil "CSE_F_MODULE_OBJ_EH") then { - CSE_F_MODULE_OBJ_EH = []; -}; - -if (!(local _entity) && _handle != "fired") exitwith {}; -_eventHandlerName = ("cse_f_eventhandler_" + _handle); - -_eventHandlerCollection = missionNamespace getvariable _eventHandlerName; -if (isnil "_eventHandlerCollection") then { - _eventHandlerCollection = []; - { - _cfg = (ConfigFile >> "Combat_Space_Enhancement" >> "CfgModules" >> _x >> "EventHandlers"); - if (isClass (_cfg)) then { - _numberOfEH = count (_cfg); - - for "_EHiterator" from 0 to (_numberOfEH -1) do { - _ehCfg = ((_cfg) select _EHiterator); - if (isClass _ehCfg) then { - _classType = (ConfigName _ehCfg); - _text = getText(_ehCfg >> _handle); - if (_text != "") then { - _code = (compile _text); - _eventHandlerCollection pushBack [_classType, _code, _x]; - true; - }; - }; - }; - }; - }count CSE_F_MODULE_OBJ_EH; - missionNamespace setvariable [_eventHandlerName, _eventHandlerCollection]; - if (isnil "cse_f_eventhandlers_collection") then { - cse_f_eventhandlers_collection = []; - }; - cse_f_eventhandlers_collection pushBack _eventHandlerName; -}; - -_setHandler = _entity getvariable ("cse_f_setEventhandler_" + _handle); -if (isnil "_setHandler") then { - { - if (_entity isKindOf (_x select 0)) then { - _args call (_x select 1); - }; - false; - }count _eventHandlerCollection; -} else { - { - _args call (_X select 1); - false; - }count _setHandler; -}; \ No newline at end of file diff --git a/TO_MERGE/cse/f_eh/functions/fn_getCustomResults_f.sqf b/TO_MERGE/cse/f_eh/functions/fn_getCustomResults_f.sqf deleted file mode 100644 index 0609a3229e..0000000000 --- a/TO_MERGE/cse/f_eh/functions/fn_getCustomResults_f.sqf +++ /dev/null @@ -1,42 +0,0 @@ -/** - * fn_getCustomResults_f.sqf - * @Descr: Executes custom results eventhandlers, collects their output and returns this. - * @Author: Glowbal - * - * @Arguments: [arguments ANY, handle STRING] - * @Return: ARRAY Collection of all return values of all executed CustomResult handlers - * @PublicAPI: true - */ - - -private ["_arguments","_handle","_ehCfg","_eventHandlerCollection","_eventHandlerName","_cfg","_code","_classType", "_return"]; -_arguments = _this select 0; -_handle = _this select 1; - -_eventHandlerName = ("cse_f_custom_results_eventhandler_" + _handle); -_eventHandlerCollection = missionNamespace getvariable _eventHandlerName; -if (isnil "_eventHandlerCollection") then { - _eventHandlerCollection = []; - - _cfg = (ConfigFile >> "Combat_Space_Enhancement" >> "CustomResults" >> _handle); - if (isClass _cfg) then { - _numberOfEH = count _cfg; - for [{_EHiterator=0}, {(_EHiterator< _numberOfEH)}, {_EHiterator=_EHiterator+1}] do { - _ehCfg = _cfg select _EHiterator; - if (isClass _ehCfg) then { - _classType = (ConfigName _ehCfg); - _code = (compile getText(_ehCfg >> "onCall")); - _eventHandlerCollection set [ count _eventHandlerCollection, [_classType, _code]]; - true; - }; - }; - }; - missionNamespace setvariable [_eventHandlerName, _eventHandlerCollection]; -}; - -_return = []; -{ - _return set [ count _return, _arguments call (_x select 1) ]; -}foreach _eventHandlerCollection; - -_return \ No newline at end of file diff --git a/TO_MERGE/cse/f_eh/functions/fn_handleDamage_eh_f.sqf b/TO_MERGE/cse/f_eh/functions/fn_handleDamage_eh_f.sqf deleted file mode 100644 index 6eb1017b77..0000000000 --- a/TO_MERGE/cse/f_eh/functions/fn_handleDamage_eh_f.sqf +++ /dev/null @@ -1,79 +0,0 @@ -/** - * fn_handleDamage_eh_f.sqf - * @Descr: Execute the handleDamage Eventhandler - * @Author: Glowbal - * - * @Arguments: [] - * @Return: NUMBER Returns a number based on output of executed eventhandlers - * @PublicAPI: false - */ - -private ["_vehicle","_allPreInitHandlers","_handle","_totalValue","_cfg","_amountOfHandlers", "_newCfg","_returnValue","_ehCfg", "_fullDamage", "_returnDamage"]; -_vehicle = (_this select 0) select 0; -_handle = _this select 1; -if (!local _vehicle) exitwith {}; -if (_vehicle isKindOf "CAManBase") then { - _name = _vehicle getVariable "cse_name"; - if (isNil "_name") then { - _vehicle setvariable ["cse_name", name _vehicle, true]; - }; -}; - -_eventHandlerName = "cse_f_eventhandler_handleDamage"; -_eventHandlerCollection = missionNamespace getvariable _eventHandlerName; -if (isnil "_eventHandlerCollection") then { - _eventHandlerCollection = []; - if (isnil "CSE_F_MODULE_OBJ_EH") then { - CSE_F_MODULE_OBJ_EH = []; - }; - { - _cfg = (ConfigFile >> "Combat_Space_Enhancement" >> "CfgModules" >> _x); - if (isClass _cfg) then { - if (isClass (_cfg >> "EventHandlers")) then { - _numberOfEH = count (_cfg >> "EventHandlers"); - - for "_j" from 0 to (_numberOfEH -1) /* step +1 */ do { - //for [{_j=0}, {_j< _numberOfEH}, {_j=_j+1}] do { - _ehCfg = ((_cfg >> "EventHandlers") select _j); - if (isClass _ehCfg) then { - if (getText(_ehCfg >> _handle) != "") then { - _eventHandlerCollection pushBack [(ConfigName _ehCfg), compile getText(_ehCfg >> _handle)]; - }; - }; - }; - }; - }; - }foreach CSE_F_MODULE_OBJ_EH; - missionNamespace setvariable [_eventHandlerName, _eventHandlerCollection]; - - if (isnil "cse_f_eventhandlers_collection") then { - cse_f_eventhandlers_collection = []; - }; - cse_f_eventhandlers_collection pushBack _eventHandlerName; -}; -_returnDamage = (_this select 0) select 2; -{ - if (_vehicle isKindOf (_x select 0)) then { - private "_returnValue"; - _returnValue = (_this select 0) call (_x select 1); - if (!isnil "_returnValue") then { - if (typeName _returnValue == typeName 0) then { - _returnDamage = _returnValue; - }; - }; - }; -}foreach _eventHandlerCollection; - -if (typeName _returnDamage == typeName 0) then { - if (_returnDamage >= 0.9) then { - if (isnil "CSE_ENABLE_REVIVE_F") then { - CSE_ENABLE_REVIVE_F = 0; - }; - if ((CSE_ENABLE_REVIVE_F == 1 && isPlayer _vehicle) || (CSE_ENABLE_REVIVE_F == 2)) then { - _returnDamage = 0.9; - }; - }; -} else { - _returnDamage = (_this select 0) select 2; -}; -_returnDamage \ No newline at end of file diff --git a/TO_MERGE/cse/f_eh/functions/fn_initialization_f.sqf b/TO_MERGE/cse/f_eh/functions/fn_initialization_f.sqf deleted file mode 100644 index 9433d8295d..0000000000 --- a/TO_MERGE/cse/f_eh/functions/fn_initialization_f.sqf +++ /dev/null @@ -1,55 +0,0 @@ -/** - * fn_initialization_f.sqf - * @Descr: Grabs all pre and post init defined events from the config files and executes those. - * @Author: Glowbal - * - * @Arguments: [setToExecute STRING] - * @Return: void - * @PublicAPI: false - */ - -private ["_allPreInitHandlers","_cfg","_cfgOpt","_text"]; -_allPreInitHandlers = []; - -if ((_this select 0) == "preInit") then { - _cfg = (ConfigFile >> "Combat_Space_Enhancement" >> "EventHandlers" >> "PreInit_EventHandlers"); - - for "_i" from 0 to ((count _cfg)-1) /* step +1 */ do { - _this spawn (compile (getText ((_cfg select _i) >> "init"))); - }; -} else { - if ((_this select 0) == "postInit") then { - _cfg = (ConfigFile >> "Combat_Space_Enhancement" >> "EventHandlers" >> "PostInit_EventHandlers"); - - for "_i" from 0 to ((count _cfg)-1) /* step +1 */ do { - _this spawn (compile (getText ((_cfg select _i) >> "init"))); - }; - }; -}; - -if (isnil "CSE_F_EH_ALLOW_MISSION_CONFIG") then { - CSE_F_EH_ALLOW_MISSION_CONFIG = true; -}; - -if (CSE_F_EH_ALLOW_MISSION_CONFIG) then { - _allPreInitHandlers = []; - if ((_this select 0) == "preInit") then { - _cfg = (missionConfigFile >> "Combat_Space_Enhancement" >> "EventHandlers" >> "PreInit_EventHandlers"); - - for "_i" from 0 to ((count _cfg)-1) /* step +1 */ do { - _this spawn (compile (getText ((_cfg select _i) >> "init"))); - }; - } else { - if ((_this select 0) == "postInit") then { - _cfg = (missionConfigFile >> "Combat_Space_Enhancement" >> "EventHandlers" >> "PostInit_EventHandlers"); - - for "_i" from 0 to ((count _cfg)-1) /* step +1 */ do { - _this spawn (compile (getText ((_cfg select _i) >> "init"))); - }; - }; - }; -}; - -if ((_this select 0) == "postInit") then { - cse_postInit = true; -}; \ No newline at end of file diff --git a/TO_MERGE/cse/f_eh/functions/fn_removeEventhandler_f.sqf b/TO_MERGE/cse/f_eh/functions/fn_removeEventhandler_f.sqf deleted file mode 100644 index 38b13bfaba..0000000000 --- a/TO_MERGE/cse/f_eh/functions/fn_removeEventhandler_f.sqf +++ /dev/null @@ -1,33 +0,0 @@ -/** - * fn_removeEventhandler_f.sqf - * @Descr: Removes an eventhandler with the specified ID - * @Author: Glowbal - * - * @Arguments: [object OBJECT, handler STRING, id STRING] - * @Return: nil - * @PublicAPI: true - */ - -private ["_obj", "_handler", "_id", "_varName", "_handlers", "_newHandlers"]; -_obj = _this select 0; -_handler = _this select 1; -_id = _this select 2; - -_varName = "cse_f_setEventhandler_" + _handler; -_handlers = _obj getvariable [_varName, []]; - -_newHandlers = []; -{ - if (_x select 0 != _id) then { - _newHandlers pushback _x; - }; -}foreach _handlers; - -if (count _newHandlers > 0) then { - _obj setvariable [_varName, _newHandlers]; -} else { - // remove and default to original CSE handlers - _obj setvariable [_varName, nil]; -}; - -true; \ No newline at end of file diff --git a/TO_MERGE/cse/f_eh/functions/fn_setEventhandler_f.sqf b/TO_MERGE/cse/f_eh/functions/fn_setEventhandler_f.sqf deleted file mode 100644 index 1eaf62bde4..0000000000 --- a/TO_MERGE/cse/f_eh/functions/fn_setEventhandler_f.sqf +++ /dev/null @@ -1,35 +0,0 @@ -/** - * fn_setEventhandler_f.sqf - * @Descr: Set the event handler for a specific object. Stacks. Overwrites the CSE module eventhandlers. - * @Author: Glowbal - * - * @Arguments: [object OBJECT, handler STRING, id STRING, code CODE] - * @Return: nil - * @PublicAPI: true - */ - -private ["_obj", "_handler", "_id", "_code", "_varName", "_handlers", "_found"]; -_obj = _this select 0; -_handler = _this select 1; -_id = _this select 2; -_code = _this select 3; - -_varName = "cse_f_setEventhandler_" + _handler; -_handlers = _obj getvariable [_varName, []]; - -_found = -1; -{ - if (_x select 0 == _id) exitwith { - _found = _foreachIndex; - }; -}foreach _handlers; - -if (_found < 0) then { - _handlers pushback [_id, _code]; -} else { - _handlers set [_found, [_id, _code]]; -}; - -_obj setvariable [_varName, _handlers]; - -true; \ No newline at end of file diff --git a/TO_MERGE/cse/f_eh/stringtable.xml b/TO_MERGE/cse/f_eh/stringtable.xml deleted file mode 100644 index 6927a1bdce..0000000000 --- a/TO_MERGE/cse/f_eh/stringtable.xml +++ /dev/null @@ -1,7 +0,0 @@ - - - - - - - \ No newline at end of file diff --git a/TO_MERGE/cse/f_modules/CfgFunctions.h b/TO_MERGE/cse/f_modules/CfgFunctions.h deleted file mode 100644 index 25e2f6cfaf..0000000000 --- a/TO_MERGE/cse/f_modules/CfgFunctions.h +++ /dev/null @@ -1,22 +0,0 @@ -class CfgFunctions -{ - class CSE - { - - class Modules - { - file = "cse\cse_f_modules\functions"; - class initalizeModule_F { recompile = 1; }; - class isModuleEnabled_F { recompile = 1; }; - class getModule_f { recompile = 1; }; - class getModuleCondition_f { recompile = 1; }; - class getModules_f { recompile = 1; }; - class initalizeModuleObjEH { recompile = 1; }; - class moduleIsActive_f { recompile = 1; }; - class enableModule_f { recompile = 1; }; - class getCfgModuleInits_f { recompile = 1; }; - class getCfgModuleArguments_f { recompile = 1; }; - class remoteModuleInit { recompile = 1; }; - }; - }; -}; diff --git a/TO_MERGE/cse/f_modules/Combat_Space_Enhancement.h b/TO_MERGE/cse/f_modules/Combat_Space_Enhancement.h deleted file mode 100644 index 1b7d525b36..0000000000 --- a/TO_MERGE/cse/f_modules/Combat_Space_Enhancement.h +++ /dev/null @@ -1,21 +0,0 @@ -class Combat_Space_Enhancement { - class EventHandlers { - class PreInit_EventHandlers { - class cse_f_modules { - init = " call compile preprocessFile 'cse\cse_f_modules\init.sqf';"; - }; - }; - class PostInit_EventHandlers { - class cse_f_modules { - init = " call compile preprocessFile 'cse\cse_f_modules\post-init.sqf';"; - }; - }; - }; - - class CustomEventHandlers { - /** - * Called when the enableModule_f function is called. Third argument is whatever or not the module has initalized. - */ - class moduleEnabled_f; // [moduleName, arguments, enabled] - }; -}; \ No newline at end of file diff --git a/TO_MERGE/cse/f_modules/config.cpp b/TO_MERGE/cse/f_modules/config.cpp deleted file mode 100644 index 0e5d5d7802..0000000000 --- a/TO_MERGE/cse/f_modules/config.cpp +++ /dev/null @@ -1,23 +0,0 @@ -class CfgPatches -{ - class cse_f_modules - { - units[] = {}; - weapons[] = {}; - requiredVersion = 0.1; - requiredAddons[] = {"cse_main"}; - version = "0.10.0_rc"; - author[] = {"Combat Space Enhancement"}; - authorUrl = "http://csemod.com"; - }; -}; -class CfgAddons { - class PreloadAddons { - class cse_f_modules { - list[] = {"cse_f_modules"}; - }; - }; -}; - -#include "CfgFunctions.h" -#include "Combat_Space_Enhancement.h" \ No newline at end of file diff --git a/TO_MERGE/cse/f_modules/functions/fn_enableModule_f.sqf b/TO_MERGE/cse/f_modules/functions/fn_enableModule_f.sqf deleted file mode 100644 index 6461eed738..0000000000 --- a/TO_MERGE/cse/f_modules/functions/fn_enableModule_f.sqf +++ /dev/null @@ -1,36 +0,0 @@ -/** - * fn_enableModule_f.sqf - * @Descr: Enable a CSE Module - * @Author: Glowbal - * - * @Arguments: [moduleName STRING, arguments ARRAY (Format: [[name STRING, value ANY]])] - * @Return: void - * @PublicAPI: true - */ - -private ["_moduleName", "_arguments", "_moduleInfo"]; -_moduleName = _this select 0; -_arguments = _this select 1; - -[format["enableModule_f %1 %2",_this, ([_moduleName] call cse_fnc_isModuleEnabled_F)]] call cse_fnc_debug; -if ([_moduleName] call cse_fnc_isModuleEnabled_F) exitwith { - [[_moduleName, _arguments, false],"moduleEnabled_f"] call cse_fnc_customEventHandler_F; -}; -if (isnil "CSE_F_MODULE_OBJ_EH") then { - CSE_F_MODULE_OBJ_EH = []; -}; -CSE_F_MODULE_OBJ_EH pushback _moduleName; - -_initField = getText(ConfigFile >> "Combat_Space_Enhancement" >> "CfgModules" >> _moduleName >> "init"); -_arguments call compile _initField; - -if !(isnil "cse_f_eventhandlers_collection") then { - { - missionNamespace setvariable [_x, nil]; // clear all eventhandlers. - }foreach cse_f_eventhandlers_collection; -}; -[_moduleName] call cse_fnc_parseModuleForConfigurations; - -[[_moduleName, _arguments, true],"moduleEnabled_f"] call cse_fnc_customEventHandler_F; - -[format["Initalize module: %1 COMPLETED. Arguments: %2", _moduleName, _arguments], 3] call cse_fnc_debug; \ No newline at end of file diff --git a/TO_MERGE/cse/f_modules/functions/fn_getCfgModuleArguments_f.sqf b/TO_MERGE/cse/f_modules/functions/fn_getCfgModuleArguments_f.sqf deleted file mode 100644 index 095dbf8a39..0000000000 --- a/TO_MERGE/cse/f_modules/functions/fn_getCfgModuleArguments_f.sqf +++ /dev/null @@ -1,98 +0,0 @@ -/** - * fn_getCfgModuleArguments_f.sqf - * @Descr: Grab Module arguments for a specific module in a config file. - * @Author: Glowbal - * - * @Arguments: [moduleName STRING (The classname of the CSE module), configPath CONFIG (Path to the module Config)] - * @Return: ARRAY An array with parameters for given module. If the parameters for the provided module have not been found within the config, default values will be used. - * @PublicAPI: true - */ - -private ["_configOfModule","_collectedInits","_cfgRoot","_amountOfClasses","_i","_arguments","_moduleName","_CfgVehEntry","_CfgModuleEntry","_moduleArguments","_j","_cfg","_value","_typeNameArgument", "_return"]; -_moduleName = _this select 0; -_configOfModule = _this select 1; -_return = []; -// Array for collection all initalization arguments for the given module. -_arguments = []; -// Grab necessary config entries - -_CfgVehEntry = (ConfigFile >> "CfgVehicles" >> _moduleName); -_CfgModuleEntry = (ConfigFile >> "Combat_Space_Enhancement" >> "CfgModules" >> _moduleName); - -if (isClass _CfgModuleEntry) then { - if (isClass _CfgVehEntry) then { - // init with parameters - _moduleArguments = (_CfgVehEntry >> "Arguments"); - if (isClass _moduleArguments) then { - - // Looping through the expected arguments, based on what is defined in the module Argument Class in CfgVehicles. - for [{_j=0}, {_j < (count _moduleArguments)}, {_j=_j+1}] do { - // if the argument is a class, parse it. Otherwise we will be ignoring it. - if (isClass (_moduleArguments select _j)) then { - - // Grab the value from the argument defined in the description.ext and current class. - _value = 0; // (_configOfModule >> configName(_moduleArguments select _j)) call bis_fnc_getCfgData; - // This will be used to validate the retrieved value for a proper value. - _typeNameArgument = getText((_moduleArguments select _j) >> "typeName"); - - call { - if (_typeNameArgument == "BOOL") exitwith { - _value = getNumber(_configOfModule >> configName(_moduleArguments select _j)) == 1; - }; - if (_typeNameArgument == "NUMBER") exitwith { - _value = getNumber(_configOfModule >> configName(_moduleArguments select _j)); - }; - if (_typeNameArgument == "STRING") exitwith { - _value = getText(_configOfModule >> configName(_moduleArguments select _j)); - }; - }; - - // If the argument is defined in the description.ext, we will validate the typeName of the argument and store it in the argument array. - if (!isnil "_value") then { - if (typeName _value == _typeNameArgument || TRUE) then { // lets assume the values are correct until we write a function to properly compare the typeNames. - _arguments pushback [(ConfigName (_moduleArguments select _j)), _value]; - } else { - // Incase the typeName is invalid, we will set a default value and store this instead. - call { - if (_typeNameArgument == "BOOL") exitwith { - _value = getNumber((_moduleArguments select _j) >> "defaultValue") == 1; - }; - if (_typeNameArgument == "NUMBER") exitwith { - _value = getNumber((_moduleArguments select _j) >> "defaultValue"); - }; - if (_typeNameArgument == "STRING") exitwith { - _value = getText((_moduleArguments select _j) >> "defaultValue"); - }; - }; - [format["Module Argument has not been set %1 %2. Module need to be replaced. Value used: %4", _moduleName, (ConfigName (_moduleArguments select _j)), _typeNameArgument, _value], 1] call cse_fnc_debug; - _arguments pushback [(ConfigName (_moduleArguments select _j)), _value]; - }; - } else { - [format["Value is nil for %1 %2", _moduleName, (ConfigName (_moduleArguments select _j))], 1] call cse_fnc_debug; - // Because the value has not been defined, we will use a default value instead. - // TODO implement defaultValue retrieval for non defined arguments. - _value = ""; - if (_typeNameArgument != "") then { - call { - if (_typeNameArgument == "BOOL") exitwith { - _value = getNumber((_moduleArguments select _j) >> "defaultValue") == 1; - }; - if (_typeNameArgument == "NUMBER") exitwith { - _value = getNumber((_moduleArguments select _j) >> "defaultValue"); - }; - if (_typeNameArgument == "STRING") exitwith { - _value = getText((_moduleArguments select _j) >> "defaultValue"); - }; - }; - [format["Module Argument has not been set %1 %2. Module need to be replaced. Value used: %4", _moduleName, (ConfigName (_moduleArguments select _j)), _typeNameArgument, _value], 1] call cse_fnc_debug; - _arguments pushback [(ConfigName (_moduleArguments select _j)), _value]; - }; - }; - }; - }; - }; - } else { - // init with no parameters. We do not have to collect anything for this. - }; -}; -_arguments \ No newline at end of file diff --git a/TO_MERGE/cse/f_modules/functions/fn_getCfgModuleInits_f.sqf b/TO_MERGE/cse/f_modules/functions/fn_getCfgModuleInits_f.sqf deleted file mode 100644 index e25bd089e6..0000000000 --- a/TO_MERGE/cse/f_modules/functions/fn_getCfgModuleInits_f.sqf +++ /dev/null @@ -1,28 +0,0 @@ -/** - * fn_getCfgModuleInits_f.sqf - * @Descr: Grab all defined modules in the given config space, collect their arguments and return them. - * @Author: Glowbal - * - * @Arguments: [config CONFIG (For example: MissionConfigFile or ConfigFile)] - * @Return: ARRAY Array with format: [[moduleName STRING, moduleArgs ARRAY (Format: [argumentName STRING, value ANY])], ...] - * @PublicAPI: false - */ - -private ["_config","_collectedInits","_cfgRoot","_amountOfClasses","_i","_arguments","_moduleName","_CfgVehEntry","_CfgModuleEntry","_moduleArguments","_j","_cfg","_value","_moduleArgs"]; -_config = [_this, 0, MissionConfigFile, [MissionConfigFile]] call BIS_fnc_Param; - -_collectedInits = []; -_cfgRoot = (_config >> "Combat_Space_Enhancement" >> "Modules"); -_amountOfClasses = count _cfgRoot; -for [{_i=0}, {_i < _amountOfClasses}, {_i=_i+1}] do { - if (isClass (_cfgRoot select _i)) then { - _moduleName = ConfigName (_cfgRoot select _i); - _disableConfigExecution = getNumber (ConfigFile >> "Combat_Space_Enhancement" >> "CfgModules" >> _moduleName >> "disableConfigExecution"); - if (_disableConfigExecution > 0) exitwith {}; - if (!([_moduleName] call cse_fnc_isModuleEnabled_f)) then { - _moduleArgs = [_moduleName, (_cfgRoot select _i)] call cse_fnc_getCfgModuleArguments_f; - _collectedInits pushback [_moduleName, _moduleArgs]; - }; - }; -}; -_collectedInits \ No newline at end of file diff --git a/TO_MERGE/cse/f_modules/functions/fn_getModuleCondition_f.sqf b/TO_MERGE/cse/f_modules/functions/fn_getModuleCondition_f.sqf deleted file mode 100644 index 8bfb2cadca..0000000000 --- a/TO_MERGE/cse/f_modules/functions/fn_getModuleCondition_f.sqf +++ /dev/null @@ -1,20 +0,0 @@ -/** - * fn_getModuleCondition_f.sqf - * @Descr: N/A DEPRECATED - * @Author: Glowbal - * - * @Arguments: [] - * @Return: - * @PublicAPI: false - */ - -private ["_moduleName","_condition","_return","_cfgFile"]; - -_moduleName = _this select 0; -_return = ""; -_cfgFile = (ConfigFile >> "Combat_Space_Enhancement" >> "CfgModules" >> _moduleName); -if (isClass _cfgFile) then { - _return = format["CSE_MODULE_CONDITION_%1",_moduleName]; - -}; -_return \ No newline at end of file diff --git a/TO_MERGE/cse/f_modules/functions/fn_getModule_f.sqf b/TO_MERGE/cse/f_modules/functions/fn_getModule_f.sqf deleted file mode 100644 index 74f2762e99..0000000000 --- a/TO_MERGE/cse/f_modules/functions/fn_getModule_f.sqf +++ /dev/null @@ -1,22 +0,0 @@ -/** - * fn_getModule_f.sqf - * @Descr: Gets module information. DEPRECATED - * @Author: Glowbal - * - * @Arguments: [ModuleName STRING] - * @Return: ARRAY Returns an array with [ModuleName STRING, initLine STRING] - * @PublicAPI: false - */ - -private ["_module","_cfg","_init","_name"]; -_moduleName = _this select 0; -_cfg = (ConfigFile >> "Combat_Space_Enhancement" >> "CfgModules" >> _moduleName); -_module = []; -if (isClass _cfg) then { - _init = getText (_cfg >> "init"); - _name = getText (_cfg >> "name"); - //_module set [count _module,[_name,_init]]; - _module = [_name,_init]; -}; - -_module \ No newline at end of file diff --git a/TO_MERGE/cse/f_modules/functions/fn_getModules_f.sqf b/TO_MERGE/cse/f_modules/functions/fn_getModules_f.sqf deleted file mode 100644 index 84fec9d862..0000000000 --- a/TO_MERGE/cse/f_modules/functions/fn_getModules_f.sqf +++ /dev/null @@ -1,15 +0,0 @@ -/** - * fn_getModules_f.sqf - * @Descr: Returns all current active CSE Modules - * @Author: Glowbal - * - * @Arguments: [] - * @Return: ARRAY List of all current Modules [moduleName STRING (Module classname), ...] - * @PublicAPI: true - */ - -if (isnil "CSE_F_MODULE_OBJ_EH") then { - CSE_F_MODULE_OBJ_EH = []; -}; - -CSE_F_MODULE_OBJ_EH; \ No newline at end of file diff --git a/TO_MERGE/cse/f_modules/functions/fn_initalizeModuleObjEH.sqf b/TO_MERGE/cse/f_modules/functions/fn_initalizeModuleObjEH.sqf deleted file mode 100644 index 02769a31cf..0000000000 --- a/TO_MERGE/cse/f_modules/functions/fn_initalizeModuleObjEH.sqf +++ /dev/null @@ -1,59 +0,0 @@ -/** - * fn_initalizeModuleObjEH.sqf - * @Descr: initalize module Object init Eventhandlers. DEPRICATED. DO NOT USE. - * @Author: Glowbal - * - * @Arguments: [object OBJECT, eventhandler STRING] - * @Return: void - * @PublicAPI: false - */ - - -private ["_entity","_handle","_cfg","_ehCfg","_numberOfEH"]; -_entity = (_this select 0) select 0; -_handle = _this select 1; - -if (!local _entity) exitwith{}; -if (isnil "cse_postInit") then { -_this spawn { - private ["_entity"]; - _entity = (_this select 0) select 0; - _handle = _this select 1; - waituntil{(!isnil 'cse_postInit')}; - { - _cfg = (ConfigFile >> "Combat_Space_Enhancement" >> "CfgModules" >> _x); - if (isClass _cfg) then { - if (isClass (_cfg >> "EventHandlers")) then { - _numberOfEH = count (_cfg >> "EventHandlers"); - for [{_j=0}, {_j< _numberOfEH}, {_j=_j+1}] do { - _ehCfg = ((_cfg >> "EventHandlers") select _j); - if (isClass _ehCfg) then { - if (_entity isKindOf (ConfigName _ehCfg)) then { - (_this select 0) call (compile getText(_ehCfg >> _handle)); - }; - }; - }; - }; - }; - }foreach (call cse_fnc_getModules); -}; -} else { - - if (!local _entity) exitwith{}; - { - _cfg = (ConfigFile >> "Combat_Space_Enhancement" >> "CfgModules" >> _x); - if (isClass _cfg) then { - if (isClass (_cfg >> "EventHandlers")) then { - _numberOfEH = count (_cfg >> "EventHandlers"); - for [{_j=0}, {_j< _numberOfEH}, {_j=_j+1}] do { - _ehCfg = ((_cfg >> "EventHandlers") select _j); - if (isClass _ehCfg) then { - if (_entity isKindOf (ConfigName _ehCfg)) then { - (_this select 0) call (compile getText(_ehCfg >> _handle)); - }; - }; - }; - }; - }; - }foreach (call cse_fnc_getModules); -}; \ No newline at end of file diff --git a/TO_MERGE/cse/f_modules/functions/fn_initalizeModule_F.sqf b/TO_MERGE/cse/f_modules/functions/fn_initalizeModule_F.sqf deleted file mode 100644 index fd9e659450..0000000000 --- a/TO_MERGE/cse/f_modules/functions/fn_initalizeModule_F.sqf +++ /dev/null @@ -1,59 +0,0 @@ -/** - * fn_initalizeModule_F.sqf - * @Descr: Initalize a CSE Module. To be called through the BI A3 Module Framework - * @Author: Glowbal - * - * @Arguments: [] - * @Return: void - * @PublicAPI: true - */ - -private ["_moduleName","_arguments","_logic","_units", "_activated","_cfg", "_moduleInfo", "_value", "_typeNameArgument"]; -if (count _this > 1) then { - _moduleName = typeOf (_this select 0); -} else { - _moduleName = _this select 0; -}; -[format["Initalize module: %1 IN QUE",_moduleName], 3] call cse_fnc_debug; -waituntil {(!isnil 'cse_f_modules')}; -[format["Initalize module: %1 STARTED",_moduleName], 3] call cse_fnc_debug; - -_arguments = []; -if (count _this >1) then { - _logic = [_this,0,objNull,[objNull]] call BIS_fnc_param; - _units = [_this,1,[],[[]]] call BIS_fnc_param; - _activated = [_this,2,true,[true]] call BIS_fnc_param; - _moduleName = typeOf _logic; - _cfg = (ConfigFile >> "CfgVehicles" >> _moduleName >> "Arguments"); - if (isClass _cfg) then { - for [{_i=0}, {_i < (count _cfg)}, {_i=_i+1}] do { - if (isClass (_cfg select _i)) then { - _value = _logic getvariable (ConfigName (_cfg select _i)); - if (!isnil "_value") then { - _arguments pushback [(ConfigName (_cfg select _i)), _value]; - } else { - _typeNameArgument = getText ((_cfg select _i) >> "typeName"); - _value = ""; - if (_typeNameArgument != "") then { - call { - if (_typeNameArgument == "BOOL") exitwith { - _value = getNumber((_cfg select _i) >> "defaultValue") == 1; - }; - if (_typeNameArgument == "NUMBER") exitwith { - _value = getNumber((_cfg select _i) >> "defaultValue"); - }; - if (_typeNameArgument == "STRING") exitwith { - _value = getText((_cfg select _i) >> "defaultValue"); - }; - }; - [format["Module Argument has not been set %1 %2. Module need to be replaced. Value used: %4", _moduleName, (ConfigName (_cfg select _i)), _typeNameArgument, _value], 1] call cse_fnc_debug; - _arguments pushback [(ConfigName (_cfg select _i)), _value]; - }; - }; - }; - }; - }; -} else { - _moduleName = _this select 0; -}; -[_moduleName, _arguments] call cse_fnc_enableModule_f; \ No newline at end of file diff --git a/TO_MERGE/cse/f_modules/functions/fn_isModuleEnabled_F.sqf b/TO_MERGE/cse/f_modules/functions/fn_isModuleEnabled_F.sqf deleted file mode 100644 index 8e3f86c295..0000000000 --- a/TO_MERGE/cse/f_modules/functions/fn_isModuleEnabled_F.sqf +++ /dev/null @@ -1,14 +0,0 @@ -/** - * fn_isModuleEnabled_F.sqf - * @Descr: Check if given CSE Module class is enabled - * @Author: Glowbal - * - * @Arguments: [moduleName STRING] - * @Return: BOOL Returns true if module is currently enabled - * @PublicAPI: true - */ - -if (isnil "CSE_F_MODULE_OBJ_EH") then { - CSE_F_MODULE_OBJ_EH = []; -}; -((_this select 0) in CSE_F_MODULE_OBJ_EH); \ No newline at end of file diff --git a/TO_MERGE/cse/f_modules/functions/fn_moduleIsActive_f.sqf b/TO_MERGE/cse/f_modules/functions/fn_moduleIsActive_f.sqf deleted file mode 100644 index 55e2205876..0000000000 --- a/TO_MERGE/cse/f_modules/functions/fn_moduleIsActive_f.sqf +++ /dev/null @@ -1,19 +0,0 @@ -/** - * fn_moduleIsActive_f.sqf - * @Descr: Check if given module name is active. DEPRICATED. DO NOT USE. - * @Author: Glowbal - * - * @Arguments: [moduleName STRING] - * @Return: BOOL Returns true if moduel is currently active - * @PublicAPI: false - */ - -private ["_moduleName","_return","_condition"]; -_moduleName = _this select 0; -_return = false; - -_condition = [_moduleNAme] call cse_fnc_getModuleCondition_F; -if (!isnil "_condition") then { - call compile format["_return = %1;",_condition]; -}; -_return \ No newline at end of file diff --git a/TO_MERGE/cse/f_modules/functions/fn_remoteModuleInit.sqf b/TO_MERGE/cse/f_modules/functions/fn_remoteModuleInit.sqf deleted file mode 100644 index bd37d9ecda..0000000000 --- a/TO_MERGE/cse/f_modules/functions/fn_remoteModuleInit.sqf +++ /dev/null @@ -1,17 +0,0 @@ -/** - * fn_remoteModuleInit.sqf - * @Descr: Called by remote execution script to initialize modules. - * @Author: Glowbal - * - * @Arguments: [[moduleName STRING, arguments ARRAY (Format: [argumentName STRING, value ANY])], ...] - * @Return: nil - * @PublicAPI: false - */ - -private ["_toinitalizeModules"]; -_toinitalizeModules = _this select 0; -sleep 5; -{ - [format["initalize module through Cfg REMOTE: %1",_x]] call cse_fnc_debug; - _x call cse_fnc_enableModule_f; -}foreach _toinitalizeModules; diff --git a/TO_MERGE/cse/f_modules/init.sqf b/TO_MERGE/cse/f_modules/init.sqf deleted file mode 100644 index 8524b1f20c..0000000000 --- a/TO_MERGE/cse/f_modules/init.sqf +++ /dev/null @@ -1,3 +0,0 @@ - - -cse_f_modules = true; \ No newline at end of file diff --git a/TO_MERGE/cse/f_modules/post-init.sqf b/TO_MERGE/cse/f_modules/post-init.sqf deleted file mode 100644 index bbc3015f39..0000000000 --- a/TO_MERGE/cse/f_modules/post-init.sqf +++ /dev/null @@ -1,21 +0,0 @@ -// Collect cfg modules and initalize them. -[] spawn { - // by waiting, we ensure that CSE Config modules aren't initalized before the modules have been. - sleep 5; - _toinitalizeModules = [MissionConfigFile] call cse_fnc_getCfgModuleInits_f; - { - [format["initalize module through cfg: %1",_x]] call cse_fnc_debug; - _x call cse_fnc_enableModule_f; - }foreach _toinitalizeModules; - - // Check if we want to collect server side modules - _allowCfg = ((getNumber(MissionConfigFile >> "Combat_Space_Enhancement" >> "DisableModuleConfig")) == 0); - if (isServer && _allowCfg) then { - _toinitalizeModules = [configFile] call cse_fnc_getCfgModuleInits_f; - - [format["initalize modules through server cfg: %1",_toinitalizeModules]] call cse_fnc_debug; - if !(_toinitalizeModules isEqualTo []) then { - [[_toinitalizeModules], "cse_fnc_remoteModuleInit", true, true] spawn BIS_fnc_MP; - }; - }; -}; \ No newline at end of file diff --git a/TO_MERGE/cse/f_modules/stringtable.xml b/TO_MERGE/cse/f_modules/stringtable.xml deleted file mode 100644 index 735441ee0b..0000000000 --- a/TO_MERGE/cse/f_modules/stringtable.xml +++ /dev/null @@ -1,7 +0,0 @@ - - - - - - - \ No newline at end of file diff --git a/TO_MERGE/cse/f_states/CfgFunctions.h b/TO_MERGE/cse/f_states/CfgFunctions.h deleted file mode 100644 index b52b213890..0000000000 --- a/TO_MERGE/cse/f_states/CfgFunctions.h +++ /dev/null @@ -1,49 +0,0 @@ -class CfgFunctions { - class CSE { - class Carry { - file = "cse\cse_f_states\carry\functions"; - class carryObj { recompile = 1; }; - class carriedByObj { recompile = 1; }; - class getCarriedObj { recompile = 1; }; - class getCarriedBy { recompile = 1; }; - class beingCarried { recompile = 1; }; - class setCarriedBy { recompile = 1; }; /* Should not be used by other developers */ - }; - class Unconscious { - file = "cse\cse_f_states\unconscious\functions"; - class setUnconsciousState { recompile = 1; }; - class isUnconscious { recompile = 1; }; - class getUnconsciousCondition { recompile = 1; }; - class registerUnconsciousCondition { recompile = 1; }; - class setCaptiveSwitch { recompile = 1; }; - class moveToTempGroup { recompile = 1; }; - class canGoUnconsciousState { recompile = 1; }; - class setWeaponsCorrectUnconscious { recompile = 1; }; - }; - class Visual { - file = "cse\cse_f_states\visual\functions"; - class effectPain { recompile = 1; }; - class effectBleeding { recompile = 1; }; - class effectBlackOut { recompile = 1; }; - }; - class Movement { - file = "cse\cse_f_states\movement\functions"; - class limitMovementSpeed { recompile = 1; }; - class limitSpeed { recompile = 1; }; - }; - class Arrest { - file = "cse\cse_f_states\arrest\functions"; - class setArrestState { recompile = 1; }; - class isArrested { recompile = 1; }; - }; - class LoadPerson { - file = "cse\cse_f_states\LoadPerson\functions"; - class loadPerson_F { recompile = 1; }; - class loadPersonLocal_F {recompile = 1; }; - class makeCopyOfBody_F { recompile = 1; }; - class makeCopyOfBodyLocal_F { recompile = 1; }; - class unloadPerson_F { recompile = 1; }; - class cleanUpCopyOfBody_F { recompile = 1; }; - }; - }; -}; \ No newline at end of file diff --git a/TO_MERGE/cse/f_states/Combat_Space_Enhancement.h b/TO_MERGE/cse/f_states/Combat_Space_Enhancement.h deleted file mode 100644 index d729a8bb80..0000000000 --- a/TO_MERGE/cse/f_states/Combat_Space_Enhancement.h +++ /dev/null @@ -1,26 +0,0 @@ -class Combat_Space_Enhancement -{ - class EventHandlers - { - class PostInit_EventHandlers - { - class cse_f_states - { - init = " call compile preprocessFile 'cse\cse_f_states\init.sqf';"; - }; - }; - }; - - - class CustomEventHandlers { - class setUnconsciousState {}; // [unit, bool] - class setArrestState {}; // [unit, bool] - class carryObject {}; // [_unit, _to, _fallDown],"carryObject" - - class carryObjectDropped { - class cleanUpCopiesAfterDrag { // [unit, droppedObject] - onCall = "[_this select 1] call cse_fnc_cleanUpCopyOfBody_f;"; - }; - }; - }; -}; \ No newline at end of file diff --git a/TO_MERGE/cse/f_states/arrest/functions/fn_isArrested.sqf b/TO_MERGE/cse/f_states/arrest/functions/fn_isArrested.sqf deleted file mode 100644 index 555a77a408..0000000000 --- a/TO_MERGE/cse/f_states/arrest/functions/fn_isArrested.sqf +++ /dev/null @@ -1,11 +0,0 @@ -/** - * fn_isArrested.sqf - * @Descr: Check if unit is in arrested state - * @Author: Glowbal - * - * @Arguments: [unit OBJECT] - * @Return: BOOL Returns true if unit or object is in arrest state - * @PublicAPI: true - */ - -((_this select 0) getvariable ["cse_state_arrested",false]) \ No newline at end of file diff --git a/TO_MERGE/cse/f_states/arrest/functions/fn_setArrestState.sqf b/TO_MERGE/cse/f_states/arrest/functions/fn_setArrestState.sqf deleted file mode 100644 index 306d2d4a2c..0000000000 --- a/TO_MERGE/cse/f_states/arrest/functions/fn_setArrestState.sqf +++ /dev/null @@ -1,43 +0,0 @@ -/** - * fn_setArrestState.sqf - * @Descr: Set a unit in arrest state - * @Author: Glowbal - * - * @Arguments: [unitToBeArrested OBJECT, setArrested BOOL] - * @Return: void - * @PublicAPI: true - */ - -private ["_unit","_setArrest"]; -_unit = [_this, 0, objNull, [objNull]] call BIS_fnc_Param; -_setArrest = [_this, 1, false, [false]] call BIS_fnc_Param; - -if (_setArrest) then { - [_unit, "cse_state_arrested", true] call cse_fnc_setVariable; - - if ([_unit] call cse_fnc_isAwake) then { - if (vehicle _unit == _unit) then { - [_unit,"UnaErcPoslechVelitele2",true] call cse_fnc_broadcastAnim; - }; - }; - if (IsPlayer _unit) then { - [["arrested", true],"cse_fnc_disableUserInput_f",_unit,false] call BIS_fnc_MP; - }; - _unit disableAI "Move"; - _unit disableAI "ANIM"; -} else { - [_unit, "cse_state_arrested", false] call cse_fnc_setVariable; - - if ([_unit] call cse_fnc_isAwake) then { - if (vehicle _unit == _unit) then { - [_unit,"",true] call cse_fnc_broadcastAnim; - }; - _unit enableAI "Move"; - _unit enableAI "ANIM"; - }; - if (IsPlayer _unit) then { - [["arrested", false],"cse_fnc_disableUserInput_f",_unit,false] call BIS_fnc_MP; - }; -}; - -[[_unit, _setArrest],"setArrestState"] call cse_fnc_customEventHandler_F; \ No newline at end of file diff --git a/TO_MERGE/cse/f_states/carry/functions/fn_beingCarried.sqf b/TO_MERGE/cse/f_states/carry/functions/fn_beingCarried.sqf deleted file mode 100644 index ae3dd0f6d7..0000000000 --- a/TO_MERGE/cse/f_states/carry/functions/fn_beingCarried.sqf +++ /dev/null @@ -1,13 +0,0 @@ -/** - * fn_beingCarried.sqf - * @Descr: Check if object is being carried - * @Author: Glowbal - * - * @Arguments: [object OBJECT] - * @Return: BOOL True if object is being carried - * @PublicAPI: true - */ - -private["_object"]; -_object = [_this,0,ObjNull,[ObjNull]] call BIS_fnc_Param; -!(isNull ([_object] call cse_fnc_getCarriedObj)); \ No newline at end of file diff --git a/TO_MERGE/cse/f_states/carry/functions/fn_carriedByObj.sqf b/TO_MERGE/cse/f_states/carry/functions/fn_carriedByObj.sqf deleted file mode 100644 index afc76bc7d8..0000000000 --- a/TO_MERGE/cse/f_states/carry/functions/fn_carriedByObj.sqf +++ /dev/null @@ -1,15 +0,0 @@ -/** - * fn_carriedByObj.sqf - * @Descr: Check if object A is being carried by object B. - * @Author: Glowbal - * - * @Arguments: [object OBJECT, unit OBJECT] - * @Return: BOOL True if B is carrying A. - * @PublicAPI: true - */ - -private ["_unit","_to"]; -_to = _this select 0; -_unit = _this select 1; - -([_to] call cse_fnc_getCarriedBy == [_unit] call cse_fnc_getCarriedBy); \ No newline at end of file diff --git a/TO_MERGE/cse/f_states/carry/functions/fn_carryObj.sqf b/TO_MERGE/cse/f_states/carry/functions/fn_carryObj.sqf deleted file mode 100644 index 06a4e3620c..0000000000 --- a/TO_MERGE/cse/f_states/carry/functions/fn_carryObj.sqf +++ /dev/null @@ -1,74 +0,0 @@ -/** - * fn_carryObj.sqf - * @Descr: Have a unit carry an object. Use ObjNull for second parameter if you want the unit to carry nothing - * @Author: Glowbal - * - * @Arguments: [unit OBJECT, objectToCarry OBJECT, attachToVector ARRAY (Optional)] - * @Return: BOOL Returns true if succesful - * @PublicAPI: true - */ - -private ["_unit","_to","_return", "_fallDown", "_carriedObj", "_positionUnit"]; -_unit = [_this, 0,ObjNull, [ObjNull]] call bis_fnc_param; -_to = [_this, 1,ObjNull, [ObjNull]] call bis_fnc_param; -_fallDown = false; -if (count _this > 3) then { - _fallDown = _this select 3; -}; -_return = false; - - [format["fnc_carryObj - UNIT: %1 ATTEMPTS TO CARRY %2",_unit,_to],2] call cse_fnc_debug; - - if (((typeName _to) == "OBJECT" && (isNull ([_unit] call cse_fnc_getCarriedObj))) || isNull _to) then { - if (vehicle _unit != _unit) exitwith {}; - if (!isNull _to) then { - if ((isNull ([_to] call cse_fnc_getCarriedObj)) && ([_unit] call cse_fnc_canInteract)) then { - _return = true; - _unit setvariable ["cse_carriedObj",_to,true]; - if (_fallDown) then { - // [_unit,_fallDown] call cse_fnc_limitMovementSpeed; - }; - [_to, _unit] call cse_fnc_setCarriedBy; - if (count _this > 2) then { - if (count (_this select 2) == 3) then { - _to attachTo [_unit,(_this select 2)]; - [format["fnc_carryObj - UNIT: %1 TO %2 - attachTo offset: %3",_unit,_to,(_this select 2)],2] call cse_fnc_debug; - }; - } else { - [format["fnc_carryObj - UNIT: %1 TO %2 - Script expects external handling of attachTo Command. Exiting",_unit,_to],2] call cse_fnc_debug; - }; - - [[_unit, _to, _fallDown],"carryObject"] call cse_fnc_customEventHandler_F; - - }; - } else { - if (!isNull ([_unit] call cse_fnc_getCarriedObj)) then { - [format["fnc_carryObj - UNIT: %1 DROPING CARRIED OBJECT",_unit],2] call cse_fnc_debug; - _carriedObj = ([_unit] call cse_fnc_getCarriedObj); - - detach _carriedObj; - //_carriedObj setPosATL [(getPosATL _carriedObj) select 0, (getPosATL _carriedObj) select 1,0]; - if (!surfaceIsWater getPos _unit) then { - _positionUnit = getPosATL _carriedObj; - _positionUnit set [2, ((getPosATL _unit) select 2) + 0.1]; - _carriedObj setPosATL _positionUnit; - } else { - _positionUnit = getPosASL _carriedObj; - _positionUnit set [2, ((getPosASL _unit) select 2) + 0.1]; - _carriedObj setPosASL _positionUnit; - }; - [[_unit, _carriedObj],"carryObjectDropped"] call cse_fnc_customEventHandler_F; - - [[_unit] call cse_fnc_getCarriedObj, objNull] call cse_fnc_setCarriedBy; - _unit setvariable ["cse_carriedObj",_to,true]; - _return = true; - - [[_unit, _to, _fallDown],"carryObject"] call cse_fnc_customEventHandler_F; - }; - }; - } else { - [format["fnc_carryObj - UNIT: %1 FAILED TO CARRY %2 - not an object or already carrying",_unit,_to],2] call cse_fnc_debug; - }; - - //[format["UNIT: %1 ATTEMPTS TO CARRY %2",_unit,_to],2] call cse_fnc_debug; -_return diff --git a/TO_MERGE/cse/f_states/carry/functions/fn_getCarriedBy.sqf b/TO_MERGE/cse/f_states/carry/functions/fn_getCarriedBy.sqf deleted file mode 100644 index de2effafbf..0000000000 --- a/TO_MERGE/cse/f_states/carry/functions/fn_getCarriedBy.sqf +++ /dev/null @@ -1,14 +0,0 @@ -/** - * fn_getCarriedBy.sqf - * @Descr: Get the object that is carrying given unit or object - * @Author: Glowbal - * - * @Arguments: [unit OBJECT] - * @Return: OBJECT Returns the object that is carrying the unit. Otherwise returns ObjNull - * @PublicAPI: true - */ - - private ["_unit","_return"]; - _unit = [_this, 0, objNull, [objNull]] call BIS_fnc_param; - _return = _unit getvariable ["cse_carriedBy",objNull]; -_return diff --git a/TO_MERGE/cse/f_states/carry/functions/fn_getCarriedObj.sqf b/TO_MERGE/cse/f_states/carry/functions/fn_getCarriedObj.sqf deleted file mode 100644 index 5da37a0099..0000000000 --- a/TO_MERGE/cse/f_states/carry/functions/fn_getCarriedObj.sqf +++ /dev/null @@ -1,14 +0,0 @@ -/** - * fn_getCarriedObj.sqf - * @Descr: Grab the registered carried object - * @Author: Glowbal - * - * @Arguments: [unit OBJECT] - * @Return: OBJECT Returns the object that the unit is currently carrying. If not carrying, returns ObjNull - * @PublicAPI: true - */ - - private ["_unit","_return"]; - _unit = _this select 0; - _return = _unit getvariable ["cse_carriedObj",objNull]; -_return diff --git a/TO_MERGE/cse/f_states/carry/functions/fn_setCarriedBy.sqf b/TO_MERGE/cse/f_states/carry/functions/fn_setCarriedBy.sqf deleted file mode 100644 index 26d773a738..0000000000 --- a/TO_MERGE/cse/f_states/carry/functions/fn_setCarriedBy.sqf +++ /dev/null @@ -1,20 +0,0 @@ -/** - * fn_setCarriedBy.sqf - * @Descr: Registers an object being carried by another object - * @Author: Glowbal - * - * @Arguments: [unitToBeCarried OBJECT, objectCarrying OBJECT] - * @Return: BOOL True if succesfully registered - * @PublicAPI: false - */ - - -private ["_unit","_to","_return"]; -_unit = [_this, 0, ObjNull,[ObjNull]] call BIS_fnc_Param; -_to = [_this, 1, ObjNull,[ObjNull]] call BIS_fnc_Param; -_return = false; -if ((isNull ([_unit] call cse_fnc_getCarriedBy)) || isNull _to) then { - _return = true; - _unit setvariable ["cse_carriedBy",_to,true]; -}; -_return \ No newline at end of file diff --git a/TO_MERGE/cse/f_states/config.cpp b/TO_MERGE/cse/f_states/config.cpp deleted file mode 100644 index 8a0a71a719..0000000000 --- a/TO_MERGE/cse/f_states/config.cpp +++ /dev/null @@ -1,26 +0,0 @@ -#define _ARMA_ -class CfgPatches -{ - class cse_f_states - { - units[] = {}; - weapons[] = {}; - requiredVersion = 0.1; - requiredAddons[] = {"cse_main"}; - version = "0.5"; - author[] = {"Combat Space Enhancement"}; - authorUrl = "http://csemod.com"; - }; -}; -class CfgAddons { - class PreloadAddons { - class cse_f_states { - list[] = {"cse_f_states"}; - }; - }; -}; -#include "CfgFunctions.h" -#include "Combat_Space_Enhancement.h" -#include "define.hpp" -#include "visual\empty.hpp" -#include "visual\effects.hpp" \ No newline at end of file diff --git a/TO_MERGE/cse/f_states/data/black_out1.paa b/TO_MERGE/cse/f_states/data/black_out1.paa deleted file mode 100644 index c50a106954..0000000000 Binary files a/TO_MERGE/cse/f_states/data/black_out1.paa and /dev/null differ diff --git a/TO_MERGE/cse/f_states/data/cse_bleedingscreen_v5.paa b/TO_MERGE/cse/f_states/data/cse_bleedingscreen_v5.paa deleted file mode 100644 index 2e88e1cf3d..0000000000 Binary files a/TO_MERGE/cse/f_states/data/cse_bleedingscreen_v5.paa and /dev/null differ diff --git a/TO_MERGE/cse/f_states/data/cse_blurryScreen.paa b/TO_MERGE/cse/f_states/data/cse_blurryScreen.paa deleted file mode 100644 index ff12bd993e..0000000000 Binary files a/TO_MERGE/cse/f_states/data/cse_blurryScreen.paa and /dev/null differ diff --git a/TO_MERGE/cse/f_states/data/cse_fadingblack.paa b/TO_MERGE/cse/f_states/data/cse_fadingblack.paa deleted file mode 100644 index 9ed471597c..0000000000 Binary files a/TO_MERGE/cse/f_states/data/cse_fadingblack.paa and /dev/null differ diff --git a/TO_MERGE/cse/f_states/data/cse_painscreen.paa b/TO_MERGE/cse/f_states/data/cse_painscreen.paa deleted file mode 100644 index 026f994fa9..0000000000 Binary files a/TO_MERGE/cse/f_states/data/cse_painscreen.paa and /dev/null differ diff --git a/TO_MERGE/cse/f_states/data/hit_screen1.paa b/TO_MERGE/cse/f_states/data/hit_screen1.paa deleted file mode 100644 index e878efff0b..0000000000 Binary files a/TO_MERGE/cse/f_states/data/hit_screen1.paa and /dev/null differ diff --git a/TO_MERGE/cse/f_states/data/pain_screen3.paa b/TO_MERGE/cse/f_states/data/pain_screen3.paa deleted file mode 100644 index f629d66280..0000000000 Binary files a/TO_MERGE/cse/f_states/data/pain_screen3.paa and /dev/null differ diff --git a/TO_MERGE/cse/f_states/define.hpp b/TO_MERGE/cse/f_states/define.hpp deleted file mode 100644 index c521de470f..0000000000 --- a/TO_MERGE/cse/f_states/define.hpp +++ /dev/null @@ -1,797 +0,0 @@ - -#ifndef CSE_DEFINE_H -#define CSE_DEFINE_H -// define.hpp - -#define true 1 -#define false 0 - -#define CT_STATIC 0 -#define CT_BUTTON 1 -#define CT_EDIT 2 -#define CT_SLIDER 3 -#define CT_COMBO 4 -#define CT_LISTBOX 5 -#define CT_TOOLBOX 6 -#define CT_CHECKBOXES 7 -#define CT_PROGRESS 8 -#define CT_HTML 9 -#define CT_STATIC_SKEW 10 -#define CT_ACTIVETEXT 11 -#define CT_TREE 12 -#define CT_STRUCTURED_TEXT 13 -#define CT_CONTEXT_MENU 14 -#define CT_CONTROLS_GROUP 15 -#define CT_SHORTCUTBUTTON 16 -#define CT_XKEYDESC 40 -#define CT_XBUTTON 41 -#define CT_XLISTBOX 42 -#define CT_XSLIDER 43 -#define CT_XCOMBO 44 -#define CT_ANIMATED_TEXTURE 45 -#define CT_OBJECT 80 -#define CT_OBJECT_ZOOM 81 -#define CT_OBJECT_CONTAINER 82 -#define CT_OBJECT_CONT_ANIM 83 -#define CT_LINEBREAK 98 -#define CT_ANIMATED_USER 99 -#define CT_MAP 100 -#define CT_MAP_MAIN 101 -#define CT_LISTNBOX 102 - -// Static styles -#define ST_POS 0x0F -#define ST_HPOS 0x03 -#define ST_VPOS 0x0C -#define ST_LEFT 0x00 -#define ST_RIGHT 0x01 -#define ST_CENTER 0x02 -#define ST_DOWN 0x04 -#define ST_UP 0x08 -#define ST_VCENTER 0x0c - -#define ST_TYPE 0xF0 -#define ST_SINGLE 0 -#define ST_MULTI 16 -#define ST_TITLE_BAR 32 -#define ST_PICTURE 48 -#define ST_FRAME 64 -#define ST_BACKGROUND 80 -#define ST_GROUP_BOX 96 -#define ST_GROUP_BOX2 112 -#define ST_HUD_BACKGROUND 128 -#define ST_TILE_PICTURE 144 -#define ST_WITH_RECT 160 -#define ST_LINE 176 - -#define ST_SHADOW 0x100 -#define ST_NO_RECT 0x200 // this style works for CT_STATIC in conjunction with ST_MULTI -#define ST_KEEP_ASPECT_RATIO 0x800 - -#define ST_TITLE ST_TITLE_BAR + ST_CENTER - -// Slider styles -#define SL_DIR 0x400 -#define SL_VERT 0 -#define SL_HORZ 0x400 - -#define SL_TEXTURES 0x10 - -// Listbox styles -#define LB_TEXTURES 0x10 -#define LB_MULTI 0x20 -#define FontCSE "PuristaMedium" - -class cse_gui_backgroundBase { - type = CT_STATIC; - idc = -1; - style = ST_PICTURE; - colorBackground[] = {0,0,0,0}; - colorText[] = {1, 1, 1, 1}; - font = FontCSE; - text = ""; - sizeEx = 0.032; -}; -class cse_gui_editBase -{ - access = 0; - type = 2; - x = 0; - y = 0; - h = 0.04; - w = 0.2; - colorBackground[] = - { - 0, - 0, - 0, - 1 - }; - colorText[] = - { - 0.95, - 0.95, - 0.95, - 1 - }; - colorSelection[] = - { - "(profilenamespace getvariable ['GUI_BCG_RGB_R',0.3843])", - "(profilenamespace getvariable ['GUI_BCG_RGB_G',0.7019])", - "(profilenamespace getvariable ['GUI_BCG_RGB_B',0.8862])", - 1 - }; - autocomplete = ""; - text = ""; - size = 0.2; - style = "0x00 + 0x40"; - font = "PuristaMedium"; - shadow = 2; - sizeEx = "(((((safezoneW / safezoneH) min 1.2) / 1.2) / 25) * 1)"; - colorDisabled[] = - { - 1, - 1, - 1, - 0.25 - }; -}; - - - -class cse_gui_buttonBase { - idc = -1; - type = 16; - style = ST_LEFT; - text = ""; - action = ""; - x = 0.0; - y = 0.0; - w = 0.25; - h = 0.04; - size = 0.03921; - sizeEx = 0.03921; - color[] = {1.0, 1.0, 1.0, 1}; - color2[] = {1.0, 1.0, 1.0, 1}; - /*colorBackground[] = {"(profilenamespace getvariable ['GUI_BCG_RGB_R',0.69])","(profilenamespace getvariable ['GUI_BCG_RGB_G',0.75])","(profilenamespace getvariable ['GUI_BCG_RGB_B',0.5])", "(profilenamespace getvariable ['GUI_BCG_RGB_A',0.5])"}; - colorbackground2[] = {"(profilenamespace getvariable ['GUI_BCG_RGB_R',0.69])","(profilenamespace getvariable ['GUI_BCG_RGB_G',0.75])","(profilenamespace getvariable ['GUI_BCG_RGB_B',0.5])", 0.4}; - colorDisabled[] = {"(profilenamespace getvariable ['GUI_BCG_RGB_R',0.69])","(profilenamespace getvariable ['GUI_BCG_RGB_G',0.75])","(profilenamespace getvariable ['GUI_BCG_RGB_B',0.5])", 0.25}; - colorFocused[] = {"(profilenamespace getvariable ['IGUI_TEXT_RGB_R',0])","(profilenamespace getvariable ['IGUI_TEXT_RGB_G',1])","(profilenamespace getvariable ['IGUI_TEXT_RGB_B',1])","(profilenamespace getvariable ['IGUI_TEXT_RGB_A',0.8])", 0.8}; - colorBackgroundFocused[] = {"(profilenamespace getvariable ['GUI_BCG_RGB_R',0.69])","(profilenamespace getvariable ['GUI_BCG_RGB_G',0.75])","(profilenamespace getvariable ['GUI_BCG_RGB_B',0.5])", 0.8}; - */ - - colorBackground[] = {1,1,1,0.95}; - colorbackground2[] = {1,1,1,0.95}; - colorDisabled[] = {1,1,1,0.6}; - colorFocused[] = {1,1,1,1}; - colorBackgroundFocused[] = {1,1,1,1}; - periodFocus = 1.2; - periodOver = 0.8; - default = false; - class HitZone { - left = 0.00; - top = 0.00; - right = 0.00; - bottom = 0.00; - }; - - class ShortcutPos { - left = 0.00; - top = 0.00; - w = 0.00; - h = 0.00; - }; - - class TextPos { - left = 0.002; - top = 0.0004; - right = 0.0; - bottom = 0.00; - }; - textureNoShortcut = ""; - animTextureNormal = "cse\cse_gui\data\buttonNormal_gradient_top.paa"; - animTextureDisabled = "cse\cse_gui\data\buttonDisabled_gradient.paa"; - animTextureOver = "cse\cse_gui\data\buttonNormal_gradient_top.paa"; - animTextureFocused = "cse\cse_gui\data\buttonNormal_gradient_top.paa"; - animTexturePressed = "cse\cse_gui\data\buttonNormal_gradient_top.paa"; - animTextureDefault = "cse\cse_gui\data\buttonNormal_gradient_top.paa"; - period = 0.5; - font = FontCSE; - soundClick[] = {"\A3\ui_f\data\sound\RscButton\soundClick",0.09,1}; - soundPush[] = {"\A3\ui_f\data\sound\RscButton\soundPush",0.0,0}; - soundEnter[] = {"\A3\ui_f\data\sound\RscButton\soundEnter",0.07,1}; - soundEscape[] = {"\A3\ui_f\data\sound\RscButton\soundEscape",0.09,1}; - class Attributes { - font = FontCSE; - color = "#E5E5E5"; - align = "center"; - shadow = "true"; - }; - class AttributesImage { - font = FontCSE; - color = "#E5E5E5"; - align = "left"; - shadow = "true"; - }; -}; - -class cse_gui_RscProgress { - type = 8; - style = 0; - colorFrame[] = {1,1,1,0.7}; - colorBar[] = {1,1,1,0.7}; - texture = "#(argb,8,8,3)color(1,1,1,0.7)"; - x = "1 * (((safezoneW / safezoneH) min 1.2) / 40) + (safezoneX + (safezoneW - ((safezoneW / safezoneH) min 1.2))/2)"; - y = "10 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + (safezoneH - (((safezoneW / safezoneH) min 1.2) / 1.2))/2)"; - w = "38 * (((safezoneW / safezoneH) min 1.2) / 40)"; - h = "0.5 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25)"; -}; - - -class cse_gui_staticBase { - idc = -1; - type = CT_STATIC; - x = 0.0; - y = 0.0; - w = 0.183825; - h = 0.104575; - style = ST_LEFT; - font = FontCSE; - sizeEx = 0.03921; - colorText[] = {0.95, 0.95, 0.95, 1.0}; - colorBackground[] = {0, 0, 0, 0}; - text = ""; -}; - -class RscListBox; -class cse_gui_listBoxBase : RscListBox{ - type = CT_LISTBOX; - style = ST_MULTI; - font = FontCSE; - sizeEx = 0.03921; - color[] = {1, 1, 1, 1}; - colorText[] = {0.543, 0.5742, 0.4102, 1.0}; - colorScrollbar[] = {0.95, 0.95, 0.95, 1}; - colorSelect[] = {0.95, 0.95, 0.95, 1}; - colorSelect2[] = {0.95, 0.95, 0.95, 1}; - colorSelectBackground[] = {0, 0, 0, 1}; - colorSelectBackground2[] = {0.543, 0.5742, 0.4102, 1.0}; - colorDisabled[] = {"(profilenamespace getvariable ['GUI_BCG_RGB_R',0.69])","(profilenamespace getvariable ['GUI_BCG_RGB_G',0.75])","(profilenamespace getvariable ['GUI_BCG_RGB_B',0.5])", 0.25}; - period = 1.2; - rowHeight = 0.03; - colorBackground[] = {0, 0, 0, 1}; - maxHistoryDelay = 1.0; - autoScrollSpeed = -1; - autoScrollDelay = 5; - autoScrollRewind = 0; - soundSelect[] = {"",0.1,1}; - soundExpand[] = {"",0.1,1}; - soundCollapse[] = {"",0.1,1}; - class ListScrollBar { - arrowEmpty = "\A3\ui_f\data\gui\cfg\scrollbar\arrowEmpty_ca.paa"; - arrowFull = "\A3\ui_f\data\gui\cfg\scrollbar\arrowFull_ca.paa"; - autoScrollDelay = 5; - autoScrollEnabled = 0; - autoScrollRewind = 0; - autoScrollSpeed = -1; - border = "\A3\ui_f\data\gui\cfg\scrollbar\border_ca.paa"; - color[] = {1,1,1,0.6}; - colorActive[] = {1,1,1,1}; - colorDisabled[] = {1,1,1,0.3}; - height = 0; - scrollSpeed = 0.06; - shadow = 0; - thumb = "\A3\ui_f\data\gui\cfg\scrollbar\thumb_ca.paa"; - width = 0; - }; - class ScrollBar { - color[] = {1, 1, 1, 0.6}; - colorActive[] = {1, 1, 1, 1}; - colorDisabled[] = {1, 1, 1, 0.3}; - thumb = ""; - arrowFull = ""; - arrowEmpty = ""; - border = ""; - }; -}; - - -class cse_gui_listNBox { - access = 0; - type = CT_LISTNBOX;// 102; - style =ST_MULTI; - w = 0.4; - h = 0.4; - font = FontCSE; - sizeEx = 0.031; - - autoScrollSpeed = -1; - autoScrollDelay = 5; - autoScrollRewind = 0; - arrowEmpty = "#(argb,8,8,3)color(1,1,1,1)"; - arrowFull = "#(argb,8,8,3)color(1,1,1,1)"; - columns[] = {0.0}; - color[] = {1, 1, 1, 1}; - - rowHeight = 0.03; - colorBackground[] = {0, 0, 0, 0.2}; - colorText[] = {1,1, 1, 1.0}; - colorScrollbar[] = {0.95, 0.95, 0.95, 1}; - colorSelect[] = {0.95, 0.95, 0.95, 1}; - colorSelect2[] = {0.95, 0.95, 0.95, 1}; - colorSelectBackground[] = {0, 0, 0, 0.0}; - colorSelectBackground2[] = {0.0, 0.0, 0.0, 0.5}; - colorActive[] = {0,0,0,1}; - colorDisabled[] = {0,0,0,0.3}; - rows = 1; - - drawSideArrows = 0; - idcLeft = -1; - idcRight = -1; - maxHistoryDelay = 1; - soundSelect[] = {"", 0.1, 1}; - period = 1; - shadow = 2; - class ScrollBar { - arrowEmpty = "#(argb,8,8,3)color(1,1,1,1)"; - arrowFull = "#(argb,8,8,3)color(1,1,1,1)"; - border = "#(argb,8,8,3)color(1,1,1,1)"; - color[] = {1,1,1,0.6}; - colorActive[] = {1,1,1,1}; - colorDisabled[] = {1,1,1,0.3}; - thumb = "#(argb,8,8,3)color(1,1,1,1)"; - }; - class ListScrollBar { - arrowEmpty = "\A3\ui_f\data\gui\cfg\scrollbar\arrowEmpty_ca.paa"; - arrowFull = "\A3\ui_f\data\gui\cfg\scrollbar\arrowFull_ca.paa"; - autoScrollDelay = 5; - autoScrollEnabled = 0; - autoScrollRewind = 0; - autoScrollSpeed = -1; - border = "\A3\ui_f\data\gui\cfg\scrollbar\border_ca.paa"; - color[] = {1,1,1,0.6}; - colorActive[] = {1,1,1,1}; - colorDisabled[] = {1,1,1,0.3}; - height = 0; - scrollSpeed = 0.06; - shadow = 0; - thumb = "\A3\ui_f\data\gui\cfg\scrollbar\thumb_ca.paa"; - width = 0; - }; -}; - - -class RscCombo; -class cse_gui_comboBoxBase: RscCombo { - idc = -1; - type = 4; - style = "0x10 + 0x200"; - x = 0; - y = 0; - w = 0.3; - h = 0.035; - color[] = {0,0,0,0.6}; - colorActive[] = {1,0,0,1}; - colorBackground[] = {0,0,0,1}; - colorDisabled[] = {1,1,1,0.25}; - colorScrollbar[] = {1,0,0,1}; - colorSelect[] = {0,0,0,1}; - colorSelectBackground[] = {1,1,1,0.7}; - colorText[] = {1,1,1,1}; - - arrowEmpty = ""; - arrowFull = ""; - wholeHeight = 0.45; - font = FontCSE; - sizeEx = 0.031; - soundSelect[] = {"\A3\ui_f\data\sound\RscCombo\soundSelect",0.1,1}; - soundExpand[] = {"\A3\ui_f\data\sound\RscCombo\soundExpand",0.1,1}; - soundCollapse[] = {"\A3\ui_f\data\sound\RscCombo\soundCollapse",0.1,1}; - maxHistoryDelay = 1.0; - class ScrollBar - { - color[] = {0.3,0.3,0.3,0.6}; - colorActive[] = {0.3,0.3,0.3,1}; - colorDisabled[] = {0.3,0.3,0.3,0.3}; - thumb = "\A3\ui_f\data\gui\cfg\scrollbar\thumb_ca.paa"; - arrowEmpty = "\A3\ui_f\data\gui\cfg\scrollbar\arrowEmpty_ca.paa"; - arrowFull = "\A3\ui_f\data\gui\cfg\scrollbar\arrowFull_ca.paa"; - border = ""; - }; - class ComboScrollBar { - arrowEmpty = "\A3\ui_f\data\gui\cfg\scrollbar\arrowEmpty_ca.paa"; - arrowFull = "\A3\ui_f\data\gui\cfg\scrollbar\arrowFull_ca.paa"; - autoScrollDelay = 5; - autoScrollEnabled = 0; - autoScrollRewind = 0; - autoScrollSpeed = -1; - border = "\A3\ui_f\data\gui\cfg\scrollbar\border_ca.paa"; - color[] = {0.3,0.3,0.3,0.6}; - colorActive[] = {0.3,0.3,0.3,1}; - colorDisabled[] = {0.3,0.3,0.3,0.3}; - height = 0; - scrollSpeed = 0.06; - shadow = 0; - thumb = "\A3\ui_f\data\gui\cfg\scrollbar\thumb_ca.paa"; - width = 0; - }; -}; - - - -class cse_gui_mapBase { - moveOnEdges = 1; - x = "SafeZoneXAbs"; - y = "SafeZoneY + 1.5 * ( ( ((safezoneW / safezoneH) min 1.2) / 1.2) / 25)"; - w = "SafeZoneWAbs"; - h = "SafeZoneH - 1.5 * ( ( ((safezoneW / safezoneH) min 1.2) / 1.2) / 25)"; - type = 100; // Use 100 to hide markers - style = 48; - shadow = 0; - - ptsPerSquareSea = 5; - ptsPerSquareTxt = 3; - ptsPerSquareCLn = 10; - ptsPerSquareExp = 10; - ptsPerSquareCost = 10; - ptsPerSquareFor = 9; - ptsPerSquareForEdge = 9; - ptsPerSquareRoad = 6; - ptsPerSquareObj = 9; - showCountourInterval = 0; - scaleMin = 0.001; - scaleMax = 1.0; - scaleDefault = 0.16; - maxSatelliteAlpha = 0.85; - alphaFadeStartScale = 0.35; - alphaFadeEndScale = 0.4; - colorBackground[] = {0.969,0.957,0.949,1.0}; - colorSea[] = {0.467,0.631,0.851,0.5}; - colorForest[] = {0.624,0.78,0.388,0.5}; - colorForestBorder[] = {0.0,0.0,0.0,0.0}; - colorRocks[] = {0.0,0.0,0.0,0.3}; - colorRocksBorder[] = {0.0,0.0,0.0,0.0}; - colorLevels[] = {0.286,0.177,0.094,0.5}; - colorMainCountlines[] = {0.572,0.354,0.188,0.5}; - colorCountlines[] = {0.572,0.354,0.188,0.25}; - colorMainCountlinesWater[] = {0.491,0.577,0.702,0.6}; - colorCountlinesWater[] = {0.491,0.577,0.702,0.3}; - colorPowerLines[] = {0.1,0.1,0.1,1.0}; - colorRailWay[] = {0.8,0.2,0.0,1.0}; - colorNames[] = {0.1,0.1,0.1,0.9}; - colorInactive[] = {1.0,1.0,1.0,0.5}; - colorOutside[] = {0.0,0.0,0.0,1.0}; - colorTracks[] = {0.84,0.76,0.65,0.15}; - colorTracksFill[] = {0.84,0.76,0.65,1.0}; - colorRoads[] = {0.7,0.7,0.7,1.0}; - colorRoadsFill[] = {1.0,1.0,1.0,1.0}; - colorMainRoads[] = {0.9,0.5,0.3,1.0}; - colorMainRoadsFill[] = {1.0,0.6,0.4,1.0}; - colorGrid[] = {0.1,0.1,0.1,0.6}; - colorGridMap[] = {0.1,0.1,0.1,0.6}; - colorText[] = {1, 1, 1, 0.85}; -font = "PuristaMedium"; -sizeEx = 0.0270000; -stickX[] = {0.20, {"Gamma", 1.00, 1.50} }; -stickY[] = {0.20, {"Gamma", 1.00, 1.50} }; -onMouseButtonClick = ""; -onMouseButtonDblClick = ""; - - fontLabel = "PuristaMedium"; - sizeExLabel = "( ( ( ((safezoneW / safezoneH) min 1.2) / 1.2) / 25) * 0.8)"; - fontGrid = "TahomaB"; - sizeExGrid = 0.02; - fontUnits = "TahomaB"; - sizeExUnits = "( ( ( ((safezoneW / safezoneH) min 1.2) / 1.2) / 25) * 0.8)"; - fontNames = "PuristaMedium"; - sizeExNames = "( ( ( ((safezoneW / safezoneH) min 1.2) / 1.2) / 25) * 0.8) * 2"; - fontInfo = "PuristaMedium"; - sizeExInfo = "( ( ( ((safezoneW / safezoneH) min 1.2) / 1.2) / 25) * 0.8)"; - fontLevel = "TahomaB"; - sizeExLevel = 0.02; - text = "#(argb,8,8,3)color(1,1,1,1)"; - class ActiveMarker { - color[] = {0.30, 0.10, 0.90, 1.00}; - size = 50; - }; - class Legend - { - x = "SafeZoneX + ( ((safezoneW / safezoneH) min 1.2) / 40)"; - y = "SafeZoneY + safezoneH - 4.5 * ( ( ((safezoneW / safezoneH) min 1.2) / 1.2) / 25)"; - w = "10 * ( ((safezoneW / safezoneH) min 1.2) / 40)"; - h = "3.5 * ( ( ((safezoneW / safezoneH) min 1.2) / 1.2) / 25)"; - font = "PuristaMedium"; - sizeEx = "( ( ( ((safezoneW / safezoneH) min 1.2) / 1.2) / 25) * 0.8)"; - colorBackground[] = {1,1,1,0.5}; - color[] = {0,0,0,1}; - }; - class Task - { - icon = "\A3\ui_f\data\map\mapcontrol\taskIcon_CA.paa"; - iconCreated = "\A3\ui_f\data\map\mapcontrol\taskIconCreated_CA.paa"; - iconCanceled = "\A3\ui_f\data\map\mapcontrol\taskIconCanceled_CA.paa"; - iconDone = "\A3\ui_f\data\map\mapcontrol\taskIconDone_CA.paa"; - iconFailed = "\A3\ui_f\data\map\mapcontrol\taskIconFailed_CA.paa"; - color[] = {"(profilenamespace getvariable ['IGUI_TEXT_RGB_R',0])","(profilenamespace getvariable ['IGUI_TEXT_RGB_G',1])","(profilenamespace getvariable ['IGUI_TEXT_RGB_B',1])","(profilenamespace getvariable ['IGUI_TEXT_RGB_A',0.8])"}; - colorCreated[] = {1,1,1,1}; - colorCanceled[] = {0.7,0.7,0.7,1}; - colorDone[] = {0.7,1,0.3,1}; - colorFailed[] = {1,0.3,0.2,1}; - size = 27; - importance = 1; - coefMin = 1; - coefMax = 1; - }; - class Waypoint - { - icon = "\A3\ui_f\data\map\mapcontrol\waypoint_ca.paa"; - color[] = {0,0,0,1}; - size = 20; - importance = "1.2 * 16 * 0.05"; - coefMin = 0.900000; - coefMax = 4; - }; - class WaypointCompleted - { - icon = "\A3\ui_f\data\map\mapcontrol\waypointCompleted_ca.paa"; - color[] = {0,0,0,1}; - size = 20; - importance = "1.2 * 16 * 0.05"; - coefMin = 0.900000; - coefMax = 4; - }; - class CustomMark - { - icon = "\A3\ui_f\data\map\mapcontrol\custommark_ca.paa"; - size = 24; - importance = 1; - coefMin = 1; - coefMax = 1; - color[] = {0,0,0,1}; - }; - class Command - { - icon = "\A3\ui_f\data\map\mapcontrol\waypoint_ca.paa"; - size = 18; - importance = 1; - coefMin = 1; - coefMax = 1; - color[] = {1,1,1,1}; - }; - class Bush - { - icon = "\A3\ui_f\data\map\mapcontrol\bush_ca.paa"; - color[] = {0.45,0.64,0.33,0.4}; - size = "14/2"; - importance = "0.2 * 14 * 0.05 * 0.05"; - coefMin = 0.25; - coefMax = 4; - }; - class Rock - { - icon = "\A3\ui_f\data\map\mapcontrol\rock_ca.paa"; - color[] = {0.1,0.1,0.1,0.8}; - size = 12; - importance = "0.5 * 12 * 0.05"; - coefMin = 0.25; - coefMax = 4; - }; - class SmallTree - { - icon = "\A3\ui_f\data\map\mapcontrol\bush_ca.paa"; - color[] = {0.45,0.64,0.33,0.4}; - size = 12; - importance = "0.6 * 12 * 0.05"; - coefMin = 0.25; - coefMax = 4; - }; - class Tree - { - icon = "\A3\ui_f\data\map\mapcontrol\bush_ca.paa"; - color[] = {0.45,0.64,0.33,0.4}; - size = 12; - importance = "0.9 * 16 * 0.05"; - coefMin = 0.25; - coefMax = 4; - }; - class busstop - { - icon = "\A3\ui_f\data\map\mapcontrol\busstop_CA.paa"; - size = 24; - importance = 1; - coefMin = 0.85; - coefMax = 1.0; - color[] = {1,1,1,1}; - }; - class fuelstation - { - icon = "\A3\ui_f\data\map\mapcontrol\fuelstation_CA.paa"; - size = 24; - importance = 1; - coefMin = 0.85; - coefMax = 1.0; - color[] = {1,1,1,1}; - }; - class hospital - { - icon = "\A3\ui_f\data\map\mapcontrol\hospital_CA.paa"; - size = 24; - importance = 1; - coefMin = 0.85; - coefMax = 1.0; - color[] = {1,1,1,1}; - }; - class church - { - icon = "\A3\ui_f\data\map\mapcontrol\church_CA.paa"; - size = 24; - importance = 1; - coefMin = 0.85; - coefMax = 1.0; - color[] = {1,1,1,1}; - }; - class lighthouse - { - icon = "\A3\ui_f\data\map\mapcontrol\lighthouse_CA.paa"; - size = 24; - importance = 1; - coefMin = 0.85; - coefMax = 1.0; - color[] = {1,1,1,1}; - }; - class power - { - icon = "\A3\ui_f\data\map\mapcontrol\power_CA.paa"; - size = 24; - importance = 1; - coefMin = 0.85; - coefMax = 1.0; - color[] = {1,1,1,1}; - }; - class powersolar - { - icon = "\A3\ui_f\data\map\mapcontrol\powersolar_CA.paa"; - size = 24; - importance = 1; - coefMin = 0.85; - coefMax = 1.0; - color[] = {1,1,1,1}; - }; - class powerwave - { - icon = "\A3\ui_f\data\map\mapcontrol\powerwave_CA.paa"; - size = 24; - importance = 1; - coefMin = 0.85; - coefMax = 1.0; - color[] = {1,1,1,1}; - }; - class powerwind - { - icon = "\A3\ui_f\data\map\mapcontrol\powerwind_CA.paa"; - size = 24; - importance = 1; - coefMin = 0.85; - coefMax = 1.0; - color[] = {1,1,1,1}; - }; - class quay - { - icon = "\A3\ui_f\data\map\mapcontrol\quay_CA.paa"; - size = 24; - importance = 1; - coefMin = 0.85; - coefMax = 1.0; - color[] = {1,1,1,1}; - }; - class shipwreck - { - icon = "\A3\ui_f\data\map\mapcontrol\shipwreck_CA.paa"; - size = 24; - importance = 1; - coefMin = 0.85; - coefMax = 1.0; - color[] = {1,1,1,1}; - }; - class transmitter - { - icon = "\A3\ui_f\data\map\mapcontrol\transmitter_CA.paa"; - size = 24; - importance = 1; - coefMin = 0.85; - coefMax = 1.0; - color[] = {1,1,1,1}; - }; - class watertower - { - icon = "\A3\ui_f\data\map\mapcontrol\watertower_CA.paa"; - size = 24; - importance = 1; - coefMin = 0.85; - coefMax = 1.0; - color[] = {1,1,1,1}; - }; - class Cross - { - icon = "\A3\ui_f\data\map\mapcontrol\Cross_CA.paa"; - size = 24; - importance = 1; - coefMin = 0.85; - coefMax = 1.0; - color[] = {0,0,0,1}; - }; - class Chapel - { - icon = "\A3\ui_f\data\map\mapcontrol\Chapel_CA.paa"; - size = 24; - importance = 1; - coefMin = 0.85; - coefMax = 1.0; - color[] = {0,0,0,1}; - }; - class Bunker - { - icon = "\A3\ui_f\data\map\mapcontrol\bunker_ca.paa"; - size = 14; - importance = "1.5 * 14 * 0.05"; - coefMin = 0.25; - coefMax = 4; - color[] = {0,0,0,1}; - }; - class Fortress - { - icon = "\A3\ui_f\data\map\mapcontrol\bunker_ca.paa"; - size = 16; - importance = "2 * 16 * 0.05"; - coefMin = 0.25; - coefMax = 4; - color[] = {0,0,0,1}; - }; - class Fountain - { - icon = "\A3\ui_f\data\map\mapcontrol\fountain_ca.paa"; - size = 11; - importance = "1 * 12 * 0.05"; - coefMin = 0.25; - coefMax = 4; - color[] = {0,0,0,1}; - }; - class Ruin - { - icon = "\A3\ui_f\data\map\mapcontrol\ruin_ca.paa"; - size = 16; - importance = "1.2 * 16 * 0.05"; - coefMin = 1; - coefMax = 4; - color[] = {0,0,0,1}; - }; - class Stack - { - icon = "\A3\ui_f\data\map\mapcontrol\stack_ca.paa"; - size = 20; - importance = "2 * 16 * 0.05"; - coefMin = 0.9; - coefMax = 4; - color[] = {0,0,0,1}; - }; - class Tourism - { - icon = "\A3\ui_f\data\map\mapcontrol\tourism_ca.paa"; - size = 16; - importance = "1 * 16 * 0.05"; - coefMin = 0.7; - coefMax = 4; - color[] = {0,0,0,1}; - }; - class ViewTower - { - icon = "\A3\ui_f\data\map\mapcontrol\viewtower_ca.paa"; - size = 16; - importance = "2.5 * 16 * 0.05"; - coefMin = 0.5; - coefMax = 4; - color[] = {0,0,0,1}; - }; -}; - -#endif \ No newline at end of file diff --git a/TO_MERGE/cse/f_states/functions.sqf b/TO_MERGE/cse/f_states/functions.sqf deleted file mode 100644 index 53534edef1..0000000000 --- a/TO_MERGE/cse/f_states/functions.sqf +++ /dev/null @@ -1,104 +0,0 @@ -/* - -*/ - - - cse_fnc_setCanSwitchAnim = { - private ["_unit","_to","_return"]; - _unit = _this select 0; - _to = _this select 1; - _return = false; - if (((typeName _to) == "BOOL")) then { - _unit setvariable ["cse_canSwitchAnimation",_to,true]; - _return = true; - }; - _return - }; - cse_fnc_getCanSwitchAnim = { - private ["_unit","_return"]; - _unit = _this select 0; - _return = _unit getvariable "cse_canSwitchAnimation"; - _return - }; - - cse_fnc_setCurrentMenu = { - _unit = _this select 0; - _to = _this select 1; - _return = false; - if ((typeName _to) == "STRING") then { - _unit setvariable ["cse_currentMenu",_to,true]; - _return = true; - }; - _return - }; - cse_fnc_getCurrentMenu = { - _unit = _this select 0; - _return = _unit getvariable ["cse_currentMenu",""]; - _return - }; - - cse_fnc_changeBlurialVisionState = { - private ["_unit","_to"]; - _unit = _this select 0; - _to = _this select 1; - _return = false; - if (((typeName _to) == "SCALAR")) then { - if (_to < -1) then { - _to = -1; - } else { - if (_to > 1) then { - _to = 1; - }; - }; - _unit setvariable ["cse_blurialVisualState", [_unit] call cse_fnc_getBlurialVisionState + _to,false]; - _return = true; - }; - _return - }; - cse_fnc_getBlurialVisionState = { - private ["_unit"]; - _unit = _this select 0; - _return = _unit getvariable ["cse_blurialVisualState",0]; - _return - }; - - // EVERYTHING BELOW HERE IS STILL WORK IN PROGRESS - - cse_fnc_setMovementState = { - private ["_unit","_to"]; - _unit = _this select 0; - _to = _this select 1; - _return = false; - if (((typeName _to) == "SCALAR")) then { - _unit setvariable ["cse_movementState",_to,false]; - _return = true; - }; - _return - }; - cse_fnc_getMovementState = { - private ["_unit"]; - _unit = _this select 0; - _return = _unit getvariable ["cse_movementState",0]; - _return - }; - - cse_fnc_setHearingState = { - private ["_unit","_to"]; - _unit = _this select 0; - _to = _this select 1; - _return = false; - if (((typeName _to) == "SCALAR")) then { - _unit setvariable ["cse_hearingState",_to,false]; - _return = true; - }; - _return - }; - cse_fnc_getHearingState = { - private ["_unit"]; - _unit = _this select 0; - _return = _unit getvariable ["cse_hearingState",0]; - _return - }; - - - diff --git a/TO_MERGE/cse/f_states/init.sqf b/TO_MERGE/cse/f_states/init.sqf deleted file mode 100644 index 881e02b95d..0000000000 --- a/TO_MERGE/cse/f_states/init.sqf +++ /dev/null @@ -1,37 +0,0 @@ -/* - -*/ - - call compileFinal preprocessFile "cse\cse_f_states\functions.sqf"; - - if (!isDedicated) then { - 45 cutRsc ["RscCSEScreenEffectsBlack","PLAIN"]; - }; - - if (isServer) then { - CSE_LOGIC_OBJECT = (createGroup sideLogic) createUnit ["logic", [1,1,1], [], 0, "FORM"]; - publicVariable "CSE_LOGIC_OBJECT"; - }; - - - ["cse_isDead",false,true,"cse"] call cse_fnc_defineVariable; - ["cse_isDeadPlayer", false, true, "cse"] call cse_fnc_defineVariable; - ["cse_state_arrested",false,true,"cse"] call cse_fnc_defineVariable; - ["cse_state_unconscious",false,true,"cse"] call cse_fnc_defineVariable; - ["CSE_ENABLE_REVIVE_SETDEAD_F",0,false,"cse"] call cse_fnc_defineVariable; - ["cse_carriedBy",objNull,false,"cse"] call cse_fnc_defineVariable; - - if (isnil "CSE_MARKED_FOR_GABAGE_COLLECTION") then { - CSE_MARKED_FOR_GABAGE_COLLECTION = []; - }; - - [] spawn { - waituntil { - { - deleteVehicle _x; - false; - }count CSE_MARKED_FOR_GABAGE_COLLECTION; - CSE_MARKED_FOR_GABAGE_COLLECTION = CSE_MARKED_FOR_GABAGE_COLLECTION - [objNull]; - false; - }; - }; \ No newline at end of file diff --git a/TO_MERGE/cse/f_states/loadPerson/functions/fn_cleanUpCopyOfBody_f.sqf b/TO_MERGE/cse/f_states/loadPerson/functions/fn_cleanUpCopyOfBody_f.sqf deleted file mode 100644 index ad9f200b8a..0000000000 --- a/TO_MERGE/cse/f_states/loadPerson/functions/fn_cleanUpCopyOfBody_f.sqf +++ /dev/null @@ -1,24 +0,0 @@ -/** - * fn_cleanUpCopyOfBody_f.sqf - * @Descr: Called from a custom eventhandler to ensure that any copies of bodies are cleaned up. - * @Author: Glowbal - * - * @Arguments: [unit OBJECT] - * @Return: BOOL - * @PublicAPI: true - */ - -private ["_unit", "_copy"]; -_unit = _this select 0; - -_copy = _unit getvariable "cse_copyOfBody_f"; -if (isnil "_copy") exitwith {false}; -[format["Cleaning up a copy of Body: %1 %2", _unit, _copy]] call cse_fnc_debug; -// lets clean it up -_unit setvariable ["cse_originalCopy_f", nil, true]; -_unit setvariable ["cse_copyOfBody_f", nil, true]; -if (!isNull _copy) then { - deleteVehicle _copy; -}; - -true; \ No newline at end of file diff --git a/TO_MERGE/cse/f_states/loadPerson/functions/fn_loadPersonLocal_f.sqf b/TO_MERGE/cse/f_states/loadPerson/functions/fn_loadPersonLocal_f.sqf deleted file mode 100644 index 7a6cee7202..0000000000 --- a/TO_MERGE/cse/f_states/loadPerson/functions/fn_loadPersonLocal_f.sqf +++ /dev/null @@ -1,37 +0,0 @@ -/** - * fn_loadPersonLocal_f.sqf - * @Descr: Load a person, local - * @Author: Glowbal - * - * @Arguments: [unit OBJECT, vehicle OBJECT, caller OBJECT] - * @Return: void - * @PublicAPI: false - */ - -private ["_unit","_vehicle","_caller","_handle","_loaded"]; -_unit = [_this, 0, ObjNull,[ObjNull]] call BIS_fnc_Param; -_vehicle = [_this, 1, ObjNull,[ObjNull]] call BIS_fnc_Param; -_caller = [_this, 2, ObjNull,[ObjNull]] call BIS_fnc_Param; - -if (!alive _unit) then { - _unit = [_unit,_caller] call cse_fnc_makeCopyOfBody_F; -}; - -_unit moveInCargo _vehicle; -_loaded = _vehicle getvariable ["cse_loaded_persons_F",[]]; -_loaded pushback _unit; -_vehicle setvariable ["cse_loaded_persons_F",_loaded,true]; -if (!([_unit] call cse_fnc_isAwake)) then { - _handle = [_unit,_vehicle] spawn { - private ["_unit","_vehicle"]; - _unit = _this select 0; - _vehicle = _this select 1; - waituntil {vehicle _unit == _vehicle}; - sleep 0.5; - [_unit,([_unit] call cse_fnc_getDeathAnim)] call cse_fnc_broadcastAnim; - }; -} else { - if ([_unit] call cse_fnc_isArrested) then { - - }; -}; \ No newline at end of file diff --git a/TO_MERGE/cse/f_states/loadPerson/functions/fn_loadPerson_f.sqf b/TO_MERGE/cse/f_states/loadPerson/functions/fn_loadPerson_f.sqf deleted file mode 100644 index 5181d74372..0000000000 --- a/TO_MERGE/cse/f_states/loadPerson/functions/fn_loadPerson_f.sqf +++ /dev/null @@ -1,40 +0,0 @@ -/** - * fn_loadPerson_f.sqf - * @Descr: Loads a specified unit into any nearby vehicle - * @Author: Glowbal - * - * @Arguments: [caller OBJECT, unitToBeLoaded OBJECT] - * @Return: OBJECT Returns the vehicle that the unitToBeloaded has been loaded in. Returns ObjNull if function failed - * @PublicAPI: true - */ - -#define GROUP_SWITCH_ID "cse_fnc_loadPerson_F" - -private ["_caller", "_unit","_vehicle", "_loadcar", "_loadhelicopter", "_loadtank"]; -_caller = [_this, 0, ObjNull,[ObjNull]] call BIS_fnc_Param; -_unit = [_this, 1, ObjNull,[ObjNull]] call BIS_fnc_Param; -_vehicle = ObjNull; - -if (!([_caller] call cse_fnc_canInteract) || {_caller == _unit}) exitwith {_vehicle}; - -_loadcar = nearestObject [_unit, "car"]; -if (_unit distance _loadcar <= 10) then { - _vehicle = _loadcar; -} else { - _loadhelicopter = nearestObject [_unit, "air"]; - if (_unit distance _loadhelicopter <= 10) then { - _vehicle = _loadhelicopter; - } else { - _loadtank = nearestObject [_unit, "tank"]; - if (_unit distance _loadtank <= 10) then { - _vehicle = _loadtank; - }; - }; -}; -if (!isNull _vehicle) then { - [_unit, true, GROUP_SWITCH_ID, side group _caller] call cse_fnc_switchToGroupSide_f; - [_caller,objNull] call cse_fnc_carryObj; - [_unit,objNull] call cse_fnc_carryObj; - [[_unit, _vehicle,_caller], "cse_fnc_loadPersonLocal_F", _unit, false] spawn BIS_fnc_MP; -}; -_vehicle \ No newline at end of file diff --git a/TO_MERGE/cse/f_states/loadPerson/functions/fn_makeCopyOfBodyLocal_f.sqf b/TO_MERGE/cse/f_states/loadPerson/functions/fn_makeCopyOfBodyLocal_f.sqf deleted file mode 100644 index 8e00653978..0000000000 --- a/TO_MERGE/cse/f_states/loadPerson/functions/fn_makeCopyOfBodyLocal_f.sqf +++ /dev/null @@ -1,62 +0,0 @@ -/** - * fn_makeCopyOfBodyLocal_f.sqf - * @Descr: Makes a copy of a dead body. For handling dead bodies for actions such as load and carry. - * @Author: Glowbal - * - * @Arguments: [oldBody OBJECT, newUnit OBJECT] - * @Return: void - * @PublicAPI: false - */ - -private ["_oldBody","_newUnit","_class","_group","_position","_side","_allVariables"]; -_oldBody = _this select 0; -_newUnit = _this select 1; - - if (alive _oldBody) exitwith {}; // we only want to do this for dead bodies - _name = _oldBody getvariable ["cse_name","unknown"]; - _allVariables = [_oldBody] call cse_fnc_getAllSetVariables; - // [NAME (STRING), TYPENAME (STRING), VALUE (ANY), DEFAULT GLOBAL (BOOLEAN)] - { - [_newUnit,_x select 0, _x select 2] call cse_fnc_setVariable; - }foreach _allVariables; - _newUnit setVariable ["cse_name",_name,true]; - - _newUnit disableAI "TARGET"; - _newUnit disableAI "AUTOTARGET"; - _newUnit disableAI "MOVE"; - _newUnit disableAI "ANIM"; - _newUnit disableAI "FSM"; - _newUnit setvariable ["cse_isDead",true,true]; - - removeallweapons _newUnit; - removeallassigneditems _newUnit; - removeUniform _newUnit; - removeHeadgear _newUnit; - removeBackpack _newUnit; - removeVest _newUnit; - - - _newUnit addHeadgear (headgear _oldBody); - _newUnit addBackpack (backpack _oldBody); - clearItemCargoGlobal (backpackContainer _newUnit); - clearMagazineCargoGlobal (backpackContainer _newUnit); - clearWeaponCargoGlobal (backpackContainer _newUnit); - - _newUnit addVest (vest _oldBody); - clearItemCargoGlobal (backpackContainer _newUnit); - clearMagazineCargoGlobal (backpackContainer _newUnit); - clearWeaponCargoGlobal (backpackContainer _newUnit); - - _newUnit addUniform (uniform _oldBody); - clearItemCargoGlobal (backpackContainer _newUnit); - clearMagazineCargoGlobal (backpackContainer _newUnit); - clearWeaponCargoGlobal (backpackContainer _newUnit); - - {_newUnit addMagazine _x} count (magazines _oldBody); - {_newUnit addWeapon _x} count (weapons _oldBody); - {_newUnit addItem _x} count (items _oldBody); - - _newUnit selectWeapon (primaryWeapon _newUnit); - //[_newUnit,([_newUnit] call cse_fnc_getDeathAnim)] call cse_fnc_broadcastAnim; - - deleteVehicle _oldBody; \ No newline at end of file diff --git a/TO_MERGE/cse/f_states/loadPerson/functions/fn_makeCopyOfBody_f.sqf b/TO_MERGE/cse/f_states/loadPerson/functions/fn_makeCopyOfBody_f.sqf deleted file mode 100644 index 77b3147a2d..0000000000 --- a/TO_MERGE/cse/f_states/loadPerson/functions/fn_makeCopyOfBody_f.sqf +++ /dev/null @@ -1,88 +0,0 @@ -/** - * fn_makeCopyOfBody_f.sqf - * @Descr: Makes a copy of a dead body. For handling dead bodies for actions such as load and carry. - * @Author: Glowbal - * - * @Arguments: [oldBody OBJECT, caller OBJECT] - * @Return: newUnit OBJECT Returns the copy of the unit. If no copy could be made, returns the oldBody - * @PublicAPI: false - */ - -private ["_oldBody","_newUnit","_class","_group","_position","_side","_allVariables"]; -_oldBody = _this select 0; -_caller = _this select 1; - - if (alive _oldBody) exitwith {_oldBody}; // we only want to do this for dead bodies - _name = _oldBody getvariable ["cse_name","unknown"]; - _class = typeof _oldBody; - _side = side _caller; - _group = createGroup _side; - _position = getPos _oldBody; - - _newUnit = _group createUnit [typeof _oldBody, _position, [], 0, "NONE"]; - - _allVariables = [_oldBody] call cse_fnc_getAllSetVariables; - // [NAME (STRING), TYPENAME (STRING), VALUE (ANY), DEFAULT GLOBAL (BOOLEAN)] - { - [_newUnit,_x select 0, _x select 2] call cse_fnc_setVariable; - }foreach _allVariables; - _newUnit setVariable ["cse_name",_name,true]; - - _newUnit disableAI "TARGET"; - _newUnit disableAI "AUTOTARGET"; - _newUnit disableAI "MOVE"; - _newUnit disableAI "ANIM"; - _newUnit disableAI "FSM"; - _newUnit setvariable ["cse_isDead",true,true]; - - removeallweapons _newUnit; - removeallassigneditems _newUnit; - removeUniform _newUnit; - removeHeadgear _newUnit; - removeBackpack _newUnit; - removeVest _newUnit; - - - _newUnit addHeadgear (headgear _oldBody); - _newUnit addBackpack (backpack _oldBody); - clearItemCargoGlobal (backpackContainer _newUnit); - clearMagazineCargoGlobal (backpackContainer _newUnit); - clearWeaponCargoGlobal (backpackContainer _newUnit); - - _newUnit addVest (vest _oldBody); - clearItemCargoGlobal (backpackContainer _newUnit); - clearMagazineCargoGlobal (backpackContainer _newUnit); - clearWeaponCargoGlobal (backpackContainer _newUnit); - - _newUnit addUniform (uniform _oldBody); - clearItemCargoGlobal (backpackContainer _newUnit); - clearMagazineCargoGlobal (backpackContainer _newUnit); - clearWeaponCargoGlobal (backpackContainer _newUnit); - - {_newUnit addMagazine _x} count (magazines _oldBody); - {_newUnit addWeapon _x} count (weapons _oldBody); - {_newUnit addItem _x} count (items _oldBody); - - _newUnit selectWeapon (primaryWeapon _newUnit); - //_newUnit playMoveNow ([_newUnit] call cse_fnc_getDeathAnim); - - deleteVehicle _oldBody; - - // try and clean it up entirely. - if (!isNull _oldBody) then { - - if (isMultiplayer) then { - _oldBody hideObjectGlobal true; - } else { - _oldBody hideObject true; - }; - _oldBody setvariable ["cse_originalCopy_f", true]; - _newUnit setvariable ["cse_copyOfBody_f", _oldBody]; - if (isnil "CSE_MARKED_FOR_GABAGE_COLLECTION") then { - CSE_MARKED_FOR_GABAGE_COLLECTION = []; - }; - CSE_MARKED_FOR_GABAGE_COLLECTION pushback _oldBody; - }; - - _newUnit setDamage 0.9; -_newUnit \ No newline at end of file diff --git a/TO_MERGE/cse/f_states/loadPerson/functions/fn_unloadPerson_f.sqf b/TO_MERGE/cse/f_states/loadPerson/functions/fn_unloadPerson_f.sqf deleted file mode 100644 index bbfcf52b3f..0000000000 --- a/TO_MERGE/cse/f_states/loadPerson/functions/fn_unloadPerson_f.sqf +++ /dev/null @@ -1,57 +0,0 @@ -/** - * fn_unloadPerson_f.sqf - * @Descr: Unload a person from a vehicle - * @Author: Glowbal - * - * @Arguments: [caller OBJECT, unit OBJECT] - * @Return: BOOL Returns true if succesfully unloaded person - * @PublicAPI: true - */ - -#define GROUP_SWITCH_ID "cse_fnc_loadPerson_F" - -private ["_caller", "_unit","_vehicle", "_loaded"]; -_caller = [_this, 0, ObjNull,[ObjNull]] call BIS_fnc_Param; -_unit = [_this, 1, ObjNull,[ObjNull]] call BIS_fnc_Param; -_vehicle = vehicle _unit; - -if (_vehicle == _unit) exitwith {false;}; -if !(speed _vehicle <1 && (((getpos _vehicle) select 2) < 2)) exitwith {false;}; -if (!([_caller] call cse_fnc_isAwake)) exitwith{false;}; - -moveOut _unit; -unassignVehicle _unit; -if (!alive _unit) then { - _unit action ["Eject", vehicle _unit]; -}; - -[_unit, false, GROUP_SWITCH_ID, side group _caller] call cse_fnc_switchToGroupSide_f; - -_loaded = _vehicle getvariable ["cse_loaded_persons_F",[]]; -_loaded = _loaded - [_unit]; -_vehicle setvariable ["cse_loaded_persons_F",_loaded,true]; - -if (!([_unit] call cse_fnc_isAwake)) then { - _handle = [_unit,_vehicle] spawn { - private ["_unit","_vehicle"]; - _unit = _this select 0; - _vehicle = _this select 1; - waituntil {vehicle _unit != _vehicle}; - [_unit,([_unit] call cse_fnc_getDeathAnim)] call cse_fnc_broadcastAnim; - [format["Unit should move into death anim: %1", _unit]] call cse_fnc_Debug; - }; -} else { - if ([_unit] call cse_fnc_isArrested) then { - _handle = [_unit,_vehicle] spawn { - _unit = _this select 0; - _vehicle = _this select 1; - waituntil {vehicle _unit != _vehicle}; - [_unit,"UnaErcPoslechVelitele2",true] call cse_fnc_broadcastAnim; - [format["Unit should move into arrested anim: %1", _unit]] call cse_fnc_Debug; - }; - } else { - [format["Unit should move into normal anim: %1", _unit]] call cse_fnc_Debug; - }; -}; - -true; \ No newline at end of file diff --git a/TO_MERGE/cse/f_states/movement/functions/fn_limitMovementSpeed.sqf b/TO_MERGE/cse/f_states/movement/functions/fn_limitMovementSpeed.sqf deleted file mode 100644 index 9a807abfd9..0000000000 --- a/TO_MERGE/cse/f_states/movement/functions/fn_limitMovementSpeed.sqf +++ /dev/null @@ -1,34 +0,0 @@ -/** - * fn_limitMovementSpeed.sqf - * @Descr: Limits the movement speed of a unit - * @Author: Glowbal - * - * @Arguments: [unit OBJECT, fallDown BOOL (Optional)] - * @Return: void - * @PublicAPI: true - */ - -_this spawn { - private ["_unit","_carriedObj"]; - _unit = _this select 0; - _fallDown = false; - if (count _this > 1) then { - _fallDown = _this select 1; - }; - _carriedObj = [_unit] call cse_fnc_getCarriedObj; - while {sleep 1;_carriedObj = [_unit] call cse_fnc_getCarriedObj; ((!isNull _carriedObj) && (alive _unit))} do { - if (speed _unit > 12 && vehicle _unit == _unit) then { - [format["Unit ran to fast (Speed: %1, is now dropping carrying obj",speed _unit],2] call cse_fnc_debug; - if (_fallDown) then { - _unit playMove "amovppnemstpsraswrfldnon"; - }; - - if (_carriedObj isKindOf "Man") then { - hint "You can not move this fast while transporting this person."; - } else { - hint "You can not move this fast while carrying this object"; - }; - [_unit,ObjNull] call cse_fnc_carryObj; - }; - }; -}; diff --git a/TO_MERGE/cse/f_states/movement/functions/fn_limitSpeed.sqf b/TO_MERGE/cse/f_states/movement/functions/fn_limitSpeed.sqf deleted file mode 100644 index 24af4ff1af..0000000000 --- a/TO_MERGE/cse/f_states/movement/functions/fn_limitSpeed.sqf +++ /dev/null @@ -1,38 +0,0 @@ -/** - * fn_limitSpeed.sqf - * @Descr: Limits the speed of an object - * @Author: Glowbal - * - * @Arguments: [vehicle OBJECT, maxSpeed NUMBER] - * @Return: void - * @PublicAPI: true - */ - -_this spawn { - private ["_vehicle", "_maxSpeed", "_velocity"]; - - _vehicle = _this select 0; - _maxSpeed = _this select 1; - if ((_vehicle getvariable ["cse_f_limitSpeed",false])) then { - _vehicle setvariable ["cse_f_limitSpeed",nil,true]; - }; - - if (_maxSpeed < 0) exitwith {}; - _vehicle setvariable ["cse_f_limitSpeed",true,true]; - - waitUntil { - _speed = speed _vehicle; - if (_speed > _maxSpeed) then { - _velocity = velocity _vehicle; - _x = _velocity select 0; - _y = _velocity select 1; - _z = _velocity select 2; - - _diff = _speed - _maxSpeed; - _percentage = (_speed / 100) * _diff; - _newVelocity = [_x - (_x * _percentage), _y - (_y * _percentage), _z - (_z * _percentage)]; - _vehicle setVelocity _newVelocity; - }; - !(_vehicle getvariable ["cse_f_limitSpeed",false]) - }; -}; \ No newline at end of file diff --git a/TO_MERGE/cse/f_states/stringtable.xml b/TO_MERGE/cse/f_states/stringtable.xml deleted file mode 100644 index db81cc6d02..0000000000 --- a/TO_MERGE/cse/f_states/stringtable.xml +++ /dev/null @@ -1,7 +0,0 @@ - - - - - - - \ No newline at end of file diff --git a/TO_MERGE/cse/f_states/unconscious/functions/fn_canGoUnconsciousState.sqf b/TO_MERGE/cse/f_states/unconscious/functions/fn_canGoUnconsciousState.sqf deleted file mode 100644 index d716df49de..0000000000 --- a/TO_MERGE/cse/f_states/unconscious/functions/fn_canGoUnconsciousState.sqf +++ /dev/null @@ -1,14 +0,0 @@ -/** - * fn_canGoUnconsciousState.sqf - * @Descr: Checks if an object can move into unconscious state - * @Author: Glowbal - * - * @Arguments: [unit OBJECT] - * @Return: BOOL true if object can move into unconscious state - * @PublicAPI: true - */ - -private ["_unit"]; -_unit = _this select 0; - -(!(isNull _unit) && {(_unit isKindOf "CaManBase") && ([_unit] call cse_fnc_isAwake)}) \ No newline at end of file diff --git a/TO_MERGE/cse/f_states/unconscious/functions/fn_getUnconsciousCondition.sqf b/TO_MERGE/cse/f_states/unconscious/functions/fn_getUnconsciousCondition.sqf deleted file mode 100644 index 6e3018baba..0000000000 --- a/TO_MERGE/cse/f_states/unconscious/functions/fn_getUnconsciousCondition.sqf +++ /dev/null @@ -1,32 +0,0 @@ -/** - * fn_getUnconsciousCondition.sqf - * @Descr: get whatever or not a unit should be or stay unconscious - * @Author: Glowbal - * - * @Arguments: [unit OBJECT] - * @Return: BOOL True when the unit should be unconscious - * @PublicAPI: true - */ - -private ["_unit","_return"]; -_unit = _this select 0; - - -if (isnil "CSE_UNCONSCIOUS_CONDITIONS_F") then { - CSE_UNCONSCIOUS_CONDITIONS_F = []; -}; - -_return = false; -{ - - - if (typeName _x == typeName {}) then { - if (([_unit] call _x)) then { - _return = true; - }; - - }; - - if (_return) exitwith{}; -}foreach CSE_UNCONSCIOUS_CONDITIONS_F; -_return \ No newline at end of file diff --git a/TO_MERGE/cse/f_states/unconscious/functions/fn_isUnconscious.sqf b/TO_MERGE/cse/f_states/unconscious/functions/fn_isUnconscious.sqf deleted file mode 100644 index 2d410d7ba5..0000000000 --- a/TO_MERGE/cse/f_states/unconscious/functions/fn_isUnconscious.sqf +++ /dev/null @@ -1,11 +0,0 @@ -/** - * fn_isUnconscious.sqf - * @Descr: Checks whatever given object is in the unconscious state - * @Author: Glowbal - * - * @Arguments: [unit OBJECT] - * @Return: BOOL True when object is in unconscious state - * @PublicAPI: true - */ - - ((_this select 0) getvariable ["cse_state_unconscious",false]); \ No newline at end of file diff --git a/TO_MERGE/cse/f_states/unconscious/functions/fn_moveToTempGroup.sqf b/TO_MERGE/cse/f_states/unconscious/functions/fn_moveToTempGroup.sqf deleted file mode 100644 index 48df97777e..0000000000 --- a/TO_MERGE/cse/f_states/unconscious/functions/fn_moveToTempGroup.sqf +++ /dev/null @@ -1,30 +0,0 @@ -/** - * fn_moveToTempGroup_f.sqf - * Moves a unit into a temporarly group and stores its original group to allow rejoining. - * @Author: Glowbal - * - * @Arguments: [unit OBJECT, moveToTempGroup BOOL] - * @Return: void - * @PublicAPI: false - */ - -private ["_unit","_moveTo","_previousGroup","_newGroup", "_currentGroup", "_switchToGroup"]; -_unit = [_this, 0,ObjNull,[ObjNull]] call BIS_fnc_Param; -_moveTo = [_this, 1,false,[false]] call BIS_fnc_Param; - -if (_moveTo) then { - _previousGroup = group _unit; - _newGroup = createGroup (side _previousGroup); - [_unit] joinSilent _newGroup; - _unit setvariable ["cse_previous_group_f",_previousGroup]; -} else { - _previousGroup = _unit getvariable "cse_previous_group_f"; - if (!isnil "_previousGroup") then { - _currentGroup = group _unit; - _unit setvariable ["cse_previous_group_f",nil]; - [_unit] joinSilent _previousGroup; - if (count units _currentGroup == 0) then { - deleteGroup _currentGroup; - }; - }; -}; \ No newline at end of file diff --git a/TO_MERGE/cse/f_states/unconscious/functions/fn_registerUnconsciousCondition.sqf b/TO_MERGE/cse/f_states/unconscious/functions/fn_registerUnconsciousCondition.sqf deleted file mode 100644 index 25742589ba..0000000000 --- a/TO_MERGE/cse/f_states/unconscious/functions/fn_registerUnconsciousCondition.sqf +++ /dev/null @@ -1,22 +0,0 @@ -/** - * fn_registerUnconsciousCondition.sqf - * @Descr: Register new condition for the unconscious state. Conditions are not actively checked for units unless unit is in unconscious state. - * @Author: Glowbal - * - * @Arguments: [code CODE] - * @Return: void - * @PublicAPI: true - */ - - -if (isnil "CSE_UNCONSCIOUS_CONDITIONS_F") then { - CSE_UNCONSCIOUS_CONDITIONS_F = []; -}; -if (typeName _this == typeName []) then { - { - if (typeName _x == typeName {}) then { - CSE_UNCONSCIOUS_CONDITIONS_F pushback _x; - }; - }foreach _this; -} else { -}; \ No newline at end of file diff --git a/TO_MERGE/cse/f_states/unconscious/functions/fn_setCaptiveSwitch.sqf b/TO_MERGE/cse/f_states/unconscious/functions/fn_setCaptiveSwitch.sqf deleted file mode 100644 index e99f6f18c3..0000000000 --- a/TO_MERGE/cse/f_states/unconscious/functions/fn_setCaptiveSwitch.sqf +++ /dev/null @@ -1,38 +0,0 @@ -/** - * fn_setCaptiveSwitch.sqf - * @Descr: Register a unit as captive for the unconscious state - * @Author: Glowbal - * - * @Arguments: [unit OBJECT, setCaptive BOOL] - * @Return: BOOL True if unit is put as set captive, otherwise false - * @PublicAPI: false - */ - -private ["_unit", "_captiveSwitch", "_setCaptive"]; -_unit = [_this, 0, objNull, [objNull]] call BIS_fnc_Param; -_setCaptive = [_this, 1, false, [false]] call BIS_fnc_Param; - - -_captiveSwitch = true; -if (_setCaptive) then { - if (captive _unit) then { - _captiveSwitch = false; - } else { - if (player == _unit) then { - missionNamespace setvariable["cse_unconscious_non_captive_f",true]; - }; - _unit setCaptive true; - [format["USED SETCAPTIVE",_unit]] call cse_fnc_debug; - }; -} else { - if (alive _unit) then { - _unit setCaptive false; - if (!isnil "cse_unconscious_non_captive_f") then { - missionNamespace setvariable["cse_unconscious_non_captive_f",nil]; - }; - } else { - _unit setCaptive false; - }; -}; - -_captiveSwitch \ No newline at end of file diff --git a/TO_MERGE/cse/f_states/unconscious/functions/fn_setUnconsciousState.sqf b/TO_MERGE/cse/f_states/unconscious/functions/fn_setUnconsciousState.sqf deleted file mode 100644 index 8ae7c75172..0000000000 --- a/TO_MERGE/cse/f_states/unconscious/functions/fn_setUnconsciousState.sqf +++ /dev/null @@ -1,95 +0,0 @@ -/** - * fn_setUnconsciousState.sqf - * @Descr: Sets a unit in the unconscious state - * @Author: Glowbal - * - * @Arguments: [unit OBJECT] - * @Return: void - * @PublicAPI: true - */ - - -private ["_unit", "_animState", "_dAnim"]; -_unit = _this select 0; - -_dAnim = ([_unit] call cse_fnc_getDeathAnim); -if !([_unit] call cse_fnc_canGoUnconsciousState) exitwith{}; -if (!local _unit) exitwith { - [[_unit], "cse_fnc_setUnconsciousState", _unit, false] spawn BIS_fnc_MP; -}; - -// get rid of the object we are carrying, before we go unconscious. -[_unit, ObjNull, [0,0,0]] call cse_fnc_carryObj; - -_unit setvariable ["cse_state_unconscious",true,true]; -[_unit] call cse_fnc_setWeaponsCorrectUnconscious; - -_animState = animationState _unit; - -_originalPos = unitPos _unit; -if (isPlayer _unit) then { - [] call cse_fnc_closeAllDialogs_f; - [true] call cse_fnc_effectBlackOut; - ["unconscious", true] call cse_fnc_disableUserInput_f; - [false] call cse_fnc_setVolume_f; - - /* Disable this, because the disableUserInput function call above - users already cannot leave vehicles because of that function. */ - //[_unit] spawn cse_fnc_lockVehicleOfUnitUntil; -} else { - _unit setUnitPos "DOWN"; - [_unit, true] call cse_fnc_disableAI_F; -}; -[_unit, true, "cse_unconsciousState", side group _unit] call cse_fnc_switchToGroupSide_f; - -_captiveSwitch = [_unit, true] call cse_fnc_setCaptiveSwitch; -_unit setUnconscious true; -[_unit, _dAnim] call cse_fnc_localAnim; - -[_unit,_animState, _captiveSwitch, _originalPos] spawn { - private ["_unit", "_vehicleOfUnit","_lockSwitch","_minWaitingTime", "_oldAnimation", "_captiveSwitch"]; - _unit = _this select 0; - _oldAnimation = _this select 1; - _captiveSwitch = _this select 2; - _originalPos = _this select 3; - - _minWaitingTime = (round(random(10)+5)); - _counter = time; - while {(((time - _counter) < _minWaitingTime) && {alive _unit})} do { - if (vehicle _unit == _unit && {animationState _unit != "deadState" && animationState _unit != "unconscious"} && {(alive _unit)} && {(isNull ([_unit] call cse_fnc_getCarriedBy))}) then { - [_unit,([_unit] call cse_fnc_getDeathAnim)] call cse_fnc_broadcastAnim; - }; - sleep 0.1; - }; - waituntil{(!([_unit] call cse_fnc_getUnconsciousCondition) || !alive _unit)}; - [format["setUnconsciousState false - %1",_unit]] call cse_fnc_debug; - sleep 0.5; - if (_captiveSwitch) then { - [_unit, false] call cse_fnc_setCaptiveSwitch; - }; - _unit setUnconscious false; - [_unit, false, "cse_unconsciousState", side group _unit] call cse_fnc_switchToGroupSide_f; - - if (isPlayer _unit) then { - [false] call cse_fnc_effectBlackOut; - [true] call cse_fnc_setVolume_f; - ["unconscious", false] call cse_fnc_disableUserInput_f; - } else { - [_unit, false] call cse_fnc_disableAI_F; - _unit setUnitPos _originalPos; // This is not position but stance (DOWN, MIDDLE, UP) - }; - - waituntil {!([_unit] call cse_fnc_beingCarried)}; - if (alive _unit) then { - if (vehicle _unit == _unit) then { - [format["Resetting unit animiation to normal %1",_unit]] call cse_fnc_debug; - //[_unit,"",false] call cse_fnc_broadcastAnim; - [_unit,"amovppnemstpsnonwnondnon",false] call cse_fnc_broadcastAnim; - } else { - [format["Resetting unit animiation to oldAnimation %1 - %2",_unit, _oldAnimation]] call cse_fnc_debug; - [_unit, _oldAnimation,false] call cse_fnc_broadcastAnim; - }; - _unit setvariable ["cse_state_unconscious", false, true]; - }; - [[_unit, false],"setUnconsciousState"] call cse_fnc_customEventHandler_F; -}; -[[_unit, true],"setUnconsciousState"] call cse_fnc_customEventHandler_F; \ No newline at end of file diff --git a/TO_MERGE/cse/f_states/unconscious/functions/fn_setWeaponsCorrectUnconscious.sqf b/TO_MERGE/cse/f_states/unconscious/functions/fn_setWeaponsCorrectUnconscious.sqf deleted file mode 100644 index 6853156aeb..0000000000 --- a/TO_MERGE/cse/f_states/unconscious/functions/fn_setWeaponsCorrectUnconscious.sqf +++ /dev/null @@ -1,36 +0,0 @@ -/** - * fn_setWeaponsCorrectUnconscious.sqf - * @Descr: Ensures the weapon of a unit is selected correctly for the unconscious state. Prefents wierd animation behaviour - * @Author: Glowbal - * - * @Arguments: [unit OBJECT] - * @Return: void - * @PublicAPI: false - */ - -private ["_unit"]; -_unit = _this select 0; - -if ((vehicle _unit) isKindOf "StaticWeapon") then { - moveOut _unit; - unassignVehicle _unit; - //unassignVehicle _unit; - //_unit action ["eject", vehicle _unit]; -}; -if (vehicle _unit == _unit) then { - if (currentWeapon _unit == secondaryWeapon _unit) then { - reload _unit; - }; -}; - -if (animationState _unit in ["ladderriflestatic","laddercivilstatic"]) then { - _unit action ["ladderOff", (nearestBuilding _unit)]; -}; - -if (vehicle _unit == _unit) then { - if (currentWeapon _unit == secondaryWeapon _unit) then { - _unit selectWeapon (primaryWeapon _unit); - _unit switchMove ""; - _unit playmoveNow ""; - }; -}; diff --git a/TO_MERGE/cse/f_states/visual/effects.hpp b/TO_MERGE/cse/f_states/visual/effects.hpp deleted file mode 100644 index 17301fe662..0000000000 --- a/TO_MERGE/cse/f_states/visual/effects.hpp +++ /dev/null @@ -1,312 +0,0 @@ -class RscTitles{ - class RscCSEScreenEffectsBlack { - duration = 10e10; - idd = 1111; - movingenable = 0; - onLoad = "uiNamespace setVariable ['CSEFadingBlackUI', _this select 0];"; - - class controlsBackground { - class cse_BlackScreen: cse_gui_backgroundBase { - text = "cse\cse_f_states\data\black_out1.paa"; - colorText[] = {0.0, 0.0, 0.0, 0.0}; - idc = 11112; - x = safezoneX; - y = safezoneY; - w = safezoneW; - h = safezoneH; - }; - }; - }; - class RscCSEScreenEffectsPain { - duration = 1; - idd = 1111; - movingenable = 0; - onLoad = "uiNamespace setVariable ['CSEPainScreen', _this select 0];"; - - class controlsBackground { - class cse_PainScreen: cse_gui_backgroundBase { - text = "cse\cse_f_states\data\pain_screen3.paa"; - colorText[] = {1, 1, 1, 0.5}; - idc = 11114; - x = safezoneX; - y = safezoneY; - w = safezoneW; - h = safezoneH; - }; - }; - }; - class RscCSEScreenEffectsBleeding { - duration = 1; - idd = 1111; - movingenable = 0; - onLoad = "uiNamespace setVariable ['CSEBleedingScreen', _this select 0];"; - - class controlsBackground { - class cse_BleedingScreen: cse_gui_backgroundBase { - text = "cse\cse_f_states\data\cse_bleedingScreen_v5.paa"; - colorText[] = {0.9, 0.2, 0.2, 0.6}; - idc = 11113; - x = safezoneX; - y = safezoneY; - w = safezoneW; - h = safezoneH; - }; - }; - }; - class RscCSEScreenEffectsHit{ - duration = 1.1; - idd = 1111; - movingenable = 0; - onLoad = "uiNamespace setVariable ['CSEHitScreen', _this select 0];"; - - class controlsBackground { - class cse_EffectHit: cse_gui_backgroundBase { - text = "cse\cse_f_states\data\hit_screen1.paa"; - colorText[] = {0.7, 0.2, 0.2, 0.4}; - idc = 11113; - x = safezoneX; - y = safezoneY; - w = safezoneW; - h = safezoneH; - }; - }; - }; - class RscCSEScreenEffectsHitPain{ - duration = 1.1; - idd = 1111; - movingenable = 0; - onLoad = "uiNamespace setVariable ['CSEHitPainScreen', _this select 0];"; - - class controlsBackground { - class cse_EffectHitNew: cse_gui_backgroundBase { - text = "cse\cse_f_states\data\hit_screen1.paa"; - colorText[] = {0.9, 0.9, 0.9, 0.7}; - idc = 11113; - x = safezoneX; - y = safezoneY; - w = safezoneW; - h = safezoneH; - }; - }; - }; -class RscCSEScreenEffectsBlur { - duration = 2; - idd = 1111; - movingenable = 0; - onLoad = "uiNamespace setVariable ['CSEBlurScreen', _this select 0];"; - - class controlsBackground { - class cse_BlurScreen: cse_gui_backgroundBase { - text = "cse\cse_f_states\data\cse_blurryScreen.paa"; - colorText[] = {0.5, 0.5, 0.5, 0.2}; - idc = 11114; - x = safezoneX; - y = safezoneY; - w = safezoneW; - h = safezoneH; - }; - }; - }; - class cse_progressBar_Sample { - idd = -1; - onLoad = "uiNamespace setVariable ['cse_progressBar_Sample', _this select 0]; "; - fadein = 0; - fadeout = 0; - duration = 10e10; - class Controls { - - class background: cse_gui_backgroundBase { - idc = -1; - colorBackground[] = {0,0,0,1}; - colorText[] = {1, 1, 1, 1}; - x = "1 * (((safezoneW / safezoneH) min 1.2) / 40) + (safezoneX + (safezoneW - ((safezoneW / safezoneH) min 1.2))/2)"; - y = "29 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + (safezoneH - (((safezoneW / safezoneH) min 1.2) / 1.2))/2)"; - w = "38 * (((safezoneW / safezoneH) min 1.2) / 40)"; - h = "0.4 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25)"; - text = "#(argb,8,8,3)color(0,0,0,0.4)"; - }; - - class Progress: cse_gui_RscProgress { - idc = 6; - x = "1 * (((safezoneW / safezoneH) min 1.2) / 40) + (safezoneX + (safezoneW - ((safezoneW / safezoneH) min 1.2))/2)"; - y = "29 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + (safezoneH - (((safezoneW / safezoneH) min 1.2) / 1.2))/2)"; - w = "38 * (((safezoneW / safezoneH) min 1.2) / 40)"; - h = "0.4 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25)"; - colorFrame[] = {0,0,0,0}; - colorBar[] = {0.27,0.5,0.31,0.6}; - // colorBar[] = {"(profilenamespace getvariable ['GUI_BCG_RGB_R',0.69])","(profilenamespace getvariable ['GUI_BCG_RGB_G',0.75])","(profilenamespace getvariable ['GUI_BCG_RGB_B',0.5])", "(profilenamespace getvariable ['GUI_BCG_RGB_A',0.9])"}; - texture = "#(argb,8,8,3)color(1,1,1,0.7)"; - }; - }; - }; - - - class CSE_DISPLAY_MESSAGE { - duration = 7; - idd = 86411; - movingenable = 0; - onLoad = "uiNamespace setVariable ['CSE_DISPLAY_MESSAGE', _this select 0];"; - fadein = 0; - class controlsBackground { - class header: cse_gui_staticBase { - idc = 1; - type = CT_STATIC; - x = "safezoneX + (safezoneW / 10)"; - y = "safezoneY + (30 * (safeZoneH / 40))"; - w = "(safeZoneW / 10)"; - h = "(safeZoneH / 40)"; - style = ST_LEFT; - font = FontCSE; - SizeEx = "(((((safezoneW / safezoneH) min 1.2) / 1.2) / 25) * 1)"; - colorText[] = {0.85, 0.85, 0.85, 1.0}; - colorBackground[] = {0, 0, 0, 0.9}; - text = ""; - }; - class text: header { - idc = 2; - y = "safezoneY + (31 * (safeZoneH / 40))"; - w = "(safeZoneW / 10) * 1.3"; - colorText[] = {0.0, 0.0, 0.0, 1.0}; - colorBackground[] = {1, 1, 1, 0.9}; - text = ""; - }; - }; - }; - - class CSE_DISPLAY_INFORMATION { - duration = 15; - idd = 86412; - movingenable = 0; - onLoad = "uiNamespace setVariable ['CSE_DISPLAY_INFORMATION', _this select 0];"; - fadein = 0; - class controlsBackground { - class header: cse_gui_staticBase { - idc = 1; - type = CT_STATIC; - x = "safezoneX + (safezoneW / 10)"; - y = "safezoneY + (6 * (safeZoneH / 40))"; - w = "(safeZoneW / 10)"; - h = "(safeZoneH / 40)"; - style = ST_LEFT; - font = FontCSE; - SizeEx = "(((((safezoneW / safezoneH) min 1.2) / 1.2) / 25) * 1)"; - colorText[] = {0.85, 0.85, 0.85, 1.0}; - colorBackground[] = {0, 0, 0, 0.9}; - text = ""; - }; - class text: header { - idc = 2; - y = "safezoneY + (7.1 * (safeZoneH / 40))"; - w = "(safeZoneW / 10) * 1.3"; - colorText[] = {0.0, 0.0, 0.0, 1.0}; - colorBackground[] = {1, 1, 1, 0.9}; - text = ""; - }; - class text2: text { - idc = 3; - y = "safezoneY + (8.2 * (safeZoneH / 40))"; - }; - class text3: text { - idc = 4; - y = "safezoneY + (9.3 * (safeZoneH / 40))"; - }; - class text4: text { - idc = 5; - y = "safezoneY + (10.4 * (safeZoneH / 40))"; - }; - class text5: text { - idc = 6; - y = "safezoneY + (11.5 * (safeZoneH / 40))"; - }; - - - class icon: cse_gui_backgroundBase { - type = CT_STATIC; - idc = 10; - style = ST_PICTURE; - colorBackground[] = {0,0,0,1}; - colorText[] = {1, 1, 1, 1}; - font = FontCSE; - text = ""; - sizeEx = 0.032; - x = "safezoneX + (safezoneW / 10)"; - y = "safezoneY + (4 * (safeZoneH / 40))"; - w = "(safeZoneH / 40)*2"; - h = "(safeZoneH / 40)*2"; - - }; - - }; - }; - - class CSE_DISPLAY_MESSAGE_CONCEPT { - duration = 15; - idd = 86413; - movingenable = 0; - onLoad = "uiNamespace setVariable ['CSE_DISPLAY_MESSAGE_CONCEPT', _this select 0];"; - fadein = 0; - class controlsBackground { - class header: cse_gui_staticBase { - idc = 1; - type = CT_STATIC; - x = "safezoneX + (safezoneW / 10)"; - y = "safezoneY + (6 * (safeZoneH / 40))"; - w = "(safeZoneW / 10)"; - h = "(safeZoneH / 40)"; - style = ST_LEFT + ST_SHADOW; - font = "EtelkaMonospacePro"; - SizeEx = "(((((safezoneW / safezoneH) min 1.2) / 1.2) / 25) * 1)"; - colorText[] = {1,1,1, 1.0}; - colorBackground[] = {0, 0, 0, 0.0}; - text = ""; - shadow = 2; - }; - class text: header { - idc = 2; - y = "safezoneY + (31 * (safeZoneH / 40))"; - w = "(safeZoneW / 10) * 1.3"; - text = ""; - }; - }; - }; - - class CSE_sys_field_rations_PlayerStatusUI { - duration = 1e+011; - idd = 1111; - movingenable = 0; - onLoad = "uiNamespace setVariable ['CSE_sys_field_rations_PlayerStatusUI', _this select 0];"; - class controlsBackground { - class FoodStatus: cse_gui_backgroundBase { - text = "cse\cse_sys_field_rations\data\hud_foodstatus.paa"; - colorText[] = {0.0,1.0,0.0,0.4}; - idc = 11112; - x = (safezoneW + safezoneX) - (2 * (((safezoneW / safezoneH) min 1.2) / 40)); - y = "28 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + (safezoneH - (((safezoneW / safezoneH) min 1.2) / 1.2))/2)"; - w = "1.75 * (((safezoneW / safezoneH) min 1.2) / 40)"; - h = "1.75 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25)"; - }; - class drinkStatus: cse_gui_backgroundBase { - text = "cse\cse_sys_field_rations\data\hud_drinkstatus.paa"; - colorText[] = {0.0,1.0,0.0,0.4}; - idc = 11113; - x = (safezoneW + safezoneX) - (2 * (((safezoneW / safezoneH) min 1.2) / 40)); - y = "30 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + (safezoneH - (((safezoneW / safezoneH) min 1.2) / 1.2))/2)"; - w = "1.75 * (((safezoneW / safezoneH) min 1.2) / 40)"; - h = "1.75 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25)"; - }; - /* class CamelBak: cse_gui_backgroundBase { - text = "cse\cse_sys_field_rations\data\hud_camelbak.paa"; - colorText[] = {0.0,1.0,0.0,0}; - idc = 11114; - x = "0.955313 * safezoneW + safezoneX"; - y = "0.80 * safezoneH + safezoneY"; - w = 0.05; - h = 0.09; - };*/ - }; - }; - -// class RscHealthTextures { -// onload = "uinamespace setvariable ['RscHealthTextures',_this select 0]; ['RscHealthTextures has activated'] call cse_fnc_debug;"; - // }; -}; \ No newline at end of file diff --git a/TO_MERGE/cse/f_states/visual/empty.hpp b/TO_MERGE/cse/f_states/visual/empty.hpp deleted file mode 100644 index 5489ad8565..0000000000 --- a/TO_MERGE/cse/f_states/visual/empty.hpp +++ /dev/null @@ -1,21 +0,0 @@ -class cse_empty_screen { - idd = 679123; - movingEnable = false; - onLoad = "uiNamespace setVariable ['cse_empty_screen', _this select 0];"; - onUnload = "if (!isnil 'CSE_DISABLE_USER_INPUT_SCREEN') then { createDialog 'cse_empty_screen';};"; - class controlsBackground { - class cse_background : cse_gui_backgroundBase { - idc = 1; - x = safezoneX; - y = safezoneY; - w = safezoneW; - h = safezoneH; - text = ""; - moving = 0; - }; - }; - - class controls { - - }; -}; \ No newline at end of file diff --git a/TO_MERGE/cse/f_states/visual/functions/fn_effectBlackOut.sqf b/TO_MERGE/cse/f_states/visual/functions/fn_effectBlackOut.sqf deleted file mode 100644 index 61a3951517..0000000000 --- a/TO_MERGE/cse/f_states/visual/functions/fn_effectBlackOut.sqf +++ /dev/null @@ -1,19 +0,0 @@ -/** - * fn_effectBlackOut.sqf - * @Descr: Displays the blacked out effect for clients. - * @Author: Glowbal - * - * @Arguments: [displayEffect BOOL] - * @Return: void - * @PublicAPI: true - */ - -private ["_displayEffect","_CSEFadingBlackUI"]; -_displayEffect = [_this, 0, false,[false]] call bis_fnc_param; -disableSerialization; -_CSEFadingBlackUI = uiNamespace getVariable "CSEFadingBlackUI"; -if (_displayEffect) then { - (_CSEFadingBlackUI displayCtrl 11112) ctrlSetTextColor [0.0,0.0,0.0,0.9]; -} else { - (_CSEFadingBlackUI displayCtrl 11112) ctrlSetTextColor [0.0,0.0,0.0,0.0]; -}; \ No newline at end of file diff --git a/TO_MERGE/cse/f_states/visual/functions/fn_effectBleeding.sqf b/TO_MERGE/cse/f_states/visual/functions/fn_effectBleeding.sqf deleted file mode 100644 index 97f17c259f..0000000000 --- a/TO_MERGE/cse/f_states/visual/functions/fn_effectBleeding.sqf +++ /dev/null @@ -1,30 +0,0 @@ -/** - * fn_effectBleeding.sqf - * @Descr: Displays the CSE Bleeding effect - * @Author: Glowbal - * - * @Arguments: [bloodLoss NUMBER] - * @Return: void - * @PublicAPI: true - */ - -private ["_handle"]; -if (isnil "cseDisplayingBleedingEffect") then { - cseDisplayingBleedingEffect = false; -}; -if (cseDisplayingBleedingEffect) exitwith {}; -_handle = _this spawn { - private ["_unit","_bloodLoss","_time"]; - _bloodLoss = _this select 0; - if (!(_bloodLoss > 0)) exitwith{}; - _time = 6 - _bloodLoss; - if (_time <1.5) then { - _time = 1.5; - }; - cseDisplayingBleedingEffect = true; - 47 cutRsc ["RscCSEScreenEffectsBleeding","PLAIN"]; - sleep _time; - cseDisplayingBleedingEffect = false; -}; - -_handle \ No newline at end of file diff --git a/TO_MERGE/cse/f_states/visual/functions/fn_effectPain.sqf b/TO_MERGE/cse/f_states/visual/functions/fn_effectPain.sqf deleted file mode 100644 index 8f3cdb3d35..0000000000 --- a/TO_MERGE/cse/f_states/visual/functions/fn_effectPain.sqf +++ /dev/null @@ -1,27 +0,0 @@ -/** - * fn_effectPain.sqf - * @Descr: Displays the CSE Pain effect - * @Author: Glowbal - * - * @Arguments: [painRatio NUMBER] - * @Return: void - * @PublicAPI: true - */ - -if (isnil "cseDisplayingPainEffect") then { - cseDisplayingPainEffect = false; -}; -if (cseDisplayingPainEffect) exitwith {}; -_this spawn { - private ["_ratio","_time"]; - _ratio = _this select 0; - if (!(_ratio > 0)) exitwith{}; - _time = 6 - _ratio; - if (_time <1.5) then { - _time = 1.5; - }; - cseDisplayingPainEffect = true; - 46 cutRsc ["RscCSEScreenEffectsPain","PLAIN"]; - sleep _time; - cseDisplayingPainEffect = false; -}; \ No newline at end of file diff --git a/TO_MERGE/cse/gui/CfgFunctions.h b/TO_MERGE/cse/gui/CfgFunctions.h deleted file mode 100644 index ef4e5c25b2..0000000000 --- a/TO_MERGE/cse/gui/CfgFunctions.h +++ /dev/null @@ -1,61 +0,0 @@ -class CfgFunctions { - class CSE - { - class GUI - { - file = "cse\cse_gui\functions"; - class gui_keyPressed { recompile = 1; }; - class gui_createInteractionMenu { recompile = 1; }; - class gui_addMenuEntry { recompile = 1; }; - class gui_getMenuEntries { recompile = 1; }; - class gui_displaySubMenuButtons { recompile = 1; }; - class gui_hideSubMenuButtons { recompile = 1; }; - class gui_hideSubSubMenuButtons { recompile = 1; }; - class gui_sortMenuEntries { recompile = 1; }; - class gui_refreshLastSubMenu { recompile = 1; }; - class gui_displayEventHandler { recompile = 1; }; - class gui_loadingBar { recompile = 1; }; - class gui_hasOptionAvailable { recompile = 1; }; - class gui_displayInformation { recompile = 1; }; - class gui_displayMessage { recompile = 1; }; - class gui_blurScreen { recompile = 1; }; - class gui_displayIcon { recompile = 1; }; - }; - class RadialMenu { - file = "cse\cse_gui\radialmenu"; - class findTargetOfMenu_GUI { recompile = 1; }; - class openRadialMenu_GUI {recompile = 1; }; - class openRadialSubMenu_GUI {recompile = 1; }; - class setRadialMenuOptions_GUI {recompile = 1; }; - class setRadialMenuName_GUI { recompile = 1; }; - class getcurrentRadialTarget_GUI { recompile = 1; }; - class returnToPreviousSubMenu_GUI { recompile = 1; }; - class setRadialSecondRing_GUI { recompile = 1; }; - class openRadialSecondRing_GUI { recompile = 1; }; - class closeRadialSecondRing_GUI { recompile = 1; }; - class setRadialMenuTargetName_GUI { recompile = 1; }; - class findtargetName_GUI { recompile = 1;}; - class setRadialOptionSelected_GUI { recompile = 1; }; - class isRadialOptionSelected_GUI { recompile = 1; }; - class isOpenSecondRing_GUI { recompile = 1; }; - class addEntryToRadialInteraction_F { recompile = 1; }; - class createRadialInteraction_F { recompile = 1; }; - class getRadialInteractionEntries_F { recompile = 1; }; - class openRadialInteractionMenu_F { recompile = 1; }; - class radialUsesSorter_F { recompile = 1; }; - class getEntryToMenuSorter_F { recompile = 1; }; - class addEntryToMenuSorter_F { recompile = 1; }; - class createCategoryRadialMenu_F { recompile = 1; }; - class getAllCategoryEntriesRadialMenu_F { recompile = 1; }; - class addCategoryEntryRadialMenu_F { recompile = 1; }; - class hasEntriesRadialInteraction_F { recompile = 1; }; - class addMultipleEntriesToRadialCategory_F { recompile = 1; }; - class getIcon_F { recompile = 1; }; - class categoryHasActionsAvailable_F { recompile = 1; }; - }; - class WeaponSelector { - file = "cse\cse_gui\WeaponSelector"; - class onWeaponSelectorOpened_GUI { recompile = 1; }; - }; - }; -}; \ No newline at end of file diff --git a/TO_MERGE/cse/gui/Combat_Space_Enhancement.h b/TO_MERGE/cse/gui/Combat_Space_Enhancement.h deleted file mode 100644 index 62d1708f5c..0000000000 --- a/TO_MERGE/cse/gui/Combat_Space_Enhancement.h +++ /dev/null @@ -1,13 +0,0 @@ -class Combat_Space_Enhancement { - class EventHandlers { - class PostInit_EventHandlers { - class cse_gui { - init = " call compile preprocessFile 'cse\cse_gui\init.sqf';"; - }; - }; - }; - - class CustomEventHandlers { - class openRadialMenu {}; // [_menuName, _entries, _target] - }; -}; \ No newline at end of file diff --git a/TO_MERGE/cse/gui/GUI.h b/TO_MERGE/cse/gui/GUI.h deleted file mode 100644 index 4e22d8ae32..0000000000 --- a/TO_MERGE/cse/gui/GUI.h +++ /dev/null @@ -1,10 +0,0 @@ -#include "gui\define.hpp" -#include "gui\interactionMenu.hpp" -#include "gui\interactionMenu_white.hpp" -#include "gui\radial.h" -#include "gui\cseLogoPlain.hpp" -#include "gui\dynamicMenu.h" -#include "gui\RscTitles.h" - - -// #include "gui\weapon_selector.h" \ No newline at end of file diff --git a/TO_MERGE/cse/gui/config.cpp b/TO_MERGE/cse/gui/config.cpp deleted file mode 100644 index 918a9208b3..0000000000 --- a/TO_MERGE/cse/gui/config.cpp +++ /dev/null @@ -1,25 +0,0 @@ -#define _ARMA_ -class CfgPatches -{ - class cse_gui - { - units[] = {}; - weapons[] = {}; - requiredVersion = 0.1; - requiredAddons[] = {"a3_ui_f", "cse_main"}; - version = "0.10.0_rc"; - author[] = {"Combat Space Enhancement"}; - authorUrl = "http://csemod.com"; - }; -}; -class CfgAddons { - class PreloadAddons { - class cse_gui { - list[] = {"cse_gui"}; - }; - }; -}; - -#include "CfgFunctions.h" -#include "Combat_Space_Enhancement.h" -#include "GUI.h" \ No newline at end of file diff --git a/TO_MERGE/cse/gui/data/background_gradient.paa b/TO_MERGE/cse/gui/data/background_gradient.paa deleted file mode 100644 index 0a56125f7a..0000000000 Binary files a/TO_MERGE/cse/gui/data/background_gradient.paa and /dev/null differ diff --git a/TO_MERGE/cse/gui/data/buttonDisabled.paa b/TO_MERGE/cse/gui/data/buttonDisabled.paa deleted file mode 100644 index 2c2a10856b..0000000000 Binary files a/TO_MERGE/cse/gui/data/buttonDisabled.paa and /dev/null differ diff --git a/TO_MERGE/cse/gui/data/buttonDisabled_gradient.paa b/TO_MERGE/cse/gui/data/buttonDisabled_gradient.paa deleted file mode 100644 index 43b1b8d100..0000000000 Binary files a/TO_MERGE/cse/gui/data/buttonDisabled_gradient.paa and /dev/null differ diff --git a/TO_MERGE/cse/gui/data/buttonNormal.paa b/TO_MERGE/cse/gui/data/buttonNormal.paa deleted file mode 100644 index 84936d8356..0000000000 Binary files a/TO_MERGE/cse/gui/data/buttonNormal.paa and /dev/null differ diff --git a/TO_MERGE/cse/gui/data/buttonNormal_gradient.paa b/TO_MERGE/cse/gui/data/buttonNormal_gradient.paa deleted file mode 100644 index 2210f98741..0000000000 Binary files a/TO_MERGE/cse/gui/data/buttonNormal_gradient.paa and /dev/null differ diff --git a/TO_MERGE/cse/gui/data/buttonNormal_gradient2.paa b/TO_MERGE/cse/gui/data/buttonNormal_gradient2.paa deleted file mode 100644 index cabe6c7fed..0000000000 Binary files a/TO_MERGE/cse/gui/data/buttonNormal_gradient2.paa and /dev/null differ diff --git a/TO_MERGE/cse/gui/data/buttonNormal_gradient3.paa b/TO_MERGE/cse/gui/data/buttonNormal_gradient3.paa deleted file mode 100644 index 7da9fbcf8a..0000000000 Binary files a/TO_MERGE/cse/gui/data/buttonNormal_gradient3.paa and /dev/null differ diff --git a/TO_MERGE/cse/gui/data/buttonNormal_gradient_top.paa b/TO_MERGE/cse/gui/data/buttonNormal_gradient_top.paa deleted file mode 100644 index 904e1a62f7..0000000000 Binary files a/TO_MERGE/cse/gui/data/buttonNormal_gradient_top.paa and /dev/null differ diff --git a/TO_MERGE/cse/gui/data/buttonNormal_gradient_top_w.paa b/TO_MERGE/cse/gui/data/buttonNormal_gradient_top_w.paa deleted file mode 100644 index 23dd190afc..0000000000 Binary files a/TO_MERGE/cse/gui/data/buttonNormal_gradient_top_w.paa and /dev/null differ diff --git a/TO_MERGE/cse/gui/functions/fn_addCatagoryEntry.sqf b/TO_MERGE/cse/gui/functions/fn_addCatagoryEntry.sqf deleted file mode 100644 index 5c45c5f466..0000000000 --- a/TO_MERGE/cse/gui/functions/fn_addCatagoryEntry.sqf +++ /dev/null @@ -1,54 +0,0 @@ -/** - * fn_addCatagoryEntry.sqf - * @Descr: Add a Catagory entry to a menu - * @Author: Glowbal - * - * @Arguments: [menuName STRING, categoryName STRING, code CODE, condition CODE] - * @Return: void - * @PublicAPI: true - */ - -private ["_menuName","_catagoryName","_code","_condition","_foundMenuName","_foundEntryName","_counter","_onPosMenu","_onPosCatagory","_catagoryCounter","_entryCollection","_entry"]; -_menuName = [_this,0,"",[""]] call BIS_fnc_Param; -_catagoryName = [_this,1, "",[""]] call BIS_fnc_Param; -_code = [_this,2,{},[{}]] call BIS_fnc_Param; -_condition = [_this,3,{},[{}]] call BIS_fnc_Param; - - -if (isnil "CSE_CATAGORY_LIST_ENTRIES") then { - CSE_CATAGORY_LIST_ENTRIES = []; -}; - -_foundMenuName = false; -_foundEntryName = false; -_onPosMenu = 0; -_onPosCatagory = 0; -_counter = 0; -{ - if ((_x select 0) == _menuName) exitwith { - // found entry - _foundMenuName = true; - _onPosMenu = _counter; - _catagoryCounter = 0; - { - if ((_x select 0) == _catagoryName) exitwith { - _foundEntryName = true; - _onPosCatagory = _catagoryCounter; - }; - _catagoryCounter = _catagoryCounter + 1; - }foreach (_x select 1); - }; - _counter = _counter + 1; -}foreach CSE_CATAGORY_LIST_ENTRIES; - - -if (!_foundMenuName) then { -} else { - if (!_foundEntryName) then { - } else { - _entry = [_catagoryName,_condition,_code]; - _arrayOfCatagories = CSE_CATAGORY_LIST_ENTRIES select _onPosMenu; - _entryCollection = _arrayOfCatagories select _onPosCatagory; - _entryCollection pushback _entry; - }; -}; diff --git a/TO_MERGE/cse/gui/functions/fn_gui_addCatagory.sqf b/TO_MERGE/cse/gui/functions/fn_gui_addCatagory.sqf deleted file mode 100644 index 0d4e91bc19..0000000000 --- a/TO_MERGE/cse/gui/functions/fn_gui_addCatagory.sqf +++ /dev/null @@ -1,76 +0,0 @@ -/** - * fn_gui_addCatagory.sqf - * @Descr: N/A - * @Author: Glowbal - * - * @Arguments: [] - * @Return: - * @PublicAPI: false - */ - -private ["_menuName","_catagoryCounter","_catagoryName","_condition","_priority","_foundEntryName","_foundMenuName", "_counter","_onPosCatagory","_onPosMenu","_catagoryCounter","_arrayOfCatagories"]; -_menuName = _this select 0; -_catagoryName = _this select 1; -_condition = _this select 2; -_priority = _this select 3; - - -if (isnil "CSE_CATAGORY_LIST_ENTRIES") then { - CSE_CATAGORY_LIST_ENTRIES = []; - CSE_CATAGORY_LIST_ENTRIES pushback [_menuName,[_catagoryName, [] ] ]; -}; - -_foundMenuName = false; -_foundEntryName = false; -_onPosMenu = 0; -_onPosCatagory = 0; -{ - if ((_x select 0) == _menuName) exitwith { - _foundMenuName = true; - _onPosMenu = _foreachIndex; - _catagoryCounter = 0; - { - if ((_x select 0) == _catagoryName) exitwith { - _foundEntryName = true; - _onPosCatagory = _catagoryCounter; - }; - _catagoryCounter = _catagoryCounter + 1; - }foreach (_x select 1); - }; -}foreach CSE_CATAGORY_LIST_ENTRIES; - -if (!_foundMenuName) then { - CSE_CATAGORY_LIST_ENTRIES pushback [_menuName,[_catagoryName, [] ] ]; -} else { - if (!_foundEntryName) then { - _arrayOfCatagories = CSE_CATAGORY_LIST_ENTRIES select _onPosMenu; - _arrayOfCatagories pushback [_catagoryName, [] ]; - }; -}; - - - cse_fnc_gui_getCatagoryEntries = { - - if (isnil "CSE_CATAGORY_LIST_ENTRIES") { - CSE_CATAGORY_LIST_ENTRIES = []; - }; - _return = []; - - { - if ((_x select 0) == (_this select 0)) exitwith { - { - if ((_x select 0) == (_this select 1)) exitwith { - _return = _x select 1; - }; - }foreach (_x select 1); - }; - }foreach CSE_CATAGORY_LIST_ENTRIES - - _return - }; - - [_menuName,_catagoryName + " >",_condition,{ - [_catagoryName,_this select 2,[_menuName,_catagoryName] call cse_fnc_gui_getCatagoryEntries] call cse_fnc_gui_displaySubMenuButtons; - },_priority] call cse_fnc_gui_addMenuEntry; - - diff --git a/TO_MERGE/cse/gui/functions/fn_gui_addCatagoryEntry.sqf b/TO_MERGE/cse/gui/functions/fn_gui_addCatagoryEntry.sqf deleted file mode 100644 index e69de29bb2..0000000000 diff --git a/TO_MERGE/cse/gui/functions/fn_gui_addMenuEntry.sqf b/TO_MERGE/cse/gui/functions/fn_gui_addMenuEntry.sqf deleted file mode 100644 index 6cd4b22d01..0000000000 --- a/TO_MERGE/cse/gui/functions/fn_gui_addMenuEntry.sqf +++ /dev/null @@ -1,47 +0,0 @@ -/** - * fn_gui_addMenuEntry.sqf - * @Descr: N/A - * @Author: Glowbal - * - * @Arguments: [] - * @Return: - * @PublicAPI: false - */ - -if (isDedicated) exitwith { [format["GUI - fnc_gui_addMenuEntry EXIT ON DEDICATED"],2] call cse_fnc_debug;}; - -if (isnil "cse_gui_availableMenuOptions") then { - cse_gui_availableMenuOptions = []; -}; -private ["_menuName","_optionName","_menuCondition","_menuAction","_priority"]; - _menuName = _this select 0; - _optionName = _this select 1; - _menuCondition = _this select 2; - _menuAction = _this select 3; - _priority = _this select 4; - -_MENU_VAR = format["CSE_GUI_MENU_OPTIONS_%1", _menuName]; -if (isnil _MENU_VAR) then { - call compile format["%1 = [];",_MENU_VAR]; -}; - -//[format["GUI - fnc_gui_addMenuEntry %1",_this, _MENU_VAR],2] call cse_fnc_debug; - -[_menuName,_optionName,_menuCondition,_menuAction,_priority] call compile format["%1 pushback _this;",_MENU_VAR]; - - //cse_gui_availableMenuOptions = cse_gui_availableMenuOptions + [[_menuName,_optionName,_menuCondition,_menuAction,_priority]]; - -/* -CSE_CONDITION_COMPARE_ARRAY_conditionCompareArray = []; -if (isnil 'CSE_CONDITION_COMPARE_CACHE') then { - CSE_CONDITION_COMPARE_CACHE = []; -}; -{ - _condition = _x select 2; - if !(_condition in CSE_CONDITION_COMPARE_CACHE) then { - CSE_CONDITION_COMPARE_CACHE set [ count CSE_CONDITION_COMPARE_CACHE , _condition ]; - } else { - player sidechat format["CACHING CONDITION: %1",_x]; - _x set [ 2 , CSE_CONDITION_COMPARE_CACHE find _condition]; - }; -}foreach (call compile (format["%1",_MENU_VAR]));*/ \ No newline at end of file diff --git a/TO_MERGE/cse/gui/functions/fn_gui_blurScreen.sqf b/TO_MERGE/cse/gui/functions/fn_gui_blurScreen.sqf deleted file mode 100644 index 9c9a901dd4..0000000000 --- a/TO_MERGE/cse/gui/functions/fn_gui_blurScreen.sqf +++ /dev/null @@ -1,37 +0,0 @@ -/** - * fn_gui_blurScreen.sqf - * @Descr: - * @Author: Glowbal - * - * @Arguments: [] - * @Return: - * @PublicAPI: true - */ - -private ["_id", "_show"]; -_id = [_this, 0, "", [""]] call BIS_fnc_Param; -_show = [_this, 1, false, [false]] call BIS_fnc_Param; - -if (isnil "CSE_GUI_SHOW_BLUR_SCREEN_COLLECTION") then { - CSE_GUI_SHOW_BLUR_SCREEN_COLLECTION = []; -}; - -if (_show) then { - CSE_GUI_SHOW_BLUR_SCREEN_COLLECTION pushback _id; - // show blur - if (isnil 'CSE_MENU_ppHandle_GUI_BLUR_SCREEN') then { - CSE_MENU_ppHandle_GUI_BLUR_SCREEN = ppEffectCreate ["DynamicBlur", 102]; - CSE_MENU_ppHandle_GUI_BLUR_SCREEN ppEffectAdjust [0.9]; - CSE_MENU_ppHandle_GUI_BLUR_SCREEN ppEffectEnable true; - CSE_MENU_ppHandle_GUI_BLUR_SCREEN ppEffectCommit 0; - }; -} else { - CSE_GUI_SHOW_BLUR_SCREEN_COLLECTION = CSE_GUI_SHOW_BLUR_SCREEN_COLLECTION - [_id]; - if (CSE_GUI_SHOW_BLUR_SCREEN_COLLECTION isEqualTo []) then { - // hide blur - if (!isnil 'CSE_MENU_ppHandle_GUI_BLUR_SCREEN') then { - ppEffectDestroy CSE_MENU_ppHandle_GUI_BLUR_SCREEN; - CSE_MENU_ppHandle_GUI_BLUR_SCREEN = nil; - }; - }; -}; \ No newline at end of file diff --git a/TO_MERGE/cse/gui/functions/fn_gui_createInteractionMenu.sqf b/TO_MERGE/cse/gui/functions/fn_gui_createInteractionMenu.sqf deleted file mode 100644 index 859aaf04c8..0000000000 --- a/TO_MERGE/cse/gui/functions/fn_gui_createInteractionMenu.sqf +++ /dev/null @@ -1,19 +0,0 @@ -/** - * fn_gui_createInteractionMenu.sqf - * @Descr: Creates a interaction menu - * @Author: Glowbal - * - * @Arguments: [name STRINg, keybinding ARRAY, idd NUMBER, condition CODE, type NUMBER] - * @Return: void - * @PublicAPI: true - */ - -private ["_name","_condition","_keyBinding","_idd","_type","_codeToExecute"]; -_name = _this select 0; -_keyBinding = _this select 1; -_idd = _this select 2; -_condition = _this select 3; -_type = _this select 4; - -_codeToExecute = compile format[ "%1 call cse_fnc_gui_keyPressed;", [_name,_condition,_type] ]; -[_name, _keyBinding, _codeToExecute, _idd] call cse_fnc_addKeyBindingForMenu_F; \ No newline at end of file diff --git a/TO_MERGE/cse/gui/functions/fn_gui_displayEventHandler.sqf b/TO_MERGE/cse/gui/functions/fn_gui_displayEventHandler.sqf deleted file mode 100644 index 083a12ed26..0000000000 --- a/TO_MERGE/cse/gui/functions/fn_gui_displayEventHandler.sqf +++ /dev/null @@ -1,74 +0,0 @@ -/** - * fn_gui_displayEventHandler.sqf - * @Descr: N/A - * @Author: Glowbal - * - * @Arguments: [] - * @Return: - * @PublicAPI: false - */ - -[] spawn { - waitUntil {!isNull player && (player == player) && !(isNull (findDisplay 46))}; - CSE_KEY_COUNTER = 0; - CSE_DISPLAY_MENU = false; - CSE_MENU_ONRELEASE = false; - - - CSE_KEY_PRESSED_HANDLER = { - // state of Shift, Ctrl and Alt - //if (!(_this select 2)) then { - if !([player] call cse_fnc_isAwake) exitwith{}; - _MENU_VAR = format['CSE_GUI_MENU_%1', (_this select 1)]; - if (isnil _MENU_VAR) exitwith {}; - - _menu = (call compile _MENU_VAR) select 0; - - _states = _menu select 4; - if (((_states select 1) == 0) && (_this select 2)) exitwith {}; - if (((_states select 1) == 1) && !(_this select 2)) exitwith {}; - - if (((_states select 2) == 0) && (_this select 3)) exitwith {}; - if (((_states select 2) == 1) && !(_this select 3)) exitwith {}; - - if (((_states select 3) == 0) && (_this select 4)) exitwith {}; - if (((_states select 3) == 1) && !(_this select 4)) exitwith {}; - - if (CSE_DISPLAY_MENU && !CSE_KEY_RELEASED) exitwith {}; - if (CSE_DISPLAY_MENU && CSE_KEY_RELEASED) exitwith { closeDialog 145201;}; - if (dialog) exitwith { closeDialog 0; }; - - _STARTINGTIME = time; - CSE_DISPLAY_MENU = true; - CSE_KEY_RELEASED = false; - //null = [_this,_STARTINGTIME,(call compile _MENU_VAR) select 0] spawn { - _handle = [_this,_STARTINGTIME] spawn { - waituntil{CSE_KEY_RELEASED || (time - ((_this select 1)) > 0.25)}; - if (!CSE_KEY_RELEASED) then { - - CSE_MENU_ONRELEASE = true; - waituntil {CSE_KEY_RELEASED}; - CSE_MENU_ONRELEASE = false; - closeDialog 145201; - } else { - CSE_KEY_RELEASED = true; - }; - waituntil {!dialog}; - CSE_DISPLAY_MENU = false; - }; - [(_menu select 0),(_menu select 1),(_menu select 3)] call cse_fnc_gui_keyPressed; - //}; - false; - }; -/* - - cse_displayEventHandler_Dialog = findDisplay 46 displayAddEventHandler ["keyDown", CSE_KEY_PRESSED_HANDLER]; - cse_displayEventHandler_DialogReleased = findDisplay 46 displayAddEventHandler ["keyUp", { - _MENU_VAR = format['CSE_GUI_MENU_%1', (_this select 1)]; - if (CSE_DISPLAY_MENU) then { - if (!isnil _MENU_VAR) then { - CSE_KEY_RELEASED = true; - }; - }; - }];*/ -}; diff --git a/TO_MERGE/cse/gui/functions/fn_gui_displayIcon.sqf b/TO_MERGE/cse/gui/functions/fn_gui_displayIcon.sqf deleted file mode 100644 index 1634228f9c..0000000000 --- a/TO_MERGE/cse/gui/functions/fn_gui_displayIcon.sqf +++ /dev/null @@ -1,70 +0,0 @@ -/** - * fn_gui_displayIcon.sqf - * @Descr: - * @Author: Glowbal - * - * @Arguments: [] - * @Return: - * @PublicAPI: true - * - * @Example ["myID", true, CSE_ICON_PATH + "icon_group.paa", [1,1,1,1]] call cse_fnc_gui_displayIcon; - */ - -#define MAX_N_ICONS 6 - -private ["_iconId", "_show", "_icon", "_spot", "_idc", "_display","_next_IDC", "_nextText"]; -_iconId = _this select 0; -_show = _this select 1; -_icon = _this select 2; -_color = _this select 3; - -disableSerialization; -_list = missionNamespace getvariable ["cse_gui_displayIconList",[]]; -_display = uiNamespace getvariable "cse_gui_iconsDisplay"; -if (_show) then { - if ({(_x select 0 == _iconId)} count _list == 0) then { - _list pushback [_iconId, _icon, _color]; - } else { - { - if (_x select 0 == _iconId) exitwith { - _list set [_foreachIndex, [_iconId, _icon, _color]]; - }; - }foreach _list; - }; - - missionNamespace setvariable ["cse_gui_displayIconList", _list]; - - { - if (_x select 0 == _iconId) exitwith { - _idc = 10501 + _foreachIndex; - _ctrl = _display displayCtrl _idc; - _ctrl ctrlsetText _icon; - _ctrl ctrlSetTextColor _color; - }; - }foreach _list; -} else { - if ({(_x select 0 == _iconId)} count _list == 1) then { - _newList = []; - { - if (_x select 0 != _iconId) then { - _newList pushback _x; - }; - }foreach _list; - - missionNamespace setvariable ["cse_gui_displayIconList", _newList]; - - for "_i" from 0 to (MAX_N_ICONS - 1) /* step +1 */ do { - _idc = 10501 + _i; - _ctrl = _display displayCtrl _idc; - _ctrl ctrlsetText ""; - _ctrl ctrlSetTextColor [1,1,1,1]; - }; - - { - _idc = 10501 + _foreachIndex; - _ctrl = _display displayCtrl _idc; - _ctrl ctrlsetText (_x select 1); - _ctrl ctrlSetTextColor (_x select 2); - }foreach _newList; - }; -}; diff --git a/TO_MERGE/cse/gui/functions/fn_gui_displayInformation.sqf b/TO_MERGE/cse/gui/functions/fn_gui_displayInformation.sqf deleted file mode 100644 index 44f675769f..0000000000 --- a/TO_MERGE/cse/gui/functions/fn_gui_displayInformation.sqf +++ /dev/null @@ -1,65 +0,0 @@ -/** - * fn_gui_displayInformation.sqf - * @Descr: N/A - * @Author: Glowbal - * - * @Arguments: [] - * @Return: - * @PublicAPI: false - */ - -#define DISPLAY_LAYER 32547 - -private["_title", "_content","_type","_display","_headerCtrl","_contentCtrl","_contentAmountOfChars","_pos","_icon","_iconCtrl"]; -_title = [_this, 0, "",[""]] call BIS_fnc_Param; -_content = [_this, 1, [""],[[""]]] call BIS_fnc_Param; -_type = [_this, 2, 0, [0]] call BIS_fnc_Param; -_icon = [_this, 3, "",[""]] call BIS_fnc_Param; - -if (_title != "") then { - DISPLAY_LAYER cutRsc ["CSE_DISPLAY_INFORMATION","PLAIN"]; - - disableSerialization; - _display = uiNamespace getvariable "CSE_DISPLAY_INFORMATION"; - if (!isnil "_display") then { - _headerCtrl = _display displayCtrl 1; - _headerCtrl ctrlSetText _title; - _iconCtrl = _display displayCtrl 10; - _iconCtrl ctrlSetText _icon; - - _idc = 2; - { - _text = _x; - if (_text != "") then { - _contentCtrl = _display displayCtrl _idc; - _contentCtrl ctrlSetText _text; - - _contentAmountOfChars = count (toArray _text); - _pos = ctrlPosition _contentCtrl; - _pos set [2, _contentAmountOfChars * ((((((safezoneW / safezoneH) min 1.2) / 1.2) / 25) * 1)/ 3.3) max (safeZoneW / 11)]; - _contentCtrl ctrlSetPosition _pos; - _contentCtrl ctrlCommit 0; - - - if (_type >0) then { - if (_type == 1) then { - _contentCtrl ctrlSetBackgroundColor [0.7,0.2,0.2,0.8]; - _contentCtrl ctrlSetTextColor [1,1,1,0.9]; - }; - }; - _idc = _idc + 1; - }; - }foreach _content; - - while {(_idc < 7)} do { - _contentCtrl = _display displayCtrl _idc; - _contentCtrl ctrlSetPosition [0,0,0,0]; - _contentCtrl ctrlCommit 0; - - _idc = _idc + 1; - }; - }; -} else { - - DISPLAY_LAYER cutText ["","PLAIN"]; -}; \ No newline at end of file diff --git a/TO_MERGE/cse/gui/functions/fn_gui_displayMessage.sqf b/TO_MERGE/cse/gui/functions/fn_gui_displayMessage.sqf deleted file mode 100644 index 1816bdfad5..0000000000 --- a/TO_MERGE/cse/gui/functions/fn_gui_displayMessage.sqf +++ /dev/null @@ -1,43 +0,0 @@ -/** - * fn_gui_displayMessage.sqf - * @Descr: N/A - * @Author: Glowbal - * - * @Arguments: [] - * @Return: - * @PublicAPI: false - */ - -#define DISPLAY_LAYER 546 - -private["_title", "_content","_type","_display","_headerCtrl","_contentCtrl","_contentAmountOfChars","_pos"]; -_title = [_this, 0, "",[""]] call BIS_fnc_Param; -_content = [_this, 1, "",[""]] call BIS_fnc_Param; -_type = [_this, 2, 0, [0]] call BIS_fnc_Param; - -if (_title != "" && _content != "") then { - DISPLAY_LAYER cutRsc ["CSE_DISPLAY_MESSAGE","PLAIN"]; - - disableSerialization; - _display = uiNamespace getvariable "CSE_DISPLAY_MESSAGE"; - if (!isnil "_display") then { - _headerCtrl = _display displayCtrl 1; - _contentCtrl = _display displayCtrl 2; - - _headerCtrl ctrlSetText _title; - _contentCtrl ctrlSetText _content; - - _contentAmountOfChars = count (toArray _content); - _pos = ctrlPosition _contentCtrl; - _pos set [2, _contentAmountOfChars * ((((((safezoneW / safezoneH) min 1.2) / 1.2) / 25) * 1)/ 3.3) max (safeZoneW / 11)]; - _contentCtrl ctrlSetPosition _pos; - _contentCtrl ctrlCommit 0; - - if (_type >0) then { - if (_type == 1) then { - _contentCtrl ctrlSetBackgroundColor [0.7,0.2,0.2,0.8]; - _contentCtrl ctrlSetTextColor [1,1,1,0.9]; - }; - }; - }; -}; \ No newline at end of file diff --git a/TO_MERGE/cse/gui/functions/fn_gui_displaySubMenuButtons.sqf b/TO_MERGE/cse/gui/functions/fn_gui_displaySubMenuButtons.sqf deleted file mode 100644 index 51b31d8873..0000000000 --- a/TO_MERGE/cse/gui/functions/fn_gui_displaySubMenuButtons.sqf +++ /dev/null @@ -1,104 +0,0 @@ -/** - * fn_gui_displaySubMenuButtons.sqf - * @Descr: N/A - * @Author: Glowbal - * - * @Arguments: [] - * @Return: - * @PublicAPI: false - */ - -private ["_rootButton","_allMenuEntries","_allAvailableMainButtons","_selectedMainMenuButton","_interactionDialog","_position","_placeEntry"]; -disableSerialization; -_interactionDialog = uiNamespace getvariable "cse_interactionGUI"; -_rootButton = (_interactionDialog displayCtrl (_this select 1)); -_allMenuEntries = _this select 2; - -_headerNumber = 112; -_selectedMainMenuButton = 201; -_maxCtrlNumber = 215; -if ((_this select 1) > 200 && (_this select 1) < 300) then { - _headerNumber = 113; - _selectedMainMenuButton = 301; - _maxCtrlNumber = 315; -}; -_allAvailableMainButtons = 15; - -//hint format ["ROOTBUTTON: %1",_rootButton]; -_position = ctrlPosition _rootButton; -//_position = [(_position select 0) + 0.26, (_position select 1)]; -_position = [(_position select 0) + 0.31, (_position select 1)]; - -CMS_GUI_LATEST_SUBMENU = _this; - - (_interactionDialog displayCtrl _headerNumber) ctrlSetText (_this select 0); - (_interactionDialog displayCtrl _headerNumber) ctrlSetPosition [_position select 0,(_position select 1) - 0.040]; - //(_interactionDialog displayCtrl _headerNumber) ctrlSetBackgroundColor [0, 0, 0.6, 0.75]; - (_interactionDialog displayCtrl _headerNumber) ctrlSetBackgroundColor [(profilenamespace getvariable ['IGUI_BCG_RGB_R',0]),(profilenamespace getvariable ['IGUI_BCG_RGB_G',1]),(profilenamespace getvariable ['IGUI_BCG_RGB_B',1]), 0.75]; - (_interactionDialog displayCtrl _headerNumber) ctrlSetBackgroundColor [(profilenamespace getvariable ['GUI_BCG_RGB_R',0]),(profilenamespace getvariable ['GUI_BCG_RGB_G',1]),(profilenamespace getvariable ['GUI_BCG_RGB_B',1]), 0.75]; - (_interactionDialog displayCtrl _headerNumber) ctrlCommit 0; - - -CSE_UI_EFFECT = true; // temp enabled - _placeEntry = { - private ["_entry"]; - _entry = (_interactionDialog displayCtrl _selectedMainMenuButton); - _entry ctrlSetText ( (_x select 0)); - _entry ctrlSetPosition _position; - if (_selectedMainMenuButton < 300) then { - _entry ctrlSetEventHandler ["ButtonClick", format["call cse_fnc_gui_hideSubSubMenuButtons;[player,CSE_interactionTarget,%2] call %1; call cse_fnc_gui_refreshLastSubMenu;",(_x select 2),_selectedMainMenuButton]]; - } else { - _entry ctrlSetEventHandler ["ButtonClick", format["[player,CSE_interactionTarget,%2] call %1; call cse_fnc_gui_refreshLastSubMenu;",(_x select 2),_selectedMainMenuButton]]; - }; - if (isnil "CSE_UI_EFFECT") then { - _entry ctrlCommit 0; - } else { - if (CSE_UI_EFFECT) then { - _entry ctrlCommit 0.2; - } else { - _entry ctrlCommit 0; - }; - }; - // updating new information - _position = [(_position select 0), (_position select 1) + 0.040]; - _selectedMainMenuButton = _selectedMainMenuButton + 1; - }; - - _returningEntries = []; - { - if ((typeName (_x select 1)) == "CODE") then { - if ([player,CSE_interactionTarget] call (_x select 1)) then { - _returningEntries set[count _returningEntries,_x]; - }; - } else { - if ((typeName (_x select 1)) == "BOOL") then { - if (_x select 1) then { - _returningEntries set[count _returningEntries,_x]; - }; - }; - }; - }foreach _allMenuEntries; - - - // for effects - { - - _entry = (_interactionDialog displayCtrl _selectedMainMenuButton); - _entry ctrlSetPosition _position; - _entry ctrlCommit 0; - _selectedMainMenuButton = _selectedMainMenuButton + 1; - - if (_selectedMainMenuButton >= _maxCtrlNumber + _allAvailableMainButtons) exitwith{}; - }foreach _returningEntries; - - - - _selectedMainMenuButton = 201; - if ((_this select 1) > 200 && (_this select 1) < 300) then { - _headerNumber = 113; - _selectedMainMenuButton = 301; - }; - { - call _placeEntry; - if (_selectedMainMenuButton >= _maxCtrlNumber + _allAvailableMainButtons) exitwith{}; - }foreach _returningEntries; diff --git a/TO_MERGE/cse/gui/functions/fn_gui_getMenuEntries.sqf b/TO_MERGE/cse/gui/functions/fn_gui_getMenuEntries.sqf deleted file mode 100644 index 655dcf91e2..0000000000 --- a/TO_MERGE/cse/gui/functions/fn_gui_getMenuEntries.sqf +++ /dev/null @@ -1,45 +0,0 @@ -/** - * fn_gui_getMenuEntries.sqf - * @Descr: N/A - * @Author: Glowbal - * - * @Arguments: [] - * @Return: - * @PublicAPI: false - */ - -private ["_menuName","_returningEntries","_MENU_VAR","_cond"]; -_menuName = _this select 0; - -//[_menuName] call cse_fnc_gui_sortMenuEntries; -// in futute, look into splitting this all up into multiple threads - _returningEntries = []; - - _MENU_VAR = format["CSE_GUI_MENU_OPTIONS_%1", _menuName]; - if (isnil _MENU_VAR) then { - call compile format["%1 = [];",_MENU_VAR]; - }; - - { - - _cond = (_x select 2); - - if ((typeName _cond) == "CODE") then { - _passing = ([player,CSE_interactionTarget] call (_x select 2)); - if (typeName _passing != "BOOL") then { - _passing = false; - } else { - }; - if (_passing) then { - _returningEntries set[count _returningEntries,_x]; - }; - } else { - if ((typeName _cond) == "BOOL") then { - if (_cond) then { - _returningEntries set[count _returningEntries,_x]; - }; - }; - }; - }foreach (call compile _MENU_VAR); - -_returningEntries \ No newline at end of file diff --git a/TO_MERGE/cse/gui/functions/fn_gui_hasOptionAvailable.sqf b/TO_MERGE/cse/gui/functions/fn_gui_hasOptionAvailable.sqf deleted file mode 100644 index 898a377fcc..0000000000 --- a/TO_MERGE/cse/gui/functions/fn_gui_hasOptionAvailable.sqf +++ /dev/null @@ -1,48 +0,0 @@ -/** - * fn_gui_hasOptionAvailable.sqf - * @Descr: N/A - * @Author: Glowbal - * - * @Arguments: [] - * @Return: - * @PublicAPI: false - */ - -private ["_menuName","_returningEntries","_MENU_VAR","_cond","_return","_target"]; -_menuName = _this select 0; -_target = _this select 1; -//[_menuName] call cse_fnc_gui_sortMenuEntries; -// in futute, look into splitting this all up into multiple threads - _returningEntries = []; - - _MENU_VAR = format["CSE_GUI_MENU_OPTIONS_%1", _menuName]; - if (isnil _MENU_VAR) then { - call compile format["%1 = [];",_MENU_VAR]; - }; - _return = false; - { - - _cond = (_x select 2); - - if ((typeName _cond) == "CODE") then { - _passing = ([player,_target] call (_x select 2)); - if (typeName _passing != "BOOL") then { - _passing = false; - } else { - }; - if (_passing) then { - _returningEntries set[count _returningEntries,_x]; - }; - } else { - if ((typeName _cond) == "BOOL") then { - if (_cond) then { - _returningEntries set[count _returningEntries,_x]; - }; - }; - }; - if (count _returningEntries > 0) exitwith { - _return = true; - }; - }foreach (call compile _MENU_VAR); - -_return \ No newline at end of file diff --git a/TO_MERGE/cse/gui/functions/fn_gui_hideSubMenuButtons.sqf b/TO_MERGE/cse/gui/functions/fn_gui_hideSubMenuButtons.sqf deleted file mode 100644 index afce751b5a..0000000000 --- a/TO_MERGE/cse/gui/functions/fn_gui_hideSubMenuButtons.sqf +++ /dev/null @@ -1,32 +0,0 @@ -/** - * fn_gui_hideSubMenuButtons.sqf - * @Descr: N/A - * @Author: Glowbal - * - * @Arguments: [] - * @Return: - * @PublicAPI: false - */ - -private ["_allAvailableMainButtons","_selectedMainMenuButton","_interactionDialog","_position","_placeEntry"]; -disableSerialization; -_interactionDialog = uiNamespace getvariable "cse_interactionGUI"; - -_allAvailableMainButtons = 20; -_selectedMainMenuButton = 201; - -_position = [100,100]; -(_interactionDialog displayCtrl 112) ctrlSetPosition [_position select 0,(_position select 1) - 0.045]; -(_interactionDialog displayCtrl 112) ctrlCommit 0; - for [{_x=0},{_x < _allAvailableMainButtons},{_x=_x+1}] do - { - private ["_entry"]; - _entry = (_interactionDialog displayCtrl _selectedMainMenuButton); - _entry ctrlSetPosition _position; - _entry ctrlRemoveAllEventHandlers "ButtonClick"; - _entry ctrlCommit 0; - _selectedMainMenuButton = _selectedMainMenuButton +1; - }; - - -call cse_fnc_gui_hideSubSubMenuButtons; \ No newline at end of file diff --git a/TO_MERGE/cse/gui/functions/fn_gui_hideSubSubMenuButtons.sqf b/TO_MERGE/cse/gui/functions/fn_gui_hideSubSubMenuButtons.sqf deleted file mode 100644 index b73f70e5c5..0000000000 --- a/TO_MERGE/cse/gui/functions/fn_gui_hideSubSubMenuButtons.sqf +++ /dev/null @@ -1,32 +0,0 @@ -/** - * fn_gui_hideSubSubMenuButtons.sqf - * @Descr: N/A - * @Author: Glowbal - * - * @Arguments: [] - * @Return: - * @PublicAPI: false - */ - -private ["_rootButton","_allMenuEntries","_allAvailableMainButtons","_selectedMainMenuButton","_interactionDialog","_position","_placeEntry"]; -disableSerialization; -_interactionDialog = uiNamespace getvariable "cse_interactionGUI"; - -_allAvailableMainButtons = 20; -_selectedMainMenuButton = 301; - -//if (((ctrlPosition (_interactionDialog displayCtrl _selectedMainMenuButton))select 0) == (0.4 + 0.26)) then { - - _position = [100,100]; - (_interactionDialog displayCtrl 113) ctrlSetPosition [_position select 0,(_position select 1) - 0.045]; - (_interactionDialog displayCtrl 113) ctrlCommit 0; - for [{_x=0},{_x < _allAvailableMainButtons},{_x=_x+1}] do - { - private ["_entry"]; - _entry = (_interactionDialog displayCtrl _selectedMainMenuButton); - _entry ctrlSetPosition _position; - _entry ctrlRemoveAllEventHandlers "ButtonClick"; - _entry ctrlCommit 0; - _selectedMainMenuButton = _selectedMainMenuButton +1; - }; -//}; \ No newline at end of file diff --git a/TO_MERGE/cse/gui/functions/fn_gui_keyPressed.sqf b/TO_MERGE/cse/gui/functions/fn_gui_keyPressed.sqf deleted file mode 100644 index 324a504485..0000000000 --- a/TO_MERGE/cse/gui/functions/fn_gui_keyPressed.sqf +++ /dev/null @@ -1,180 +0,0 @@ -/** - * fn_gui_keyPressed.sqf - * @Descr: N/A - * @Author: Glowbal - * - * @Arguments: [] - * @Return: - * @PublicAPI: false - */ - -private ["_menu","_condition","_target","_type","_allAvailableMainButtons","_selectedMainMenuButton","_menuName","_carriedObj", "_allMenuEntries"]; -_menu = _this select 0; -_condition = _this select 1; -_type = _this select 2; -if (isDedicated) exitwith{}; -if (! call _condition) exitwith {}; - -//if (cursortarget iskindof "MAN") then { -//}; -CMS_GUI_LATEST_SUBMENU = []; -_allAvailableMainButtons = 10; -_selectedMainMenuButton = 150; -_menuName = ""; -if (isnil "_type") then { - _type = 0; -}; - - -_target = switch (_type) do { - case 2: {if (isNull cursortarget) then {player} else{cursortarget};}; - case 1: {cursortarget}; - case 0: {player}; - default {player}; -}; -if ((_target distance player) > 10 && {(_type == 2)}) then { - _target = player; -}; -if (_target == player) then { - _menuName = "Your Person"; - if (_type == 2) then { - _menu = "SelfInteraction"; - }; - _targetName = [_target] call cse_fnc_getName; - -} else { - _carriedObj = [player] call cse_fnc_getCarriedObj; - if (!isNull _carriedObj) then { - _target = _carriedObj; - }; - - _menuName = switch (true) do { - case (_target isKindOf "CaManBase"): {([_target] call cse_fnc_getName)}; - case ((_target isKindOf "All")): {(getText(configFile >> "Cfgvehicles" >> typeof _target >> "displayName"))}; - default {"Object"}; - }; - if (_type == 2) then { - _menu = "InteractionMenu"; - }; -}; - -//_allMenuEntries = [_menu] call cse_fnc_gui_getMenuEntries; -if (!([_menu,_target] call cse_fnc_gui_hasOptionAvailable) && _type == 2 && (_menu != "SelfInteraction")) then { - //_allMenuEntries = ["SelfInteraction"] call cse_fnc_gui_getMenuEntries; - _menu = "SelfInteraction"; - _menuName = "Your Person"; - _target = player; - _targetName = [_target] call cse_fnc_getName; -}; -if (!([_menu,_target] call cse_fnc_gui_hasOptionAvailable)) exitwith {}; -//if (count _allMenuEntries <1) exitwith { [format["GUI - FAILED TO OPEN MENU: NO ENTRIES PASSED CONDITION TEST"],2] call cse_fnc_debug; }; - - -CSE_interactionTarget = _target; -//[format["GUI - MENU OPENING %1",_menu],3] call cse_fnc_debug; -[player,_target] call cse_fnc_registerInteractingWith; -if (isnil "cse_use_white_menu") then { - createDialog "cse_interactionGUI"; -} else { - createDialog "cse_interactionGUI_w"; -}; -setMousePosition [0.45, 0.55]; - -disableSerialization; -_interactionDialog = uiNamespace getvariable "cse_interactionGUI"; - -//_position = [0.46,0.5]; -_position = [safezoneX + (safezoneW / 1.9), safezoneY + (safezoneH / 1.9) ]; -//_position = [0.4 * safezoneW + safezoneX, 0.55 * safezoneH + safezoneY]; - -ctrlSetFocus (_interactionDialog displayCtrl 210) ; -(_interactionDialog displayCtrl 111) ctrlSetText _menuName; -(_interactionDialog displayCtrl 111) ctrlSetPosition [_position select 0,(_position select 1) - 0.040]; -//(_interactionDialog displayCtrl 111) ctrlSetBackgroundColor [0, 0, 0.6, 0.75]; -//(_interactionDialog displayCtrl 111) ctrlSetBackgroundColor [(profilenamespace getvariable ['IGUI_BCG_RGB_R',0]),(profilenamespace getvariable ['IGUI_BCG_RGB_G',1]),(profilenamespace getvariable ['IGUI_BCG_RGB_B',1]), 0.75]; -(_interactionDialog displayCtrl 111) ctrlSetBackgroundColor [(profilenamespace getvariable ['GUI_BCG_RGB_R',0]),(profilenamespace getvariable ['GUI_BCG_RGB_G',1]),(profilenamespace getvariable ['GUI_BCG_RGB_B',1]), 0.75]; -(_interactionDialog displayCtrl 111) ctrlCommit 0; - -_allMenuEntries = [_menu] call cse_fnc_gui_getMenuEntries; -{ - private ["_entry"]; - _entry = (_interactionDialog displayCtrl _selectedMainMenuButton); - _entry ctrlSetText ((_x select 1)); - _entry ctrlSetPosition _position; - _entry ctrlSetEventHandler ["ButtonClick", format["[] call cse_fnc_gui_hideSubMenuButtons; [player,CSE_interactionTarget,%2] spawn %1",(_x select 3),_selectedMainMenuButton]]; - _entry ctrlCommit 0; - - // updating new information - _position = [(_position select 0), (_position select 1) + 0.040]; - _selectedMainMenuButton = _selectedMainMenuButton + 1; - if (_selectedMainMenuButton >= 164 + _allAvailableMainButtons) exitwith{}; -}foreach _allMenuEntries; - -[] spawn { - waituntil {!dialog}; - [player,CSE_interactionTarget] call cse_fnc_unregisterInteractingWith; - //[format["GUI - MENU CLOSED"]] call cse_fnc_debug; -}; - -// ICONS SUPPORT - -// cse\cse_gui\data\icon_tags.paa - -_IDC_OF_ICON_OPTION = 400; -(_interactionDialog displayCtrl _IDC_OF_ICON_OPTION) ctrlSetText "cse\cse_gui\data\icon_settings.paa"; -(_interactionDialog displayCtrl (_IDC_OF_ICON_OPTION + 100)) ctrlSetEventHandler ["ButtonClick", " - CloseDialog 0; createDialog 'cse_settingsMenu'; -"]; -(_interactionDialog displayCtrl (_IDC_OF_ICON_OPTION + 100)) ctrlSetTooltip "Open the Settings Menu"; -_IDC_OF_ICON_OPTION = _IDC_OF_ICON_OPTION + 1; - - -if (["cse_sys_tags"] call cse_fnc_isModuleEnabled_F) then { - (_interactionDialog displayCtrl _IDC_OF_ICON_OPTION) ctrlSetText "cse\cse_gui\data\icon_tags.paa"; - (_interactionDialog displayCtrl (_IDC_OF_ICON_OPTION + 100)) ctrlSetEventHandler ["ButtonClick", " - if (isnil 'CSE_DRAW_TAG_ICONS_TAGS') then { - CSE_DRAW_TAG_ICONS_TAGS = false; - }; - CSE_DRAW_TAG_ICONS_TAGS = !CSE_DRAW_TAG_ICONS_TAGS; - if (CSE_DRAW_TAG_ICONS_TAGS) then { - hintSilent 'Enabled Tags'; - } else { - hintSilent 'Disabled Tags'; - }; - "]; - - (_interactionDialog displayCtrl (_IDC_OF_ICON_OPTION + 100)) ctrlSetTooltip "Toggle CSE Tag System ON/OFF"; - _IDC_OF_ICON_OPTION = _IDC_OF_ICON_OPTION + 1; -}; - -if (isnil "CSE_DEBUG_ALLOW_RESET_MODE_ENABLED") then { - CSE_DEBUG_ALLOW_RESET_MODE_ENABLED = false; -}; -if (CSE_DEBUG_ALLOW_RESET_MODE_ENABLED) then { - (_interactionDialog displayCtrl _IDC_OF_ICON_OPTION) ctrlSetText "cse\cse_gui\data\icon_reset_small.paa"; - (_interactionDialog displayCtrl (_IDC_OF_ICON_OPTION + 100)) ctrlSetEventHandler ["ButtonClick", " - [CSE_interactionTarget] spawn cse_fnc_resetAllDefaults; - "]; - - (_interactionDialog displayCtrl (_IDC_OF_ICON_OPTION + 100)) ctrlSetTooltip "Full CSE reset off target"; - _IDC_OF_ICON_OPTION = _IDC_OF_ICON_OPTION + 1; -}; - -while {(_IDC_OF_ICON_OPTION < 403)} do { - ctrlEnable[_IDC_OF_ICON_OPTION+100,false]; - _IDC_OF_ICON_OPTION = _IDC_OF_ICON_OPTION + 1; -}; - -/* -if (["cse_sys_medical"] call cse_fnc_isModuleEnabled_F) then { - if (CSE_interactionTarget isKindOf "CAManBase") then { - [] spawn { - while {(dialog)} do { - _status = [CSE_interactionTarget] call cse_fnc_getTriageStatus_CMS; - [[CSE_interactionTarget] call cse_fnc_getName,["Triage status: "+ (_status select 0)],0] call cse_fnc_gui_displayInformation; - sleep 0.1; - }; - ["",[""],0] call cse_fnc_gui_displayInformation; - }; - }; -};*/ \ No newline at end of file diff --git a/TO_MERGE/cse/gui/functions/fn_gui_loadingbar.sqf b/TO_MERGE/cse/gui/functions/fn_gui_loadingbar.sqf deleted file mode 100644 index d17321ba94..0000000000 --- a/TO_MERGE/cse/gui/functions/fn_gui_loadingbar.sqf +++ /dev/null @@ -1,46 +0,0 @@ -/** - * fn_gui_loadingbar.sqf - * @Descr: Displays a loading bar and halts script until loading bar has finished - * @Author: Glowbal - * - * @Arguments: [timeToWait NUMBER, condition CODE (Optional), onSuccess CODE (Optional), onFailure CODE (Optional), arguments ARRAY (Optional)] - * @Return: BOOl Returns true if loading bar has fully finished. Otherwise false - * @PublicAPI: true - */ - -private ["_timeToWait","_cond","_onfailure","_onSuccess","_args","_dialog","_ctrl","_newStatus","_start","_return"]; -_timeToWait = _this select 0; -_cond = [_this, 1, {true}, [{true}]] call BIS_fnc_Param; -_onSuccess = [_this, 2, {}, [{}]] call BIS_fnc_Param; -_onfailure = [_this, 3, {}, [{}]] call BIS_fnc_Param; -_args = [_this, 4, [], [[]]] call BIS_fnc_Param; - -if (_timeToWait > 0) then { - disableSerialization; - 1534 cutRsc ["cse_progressBar_Sample","plain"]; - _dialog = uiNamespace getvariable "cse_progressBar_Sample"; - _ctrl = _dialog displayCtrl 6; - _newStatus = 0; - _start = diag_tickTime; - while {(_newStatus <= 1.00 && (call _cond))} do { - uisleep 0.01; - _ctrl progressSetPosition _newStatus; - _newStatus = (diag_tickTime - _start) / _timeToWait; - }; - 1534 cutText ["","plain"]; - _return = false; - if (_newStatus >= 1.00) then { - _return = true; - _args call _onSuccess; - } else { - _args call _onfailure; - }; -} else { - if ((call _cond)) then { - _return = true; - _args call _onSuccess; - } else { - _args call _onfailure; - }; -}; -_return \ No newline at end of file diff --git a/TO_MERGE/cse/gui/functions/fn_gui_refreshLastSubMenu.sqf b/TO_MERGE/cse/gui/functions/fn_gui_refreshLastSubMenu.sqf deleted file mode 100644 index 9c1db43f91..0000000000 --- a/TO_MERGE/cse/gui/functions/fn_gui_refreshLastSubMenu.sqf +++ /dev/null @@ -1,19 +0,0 @@ -/** - * fn_gui_refreshLastSubMenu.sqf - * @Descr: N/A - * @Author: Glowbal - * - * @Arguments: [] - * @Return: - * @PublicAPI: false - */ - -private ["_lastMenu"]; -_lastMenu = CMS_GUI_LATEST_SUBMENU; - -if ((_lastMenu select 1) > 200 && (_lastMenu select 1) < 300) then { - call cse_fnc_gui_hideSubSubMenuButtons; -} else { - call cse_fnc_gui_hideSubMenuButtons; -}; -_lastMenu call cse_fnc_gui_displaySubMenuButtons; diff --git a/TO_MERGE/cse/gui/functions/fn_gui_sortMenuEntries.sqf b/TO_MERGE/cse/gui/functions/fn_gui_sortMenuEntries.sqf deleted file mode 100644 index 373cd980bf..0000000000 --- a/TO_MERGE/cse/gui/functions/fn_gui_sortMenuEntries.sqf +++ /dev/null @@ -1,23 +0,0 @@ -/** - * fn_gui_sortMenuEntries.sqf - * @Descr: N/A - * @Author: Glowbal - * - * @Arguments: [] - * @Return: - * @PublicAPI: false - */ - - -private ["_menuName"]; -_menuName = _this select 0; - -_MENU_VAR = format["CSE_GUI_MENU_OPTIONS_%1", _menuName]; -if (isnil _MENU_VAR) then { - call compile format["%1 = [];",_MENU_VAR]; -}; - -if (count (call compile _MENU_VAR) > 1) then { - format["%1 = [%1,[],{_x}] call BIS_fnc_sortBy;",_MENU_VAR]; -}; -true \ No newline at end of file diff --git a/TO_MERGE/cse/gui/gui/RscTitles.h b/TO_MERGE/cse/gui/gui/RscTitles.h deleted file mode 100644 index f4e8b8a5cf..0000000000 --- a/TO_MERGE/cse/gui/gui/RscTitles.h +++ /dev/null @@ -1,50 +0,0 @@ - -#define RIGHT_SIDE (safezoneW + safezoneX) -#define LEFT_SIDE safezoneX -#define TOP_SIDE safeZoneY -#define BOTTOM_SIDE (safeZoneH + safezoneY) - -#define ICON_WIDTH (1.75 * (((safezoneW / safezoneH) min 1.2) / 40)) -#define X_POS_ICONS RIGHT_SIDE - (1.1 * ICON_WIDTH) -#define Y_POS_ICONS TOP_SIDE + (2.2 * ICON_WIDTH) -#define DIFFERENCE_ICONS (1.1 * ICON_WIDTH) - -class RscTitles { - class cse_gui_iconsDisplay { - duration = 1e+011; - idd = 1111; - movingenable = 0; - onLoad = "uiNamespace setVariable ['cse_gui_iconsDisplay', _this select 0];"; - class controlsBackground { - class icon_1: cse_gui_backgroundBase { - text = ""; - colorText[] = {0.0,1.0,0.0,0.4}; - idc = 10501; - x = X_POS_ICONS; - y = Y_POS_ICONS + (0 * DIFFERENCE_ICONS); - w = ICON_WIDTH; - h = ICON_WIDTH; - }; - class icon_2: icon_1 { - idc = 10502; - y = Y_POS_ICONS + (1 * DIFFERENCE_ICONS); - }; - class icon_3: icon_1 { - idc = 10503; - y = Y_POS_ICONS + (2 * DIFFERENCE_ICONS); - }; - class icon_4: icon_1 { - idc = 10504; - y = Y_POS_ICONS + (3 * DIFFERENCE_ICONS); - }; - class icon_5: icon_1 { - idc = 10505; - y = Y_POS_ICONS + (4 * DIFFERENCE_ICONS); - }; - class icon_6: icon_1 { - idc = 10506; - y = Y_POS_ICONS + (5 * DIFFERENCE_ICONS); - }; - }; - }; -}; \ No newline at end of file diff --git a/TO_MERGE/cse/gui/gui/cseLogoPlain.hpp b/TO_MERGE/cse/gui/gui/cseLogoPlain.hpp deleted file mode 100644 index 248556fedc..0000000000 --- a/TO_MERGE/cse/gui/gui/cseLogoPlain.hpp +++ /dev/null @@ -1,31 +0,0 @@ - -class CSE_LogoPlain { - idd = 432350; - movingenable = 0; - fadein = 1; - fadeout = 1; - onLoad = "uiNamespace setVariable ['CSE_LogoPlain', _this select 0];"; - onUnload = "uiNamespace setVariable ['CSE_LogoPlain', nil];"; - onMouseButtonClick = "closeDialog 432350;"; - class controlsBackground { - class backgroundTop: cse_gui_backgroundBase{ - idc = 1; - type = CT_STATIC; - x = "safezoneX"; - y = "safezoneY"; - w = "safezoneW"; - h = "safezoneH"; - font = "PuristaMedium"; - SizeEx = "(((((safezoneW / safezoneH) min 1.2) / 1.2) / 25) * 1)"; - colorText[] = {1,1,1,1}; - colorBackground[] = {1,1,1,1}; - text = "cse\cse_gui\data\logo_black_background.paa"; - onMouseButtonClick = "closeDialog 432350;"; - }; - - }; - - class controls { - - }; -}; diff --git a/TO_MERGE/cse/gui/gui/define.hpp b/TO_MERGE/cse/gui/gui/define.hpp deleted file mode 100644 index c521de470f..0000000000 --- a/TO_MERGE/cse/gui/gui/define.hpp +++ /dev/null @@ -1,797 +0,0 @@ - -#ifndef CSE_DEFINE_H -#define CSE_DEFINE_H -// define.hpp - -#define true 1 -#define false 0 - -#define CT_STATIC 0 -#define CT_BUTTON 1 -#define CT_EDIT 2 -#define CT_SLIDER 3 -#define CT_COMBO 4 -#define CT_LISTBOX 5 -#define CT_TOOLBOX 6 -#define CT_CHECKBOXES 7 -#define CT_PROGRESS 8 -#define CT_HTML 9 -#define CT_STATIC_SKEW 10 -#define CT_ACTIVETEXT 11 -#define CT_TREE 12 -#define CT_STRUCTURED_TEXT 13 -#define CT_CONTEXT_MENU 14 -#define CT_CONTROLS_GROUP 15 -#define CT_SHORTCUTBUTTON 16 -#define CT_XKEYDESC 40 -#define CT_XBUTTON 41 -#define CT_XLISTBOX 42 -#define CT_XSLIDER 43 -#define CT_XCOMBO 44 -#define CT_ANIMATED_TEXTURE 45 -#define CT_OBJECT 80 -#define CT_OBJECT_ZOOM 81 -#define CT_OBJECT_CONTAINER 82 -#define CT_OBJECT_CONT_ANIM 83 -#define CT_LINEBREAK 98 -#define CT_ANIMATED_USER 99 -#define CT_MAP 100 -#define CT_MAP_MAIN 101 -#define CT_LISTNBOX 102 - -// Static styles -#define ST_POS 0x0F -#define ST_HPOS 0x03 -#define ST_VPOS 0x0C -#define ST_LEFT 0x00 -#define ST_RIGHT 0x01 -#define ST_CENTER 0x02 -#define ST_DOWN 0x04 -#define ST_UP 0x08 -#define ST_VCENTER 0x0c - -#define ST_TYPE 0xF0 -#define ST_SINGLE 0 -#define ST_MULTI 16 -#define ST_TITLE_BAR 32 -#define ST_PICTURE 48 -#define ST_FRAME 64 -#define ST_BACKGROUND 80 -#define ST_GROUP_BOX 96 -#define ST_GROUP_BOX2 112 -#define ST_HUD_BACKGROUND 128 -#define ST_TILE_PICTURE 144 -#define ST_WITH_RECT 160 -#define ST_LINE 176 - -#define ST_SHADOW 0x100 -#define ST_NO_RECT 0x200 // this style works for CT_STATIC in conjunction with ST_MULTI -#define ST_KEEP_ASPECT_RATIO 0x800 - -#define ST_TITLE ST_TITLE_BAR + ST_CENTER - -// Slider styles -#define SL_DIR 0x400 -#define SL_VERT 0 -#define SL_HORZ 0x400 - -#define SL_TEXTURES 0x10 - -// Listbox styles -#define LB_TEXTURES 0x10 -#define LB_MULTI 0x20 -#define FontCSE "PuristaMedium" - -class cse_gui_backgroundBase { - type = CT_STATIC; - idc = -1; - style = ST_PICTURE; - colorBackground[] = {0,0,0,0}; - colorText[] = {1, 1, 1, 1}; - font = FontCSE; - text = ""; - sizeEx = 0.032; -}; -class cse_gui_editBase -{ - access = 0; - type = 2; - x = 0; - y = 0; - h = 0.04; - w = 0.2; - colorBackground[] = - { - 0, - 0, - 0, - 1 - }; - colorText[] = - { - 0.95, - 0.95, - 0.95, - 1 - }; - colorSelection[] = - { - "(profilenamespace getvariable ['GUI_BCG_RGB_R',0.3843])", - "(profilenamespace getvariable ['GUI_BCG_RGB_G',0.7019])", - "(profilenamespace getvariable ['GUI_BCG_RGB_B',0.8862])", - 1 - }; - autocomplete = ""; - text = ""; - size = 0.2; - style = "0x00 + 0x40"; - font = "PuristaMedium"; - shadow = 2; - sizeEx = "(((((safezoneW / safezoneH) min 1.2) / 1.2) / 25) * 1)"; - colorDisabled[] = - { - 1, - 1, - 1, - 0.25 - }; -}; - - - -class cse_gui_buttonBase { - idc = -1; - type = 16; - style = ST_LEFT; - text = ""; - action = ""; - x = 0.0; - y = 0.0; - w = 0.25; - h = 0.04; - size = 0.03921; - sizeEx = 0.03921; - color[] = {1.0, 1.0, 1.0, 1}; - color2[] = {1.0, 1.0, 1.0, 1}; - /*colorBackground[] = {"(profilenamespace getvariable ['GUI_BCG_RGB_R',0.69])","(profilenamespace getvariable ['GUI_BCG_RGB_G',0.75])","(profilenamespace getvariable ['GUI_BCG_RGB_B',0.5])", "(profilenamespace getvariable ['GUI_BCG_RGB_A',0.5])"}; - colorbackground2[] = {"(profilenamespace getvariable ['GUI_BCG_RGB_R',0.69])","(profilenamespace getvariable ['GUI_BCG_RGB_G',0.75])","(profilenamespace getvariable ['GUI_BCG_RGB_B',0.5])", 0.4}; - colorDisabled[] = {"(profilenamespace getvariable ['GUI_BCG_RGB_R',0.69])","(profilenamespace getvariable ['GUI_BCG_RGB_G',0.75])","(profilenamespace getvariable ['GUI_BCG_RGB_B',0.5])", 0.25}; - colorFocused[] = {"(profilenamespace getvariable ['IGUI_TEXT_RGB_R',0])","(profilenamespace getvariable ['IGUI_TEXT_RGB_G',1])","(profilenamespace getvariable ['IGUI_TEXT_RGB_B',1])","(profilenamespace getvariable ['IGUI_TEXT_RGB_A',0.8])", 0.8}; - colorBackgroundFocused[] = {"(profilenamespace getvariable ['GUI_BCG_RGB_R',0.69])","(profilenamespace getvariable ['GUI_BCG_RGB_G',0.75])","(profilenamespace getvariable ['GUI_BCG_RGB_B',0.5])", 0.8}; - */ - - colorBackground[] = {1,1,1,0.95}; - colorbackground2[] = {1,1,1,0.95}; - colorDisabled[] = {1,1,1,0.6}; - colorFocused[] = {1,1,1,1}; - colorBackgroundFocused[] = {1,1,1,1}; - periodFocus = 1.2; - periodOver = 0.8; - default = false; - class HitZone { - left = 0.00; - top = 0.00; - right = 0.00; - bottom = 0.00; - }; - - class ShortcutPos { - left = 0.00; - top = 0.00; - w = 0.00; - h = 0.00; - }; - - class TextPos { - left = 0.002; - top = 0.0004; - right = 0.0; - bottom = 0.00; - }; - textureNoShortcut = ""; - animTextureNormal = "cse\cse_gui\data\buttonNormal_gradient_top.paa"; - animTextureDisabled = "cse\cse_gui\data\buttonDisabled_gradient.paa"; - animTextureOver = "cse\cse_gui\data\buttonNormal_gradient_top.paa"; - animTextureFocused = "cse\cse_gui\data\buttonNormal_gradient_top.paa"; - animTexturePressed = "cse\cse_gui\data\buttonNormal_gradient_top.paa"; - animTextureDefault = "cse\cse_gui\data\buttonNormal_gradient_top.paa"; - period = 0.5; - font = FontCSE; - soundClick[] = {"\A3\ui_f\data\sound\RscButton\soundClick",0.09,1}; - soundPush[] = {"\A3\ui_f\data\sound\RscButton\soundPush",0.0,0}; - soundEnter[] = {"\A3\ui_f\data\sound\RscButton\soundEnter",0.07,1}; - soundEscape[] = {"\A3\ui_f\data\sound\RscButton\soundEscape",0.09,1}; - class Attributes { - font = FontCSE; - color = "#E5E5E5"; - align = "center"; - shadow = "true"; - }; - class AttributesImage { - font = FontCSE; - color = "#E5E5E5"; - align = "left"; - shadow = "true"; - }; -}; - -class cse_gui_RscProgress { - type = 8; - style = 0; - colorFrame[] = {1,1,1,0.7}; - colorBar[] = {1,1,1,0.7}; - texture = "#(argb,8,8,3)color(1,1,1,0.7)"; - x = "1 * (((safezoneW / safezoneH) min 1.2) / 40) + (safezoneX + (safezoneW - ((safezoneW / safezoneH) min 1.2))/2)"; - y = "10 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + (safezoneH - (((safezoneW / safezoneH) min 1.2) / 1.2))/2)"; - w = "38 * (((safezoneW / safezoneH) min 1.2) / 40)"; - h = "0.5 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25)"; -}; - - -class cse_gui_staticBase { - idc = -1; - type = CT_STATIC; - x = 0.0; - y = 0.0; - w = 0.183825; - h = 0.104575; - style = ST_LEFT; - font = FontCSE; - sizeEx = 0.03921; - colorText[] = {0.95, 0.95, 0.95, 1.0}; - colorBackground[] = {0, 0, 0, 0}; - text = ""; -}; - -class RscListBox; -class cse_gui_listBoxBase : RscListBox{ - type = CT_LISTBOX; - style = ST_MULTI; - font = FontCSE; - sizeEx = 0.03921; - color[] = {1, 1, 1, 1}; - colorText[] = {0.543, 0.5742, 0.4102, 1.0}; - colorScrollbar[] = {0.95, 0.95, 0.95, 1}; - colorSelect[] = {0.95, 0.95, 0.95, 1}; - colorSelect2[] = {0.95, 0.95, 0.95, 1}; - colorSelectBackground[] = {0, 0, 0, 1}; - colorSelectBackground2[] = {0.543, 0.5742, 0.4102, 1.0}; - colorDisabled[] = {"(profilenamespace getvariable ['GUI_BCG_RGB_R',0.69])","(profilenamespace getvariable ['GUI_BCG_RGB_G',0.75])","(profilenamespace getvariable ['GUI_BCG_RGB_B',0.5])", 0.25}; - period = 1.2; - rowHeight = 0.03; - colorBackground[] = {0, 0, 0, 1}; - maxHistoryDelay = 1.0; - autoScrollSpeed = -1; - autoScrollDelay = 5; - autoScrollRewind = 0; - soundSelect[] = {"",0.1,1}; - soundExpand[] = {"",0.1,1}; - soundCollapse[] = {"",0.1,1}; - class ListScrollBar { - arrowEmpty = "\A3\ui_f\data\gui\cfg\scrollbar\arrowEmpty_ca.paa"; - arrowFull = "\A3\ui_f\data\gui\cfg\scrollbar\arrowFull_ca.paa"; - autoScrollDelay = 5; - autoScrollEnabled = 0; - autoScrollRewind = 0; - autoScrollSpeed = -1; - border = "\A3\ui_f\data\gui\cfg\scrollbar\border_ca.paa"; - color[] = {1,1,1,0.6}; - colorActive[] = {1,1,1,1}; - colorDisabled[] = {1,1,1,0.3}; - height = 0; - scrollSpeed = 0.06; - shadow = 0; - thumb = "\A3\ui_f\data\gui\cfg\scrollbar\thumb_ca.paa"; - width = 0; - }; - class ScrollBar { - color[] = {1, 1, 1, 0.6}; - colorActive[] = {1, 1, 1, 1}; - colorDisabled[] = {1, 1, 1, 0.3}; - thumb = ""; - arrowFull = ""; - arrowEmpty = ""; - border = ""; - }; -}; - - -class cse_gui_listNBox { - access = 0; - type = CT_LISTNBOX;// 102; - style =ST_MULTI; - w = 0.4; - h = 0.4; - font = FontCSE; - sizeEx = 0.031; - - autoScrollSpeed = -1; - autoScrollDelay = 5; - autoScrollRewind = 0; - arrowEmpty = "#(argb,8,8,3)color(1,1,1,1)"; - arrowFull = "#(argb,8,8,3)color(1,1,1,1)"; - columns[] = {0.0}; - color[] = {1, 1, 1, 1}; - - rowHeight = 0.03; - colorBackground[] = {0, 0, 0, 0.2}; - colorText[] = {1,1, 1, 1.0}; - colorScrollbar[] = {0.95, 0.95, 0.95, 1}; - colorSelect[] = {0.95, 0.95, 0.95, 1}; - colorSelect2[] = {0.95, 0.95, 0.95, 1}; - colorSelectBackground[] = {0, 0, 0, 0.0}; - colorSelectBackground2[] = {0.0, 0.0, 0.0, 0.5}; - colorActive[] = {0,0,0,1}; - colorDisabled[] = {0,0,0,0.3}; - rows = 1; - - drawSideArrows = 0; - idcLeft = -1; - idcRight = -1; - maxHistoryDelay = 1; - soundSelect[] = {"", 0.1, 1}; - period = 1; - shadow = 2; - class ScrollBar { - arrowEmpty = "#(argb,8,8,3)color(1,1,1,1)"; - arrowFull = "#(argb,8,8,3)color(1,1,1,1)"; - border = "#(argb,8,8,3)color(1,1,1,1)"; - color[] = {1,1,1,0.6}; - colorActive[] = {1,1,1,1}; - colorDisabled[] = {1,1,1,0.3}; - thumb = "#(argb,8,8,3)color(1,1,1,1)"; - }; - class ListScrollBar { - arrowEmpty = "\A3\ui_f\data\gui\cfg\scrollbar\arrowEmpty_ca.paa"; - arrowFull = "\A3\ui_f\data\gui\cfg\scrollbar\arrowFull_ca.paa"; - autoScrollDelay = 5; - autoScrollEnabled = 0; - autoScrollRewind = 0; - autoScrollSpeed = -1; - border = "\A3\ui_f\data\gui\cfg\scrollbar\border_ca.paa"; - color[] = {1,1,1,0.6}; - colorActive[] = {1,1,1,1}; - colorDisabled[] = {1,1,1,0.3}; - height = 0; - scrollSpeed = 0.06; - shadow = 0; - thumb = "\A3\ui_f\data\gui\cfg\scrollbar\thumb_ca.paa"; - width = 0; - }; -}; - - -class RscCombo; -class cse_gui_comboBoxBase: RscCombo { - idc = -1; - type = 4; - style = "0x10 + 0x200"; - x = 0; - y = 0; - w = 0.3; - h = 0.035; - color[] = {0,0,0,0.6}; - colorActive[] = {1,0,0,1}; - colorBackground[] = {0,0,0,1}; - colorDisabled[] = {1,1,1,0.25}; - colorScrollbar[] = {1,0,0,1}; - colorSelect[] = {0,0,0,1}; - colorSelectBackground[] = {1,1,1,0.7}; - colorText[] = {1,1,1,1}; - - arrowEmpty = ""; - arrowFull = ""; - wholeHeight = 0.45; - font = FontCSE; - sizeEx = 0.031; - soundSelect[] = {"\A3\ui_f\data\sound\RscCombo\soundSelect",0.1,1}; - soundExpand[] = {"\A3\ui_f\data\sound\RscCombo\soundExpand",0.1,1}; - soundCollapse[] = {"\A3\ui_f\data\sound\RscCombo\soundCollapse",0.1,1}; - maxHistoryDelay = 1.0; - class ScrollBar - { - color[] = {0.3,0.3,0.3,0.6}; - colorActive[] = {0.3,0.3,0.3,1}; - colorDisabled[] = {0.3,0.3,0.3,0.3}; - thumb = "\A3\ui_f\data\gui\cfg\scrollbar\thumb_ca.paa"; - arrowEmpty = "\A3\ui_f\data\gui\cfg\scrollbar\arrowEmpty_ca.paa"; - arrowFull = "\A3\ui_f\data\gui\cfg\scrollbar\arrowFull_ca.paa"; - border = ""; - }; - class ComboScrollBar { - arrowEmpty = "\A3\ui_f\data\gui\cfg\scrollbar\arrowEmpty_ca.paa"; - arrowFull = "\A3\ui_f\data\gui\cfg\scrollbar\arrowFull_ca.paa"; - autoScrollDelay = 5; - autoScrollEnabled = 0; - autoScrollRewind = 0; - autoScrollSpeed = -1; - border = "\A3\ui_f\data\gui\cfg\scrollbar\border_ca.paa"; - color[] = {0.3,0.3,0.3,0.6}; - colorActive[] = {0.3,0.3,0.3,1}; - colorDisabled[] = {0.3,0.3,0.3,0.3}; - height = 0; - scrollSpeed = 0.06; - shadow = 0; - thumb = "\A3\ui_f\data\gui\cfg\scrollbar\thumb_ca.paa"; - width = 0; - }; -}; - - - -class cse_gui_mapBase { - moveOnEdges = 1; - x = "SafeZoneXAbs"; - y = "SafeZoneY + 1.5 * ( ( ((safezoneW / safezoneH) min 1.2) / 1.2) / 25)"; - w = "SafeZoneWAbs"; - h = "SafeZoneH - 1.5 * ( ( ((safezoneW / safezoneH) min 1.2) / 1.2) / 25)"; - type = 100; // Use 100 to hide markers - style = 48; - shadow = 0; - - ptsPerSquareSea = 5; - ptsPerSquareTxt = 3; - ptsPerSquareCLn = 10; - ptsPerSquareExp = 10; - ptsPerSquareCost = 10; - ptsPerSquareFor = 9; - ptsPerSquareForEdge = 9; - ptsPerSquareRoad = 6; - ptsPerSquareObj = 9; - showCountourInterval = 0; - scaleMin = 0.001; - scaleMax = 1.0; - scaleDefault = 0.16; - maxSatelliteAlpha = 0.85; - alphaFadeStartScale = 0.35; - alphaFadeEndScale = 0.4; - colorBackground[] = {0.969,0.957,0.949,1.0}; - colorSea[] = {0.467,0.631,0.851,0.5}; - colorForest[] = {0.624,0.78,0.388,0.5}; - colorForestBorder[] = {0.0,0.0,0.0,0.0}; - colorRocks[] = {0.0,0.0,0.0,0.3}; - colorRocksBorder[] = {0.0,0.0,0.0,0.0}; - colorLevels[] = {0.286,0.177,0.094,0.5}; - colorMainCountlines[] = {0.572,0.354,0.188,0.5}; - colorCountlines[] = {0.572,0.354,0.188,0.25}; - colorMainCountlinesWater[] = {0.491,0.577,0.702,0.6}; - colorCountlinesWater[] = {0.491,0.577,0.702,0.3}; - colorPowerLines[] = {0.1,0.1,0.1,1.0}; - colorRailWay[] = {0.8,0.2,0.0,1.0}; - colorNames[] = {0.1,0.1,0.1,0.9}; - colorInactive[] = {1.0,1.0,1.0,0.5}; - colorOutside[] = {0.0,0.0,0.0,1.0}; - colorTracks[] = {0.84,0.76,0.65,0.15}; - colorTracksFill[] = {0.84,0.76,0.65,1.0}; - colorRoads[] = {0.7,0.7,0.7,1.0}; - colorRoadsFill[] = {1.0,1.0,1.0,1.0}; - colorMainRoads[] = {0.9,0.5,0.3,1.0}; - colorMainRoadsFill[] = {1.0,0.6,0.4,1.0}; - colorGrid[] = {0.1,0.1,0.1,0.6}; - colorGridMap[] = {0.1,0.1,0.1,0.6}; - colorText[] = {1, 1, 1, 0.85}; -font = "PuristaMedium"; -sizeEx = 0.0270000; -stickX[] = {0.20, {"Gamma", 1.00, 1.50} }; -stickY[] = {0.20, {"Gamma", 1.00, 1.50} }; -onMouseButtonClick = ""; -onMouseButtonDblClick = ""; - - fontLabel = "PuristaMedium"; - sizeExLabel = "( ( ( ((safezoneW / safezoneH) min 1.2) / 1.2) / 25) * 0.8)"; - fontGrid = "TahomaB"; - sizeExGrid = 0.02; - fontUnits = "TahomaB"; - sizeExUnits = "( ( ( ((safezoneW / safezoneH) min 1.2) / 1.2) / 25) * 0.8)"; - fontNames = "PuristaMedium"; - sizeExNames = "( ( ( ((safezoneW / safezoneH) min 1.2) / 1.2) / 25) * 0.8) * 2"; - fontInfo = "PuristaMedium"; - sizeExInfo = "( ( ( ((safezoneW / safezoneH) min 1.2) / 1.2) / 25) * 0.8)"; - fontLevel = "TahomaB"; - sizeExLevel = 0.02; - text = "#(argb,8,8,3)color(1,1,1,1)"; - class ActiveMarker { - color[] = {0.30, 0.10, 0.90, 1.00}; - size = 50; - }; - class Legend - { - x = "SafeZoneX + ( ((safezoneW / safezoneH) min 1.2) / 40)"; - y = "SafeZoneY + safezoneH - 4.5 * ( ( ((safezoneW / safezoneH) min 1.2) / 1.2) / 25)"; - w = "10 * ( ((safezoneW / safezoneH) min 1.2) / 40)"; - h = "3.5 * ( ( ((safezoneW / safezoneH) min 1.2) / 1.2) / 25)"; - font = "PuristaMedium"; - sizeEx = "( ( ( ((safezoneW / safezoneH) min 1.2) / 1.2) / 25) * 0.8)"; - colorBackground[] = {1,1,1,0.5}; - color[] = {0,0,0,1}; - }; - class Task - { - icon = "\A3\ui_f\data\map\mapcontrol\taskIcon_CA.paa"; - iconCreated = "\A3\ui_f\data\map\mapcontrol\taskIconCreated_CA.paa"; - iconCanceled = "\A3\ui_f\data\map\mapcontrol\taskIconCanceled_CA.paa"; - iconDone = "\A3\ui_f\data\map\mapcontrol\taskIconDone_CA.paa"; - iconFailed = "\A3\ui_f\data\map\mapcontrol\taskIconFailed_CA.paa"; - color[] = {"(profilenamespace getvariable ['IGUI_TEXT_RGB_R',0])","(profilenamespace getvariable ['IGUI_TEXT_RGB_G',1])","(profilenamespace getvariable ['IGUI_TEXT_RGB_B',1])","(profilenamespace getvariable ['IGUI_TEXT_RGB_A',0.8])"}; - colorCreated[] = {1,1,1,1}; - colorCanceled[] = {0.7,0.7,0.7,1}; - colorDone[] = {0.7,1,0.3,1}; - colorFailed[] = {1,0.3,0.2,1}; - size = 27; - importance = 1; - coefMin = 1; - coefMax = 1; - }; - class Waypoint - { - icon = "\A3\ui_f\data\map\mapcontrol\waypoint_ca.paa"; - color[] = {0,0,0,1}; - size = 20; - importance = "1.2 * 16 * 0.05"; - coefMin = 0.900000; - coefMax = 4; - }; - class WaypointCompleted - { - icon = "\A3\ui_f\data\map\mapcontrol\waypointCompleted_ca.paa"; - color[] = {0,0,0,1}; - size = 20; - importance = "1.2 * 16 * 0.05"; - coefMin = 0.900000; - coefMax = 4; - }; - class CustomMark - { - icon = "\A3\ui_f\data\map\mapcontrol\custommark_ca.paa"; - size = 24; - importance = 1; - coefMin = 1; - coefMax = 1; - color[] = {0,0,0,1}; - }; - class Command - { - icon = "\A3\ui_f\data\map\mapcontrol\waypoint_ca.paa"; - size = 18; - importance = 1; - coefMin = 1; - coefMax = 1; - color[] = {1,1,1,1}; - }; - class Bush - { - icon = "\A3\ui_f\data\map\mapcontrol\bush_ca.paa"; - color[] = {0.45,0.64,0.33,0.4}; - size = "14/2"; - importance = "0.2 * 14 * 0.05 * 0.05"; - coefMin = 0.25; - coefMax = 4; - }; - class Rock - { - icon = "\A3\ui_f\data\map\mapcontrol\rock_ca.paa"; - color[] = {0.1,0.1,0.1,0.8}; - size = 12; - importance = "0.5 * 12 * 0.05"; - coefMin = 0.25; - coefMax = 4; - }; - class SmallTree - { - icon = "\A3\ui_f\data\map\mapcontrol\bush_ca.paa"; - color[] = {0.45,0.64,0.33,0.4}; - size = 12; - importance = "0.6 * 12 * 0.05"; - coefMin = 0.25; - coefMax = 4; - }; - class Tree - { - icon = "\A3\ui_f\data\map\mapcontrol\bush_ca.paa"; - color[] = {0.45,0.64,0.33,0.4}; - size = 12; - importance = "0.9 * 16 * 0.05"; - coefMin = 0.25; - coefMax = 4; - }; - class busstop - { - icon = "\A3\ui_f\data\map\mapcontrol\busstop_CA.paa"; - size = 24; - importance = 1; - coefMin = 0.85; - coefMax = 1.0; - color[] = {1,1,1,1}; - }; - class fuelstation - { - icon = "\A3\ui_f\data\map\mapcontrol\fuelstation_CA.paa"; - size = 24; - importance = 1; - coefMin = 0.85; - coefMax = 1.0; - color[] = {1,1,1,1}; - }; - class hospital - { - icon = "\A3\ui_f\data\map\mapcontrol\hospital_CA.paa"; - size = 24; - importance = 1; - coefMin = 0.85; - coefMax = 1.0; - color[] = {1,1,1,1}; - }; - class church - { - icon = "\A3\ui_f\data\map\mapcontrol\church_CA.paa"; - size = 24; - importance = 1; - coefMin = 0.85; - coefMax = 1.0; - color[] = {1,1,1,1}; - }; - class lighthouse - { - icon = "\A3\ui_f\data\map\mapcontrol\lighthouse_CA.paa"; - size = 24; - importance = 1; - coefMin = 0.85; - coefMax = 1.0; - color[] = {1,1,1,1}; - }; - class power - { - icon = "\A3\ui_f\data\map\mapcontrol\power_CA.paa"; - size = 24; - importance = 1; - coefMin = 0.85; - coefMax = 1.0; - color[] = {1,1,1,1}; - }; - class powersolar - { - icon = "\A3\ui_f\data\map\mapcontrol\powersolar_CA.paa"; - size = 24; - importance = 1; - coefMin = 0.85; - coefMax = 1.0; - color[] = {1,1,1,1}; - }; - class powerwave - { - icon = "\A3\ui_f\data\map\mapcontrol\powerwave_CA.paa"; - size = 24; - importance = 1; - coefMin = 0.85; - coefMax = 1.0; - color[] = {1,1,1,1}; - }; - class powerwind - { - icon = "\A3\ui_f\data\map\mapcontrol\powerwind_CA.paa"; - size = 24; - importance = 1; - coefMin = 0.85; - coefMax = 1.0; - color[] = {1,1,1,1}; - }; - class quay - { - icon = "\A3\ui_f\data\map\mapcontrol\quay_CA.paa"; - size = 24; - importance = 1; - coefMin = 0.85; - coefMax = 1.0; - color[] = {1,1,1,1}; - }; - class shipwreck - { - icon = "\A3\ui_f\data\map\mapcontrol\shipwreck_CA.paa"; - size = 24; - importance = 1; - coefMin = 0.85; - coefMax = 1.0; - color[] = {1,1,1,1}; - }; - class transmitter - { - icon = "\A3\ui_f\data\map\mapcontrol\transmitter_CA.paa"; - size = 24; - importance = 1; - coefMin = 0.85; - coefMax = 1.0; - color[] = {1,1,1,1}; - }; - class watertower - { - icon = "\A3\ui_f\data\map\mapcontrol\watertower_CA.paa"; - size = 24; - importance = 1; - coefMin = 0.85; - coefMax = 1.0; - color[] = {1,1,1,1}; - }; - class Cross - { - icon = "\A3\ui_f\data\map\mapcontrol\Cross_CA.paa"; - size = 24; - importance = 1; - coefMin = 0.85; - coefMax = 1.0; - color[] = {0,0,0,1}; - }; - class Chapel - { - icon = "\A3\ui_f\data\map\mapcontrol\Chapel_CA.paa"; - size = 24; - importance = 1; - coefMin = 0.85; - coefMax = 1.0; - color[] = {0,0,0,1}; - }; - class Bunker - { - icon = "\A3\ui_f\data\map\mapcontrol\bunker_ca.paa"; - size = 14; - importance = "1.5 * 14 * 0.05"; - coefMin = 0.25; - coefMax = 4; - color[] = {0,0,0,1}; - }; - class Fortress - { - icon = "\A3\ui_f\data\map\mapcontrol\bunker_ca.paa"; - size = 16; - importance = "2 * 16 * 0.05"; - coefMin = 0.25; - coefMax = 4; - color[] = {0,0,0,1}; - }; - class Fountain - { - icon = "\A3\ui_f\data\map\mapcontrol\fountain_ca.paa"; - size = 11; - importance = "1 * 12 * 0.05"; - coefMin = 0.25; - coefMax = 4; - color[] = {0,0,0,1}; - }; - class Ruin - { - icon = "\A3\ui_f\data\map\mapcontrol\ruin_ca.paa"; - size = 16; - importance = "1.2 * 16 * 0.05"; - coefMin = 1; - coefMax = 4; - color[] = {0,0,0,1}; - }; - class Stack - { - icon = "\A3\ui_f\data\map\mapcontrol\stack_ca.paa"; - size = 20; - importance = "2 * 16 * 0.05"; - coefMin = 0.9; - coefMax = 4; - color[] = {0,0,0,1}; - }; - class Tourism - { - icon = "\A3\ui_f\data\map\mapcontrol\tourism_ca.paa"; - size = 16; - importance = "1 * 16 * 0.05"; - coefMin = 0.7; - coefMax = 4; - color[] = {0,0,0,1}; - }; - class ViewTower - { - icon = "\A3\ui_f\data\map\mapcontrol\viewtower_ca.paa"; - size = 16; - importance = "2.5 * 16 * 0.05"; - coefMin = 0.5; - coefMax = 4; - color[] = {0,0,0,1}; - }; -}; - -#endif \ No newline at end of file diff --git a/TO_MERGE/cse/gui/gui/dynamicMenu.h b/TO_MERGE/cse/gui/gui/dynamicMenu.h deleted file mode 100644 index 1ae5206fe2..0000000000 --- a/TO_MERGE/cse/gui/gui/dynamicMenu.h +++ /dev/null @@ -1,12 +0,0 @@ -class cse_dynamicMenuGUI { - idd = 176890; - movingEnable = false; - onLoad = "uiNamespace setVariable ['cse_dynamicMenuGUI', _this select 0];"; - - class controlsBackground { - }; - - class controls { - - }; -}; \ No newline at end of file diff --git a/TO_MERGE/cse/gui/gui/interactionMenu.hpp b/TO_MERGE/cse/gui/gui/interactionMenu.hpp deleted file mode 100644 index b93918c407..0000000000 --- a/TO_MERGE/cse/gui/gui/interactionMenu.hpp +++ /dev/null @@ -1,494 +0,0 @@ -class cse_interactionGUI { - idd = 145201; - movingEnable = false; - onLoad = "uiNamespace setVariable ['cse_interactionGUI', _this select 0];"; - - - class controlsBackground { - class cse_background : cse_gui_backgroundBase { - idc = -1; - x = 0.138; - y = 0.17; - w = 1.2549; - h = 0.836601; - text = ""; - }; - }; - - class controls { - - class cse_interactionName { - idc = 111; - type = CT_STATIC; - x = 10.44; - y = 10.75; - w = 0.3; - h = 0.04; - style = ST_CENTER + ST_SHADOW; - font = "PuristaMedium"; - sizeEx = 0.0406536; - colorText[] = {0.95, 0.95, 0.95, 1}; - //colorBackground[] = {1, 1, 1, 0}; - colorBackground[] = {"(profilenamespace getvariable ['GUI_BCG_RGB_R',0.69])","(profilenamespace getvariable ['GUI_BCG_RGB_G',0.75])","(profilenamespace getvariable ['GUI_BCG_RGB_B',0.5])", 0.9}; - text = ""; - }; - class cse_subMenuName: cse_interactionName { - idc = 112; - }; - class cse_subSubMenuName: cse_interactionName { - idc = 113; - }; - - class cse_option1 : cse_gui_buttonBase { - - idc = 150; - text = ""; - onButtonClick = ""; - x = 10.4; // add 5 to each - y = 10.45; - w = 0.3; - h = 0.04; - color[] = {1, 1, 1, 1}; - color2[] = {0,0,0, 1}; - colorText[] = {1, 1, 1,1}; - colorBackground[] = {1,1,1,0.95}; - colorbackground2[] = {1,1,1,0.95}; - colorDisabled[] = {1,1,1,0.6}; - colorFocused[] = {0,0,0,1}; - colorBackgroundFocused[] = {1,1,1,1}; - animTextureNormal = "cse\cse_gui\data\buttonNormal_gradient_top.paa"; - animTextureDisabled = "cse\cse_gui\data\buttonDisabled_gradient.paa"; - animTextureOver = "cse\cse_gui\data\buttonNormal_gradient_top_w.paa"; - animTextureFocused = "cse\cse_gui\data\buttonNormal_gradient_top_w.paa"; - animTexturePressed = "cse\cse_gui\data\buttonNormal_gradient_top_w.paa"; - animTextureDefault = "cse\cse_gui\data\buttonNormal_gradient_top.paa"; - - /* animTextureNormal = ""; - animTextureDisabled = ""; - animTextureOver = ""; - animTextureFocused = ""; - animTexturePressed = ""; - animTextureDefault = ""; */ - }; - class cse_option2 : cse_option1 { - idc = 151; - text = ""; - onButtonClick = ""; - x = 10.4; - y = 10.5; - }; - class cse_option3 : cse_option1 { - idc = 152; - text = ""; - onButtonClick = ""; - x = 10.4; - y = 10.55; - }; - class cse_option4 : cse_option1 { - idc = 153; - text = ""; - onButtonClick = ""; - x = 10.4; - y = 10.6; - }; - class cse_option5 : cse_option1 { - idc = 154; - text = ""; - onButtonClick = ""; - x = 10.4; - y = 10.65; - }; - class cse_option6 : cse_option1 { - idc = 155; - text = ""; - onButtonClick = ""; - x = 10.4; - y = 10.7; - }; - class cse_option7 : cse_option1 { - idc = 156; - text = ""; - onButtonClick = ""; - x = 10.4; - y = 10.75; - }; - class cse_option8 : cse_option1 { - idc = 157; - text = ""; - onButtonClick = ""; - x = 10.4; - y = 10.8; - }; - class cse_option9 : cse_option1 { - idc = 158; - text = ""; - onButtonClick = ""; - x = 10.4; - y = 10.85; - }; - class cse_option10 : cse_option1 { - idc = 159; - text = ""; - onButtonClick = ""; - x = 10.4; - y = 10.9; - }; - class cse_option11 : cse_option1 { - idc = 160; - text = ""; - onButtonClick = ""; - x = 10.4; - y = 10.9; - }; - class cse_option12 : cse_option1 { - idc = 161; - text = ""; - onButtonClick = ""; - x = 10.4; - y = 10.9; - }; - class cse_option13 : cse_option1 { - idc = 162; - text = ""; - onButtonClick = ""; - x = 10.4; - y = 10.9; - }; - class cse_option14 : cse_option1 { - idc = 163; - text = ""; - onButtonClick = ""; - x = 10.4; - y = 10.9; - }; - class cse_option15 : cse_option1 { - idc = 164; - text = ""; - onButtonClick = ""; - x = 10.4; - y = 10.9; - }; - - - // Sub menu Options - class cse_subMenuButton1 : cse_option1 { - idc = 201; - text = ""; - onButtonClick = ""; - x = 10.88; - y = 10.75; - }; - class cse_subMenuButton2 : cse_option1 { - idc = 202; - text = ""; - onButtonClick = ""; - x = 10.88; - y = 10.8; - }; - class cse_subMenuButton3 : cse_option1 { - idc = 203; - text = ""; - onButtonClick = ""; - x = 10.88; - y = 10.85; - }; - class cse_subMenuButton4 : cse_option1 { - idc = 204; - text = ""; - onButtonClick = ""; - x = 10.88; - y = 10.9; - }; - class cse_subMenuButton5 : cse_option1 { - idc = 205; - text = ""; - onButtonClick = ""; - x = 10.88; - y = 10.95; - }; - class cse_subMenuButton6 : cse_option1 { - idc = 206; - text = ""; - onButtonClick = ""; - x = 10.88; - y = 10.0; - }; - class cse_subMenuButton7 : cse_option1 { - idc = 207; - text = ""; - onButtonClick = ""; - x = 10.88; - y = 10.0; - }; - class cse_subMenuButton8 : cse_option1 { - idc = 208; - text = ""; - onButtonClick = ""; - x = 10.88; - y = 10.0; - }; - class cse_subMenuButton9 : cse_option1 { - idc = 209; - text = ""; - onButtonClick = ""; - x = 10.88; - y = 10.0; - }; - class cse_subMenuButton10 : cse_option1 { - idc = 210; - text = ""; - onButtonClick = ""; - x = 100.88; - y = 100.0; - }; - class cse_subMenuButton11 : cse_option1 { - idc = 211; - text = ""; - onButtonClick = ""; - x = 100.88; - y = 100.0; - }; - class cse_subMenuButton12 : cse_option1 { - idc = 212; - text = ""; - onButtonClick = ""; - x = 100.88; - y = 100.0; - }; - class cse_subMenuButton13 : cse_option1 { - idc = 213; - text = ""; - onButtonClick = ""; - x = 100.88; - y = 100.0; - }; - class cse_subMenuButton14 : cse_option1 { - idc = 214; - text = ""; - onButtonClick = ""; - x = 100.88; - y = 100.0; - }; - class cse_subMenuButton15 : cse_option1 { - idc = 215; - text = ""; - onButtonClick = ""; - x = 100.88; - y = 100.0; - }; - - - class cse_subMenuSub1 : cse_option1 { - idc = 301; - text = ""; - onButtonClick = ""; - x = 10.88; - y = 10.75; - }; - class cse_subMenuSub2 : cse_option1 { - idc = 302; - text = ""; - onButtonClick = ""; - x = 10.88; - y = 10.8; - }; - class cse_subMenuSub3 : cse_option1 { - idc = 303; - text = ""; - onButtonClick = ""; - x = 10.88; - y = 10.85; - }; - class cse_subMenuSub4 : cse_option1 { - idc = 304; - text = ""; - onButtonClick = ""; - x = 10.88; - y = 10.9; - }; - class cse_subMenuSub5 : cse_option1 { - idc = 305; - text = ""; - onButtonClick = ""; - x = 10.88; - y = 10.95; - }; - class cse_subMenuSub6 : cse_option1 { - idc = 306; - text = ""; - onButtonClick = ""; - x = 10.88; - y = 10.0; - }; - class cse_subMenuSub7 : cse_option1 { - idc = 307; - text = ""; - onButtonClick = ""; - x = 10.88; - y = 10.0; - }; - class cse_subMenuSub8 : cse_option1 { - idc = 308; - text = ""; - onButtonClick = ""; - x = 10.88; - y = 10.0; - }; - class cse_subMenuSub9 : cse_option1 { - idc = 309; - text = ""; - onButtonClick = ""; - x = 10.88; - y = 10.0; - }; - class cse_subMenuSub10 : cse_option1 { - idc = 310; - text = ""; - onButtonClick = ""; - x = 100.88; - y = 100.0; - }; - class cse_subMenuSub11 : cse_option1 { - idc = 311; - text = ""; - onButtonClick = ""; - x = 100.88; - y = 100.0; - }; - class cse_subMenuSub12 : cse_option1 { - idc = 312; - text = ""; - onButtonClick = ""; - x = 100.88; - y = 100.0; - }; - class cse_subMenuSub13 : cse_option1 { - idc = 313; - text = ""; - onButtonClick = ""; - x = 100.88; - y = 100.0; - }; - class cse_subMenuSub14 : cse_option1 { - idc = 314; - text = ""; - onButtonClick = ""; - x = 100.88; - y = 100.0; - }; - class cse_subMenuSub15 : cse_option1 { - idc = 315; - text = ""; - onButtonClick = ""; - x = 100.88; - y = 100.0; - }; - - class iconImg1: cse_gui_backgroundBase { - idc = 400; - x = (safezoneX + (safeZoneW - 0.1)); - y = (safezoneY + (safeZoneH - 0.1)); - w = 0.05; - h = 0.05; - size = 0.1; - SizeEx = 0.1; - colorBackground[] = {0,0,0,1}; - colorPicture[] = {1,1,1,1}; - colorText[] = {1,1,1,1}; - text = ""; - }; - - class option_tags : cse_gui_buttonBase { - idc = 500; - text = ""; - onButtonClick = ""; - x = (safezoneX + (safeZoneW - 0.1)); - y = (safezoneY + (safeZoneH - 0.1)); - w = 0.05; - h = 0.05; - class TextPos { - left = 0; - top = 0; - right = 0.0; - bottom = 0.00; - }; - animTextureNormal = ""; - animTextureDisabled = ""; - animTextureOver = ""; - animTextureFocused = ""; - animTexturePressed = ""; - animTextureDefault = ""; - }; - - class iconImg2: iconImg1 { - idc = 401; - x = (safezoneX + (safeZoneW - 0.15)); - y = (safezoneY + (safeZoneH - 0.1)); - w = 0.05; - h = 0.05; - size = 0.1; - SizeEx = 0.1; - colorBackground[] = {0,0,0,1}; - colorPicture[] = {1,1,1,1}; - colorText[] = {1,1,1,1}; - text = ""; - }; - class iconImg3: iconImg1 { - idc = 402; - x = (safezoneX + (safeZoneW - 0.2)); - y = (safezoneY + (safeZoneH - 0.1)); - w = 0.05; - h = 0.05; - size = 0.1; - SizeEx = 0.1; - colorBackground[] = {0,0,0,1}; - colorPicture[] = {1,1,1,1}; - colorText[] = {1,1,1,1}; - text = ""; - }; - - class option_icon2 : option_tags { - idc = 501; - text = ""; - onButtonClick = ""; - x = (safezoneX + (safeZoneW - 0.15)); - y = (safezoneY + (safeZoneH - 0.1)); - w = 0.05; - h = 0.05; - class TextPos { - left = 0; - top = 0; - right = 0.0; - bottom = 0.00; - }; - animTextureNormal = ""; - animTextureDisabled = ""; - animTextureOver = ""; - animTextureFocused = ""; - animTexturePressed = ""; - animTextureDefault = ""; - }; - - class option_icon3 : option_tags { - idc = 502; - text = ""; - onButtonClick = ""; - x = (safezoneX + (safeZoneW - 0.2)); - y = (safezoneY + (safeZoneH - 0.1)); - w = 0.05; - h = 0.05; - class TextPos { - left = 0; - top = 0; - right = 0.0; - bottom = 0.00; - }; - animTextureNormal = ""; - animTextureDisabled = ""; - animTextureOver = ""; - animTextureFocused = ""; - animTexturePressed = ""; - animTextureDefault = ""; - }; - }; -}; \ No newline at end of file diff --git a/TO_MERGE/cse/gui/gui/interactionMenu_white.hpp b/TO_MERGE/cse/gui/gui/interactionMenu_white.hpp deleted file mode 100644 index d32752f42d..0000000000 --- a/TO_MERGE/cse/gui/gui/interactionMenu_white.hpp +++ /dev/null @@ -1,417 +0,0 @@ -class cse_interactionGUI_w { - idd = 145201; - movingEnable = false; - onLoad = "uiNamespace setVariable ['cse_interactionGUI', _this select 0];"; - - - class controlsBackground { - class cse_background : cse_gui_backgroundBase { - idc = -1; - x = 0.138; - y = 0.17; - w = 1.2549; - h = 0.836601; - text = ""; - }; - }; - - class controls { - - class cse_interactionName { - idc = 111; - type = CT_STATIC; - x = 10.44; - y = 10.75; - w = 0.3; - h = 0.04; - style = ST_CENTER + ST_SHADOW; - font = "PuristaMedium"; - sizeEx = 0.0406536; - colorText[] = {0.95, 0.95, 0.95, 1}; - //colorBackground[] = {1, 1, 1, 0}; - colorBackground[] = {"(profilenamespace getvariable ['GUI_BCG_RGB_R',0.69])","(profilenamespace getvariable ['GUI_BCG_RGB_G',0.75])","(profilenamespace getvariable ['GUI_BCG_RGB_B',0.5])", 0.9}; - text = ""; - }; - class cse_subMenuName: cse_interactionName { - idc = 112; - }; - class cse_subSubMenuName: cse_interactionName { - idc = 113; - }; - - class cse_option1 : cse_gui_buttonBase { - - idc = 150; - text = ""; - onButtonClick = ""; - x = 10.4; // add 5 to each - y = 10.45; - w = 0.3; - h = 0.04; - color[] = {0,0,0, 1}; - color2[] = {1,1,1, 1}; - colorText[] = {0,0,0,1}; - colorBackground[] = {1,1,1,0.95}; - colorbackground2[] = {1,1,1,0.95}; - colorDisabled[] = {1,1,1,0.6}; - colorFocused[] = {0,0,0,1}; - colorBackgroundFocused[] = {1,1,1,1}; - animTextureNormal = "cse\cse_gui\data\buttonNormal_gradient_top_w.paa"; - animTextureDisabled = "cse\cse_gui\data\buttonDisabled_gradient.paa"; - animTextureOver = "cse\cse_gui\data\buttonNormal_gradient_top.paa"; - animTextureFocused = "cse\cse_gui\data\buttonNormal_gradient_top.paa"; - animTexturePressed = "cse\cse_gui\data\buttonNormal_gradient_top.paa"; - animTextureDefault = "cse\cse_gui\data\buttonNormal_gradient_top_w.paa"; - }; - class cse_option2 : cse_option1 { - idc = 151; - text = ""; - onButtonClick = ""; - x = 10.4; - y = 10.5; - }; - class cse_option3 : cse_option1 { - idc = 152; - text = ""; - onButtonClick = ""; - x = 10.4; - y = 10.55; - }; - class cse_option4 : cse_option1 { - idc = 153; - text = ""; - onButtonClick = ""; - x = 10.4; - y = 10.6; - }; - class cse_option5 : cse_option1 { - idc = 154; - text = ""; - onButtonClick = ""; - x = 10.4; - y = 10.65; - }; - class cse_option6 : cse_option1 { - idc = 155; - text = ""; - onButtonClick = ""; - x = 10.4; - y = 10.7; - }; - class cse_option7 : cse_option1 { - idc = 156; - text = ""; - onButtonClick = ""; - x = 10.4; - y = 10.75; - }; - class cse_option8 : cse_option1 { - idc = 157; - text = ""; - onButtonClick = ""; - x = 10.4; - y = 10.8; - }; - class cse_option9 : cse_option1 { - idc = 158; - text = ""; - onButtonClick = ""; - x = 10.4; - y = 10.85; - }; - class cse_option10 : cse_option1 { - idc = 159; - text = ""; - onButtonClick = ""; - x = 10.4; - y = 10.9; - }; - class cse_option11 : cse_option1 { - idc = 160; - text = ""; - onButtonClick = ""; - x = 10.4; - y = 10.9; - }; - class cse_option12 : cse_option1 { - idc = 161; - text = ""; - onButtonClick = ""; - x = 10.4; - y = 10.9; - }; - class cse_option13 : cse_option1 { - idc = 162; - text = ""; - onButtonClick = ""; - x = 10.4; - y = 10.9; - }; - class cse_option14 : cse_option1 { - idc = 163; - text = ""; - onButtonClick = ""; - x = 10.4; - y = 10.9; - }; - class cse_option15 : cse_option1 { - idc = 164; - text = ""; - onButtonClick = ""; - x = 10.4; - y = 10.9; - }; - - - // Sub menu Options - class cse_subMenuButton1 : cse_option1 { - idc = 201; - text = ""; - onButtonClick = ""; - x = 10.88; - y = 10.75; - }; - class cse_subMenuButton2 : cse_option1 { - idc = 202; - text = ""; - onButtonClick = ""; - x = 10.88; - y = 10.8; - }; - class cse_subMenuButton3 : cse_option1 { - idc = 203; - text = ""; - onButtonClick = ""; - x = 10.88; - y = 10.85; - }; - class cse_subMenuButton4 : cse_option1 { - idc = 204; - text = ""; - onButtonClick = ""; - x = 10.88; - y = 10.9; - }; - class cse_subMenuButton5 : cse_option1 { - idc = 205; - text = ""; - onButtonClick = ""; - x = 10.88; - y = 10.95; - }; - class cse_subMenuButton6 : cse_option1 { - idc = 206; - text = ""; - onButtonClick = ""; - x = 10.88; - y = 10.0; - }; - class cse_subMenuButton7 : cse_option1 { - idc = 207; - text = ""; - onButtonClick = ""; - x = 10.88; - y = 10.0; - }; - class cse_subMenuButton8 : cse_option1 { - idc = 208; - text = ""; - onButtonClick = ""; - x = 10.88; - y = 10.0; - }; - class cse_subMenuButton9 : cse_option1 { - idc = 209; - text = ""; - onButtonClick = ""; - x = 10.88; - y = 10.0; - }; - class cse_subMenuButton10 : cse_option1 { - idc = 210; - text = ""; - onButtonClick = ""; - x = 100.88; - y = 100.0; - }; - class cse_subMenuButton11 : cse_option1 { - idc = 211; - text = ""; - onButtonClick = ""; - x = 100.88; - y = 100.0; - }; - class cse_subMenuButton12 : cse_option1 { - idc = 212; - text = ""; - onButtonClick = ""; - x = 100.88; - y = 100.0; - }; - class cse_subMenuButton13 : cse_option1 { - idc = 213; - text = ""; - onButtonClick = ""; - x = 100.88; - y = 100.0; - }; - class cse_subMenuButton14 : cse_option1 { - idc = 214; - text = ""; - onButtonClick = ""; - x = 100.88; - y = 100.0; - }; - class cse_subMenuButton15 : cse_option1 { - idc = 215; - text = ""; - onButtonClick = ""; - x = 100.88; - y = 100.0; - }; - - - class cse_subMenuSub1 : cse_option1 { - idc = 301; - text = ""; - onButtonClick = ""; - x = 10.88; - y = 10.75; - }; - class cse_subMenuSub2 : cse_option1 { - idc = 302; - text = ""; - onButtonClick = ""; - x = 10.88; - y = 10.8; - }; - class cse_subMenuSub3 : cse_option1 { - idc = 303; - text = ""; - onButtonClick = ""; - x = 10.88; - y = 10.85; - }; - class cse_subMenuSub4 : cse_option1 { - idc = 304; - text = ""; - onButtonClick = ""; - x = 10.88; - y = 10.9; - }; - class cse_subMenuSub5 : cse_option1 { - idc = 305; - text = ""; - onButtonClick = ""; - x = 10.88; - y = 10.95; - }; - class cse_subMenuSub6 : cse_option1 { - idc = 306; - text = ""; - onButtonClick = ""; - x = 10.88; - y = 10.0; - }; - class cse_subMenuSub7 : cse_option1 { - idc = 307; - text = ""; - onButtonClick = ""; - x = 10.88; - y = 10.0; - }; - class cse_subMenuSub8 : cse_option1 { - idc = 308; - text = ""; - onButtonClick = ""; - x = 10.88; - y = 10.0; - }; - class cse_subMenuSub9 : cse_option1 { - idc = 309; - text = ""; - onButtonClick = ""; - x = 10.88; - y = 10.0; - }; - class cse_subMenuSub10 : cse_option1 { - idc = 310; - text = ""; - onButtonClick = ""; - x = 100.88; - y = 100.0; - }; - class cse_subMenuSub11 : cse_option1 { - idc = 311; - text = ""; - onButtonClick = ""; - x = 100.88; - y = 100.0; - }; - class cse_subMenuSub12 : cse_option1 { - idc = 312; - text = ""; - onButtonClick = ""; - x = 100.88; - y = 100.0; - }; - class cse_subMenuSub13 : cse_option1 { - idc = 313; - text = ""; - onButtonClick = ""; - x = 100.88; - y = 100.0; - }; - class cse_subMenuSub14 : cse_option1 { - idc = 314; - text = ""; - onButtonClick = ""; - x = 100.88; - y = 100.0; - }; - class cse_subMenuSub15 : cse_option1 { - idc = 315; - text = ""; - onButtonClick = ""; - x = 100.88; - y = 100.0; - }; - - class iconImg1: cse_gui_backgroundBase { - idc = 400; - x = (safezoneX + (safeZoneW - 0.1)); - y = (safezoneY + (safeZoneH - 0.1)); - w = 0.1; - h = 0.1; - size = 0.1; - SizeEx = 0.1; - colorBackground[] = {0,0,0,1}; - colorPicture[] = {1,1,1,1}; - colorText[] = {1,1,1,1}; - text = ""; - }; - - class option_tags : cse_gui_buttonBase { - idc = 500; - text = ""; - onButtonClick = ""; - x = (safezoneX + (safeZoneW - 0.1)); - y = (safezoneY + (safeZoneH - 0.1)); - w = 0.1; - h = 0.1; - class TextPos { - left = 0; - top = 0; - right = 0.0; - bottom = 0.00; - }; - animTextureNormal = ""; - animTextureDisabled = ""; - animTextureOver = ""; - animTextureFocused = ""; - animTexturePressed = ""; - animTextureDefault = ""; - }; - - }; -}; \ No newline at end of file diff --git a/TO_MERGE/cse/gui/gui/radial.h b/TO_MERGE/cse/gui/gui/radial.h deleted file mode 100644 index 2b56b40a14..0000000000 --- a/TO_MERGE/cse/gui/gui/radial.h +++ /dev/null @@ -1,648 +0,0 @@ - -class CSE_RADIAL_MENU { - idd = 432341; - movingenable = 0; - fadein = 0; - fadeout = 0; - onLoad = "uiNamespace setVariable ['CSE_RADIAL_MENU', _this select 0]; ['CSE_RADIAL_MENU', true] call cse_fnc_gui_blurScreen;"; - onUnload = "['CSE_RADIAL_MENU', false] call cse_fnc_gui_blurScreen; "; - class controlsBackground { - class backgroundTop: cse_gui_backgroundBase{ - idc = 800; - type = CT_STATIC; - x = "12.5 * (((safezoneW / safezoneH) min 1.2) / 40) + (safezoneX + (safezoneW - ((safezoneW / safezoneH) min 1.2))/2)"; - y = "7.5 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + (safezoneH - (((safezoneW / safezoneH) min 1.2) / 1.2))/2)"; - w = "15 * (((safezoneW / safezoneH) min 1.2) / 40)"; - h = "15 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25)"; - font = "PuristaMedium"; - SizeEx = "(((((safezoneW / safezoneH) min 1.2) / 1.2) / 25) * 1)"; - colorText[] = {0, 0, 0, 0.66}; - colorBackground[] = {0, 0, 0, 0.66}; - text = "cse\cse_gui\radialmenu\data\radial_background_top_w.paa"; - }; - class backgroundTopLeft: backgroundTop{ - idc = 801; - text = "cse\cse_gui\radialmenu\data\radial_background_topleft_w.paa"; - }; - class backgroundTopRight: backgroundTop{ - idc = 802; - text = "cse\cse_gui\radialmenu\data\radial_background_topright_w.paa"; - }; - class backgroundCenterLeft: backgroundTop{ - idc = 803; - text = "cse\cse_gui\radialmenu\data\radial_background_centerleft_w.paa"; - }; - class backgroundCenterRight: backgroundTop{ - idc = 804; - text = "cse\cse_gui\radialmenu\data\radial_background_centerright_w.paa"; - }; - - class backgroundBottomLeft: backgroundTop{ - idc = 805; - text = "cse\cse_gui\radialmenu\data\radial_background_bottomleft_w.paa"; - }; - class backgroundBottomRight: backgroundTop{ - idc = 806; - text = "cse\cse_gui\radialmenu\data\radial_background_bottomright_w.paa"; - }; - class backgroundBottom: backgroundTop{ - idc = 807; - text = "cse\cse_gui\radialmenu\data\radial_background_bottom_w.paa"; - }; - class backgroundCenter: backgroundTop{ - idc = 808; - text = "cse\cse_gui\radialmenu\data\radial_center_info_background.paa"; - }; - class submenu_background_topleft: cse_gui_backgroundBase{ - idc = 700; - type = CT_STATIC; - x = "5 * (((safezoneW / safezoneH) min 1.2) / 40) + (safezoneX + (safezoneW - ((safezoneW / safezoneH) min 1.2))/2)"; - y = "-1.25 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + (safezoneH - (((safezoneW / safezoneH) min 1.2) / 1.2))/2)"; - w = "30 * (((safezoneW / safezoneH) min 1.2) / 40)"; - h = "30 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25)"; - font = "PuristaMedium"; - SizeEx = "(((((safezoneW / safezoneH) min 1.2) / 1.2) / 25) * 1)"; - colorText[] = {0, 0, 0, 0.0}; - colorBackground[] = {0, 0, 0, 0.66}; - text = "cse\cse_gui\radialmenu\data\radial_submenu_topleft.paa"; - }; - class submenu_background_topright: submenu_background_topleft{ - idc = 701; - text = "cse\cse_gui\radialmenu\data\radial_submenu_topright.paa"; - }; - class submenu_background_bottomleft: submenu_background_topleft{ - idc = 702; - text = "cse\cse_gui\radialmenu\data\radial_submenu_bottomleft.paa"; - }; - class submenu_background_bottomright: submenu_background_topleft{ - idc = 703; - text = "cse\cse_gui\radialmenu\data\radial_submenu_bottomright.paa"; - }; - - - class iconCenter: cse_gui_backgroundBase{ - idc = 710; - type = CT_STATIC; - x = "18.5 * (((safezoneW / safezoneH) min 1.2) / 40) + (safezoneX + (safezoneW - ((safezoneW / safezoneH) min 1.2))/2)"; - y = "13.5 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + (safezoneH - (((safezoneW / safezoneH) min 1.2) / 1.2))/2)"; - w = "4 * (((safezoneW / safezoneH) min 1.2) / 40)"; - h = "4 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25)"; - font = "PuristaMedium"; - SizeEx = "(((((safezoneW / safezoneH) min 1.2) / 1.2) / 25) * 1)"; - colorText[] = {1,1,1, 0.4}; - colorBackground[] = {1,1,1, 0.0}; - text = ""; - }; - class iconCenter_return: cse_gui_backgroundBase{ - idc = 711; - type = CT_STATIC; - x = "19.25 * (((safezoneW / safezoneH) min 1.2) / 40) + (safezoneX + (safezoneW - ((safezoneW / safezoneH) min 1.2))/2)"; - y = "16.7 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + (safezoneH - (((safezoneW / safezoneH) min 1.2) / 1.2))/2)"; - w = "1.5 * (((safezoneW / safezoneH) min 1.2) / 40)"; - h = "1.5 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25)"; - font = "PuristaMedium"; - SizeEx = "(((((safezoneW / safezoneH) min 1.2) / 1.2) / 25) * 1)"; - colorText[] = {1,1,1, 0.4}; - colorBackground[] = {1,1,1, 0.0}; - text = "cse\cse_gui\radialmenu\data\icons\icon_return.paa"; - }; - - }; - class controls { - class LabelmenuName: cse_gui_staticBase{ - idc = 1; - x = "17 * (((safezoneW / safezoneH) min 1.2) / 40) + (safezoneX + (safezoneW - ((safezoneW / safezoneH) min 1.2))/2)"; - y = "13 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + (safezoneH - (((safezoneW / safezoneH) min 1.2) / 1.2))/2)"; - w = "6 * (((safezoneW / safezoneH) min 1.2) / 40)"; - h = "1 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25)"; - font = "PuristaMedium"; - SizeEx = "(((((safezoneW / safezoneH) min 1.2) / 1.2) / 25) * 0.8)"; - colorText[] = {0.97,0.97,0.97,1}; - colorBackground[] = {0,0,0, 0.0}; - text = ""; - style = ST_CENTER; - }; - - class LabeltargetName: LabelmenuName{ - idc = 2; - y = "14 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + (safezoneH - (((safezoneW / safezoneH) min 1.2) / 1.2))/2)"; - SizeEx = "(((((safezoneW / safezoneH) min 1.2) / 1.2) / 25) * 0.6)"; - }; - class actionToPrevious : cse_gui_buttonBase { - idc = 2315; - text = ""; - /*x = "12.5 * (((safezoneW / safezoneH) min 1.2) / 40) + (safezoneX + (safezoneW - ((safezoneW / safezoneH) min 1.2))/2)"; - y = "23.5 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + (safezoneH - (((safezoneW / safezoneH) min 1.2) / 1.2))/2)"; - w = "15 * (((safezoneW / safezoneH) min 1.2) / 40)"; - h = "1 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25)";*/ - x = "19.25 * (((safezoneW / safezoneH) min 1.2) / 40) + (safezoneX + (safezoneW - ((safezoneW / safezoneH) min 1.2))/2)"; - y = "16.7 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + (safezoneH - (((safezoneW / safezoneH) min 1.2) / 1.2))/2)"; - w = "1.5 * (((safezoneW / safezoneH) min 1.2) / 40)"; - h = "1.5 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25)"; - animTextureNormal = "#(argb,8,8,3)color(0,0,0,0.0)"; - animTextureDisabled = "#(argb,8,8,3)color(0,0,0,0.0)"; - animTextureOver = "#(argb,8,8,3)color(1,1,1,0.0)"; - animTextureFocused = "#(argb,8,8,3)color(1,1,1,0.0)"; - animTexturePressed = "#(argb,8,8,3)color(1,1,1,0.0)"; - animTextureDefault = "#(argb,8,8,3)color(1,1,1,0.0)"; - color[] = {1, 1, 1, 1}; - color2[] = {0,0,0, 1}; - colorBackgroundFocused[] = {1,1,1,1}; - colorBackground[] = {1,1,1,1}; - colorbackground2[] = {1,1,1,1}; - colorDisabled[] = {0.5,0.5,0.5,0.8}; - colorFocused[] = {0,0,0,1}; - periodFocus = 1; - periodOver = 1; - action = "[] call cse_fnc_returnToPreviousSubMenu_GUI;"; - }; - - /** ICONS FOR INNER CYCIRLE */ - class InnerCycle_iconTop: cse_gui_backgroundBase{ - idc = 100; - type = CT_STATIC; - x = "19 * (((safezoneW / safezoneH) min 1.2) / 40) + (safezoneX + (safezoneW - ((safezoneW / safezoneH) min 1.2))/2)"; - y = "7.75 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + (safezoneH - (((safezoneW / safezoneH) min 1.2) / 1.2))/2)"; - w = "1.75 * (((safezoneW / safezoneH) min 1.2) / 40)"; - h = "1.75 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25)"; - font = "PuristaMedium"; - SizeEx = "(((((safezoneW / safezoneH) min 1.2) / 1.2) / 25) * 1)"; - colorText[] = {1,1,1, 0.66}; - colorBackground[] = {1,1,1, 0.66}; - text = ""; - }; - class InnerCycle_iconTopLeft : InnerCycle_iconTop { - idc = 101; - x = "15 * (((safezoneW / safezoneH) min 1.2) / 40) + (safezoneX + (safezoneW - ((safezoneW / safezoneH) min 1.2))/2)"; - y = "9.5 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + (safezoneH - (((safezoneW / safezoneH) min 1.2) / 1.2))/2)"; - - }; - class InnerCycle_iconTopRight : InnerCycle_iconTop { - idc = 102; - x = "23.1 * (((safezoneW / safezoneH) min 1.2) / 40) + (safezoneX + (safezoneW - ((safezoneW / safezoneH) min 1.2))/2)"; - y = "9.5 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + (safezoneH - (((safezoneW / safezoneH) min 1.2) / 1.2))/2)"; - }; - class InnerCycle_iconCenterLeft : InnerCycle_iconTop { - idc = 103; - x = "13.5 * (((safezoneW / safezoneH) min 1.2) / 40) + (safezoneX + (safezoneW - ((safezoneW / safezoneH) min 1.2))/2)"; - y = "13.5 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + (safezoneH - (((safezoneW / safezoneH) min 1.2) / 1.2))/2)"; - }; - class InnerCycle_iconCenterRight : InnerCycle_iconTop { - idc = 104; - x = "24.5 * (((safezoneW / safezoneH) min 1.2) / 40) + (safezoneX + (safezoneW - ((safezoneW / safezoneH) min 1.2))/2)"; - y = "13.5 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + (safezoneH - (((safezoneW / safezoneH) min 1.2) / 1.2))/2)"; - }; - class InnerCycle_iconBottomLeft : InnerCycle_iconTop { - idc = 105; - x = "15 * (((safezoneW / safezoneH) min 1.2) / 40) + (safezoneX + (safezoneW - ((safezoneW / safezoneH) min 1.2))/2)"; - y = "17.1 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + (safezoneH - (((safezoneW / safezoneH) min 1.2) / 1.2))/2)"; - }; - class InnerCycle_iconBottomRight : InnerCycle_iconTop { - idc = 106; - x = "23.1 * (((safezoneW / safezoneH) min 1.2) / 40) + (safezoneX + (safezoneW - ((safezoneW / safezoneH) min 1.2))/2)"; - y = "17.1 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + (safezoneH - (((safezoneW / safezoneH) min 1.2) / 1.2))/2)"; - }; - - class InnerCycle_iconBottom : InnerCycle_iconTop { - idc = 107; - x = "19 * (((safezoneW / safezoneH) min 1.2) / 40) + (safezoneX + (safezoneW - ((safezoneW / safezoneH) min 1.2))/2)"; - y = "18.5 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + (safezoneH - (((safezoneW / safezoneH) min 1.2) / 1.2))/2)"; - }; - - /** TEXT */ - class InnerCycle_TextTop: cse_gui_staticBase{ - idc = 200; - x = "18 * (((safezoneW / safezoneH) min 1.2) / 40) + (safezoneX + (safezoneW - ((safezoneW / safezoneH) min 1.2))/2)"; - y = "9.5 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + (safezoneH - (((safezoneW / safezoneH) min 1.2) / 1.2))/2)"; - w = "3.6 * (((safezoneW / safezoneH) min 1.2) / 40)"; - h = "1 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25)"; - font = "PuristaMedium"; - SizeEx = "(((((safezoneW / safezoneH) min 1.2) / 1.2) / 25) * 0.7)"; - colorText[] = {1,1,1, 0.66}; - colorBackground[] = {1,1,1, 0.0}; - text = ""; - style = ST_CENTER; - }; - class InnerCycle_TextTopLeft : InnerCycle_TextTop { - idc = 201; - x = "14.6 * (((safezoneW / safezoneH) min 1.2) / 40) + (safezoneX + (safezoneW - ((safezoneW / safezoneH) min 1.2))/2)"; - y = "11.5 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + (safezoneH - (((safezoneW / safezoneH) min 1.2) / 1.2))/2)"; - - }; - class InnerCycle_TextTopRight : InnerCycle_TextTop { - idc = 202; - x = "22.1 * (((safezoneW / safezoneH) min 1.2) / 40) + (safezoneX + (safezoneW - ((safezoneW / safezoneH) min 1.2))/2)"; - y = "11.5 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + (safezoneH - (((safezoneW / safezoneH) min 1.2) / 1.2))/2)"; - }; - class InnerCycle_TextCenterLeft : InnerCycle_TextTop { - idc = 203; - x = "12.5 * (((safezoneW / safezoneH) min 1.2) / 40) + (safezoneX + (safezoneW - ((safezoneW / safezoneH) min 1.2))/2)"; - y = "15.5 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + (safezoneH - (((safezoneW / safezoneH) min 1.2) / 1.2))/2)"; - }; - class InnerCycle_TextCenterRight : InnerCycle_TextTop { - idc = 204; - x = "23.5 * (((safezoneW / safezoneH) min 1.2) / 40) + (safezoneX + (safezoneW - ((safezoneW / safezoneH) min 1.2))/2)"; - y = "15.5 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + (safezoneH - (((safezoneW / safezoneH) min 1.2) / 1.2))/2)"; - }; - class InnerCycle_TextBottomLeft : InnerCycle_TextTop { - idc = 205; - x = "14.6 * (((safezoneW / safezoneH) min 1.2) / 40) + (safezoneX + (safezoneW - ((safezoneW / safezoneH) min 1.2))/2)"; - y = "19.1 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + (safezoneH - (((safezoneW / safezoneH) min 1.2) / 1.2))/2)"; - }; - class InnerCycle_TextBottomRight : InnerCycle_TextTop { - idc = 206; - x = "22.1 * (((safezoneW / safezoneH) min 1.2) / 40) + (safezoneX + (safezoneW - ((safezoneW / safezoneH) min 1.2))/2)"; - y = "19.1 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + (safezoneH - (((safezoneW / safezoneH) min 1.2) / 1.2))/2)"; - }; - - class InnerCycle_TextBottom : InnerCycle_TextTop { - idc = 207; - x = "18 * (((safezoneW / safezoneH) min 1.2) / 40) + (safezoneX + (safezoneW - ((safezoneW / safezoneH) min 1.2))/2)"; - y = "20.5 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + (safezoneH - (((safezoneW / safezoneH) min 1.2) / 1.2))/2)"; - }; - -class InnerCycle_actionTop : cse_gui_buttonBase { - idc = 10; - text = ""; - x = "18.5 * (((safezoneW / safezoneH) min 1.2) / 40) + (safezoneX + (safezoneW - ((safezoneW / safezoneH) min 1.2))/2)"; - y = "7.5 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + (safezoneH - (((safezoneW / safezoneH) min 1.2) / 1.2))/2)"; - w = "2.7 * (((safezoneW / safezoneH) min 1.2) / 40)"; - h = "3.9 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25)"; - /*animTextureNormal = "#(argb,8,8,3)color(0,0,0,0.6)"; - animTextureDisabled = "#(argb,8,8,3)color(0,0,0,0.5)"; - animTextureOver = "#(argb,8,8,3)color(1,1,1,0.5)"; - animTextureFocused = "#(argb,8,8,3)color(1,1,1,0.5)"; - animTexturePressed = "#(argb,8,8,3)color(1,1,1,0.5)"; - animTextureDefault = "#(argb,8,8,3)color(1,1,1,0.5)";*/ - animTextureNormal = "#(argb,8,8,3)color(0,0,0,0)"; - animTextureDisabled = "#(argb,8,8,3)color(0,0,0,0)"; - animTextureOver = "#(argb,8,8,3)color(1,1,1,0)"; - animTextureFocused = "#(argb,8,8,3)color(1,1,1,0)"; - animTexturePressed = "#(argb,8,8,3)color(1,1,1,0)"; - animTextureDefault = "#(argb,8,8,3)color(1,1,1,0)"; - color[] = {1, 1, 1, 1}; - color2[] = {0,0,0, 1}; - colorBackgroundFocused[] = {1,1,1,1}; - colorBackground[] = {1,1,1,1}; - colorbackground2[] = {1,1,1,1}; - colorDisabled[] = {0.5,0.5,0.5,0.8}; - colorFocused[] = {0,0,0,1}; - periodFocus = 1; - periodOver = 1; - action = ""; - onMouseEnter = "[] call compile CSE_RADIAL_MENU_CODE_ON_MOUSE_IN_BUTTON_10;"; - }; - - class InnerCycle_actionTopLeft : InnerCycle_actionTop { - idc = 11; - text = ""; - x = "14.1 * (((safezoneW / safezoneH) min 1.2) / 40) + (safezoneX + (safezoneW - ((safezoneW / safezoneH) min 1.2))/2)"; - y = "9.5 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + (safezoneH - (((safezoneW / safezoneH) min 1.2) / 1.2))/2)"; - w = "3.5 * (((safezoneW / safezoneH) min 1.2) / 40)"; - h = "3.3 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25)"; - onMouseEnter = "[] call compile CSE_RADIAL_MENU_CODE_ON_MOUSE_IN_BUTTON_11;"; - }; - class InnerCycle_actionTopRight : InnerCycle_actionTop { - idc = 12; - text = ""; - x = "22.1 * (((safezoneW / safezoneH) min 1.2) / 40) + (safezoneX + (safezoneW - ((safezoneW / safezoneH) min 1.2))/2)"; - y = "9.5 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + (safezoneH - (((safezoneW / safezoneH) min 1.2) / 1.2))/2)"; - w = "3.5 * (((safezoneW / safezoneH) min 1.2) / 40)"; - h = "3.3 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25)"; - onMouseEnter = "[] call compile CSE_RADIAL_MENU_CODE_ON_MOUSE_IN_BUTTON_12;"; - }; - - - - class InnerCycle_actionCenterLeft : InnerCycle_actionTop { - idc = 13; - text = ""; - x = "12.5 * (((safezoneW / safezoneH) min 1.2) / 40) + (safezoneX + (safezoneW - ((safezoneW / safezoneH) min 1.2))/2)"; - y = "13.5 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + (safezoneH - (((safezoneW / safezoneH) min 1.2) / 1.2))/2)"; - w = "4 * (((safezoneW / safezoneH) min 1.2) / 40)"; - h = "3 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25)"; - onMouseEnter = "[] call compile CSE_RADIAL_MENU_CODE_ON_MOUSE_IN_BUTTON_13;"; - }; - class InnerCycle_actionCenterRight : InnerCycle_actionTop { - idc = 14; - text = ""; - x = "23.3 * (((safezoneW / safezoneH) min 1.2) / 40) + (safezoneX + (safezoneW - ((safezoneW / safezoneH) min 1.2))/2)"; - y = "13.5 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + (safezoneH - (((safezoneW / safezoneH) min 1.2) / 1.2))/2)"; - w = "4 * (((safezoneW / safezoneH) min 1.2) / 40)"; - h = "3 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25)"; - onMouseEnter = "[] call compile CSE_RADIAL_MENU_CODE_ON_MOUSE_IN_BUTTON_14;"; - }; - - - class InnerCycle_actionBottomLeft : InnerCycle_actionTop { - idc = 15; - text = ""; - x = "14.1 * (((safezoneW / safezoneH) min 1.2) / 40) + (safezoneX + (safezoneW - ((safezoneW / safezoneH) min 1.2))/2)"; - y = "17.1 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + (safezoneH - (((safezoneW / safezoneH) min 1.2) / 1.2))/2)"; - w = "3.5 * (((safezoneW / safezoneH) min 1.2) / 40)"; - h = "3.3 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25)"; - onMouseEnter = "[] call compile CSE_RADIAL_MENU_CODE_ON_MOUSE_IN_BUTTON_15;"; - }; - class InnerCycle_actionBottomRight : InnerCycle_actionTop { - idc = 16; - text = ""; - x = "22.1 * (((safezoneW / safezoneH) min 1.2) / 40) + (safezoneX + (safezoneW - ((safezoneW / safezoneH) min 1.2))/2)"; - y = "17.1 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + (safezoneH - (((safezoneW / safezoneH) min 1.2) / 1.2))/2)"; - w = "3.5 * (((safezoneW / safezoneH) min 1.2) / 40)"; - h = "3.3 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25)"; - onMouseEnter = "[] call compile CSE_RADIAL_MENU_CODE_ON_MOUSE_IN_BUTTON_16;"; - }; - - class InnerCycle_actionBottom : InnerCycle_actionTop { - idc = 17; - text = ""; - x = "18.5 * (((safezoneW / safezoneH) min 1.2) / 40) + (safezoneX + (safezoneW - ((safezoneW / safezoneH) min 1.2))/2)"; - y = "18.5 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + (safezoneH - (((safezoneW / safezoneH) min 1.2) / 1.2))/2)"; - w = "2.7 * (((safezoneW / safezoneH) min 1.2) / 40)"; - h = "3.9 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25)"; - onMouseEnter = "[] call compile CSE_RADIAL_MENU_CODE_ON_MOUSE_IN_BUTTON_17;"; - }; - - - - - class secondCycle_iconBottomLeft: cse_gui_backgroundBase{ - idc = 350; - type = CT_STATIC; - x = "10.25 * (((safezoneW / safezoneH) min 1.2) / 40) + (safezoneX + (safezoneW - ((safezoneW / safezoneH) min 1.2))/2)"; - y = "18 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + (safezoneH - (((safezoneW / safezoneH) min 1.2) / 1.2))/2)"; - w = "1.75 * (((safezoneW / safezoneH) min 1.2) / 40)"; - h = "1.75 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25)"; - font = "PuristaMedium"; - SizeEx = "(((((safezoneW / safezoneH) min 1.2) / 1.2) / 25) * 1)"; - colorText[] = {1,1,1, 0.66}; - colorBackground[] = {1,1,1, 0.66}; - text = ""; - }; - class secondCycle_iconBottomLeftTwo : secondCycle_iconBottomLeft { - idc = 351; - x = "9.25 * (((safezoneW / safezoneH) min 1.2) / 40) + (safezoneX + (safezoneW - ((safezoneW / safezoneH) min 1.2))/2)"; - y = "14.5 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + (safezoneH - (((safezoneW / safezoneH) min 1.2) / 1.2))/2)"; - }; - class secondCycle_iconBottomLeftThree : secondCycle_iconBottomLeft { - idc = 352; - x = "9.25 * (((safezoneW / safezoneH) min 1.2) / 40) + (safezoneX + (safezoneW - ((safezoneW / safezoneH) min 1.2))/2)"; - y = "11.25 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + (safezoneH - (((safezoneW / safezoneH) min 1.2) / 1.2))/2)"; - }; - class secondCycle_iconTopLeftOne : secondCycle_iconBottomLeft { - idc = 353; - x = "10.75 * (((safezoneW / safezoneH) min 1.2) / 40) + (safezoneX + (safezoneW - ((safezoneW / safezoneH) min 1.2))/2)"; - y = "8.25 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + (safezoneH - (((safezoneW / safezoneH) min 1.2) / 1.2))/2)"; - }; - class secondCycle_iconTopLeftTwo : secondCycle_iconBottomLeft { - idc = 354; - text = ""; - x = "13.75 * (((safezoneW / safezoneH) min 1.2) / 40) + (safezoneX + (safezoneW - ((safezoneW / safezoneH) min 1.2))/2)"; - y = "5 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + (safezoneH - (((safezoneW / safezoneH) min 1.2) / 1.2))/2)"; - }; - class secondCycle_iconTopLeftThree : secondCycle_iconBottomLeft { - idc = 355; - x = "17.25 * (((safezoneW / safezoneH) min 1.2) / 40) + (safezoneX + (safezoneW - ((safezoneW / safezoneH) min 1.2))/2)"; - y = "4 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + (safezoneH - (((safezoneW / safezoneH) min 1.2) / 1.2))/2)"; - }; - class secondCycle_iconTopRightOne : secondCycle_iconBottomLeft { - idc = 356; - x = "21.35 * (((safezoneW / safezoneH) min 1.2) / 40) + (safezoneX + (safezoneW - ((safezoneW / safezoneH) min 1.2))/2)"; - y = "4 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + (safezoneH - (((safezoneW / safezoneH) min 1.2) / 1.2))/2)"; - }; - class secondCycle_iconTopRightTwo : secondCycle_iconBottomLeft { - idc = 357; - x = "24.84 * (((safezoneW / safezoneH) min 1.2) / 40) + (safezoneX + (safezoneW - ((safezoneW / safezoneH) min 1.2))/2)"; - y = "5 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + (safezoneH - (((safezoneW / safezoneH) min 1.2) / 1.2))/2)"; - }; - class secondCycle_iconTopRightThree : secondCycle_iconBottomLeft { - idc = 358; - x = "27.48 * (((safezoneW / safezoneH) min 1.2) / 40) + (safezoneX + (safezoneW - ((safezoneW / safezoneH) min 1.2))/2)"; - y = "8.25 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + (safezoneH - (((safezoneW / safezoneH) min 1.2) / 1.2))/2)"; - }; - class secondCycle_iconBottomRightOne : secondCycle_iconBottomLeft { - idc = 359; - x = "29.65 * (((safezoneW / safezoneH) min 1.2) / 40) + (safezoneX + (safezoneW - ((safezoneW / safezoneH) min 1.2))/2)"; - y = "11.25 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + (safezoneH - (((safezoneW / safezoneH) min 1.2) / 1.2))/2)"; - }; - class secondCycle_iconBottomRightTwo : secondCycle_iconBottomLeft { - idc = 360; - x = "29.65 * (((safezoneW / safezoneH) min 1.2) / 40) + (safezoneX + (safezoneW - ((safezoneW / safezoneH) min 1.2))/2)"; - y = "14.5 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + (safezoneH - (((safezoneW / safezoneH) min 1.2) / 1.2))/2)"; - }; - class secondCycle_iconBottomRightThree : secondCycle_iconBottomLeft { - idc = 361; - x = "28.65 * (((safezoneW / safezoneH) min 1.2) / 40) + (safezoneX + (safezoneW - ((safezoneW / safezoneH) min 1.2))/2)"; - y = "18 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + (safezoneH - (((safezoneW / safezoneH) min 1.2) / 1.2))/2)"; - }; - - - class secondCycle_TextBottomLeft: cse_gui_staticBase{ - idc = 400; - x = "8.5 * (((safezoneW / safezoneH) min 1.2) / 40) + (safezoneX + (safezoneW - ((safezoneW / safezoneH) min 1.2))/2)"; - y = "20 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + (safezoneH - (((safezoneW / safezoneH) min 1.2) / 1.2))/2)"; - w = "4.6 * (((safezoneW / safezoneH) min 1.2) / 40)"; - h = "1 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25)"; - font = "PuristaMedium"; - SizeEx = "(((((safezoneW / safezoneH) min 1.2) / 1.2) / 25) * 0.7)"; - colorText[] = {1,1,1, 0.66}; - colorBackground[] = {1,1,1, 0.0}; - text = ""; - style = ST_CENTER; - }; - - - class secondCycle_textBottomLeftTwo : secondCycle_TextBottomLeft { - idc = 401; - x = "7.5 * (((safezoneW / safezoneH) min 1.2) / 40) + (safezoneX + (safezoneW - ((safezoneW / safezoneH) min 1.2))/2)"; - y = "16.5 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + (safezoneH - (((safezoneW / safezoneH) min 1.2) / 1.2))/2)"; - }; - class secondCycle_textBottomLeftThree : secondCycle_TextBottomLeft { - idc = 402; - x = "7.5 * (((safezoneW / safezoneH) min 1.2) / 40) + (safezoneX + (safezoneW - ((safezoneW / safezoneH) min 1.2))/2)"; - y = "13.5 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + (safezoneH - (((safezoneW / safezoneH) min 1.2) / 1.2))/2)"; - }; - class secondCycle_textTopLeftOne : secondCycle_TextBottomLeft { - idc = 403; - x = "9 * (((safezoneW / safezoneH) min 1.2) / 40) + (safezoneX + (safezoneW - ((safezoneW / safezoneH) min 1.2))/2)"; - y = "10 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + (safezoneH - (((safezoneW / safezoneH) min 1.2) / 1.2))/2)"; - }; - class secondCycle_textTopLeftTwo : secondCycle_TextBottomLeft { - idc = 404; - text = ""; - x = "12 * (((safezoneW / safezoneH) min 1.2) / 40) + (safezoneX + (safezoneW - ((safezoneW / safezoneH) min 1.2))/2)"; - y = "7 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + (safezoneH - (((safezoneW / safezoneH) min 1.2) / 1.2))/2)"; - }; - class secondCycle_textTopLeftThree : secondCycle_TextBottomLeft { - idc = 405; - x = "15.5 * (((safezoneW / safezoneH) min 1.2) / 40) + (safezoneX + (safezoneW - ((safezoneW / safezoneH) min 1.2))/2)"; - y = "6 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + (safezoneH - (((safezoneW / safezoneH) min 1.2) / 1.2))/2)"; - }; - class secondCycle_textTopRightOne : secondCycle_TextBottomLeft { - idc = 406; - x = "19.1 * (((safezoneW / safezoneH) min 1.2) / 40) + (safezoneX + (safezoneW - ((safezoneW / safezoneH) min 1.2))/2)"; - y = "6 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + (safezoneH - (((safezoneW / safezoneH) min 1.2) / 1.2))/2)"; - }; - class secondCycle_textTopRightTwo : secondCycle_TextBottomLeft { - idc = 407; - x = "22.6 * (((safezoneW / safezoneH) min 1.2) / 40) + (safezoneX + (safezoneW - ((safezoneW / safezoneH) min 1.2))/2)"; - y = "7 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + (safezoneH - (((safezoneW / safezoneH) min 1.2) / 1.2))/2)"; - }; - class secondCycle_textTopRightThree : secondCycle_TextBottomLeft { - idc = 408; - x = "25.6 * (((safezoneW / safezoneH) min 1.2) / 40) + (safezoneX + (safezoneW - ((safezoneW / safezoneH) min 1.2))/2)"; - y = "10 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + (safezoneH - (((safezoneW / safezoneH) min 1.2) / 1.2))/2)"; - }; - class secondCycle_textBottomRightOne : secondCycle_TextBottomLeft { - idc = 409; - x = "27.4 * (((safezoneW / safezoneH) min 1.2) / 40) + (safezoneX + (safezoneW - ((safezoneW / safezoneH) min 1.2))/2)"; - y = "13.5 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + (safezoneH - (((safezoneW / safezoneH) min 1.2) / 1.2))/2)"; - }; - class secondCycle_textBottomRightTwo : secondCycle_TextBottomLeft { - idc = 410; - x = "27.4 * (((safezoneW / safezoneH) min 1.2) / 40) + (safezoneX + (safezoneW - ((safezoneW / safezoneH) min 1.2))/2)"; - y = "16.5 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + (safezoneH - (((safezoneW / safezoneH) min 1.2) / 1.2))/2)"; - }; - class secondCycle_textBottomRightThree : secondCycle_TextBottomLeft { - idc = 411; - x = "26.4 * (((safezoneW / safezoneH) min 1.2) / 40) + (safezoneX + (safezoneW - ((safezoneW / safezoneH) min 1.2))/2)"; - y = "20 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + (safezoneH - (((safezoneW / safezoneH) min 1.2) / 1.2))/2)"; - }; - - class secondCycle_actionBottomLeft : cse_gui_buttonBase { - idc = 300; - text = ""; - x = "9.5 * (((safezoneW / safezoneH) min 1.2) / 40) + (safezoneX + (safezoneW - ((safezoneW / safezoneH) min 1.2))/2)"; - y = "18 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + (safezoneH - (((safezoneW / safezoneH) min 1.2) / 1.2))/2)"; - w = "3.5 * (((safezoneW / safezoneH) min 1.2) / 40)"; - h = "3.5 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25)"; - /*animTextureNormal = "#(argb,8,8,3)color(0,0,0,0.6)"; - animTextureDisabled = "#(argb,8,8,3)color(0,0,0,0.5)"; - animTextureOver = "#(argb,8,8,3)color(1,1,1,0.5)"; - animTextureFocused = "#(argb,8,8,3)color(1,1,1,0.5)"; - animTexturePressed = "#(argb,8,8,3)color(1,1,1,0.5)"; - animTextureDefault = "#(argb,8,8,3)color(1,1,1,0.5)";*/ - animTextureNormal = "#(argb,8,8,3)color(0,0,0,0)"; - animTextureDisabled = "#(argb,8,8,3)color(0,0,0,0)"; - animTextureOver = "#(argb,8,8,3)color(1,1,1,0)"; - animTextureFocused = "#(argb,8,8,3)color(1,1,1,0)"; - animTexturePressed = "#(argb,8,8,3)color(1,1,1,0)"; - animTextureDefault = "#(argb,8,8,3)color(1,1,1,0)"; - color[] = {1, 1, 1, 1}; - color2[] = {0,0,0, 1}; - colorBackgroundFocused[] = {1,1,1,1}; - colorBackground[] = {1,1,1,1}; - colorbackground2[] = {1,1,1,1}; - colorDisabled[] = {0.5,0.5,0.5,0.8}; - colorFocused[] = {0,0,0,1}; - periodFocus = 1; - periodOver = 1; - action = ""; - onMouseEnter = "((uiNamespace getvariable 'CSE_RADIAL_MENU') displayCtrl 350) ctrlSetTextColor [1, 1, 1, 1];"; - onMouseExit = "((uiNamespace getvariable 'CSE_RADIAL_MENU') displayCtrl 350) ctrlSetTextColor [1, 1, 1, 0.66];"; - }; - - class secondCycle_actionBottomLeftTwo : secondCycle_actionBottomLeft { - idc = 301; - x = "8.5 * (((safezoneW / safezoneH) min 1.2) / 40) + (safezoneX + (safezoneW - ((safezoneW / safezoneH) min 1.2))/2)"; - y = "14.5 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + (safezoneH - (((safezoneW / safezoneH) min 1.2) / 1.2))/2)"; - w = "3.5 * (((safezoneW / safezoneH) min 1.2) / 40)"; - h = "3.5 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25)"; - onMouseEnter = "((uiNamespace getvariable 'CSE_RADIAL_MENU') displayCtrl 351) ctrlSetTextColor [1, 1, 1, 1];"; - onMouseExit = "((uiNamespace getvariable 'CSE_RADIAL_MENU') displayCtrl 351) ctrlSetTextColor [1, 1, 1, 0.66];"; - }; - class secondCycle_actionBottomLeftThree : secondCycle_actionBottomLeft { - idc = 302; - x = "8.5 * (((safezoneW / safezoneH) min 1.2) / 40) + (safezoneX + (safezoneW - ((safezoneW / safezoneH) min 1.2))/2)"; - y = "11.5 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + (safezoneH - (((safezoneW / safezoneH) min 1.2) / 1.2))/2)"; - w = "3.5 * (((safezoneW / safezoneH) min 1.2) / 40)"; - h = "3 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25)"; - onMouseEnter = "((uiNamespace getvariable 'CSE_RADIAL_MENU') displayCtrl 352) ctrlSetTextColor [1, 1, 1, 1];"; - onMouseExit = "((uiNamespace getvariable 'CSE_RADIAL_MENU') displayCtrl 352) ctrlSetTextColor [1, 1, 1, 0.66];"; - }; - - class secondCycle_actionTopLeftOne : secondCycle_actionBottomLeft { - idc = 303; - x = "10 * (((safezoneW / safezoneH) min 1.2) / 40) + (safezoneX + (safezoneW - ((safezoneW / safezoneH) min 1.2))/2)"; - y = "8 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + (safezoneH - (((safezoneW / safezoneH) min 1.2) / 1.2))/2)"; - w = "3.5 * (((safezoneW / safezoneH) min 1.2) / 40)"; - h = "3 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25)"; - onMouseEnter = "((uiNamespace getvariable 'CSE_RADIAL_MENU') displayCtrl 353) ctrlSetTextColor [1, 1, 1, 1];"; - onMouseExit = "((uiNamespace getvariable 'CSE_RADIAL_MENU') displayCtrl 353) ctrlSetTextColor [1, 1, 1, 0.66];"; - }; - class secondCycle_actionTopLeftTwo : secondCycle_actionBottomLeft { - idc = 304; - text = ""; - x = "13 * (((safezoneW / safezoneH) min 1.2) / 40) + (safezoneX + (safezoneW - ((safezoneW / safezoneH) min 1.2))/2)"; - y = "5 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + (safezoneH - (((safezoneW / safezoneH) min 1.2) / 1.2))/2)"; - w = "3.5 * (((safezoneW / safezoneH) min 1.2) / 40)"; - h = "3 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25)"; - onMouseEnter = "((uiNamespace getvariable 'CSE_RADIAL_MENU') displayCtrl 354) ctrlSetTextColor [1, 1, 1, 1];"; - onMouseExit = "((uiNamespace getvariable 'CSE_RADIAL_MENU') displayCtrl 354) ctrlSetTextColor [1, 1, 1, 0.66];"; - }; - class secondCycle_actionTopLeftThree : secondCycle_actionBottomLeft { - idc = 305; - x = "16.5 * (((safezoneW / safezoneH) min 1.2) / 40) + (safezoneX + (safezoneW - ((safezoneW / safezoneH) min 1.2))/2)"; - y = "4 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + (safezoneH - (((safezoneW / safezoneH) min 1.2) / 1.2))/2)"; - w = "3.5 * (((safezoneW / safezoneH) min 1.2) / 40)"; - h = "3 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25)"; - onMouseEnter = "((uiNamespace getvariable 'CSE_RADIAL_MENU') displayCtrl 355) ctrlSetTextColor [1, 1, 1, 1];"; - onMouseExit = "((uiNamespace getvariable 'CSE_RADIAL_MENU') displayCtrl 355) ctrlSetTextColor [1, 1, 1, 0.66];"; - }; - class secondCycle_actionTopRightOne : secondCycle_actionBottomLeft { - idc = 306; - x = "20.1 * (((safezoneW / safezoneH) min 1.2) / 40) + (safezoneX + (safezoneW - ((safezoneW / safezoneH) min 1.2))/2)"; - y = "4 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + (safezoneH - (((safezoneW / safezoneH) min 1.2) / 1.2))/2)"; - w = "3.5 * (((safezoneW / safezoneH) min 1.2) / 40)"; - h = "3 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25)"; - onMouseEnter = "((uiNamespace getvariable 'CSE_RADIAL_MENU') displayCtrl 356) ctrlSetTextColor [1, 1, 1, 1];"; - onMouseExit = "((uiNamespace getvariable 'CSE_RADIAL_MENU') displayCtrl 356) ctrlSetTextColor [1, 1, 1, 0.66];"; - }; - class secondCycle_actionTopRightTwo : secondCycle_actionBottomLeft { - idc = 307; - x = "23.6 * (((safezoneW / safezoneH) min 1.2) / 40) + (safezoneX + (safezoneW - ((safezoneW / safezoneH) min 1.2))/2)"; - y = "5 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + (safezoneH - (((safezoneW / safezoneH) min 1.2) / 1.2))/2)"; - w = "3.5 * (((safezoneW / safezoneH) min 1.2) / 40)"; - h = "3 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25)"; - onMouseEnter = "((uiNamespace getvariable 'CSE_RADIAL_MENU') displayCtrl 357) ctrlSetTextColor [1, 1, 1, 1];"; - onMouseExit = "((uiNamespace getvariable 'CSE_RADIAL_MENU') displayCtrl 357) ctrlSetTextColor [1, 1, 1, 0.66];"; - }; - class secondCycle_actionTopRightThree : secondCycle_actionBottomLeft { - idc = 308; - x = "26.6 * (((safezoneW / safezoneH) min 1.2) / 40) + (safezoneX + (safezoneW - ((safezoneW / safezoneH) min 1.2))/2)"; - y = "8 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + (safezoneH - (((safezoneW / safezoneH) min 1.2) / 1.2))/2)"; - w = "3.5 * (((safezoneW / safezoneH) min 1.2) / 40)"; - h = "3 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25)"; - onMouseEnter = "((uiNamespace getvariable 'CSE_RADIAL_MENU') displayCtrl 358) ctrlSetTextColor [1, 1, 1, 1];"; - onMouseExit = "((uiNamespace getvariable 'CSE_RADIAL_MENU') displayCtrl 358) ctrlSetTextColor [1, 1, 1, 0.66];"; - }; - class secondCycle_actionBottomRightOne : secondCycle_actionBottomLeft { - idc = 309; - x = "28.4 * (((safezoneW / safezoneH) min 1.2) / 40) + (safezoneX + (safezoneW - ((safezoneW / safezoneH) min 1.2))/2)"; - y = "11.5 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + (safezoneH - (((safezoneW / safezoneH) min 1.2) / 1.2))/2)"; - w = "3.5 * (((safezoneW / safezoneH) min 1.2) / 40)"; - h = "3 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25)"; - onMouseEnter = "((uiNamespace getvariable 'CSE_RADIAL_MENU') displayCtrl 359) ctrlSetTextColor [1, 1, 1, 1];"; - onMouseExit = "((uiNamespace getvariable 'CSE_RADIAL_MENU') displayCtrl 359) ctrlSetTextColor [1, 1, 1, 0.66];"; - }; - class secondCycle_actionBottomRightTwo : secondCycle_actionBottomLeft { - idc = 310; - x = "28.4 * (((safezoneW / safezoneH) min 1.2) / 40) + (safezoneX + (safezoneW - ((safezoneW / safezoneH) min 1.2))/2)"; - y = "14.5 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + (safezoneH - (((safezoneW / safezoneH) min 1.2) / 1.2))/2)"; - w = "3.5 * (((safezoneW / safezoneH) min 1.2) / 40)"; - h = "3.5 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25)"; - onMouseEnter = "((uiNamespace getvariable 'CSE_RADIAL_MENU') displayCtrl 360) ctrlSetTextColor [1, 1, 1, 1];"; - onMouseExit = "((uiNamespace getvariable 'CSE_RADIAL_MENU') displayCtrl 360) ctrlSetTextColor [1, 1, 1, 0.66];"; - }; - class secondCycle_actionBottomRightThree : secondCycle_actionBottomLeft { - idc = 311; - x = "27.4 * (((safezoneW / safezoneH) min 1.2) / 40) + (safezoneX + (safezoneW - ((safezoneW / safezoneH) min 1.2))/2)"; - y = "18 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + (safezoneH - (((safezoneW / safezoneH) min 1.2) / 1.2))/2)"; - w = "3.5 * (((safezoneW / safezoneH) min 1.2) / 40)"; - h = "3.5 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25)"; - onMouseEnter = "((uiNamespace getvariable 'CSE_RADIAL_MENU') displayCtrl 361) ctrlSetTextColor [1, 1, 1, 1];"; - onMouseExit = "((uiNamespace getvariable 'CSE_RADIAL_MENU') displayCtrl 361) ctrlSetTextColor [1, 1, 1, 0.66];"; - }; - - }; -}; diff --git a/TO_MERGE/cse/gui/gui/weapon_selector.h b/TO_MERGE/cse/gui/gui/weapon_selector.h deleted file mode 100644 index ec1e7c3451..0000000000 --- a/TO_MERGE/cse/gui/gui/weapon_selector.h +++ /dev/null @@ -1,195 +0,0 @@ - -class CSE_RscWeaponSelector { - idd = 432342; - movingenable = 0; - fadein = 0; - fadeout = 0; - onLoad = "uiNamespace setVariable ['CSE_RscWeaponSelector', _this select 0]; _this call cse_fnc_onWeaponSelectorOpened_GUI;"; - - class controlsBackground { - class backgroundTop: cse_gui_backgroundBase{ - idc = 800; - type = CT_STATIC; - x = "12.5 * (((safezoneW / safezoneH) min 1.2) / 40) + (safezoneX + (safezoneW - ((safezoneW / safezoneH) min 1.2))/2)"; - y = "7.5 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + (safezoneH - (((safezoneW / safezoneH) min 1.2) / 1.2))/2)"; - w = "15 * (((safezoneW / safezoneH) min 1.2) / 40)"; - h = "15 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25)"; - font = "PuristaMedium"; - SizeEx = "(((((safezoneW / safezoneH) min 1.2) / 1.2) / 25) * 1)"; - colorText[] = {0.5, 0.2, 0.1, 0.4}; - colorBackground[] = {0, 0, 0, 0.4}; - text = "cse\cse_gui\radialmenu\data\radial_center_background_full_512.paa"; - }; - class backgroundCenter: backgroundTop{ - idc = 808; - text = "cse\cse_gui\radialmenu\data\radial_center_info_background.paa"; - }; - class iconCenter: cse_gui_backgroundBase{ - idc = 710; - type = CT_STATIC; - x = "17 * (((safezoneW / safezoneH) min 1.2) / 40) + (safezoneX + (safezoneW - ((safezoneW / safezoneH) min 1.2))/2)"; - y = "12 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + (safezoneH - (((safezoneW / safezoneH) min 1.2) / 1.2))/2)"; - w = "5 * (((safezoneW / safezoneH) min 1.2) / 40)"; - h = "5 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25)"; - font = "PuristaMedium"; - SizeEx = "(((((safezoneW / safezoneH) min 1.2) / 1.2) / 25) * 1)"; - colorText[] = {1,1,1, 0.4}; - colorBackground[] = {1,1,1, 0.0}; - text = ""; - }; - }; - - class controls { - class LabelmenuName: cse_gui_staticBase{ - idc = 1; - x = "17 * (((safezoneW / safezoneH) min 1.2) / 40) + (safezoneX + (safezoneW - ((safezoneW / safezoneH) min 1.2))/2)"; - y = "13 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + (safezoneH - (((safezoneW / safezoneH) min 1.2) / 1.2))/2)"; - w = "6 * (((safezoneW / safezoneH) min 1.2) / 40)"; - h = "1 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25)"; - font = "PuristaMedium"; - SizeEx = "(((((safezoneW / safezoneH) min 1.2) / 1.2) / 25) * 0.8)"; - colorText[] = {1,1,1, 1}; - colorBackground[] = {0,0,0, 0.2}; - text = ""; - style = ST_CENTER; - }; - - class labelCurrentSelectedName: LabelmenuName{ - idc = 2; - y = "14 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + (safezoneH - (((safezoneW / safezoneH) min 1.2) / 1.2))/2)"; - SizeEx = "(((((safezoneW / safezoneH) min 1.2) / 1.2) / 25) * 0.6)"; - }; - - /** ICONS FOR INNER CYCIRLE */ - class InnerCycle_iconTop: cse_gui_backgroundBase{ - idc = 100; - type = CT_STATIC; - x = "17.5 * (((safezoneW / safezoneH) min 1.2) / 40) + (safezoneX + (safezoneW - ((safezoneW / safezoneH) min 1.2))/2)"; - y = "7.75 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + (safezoneH - (((safezoneW / safezoneH) min 1.2) / 1.2))/2)"; - w = "5 * (((safezoneW / safezoneH) min 1.2) / 40)"; - h = "4 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25)"; - font = "PuristaMedium"; - SizeEx = "(((((safezoneW / safezoneH) min 1.2) / 1.2) / 25) * 1)"; - colorText[] = {1,1,1, 0.66}; - colorBackground[] = {1,1,1, 0.66}; - text = ""; - }; - - class InnerCycle_iconCenterLeft : InnerCycle_iconTop { - idc = 103; - x = "13.5 * (((safezoneW / safezoneH) min 1.2) / 40) + (safezoneX + (safezoneW - ((safezoneW / safezoneH) min 1.2))/2)"; - y = "13.5 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + (safezoneH - (((safezoneW / safezoneH) min 1.2) / 1.2))/2)"; - }; - class InnerCycle_iconCenterRight : InnerCycle_iconTop { - idc = 104; - x = "24.5 * (((safezoneW / safezoneH) min 1.2) / 40) + (safezoneX + (safezoneW - ((safezoneW / safezoneH) min 1.2))/2)"; - y = "13.5 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + (safezoneH - (((safezoneW / safezoneH) min 1.2) / 1.2))/2)"; - }; - class InnerCycle_iconBottom : InnerCycle_iconTop { - idc = 107; - x = "17.5 * (((safezoneW / safezoneH) min 1.2) / 40) + (safezoneX + (safezoneW - ((safezoneW / safezoneH) min 1.2))/2)"; - y = "18.5 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + (safezoneH - (((safezoneW / safezoneH) min 1.2) / 1.2))/2)"; - }; - - /** TEXT */ - class InnerCycle_TextTop: cse_gui_staticBase{ - idc = 200; - x = "18 * (((safezoneW / safezoneH) min 1.2) / 40) + (safezoneX + (safezoneW - ((safezoneW / safezoneH) min 1.2))/2)"; - y = "9.5 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + (safezoneH - (((safezoneW / safezoneH) min 1.2) / 1.2))/2)"; - w = "3.6 * (((safezoneW / safezoneH) min 1.2) / 40)"; - h = "1 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25)"; - font = "PuristaMedium"; - SizeEx = "(((((safezoneW / safezoneH) min 1.2) / 1.2) / 25) * 0.7)"; - colorText[] = {1,1,1, 0.66}; - colorBackground[] = {1,1,1, 0.0}; - text = ""; - style = ST_CENTER; - }; - - class InnerCycle_TextCenterLeft : InnerCycle_TextTop { - idc = 203; - x = "12.5 * (((safezoneW / safezoneH) min 1.2) / 40) + (safezoneX + (safezoneW - ((safezoneW / safezoneH) min 1.2))/2)"; - y = "15.5 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + (safezoneH - (((safezoneW / safezoneH) min 1.2) / 1.2))/2)"; - }; - class InnerCycle_TextCenterRight : InnerCycle_TextTop { - idc = 204; - x = "23.5 * (((safezoneW / safezoneH) min 1.2) / 40) + (safezoneX + (safezoneW - ((safezoneW / safezoneH) min 1.2))/2)"; - y = "15.5 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + (safezoneH - (((safezoneW / safezoneH) min 1.2) / 1.2))/2)"; - }; - - class InnerCycle_TextBottom : InnerCycle_TextTop { - idc = 207; - x = "18 * (((safezoneW / safezoneH) min 1.2) / 40) + (safezoneX + (safezoneW - ((safezoneW / safezoneH) min 1.2))/2)"; - y = "20.5 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + (safezoneH - (((safezoneW / safezoneH) min 1.2) / 1.2))/2)"; - }; - - class InnerCycle_actionTop : cse_gui_buttonBase { - idc = 10; - text = ""; - x = "18.5 * (((safezoneW / safezoneH) min 1.2) / 40) + (safezoneX + (safezoneW - ((safezoneW / safezoneH) min 1.2))/2)"; - y = "7.5 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + (safezoneH - (((safezoneW / safezoneH) min 1.2) / 1.2))/2)"; - w = "2.7 * (((safezoneW / safezoneH) min 1.2) / 40)"; - h = "3.9 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25)"; - /*animTextureNormal = "#(argb,8,8,3)color(0,0,0,0.6)"; - animTextureDisabled = "#(argb,8,8,3)color(0,0,0,0.5)"; - animTextureOver = "#(argb,8,8,3)color(1,1,1,0.5)"; - animTextureFocused = "#(argb,8,8,3)color(1,1,1,0.5)"; - animTexturePressed = "#(argb,8,8,3)color(1,1,1,0.5)"; - animTextureDefault = "#(argb,8,8,3)color(1,1,1,0.5)";*/ - animTextureNormal = "#(argb,8,8,3)color(0,0,0,0)"; - animTextureDisabled = "#(argb,8,8,3)color(0,0,0,0)"; - animTextureOver = "#(argb,8,8,3)color(1,1,1,0)"; - animTextureFocused = "#(argb,8,8,3)color(1,1,1,0)"; - animTexturePressed = "#(argb,8,8,3)color(1,1,1,0)"; - animTextureDefault = "#(argb,8,8,3)color(1,1,1,0)"; - color[] = {1, 1, 1, 1}; - color2[] = {0,0,0, 1}; - colorBackgroundFocused[] = {1,1,1,1}; - colorBackground[] = {1,1,1,1}; - colorbackground2[] = {1,1,1,1}; - colorDisabled[] = {0.5,0.5,0.5,0.8}; - colorFocused[] = {0,0,0,1}; - periodFocus = 1; - periodOver = 1; - action = ""; - onMouseEnter = "((uiNamespace getvariable 'CSE_RscWeaponSelector') displayCtrl 100) ctrlSetTextColor [1, 1, 1, 1];"; - onMouseExit = "((uiNamespace getvariable 'CSE_RscWeaponSelector') displayCtrl 100) ctrlSetTextColor [1, 1, 1, 0.66];"; - }; - - - class InnerCycle_actionCenterLeft : InnerCycle_actionTop { - idc = 13; - text = ""; - x = "12.5 * (((safezoneW / safezoneH) min 1.2) / 40) + (safezoneX + (safezoneW - ((safezoneW / safezoneH) min 1.2))/2)"; - y = "13.5 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + (safezoneH - (((safezoneW / safezoneH) min 1.2) / 1.2))/2)"; - w = "4 * (((safezoneW / safezoneH) min 1.2) / 40)"; - h = "3 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25)"; - onMouseEnter = "((uiNamespace getvariable 'CSE_RscWeaponSelector') displayCtrl 103) ctrlSetTextColor [1, 1, 1, 1];"; - onMouseExit = "((uiNamespace getvariable 'CSE_RscWeaponSelector') displayCtrl 103) ctrlSetTextColor [1, 1, 1, 0.66];"; - }; - class InnerCycle_actionCenterRight : InnerCycle_actionTop { - idc = 14; - text = ""; - x = "23.3 * (((safezoneW / safezoneH) min 1.2) / 40) + (safezoneX + (safezoneW - ((safezoneW / safezoneH) min 1.2))/2)"; - y = "13.5 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + (safezoneH - (((safezoneW / safezoneH) min 1.2) / 1.2))/2)"; - w = "4 * (((safezoneW / safezoneH) min 1.2) / 40)"; - h = "3 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25)"; - onMouseEnter = "((uiNamespace getvariable 'CSE_RscWeaponSelector') displayCtrl 104) ctrlSetTextColor [1, 1, 1, 1];"; - onMouseExit = "((uiNamespace getvariable 'CSE_RscWeaponSelector') displayCtrl 104) ctrlSetTextColor [1, 1, 1, 0.66];"; - }; - - - class InnerCycle_actionBottom : InnerCycle_actionTop { - idc = 17; - text = ""; - x = "18.5 * (((safezoneW / safezoneH) min 1.2) / 40) + (safezoneX + (safezoneW - ((safezoneW / safezoneH) min 1.2))/2)"; - y = "18.5 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + (safezoneH - (((safezoneW / safezoneH) min 1.2) / 1.2))/2)"; - w = "2.7 * (((safezoneW / safezoneH) min 1.2) / 40)"; - h = "3.9 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25)"; - onMouseEnter = "((uiNamespace getvariable 'CSE_RscWeaponSelector') displayCtrl 107) ctrlSetTextColor [1, 1, 1, 1];"; - onMouseExit = "((uiNamespace getvariable 'CSE_RscWeaponSelector') displayCtrl 107) ctrlSetTextColor [1, 1, 1, 0.66];"; - }; - - - }; -}; diff --git a/TO_MERGE/cse/gui/init.sqf b/TO_MERGE/cse/gui/init.sqf deleted file mode 100644 index 96dfd03389..0000000000 --- a/TO_MERGE/cse/gui/init.sqf +++ /dev/null @@ -1,37 +0,0 @@ -CSE_ALLOW_ON_MOUSE_OVER_OPEN_RADIALMENU = false; -CSE_ICON_PATH = "cse\cse_gui\radialmenu\data\icons\"; - -if (!isDedicated) then { - call cse_fnc_gui_displayEventHandler; - [format["GUI - REGISTERING INTERACTION MENUS"],3] call cse_fnc_debug; - #include "init_action_ui.sqf" // radis menu + action keybindings - - if ((((["CombinedInteractionMenu","menu",[0,0,0,0]] call cse_fnc_getKeyBindingFromProfile_F) select 0) != 0) && (((["radius_menu","menu",[0,0,0,0]] call cse_fnc_getKeyBindingFromProfile_F) select 0) == 0)) then { - ["radius_menu", (["CombinedInteractionMenu","menu",[0,0,0,0]] call cse_fnc_getKeyBindingFromProfile_F)] call cse_fnc_updateMenuKeyBinding_f; - ["CombinedInteractionMenu", [0,0,0,0]] call cse_fnc_updateMenuKeyBinding_f; - }; -}; -cse_gui = true; - -[format["GUI - INIT COMPLETE"],3] call cse_fnc_debug; - - -["cse_gui_radialMenu_AllowOnMouseOver", ["Enable", "Disable"], (["cse_gui_radialMenu_AllowOnMouseOver", 0] call cse_fnc_getClientSideOptionFromProfile_F), { - CSE_ALLOW_ON_MOUSE_OVER_OPEN_RADIALMENU = (_this select 1) == 0; -}] call cse_fnc_addClientSideOptions_f; - -["cse_gui_radialMenu_AllowOnMouseOver","option","Radial Menu (Hover)","Open the radial menu category when you hover your mouse over the button."] call cse_fnc_settingsDefineDetails_F; - - -cse_fnc_interactWithVehicle_Crew_Condition = { -private ["_return"]; - _return = false; - if (((_this select 0) distance (_this select 1) < 10)) then { - if (((_this select 1) isKindOf "Car") || ((_this select 1) isKindOf "Air") || ((_this select 1) isKindOf "Tank")) then { - if (count (crew (_this select 1)) > 0) then { - _return = true; - }; - }; - }; - _return -}; \ No newline at end of file diff --git a/TO_MERGE/cse/gui/init_action_ui.sqf b/TO_MERGE/cse/gui/init_action_ui.sqf deleted file mode 100644 index f86d1ec9fc..0000000000 --- a/TO_MERGE/cse/gui/init_action_ui.sqf +++ /dev/null @@ -1,63 +0,0 @@ -#define ACTION_MENU "ActionMenu" - - -[ACTION_MENU, "Action Menu", {[player] call cse_fnc_isAwake && vehicle player == cameraOn}, 2, "", {}, false] call cse_fnc_createRadialInteraction_F; -cse_fnc_openActionMenu_GUI = { - - ["ActionMenu"] call cse_fnc_openRadialInteractionMenu_F; - if ([player] call cse_fnc_canInteract && {animationState player == 'deadState' || animationState player == 'unconscious'} && {(vehicle player == player)}) then { - [player, 'amovppnemstpsnonwnondnon'] call cse_fnc_broadcastAnim; - }; -}; - -["radius_menu", (["radius_menu","menu",[0,0,0,0]] call cse_fnc_getKeyBindingFromProfile_F), cse_fnc_openActionMenu_GUI, 800] call cse_fnc_addKeyBindingForMenu_F; -["radius_menu","menu","Open Action Menu","Opens the CSE Radial Action Menu"] call cse_fnc_settingsDefineDetails_F; - - -cse_fnc_playerCanInteractWithPerson = { - private ["_person","_modify"]; - _person = _this select 0; - _modify = _this select 1; - _return = false; - if (_person isKindOf "CAManBase") then { - _return = switch (_modify) do { - case 0: {([_person] call cse_fnc_isAwake)}; - case 1: {true}; - default {false}; - }; - }; - _return -}; - -// CATEGORIES -[ACTION_MENU,"interaction", "Interact", {["ActionMenu", "interaction", _this select 1] call cse_fnc_categoryHasActionsAvailable_F}, CSE_ICON_PATH + "icon_interact.paa", 0, "Interact with"] call cse_fnc_createCategoryRadialMenu_F; -[ACTION_MENU,"equipment", "Equipment", {["ActionMenu", "equipment", _this select 1] call cse_fnc_categoryHasActionsAvailable_F}, CSE_ICON_PATH + "icon_backpack_radio.paa", 1, "Equipment & Gear"] call cse_fnc_createCategoryRadialMenu_F; -[ACTION_MENU,"medical_menu", "Medical", {["ActionMenu", "medical_menu", _this select 1] call cse_fnc_categoryHasActionsAvailable_F}, CSE_ICON_PATH + "icon_examine_patient.paa", 2, "Medical Interaction"] call cse_fnc_createCategoryRadialMenu_F; -[ACTION_MENU,"group_actions", "Group", {["ActionMenu", "group_actions", _this select 1] call cse_fnc_categoryHasActionsAvailable_F}, CSE_ICON_PATH + "icon_group.paa", 3, "Your Group"] call cse_fnc_createCategoryRadialMenu_F; -[ACTION_MENU,"survival", "Survival", {["ActionMenu", "survival", _this select 1] call cse_fnc_categoryHasActionsAvailable_F}, CSE_ICON_PATH + "icon_survival.paa", 4, "Survival actions"] call cse_fnc_createCategoryRadialMenu_F; - -if ([] call cse_fnc_isLoaded_ALiVE_Mod) then { - [ACTION_MENU,"alive_actions", "ALiVE", {["ActionMenu", "alive_actions", _this select 1] call cse_fnc_categoryHasActionsAvailable_F}, CSE_ICON_PATH + "icon_alive_mod.paa", 5, "ALiVE actions"] call cse_fnc_createCategoryRadialMenu_F; -}; - -[ACTION_MENU,"custom_actions", "Custom", {["ActionMenu", "custom_actions", _this select 1] call cse_fnc_categoryHasActionsAvailable_F}, CSE_ICON_PATH + "icon_lines_horizontal_s.paa", 6, "Custom actions"] call cse_fnc_createCategoryRadialMenu_F; - -// Entries -[ACTION_MENU,"custom_actions", [["Curator", {getAssignedCuratorLogic player in allCurators}, CSE_ICON_PATH + "icon_curator.paa", {closeDialog 0; openCuratorInterface; }, "Open Curator Interface"]] ] call cse_fnc_addMultipleEntriesToRadialCategory_F; - - - - -/* -["myID_1", true, CSE_ICON_PATH + "icon_group.paa", [1,1,1,1]] call cse_fnc_gui_displayIcon; -["myID_2", true, CSE_ICON_PATH + "icon_backpack_radio.paa", [1,1,1,1]] call cse_fnc_gui_displayIcon; -["myID_3", true, CSE_ICON_PATH + "icon_interact.paa", [1,1,1,1]] call cse_fnc_gui_displayIcon; -["myID_4", true, CSE_ICON_PATH + "icon_survival.paa", [1,1,1,1]] call cse_fnc_gui_displayIcon; - - -["myID_1", false, CSE_ICON_PATH + "icon_group.paa", [1,1,1,1]] call cse_fnc_gui_displayIcon; -["myID_2", false, CSE_ICON_PATH + "icon_backpack_radio.paa", [1,1,1,1]] call cse_fnc_gui_displayIcon; -["myID_3", false, CSE_ICON_PATH + "icon_interact.paa", [1,1,1,1]] call cse_fnc_gui_displayIcon; -["myID_4", false, CSE_ICON_PATH + "icon_survival.paa", [1,1,1,1]] call cse_fnc_gui_displayIcon; - -*/ \ No newline at end of file diff --git a/TO_MERGE/cse/gui/init_interaction_ui.sqf b/TO_MERGE/cse/gui/init_interaction_ui.sqf deleted file mode 100644 index b7354a0e24..0000000000 --- a/TO_MERGE/cse/gui/init_interaction_ui.sqf +++ /dev/null @@ -1,6 +0,0 @@ - - if ((((["CombinedInteractionMenu","menu",[0,0,0,0]] call cse_fnc_getKeyBindingFromProfile_F) select 0) != 0) && (((["radius_menu","menu",[0,0,0,0]] call cse_fnc_getKeyBindingFromProfile_F) select 0) == 0)) then { - ["radius_menu", (["CombinedInteractionMenu","menu",[0,0,0,0]] call cse_fnc_getKeyBindingFromProfile_F)] call cse_fnc_updateMenuKeyBinding_f; - ["CombinedInteractionMenu", [0,0,0,0]] call cse_fnc_updateMenuKeyBinding_f; - }; - diff --git a/TO_MERGE/cse/gui/radialmenu/data/radial_background_bottom_w.paa b/TO_MERGE/cse/gui/radialmenu/data/radial_background_bottom_w.paa deleted file mode 100644 index 5142a62573..0000000000 Binary files a/TO_MERGE/cse/gui/radialmenu/data/radial_background_bottom_w.paa and /dev/null differ diff --git a/TO_MERGE/cse/gui/radialmenu/data/radial_background_bottomleft_w.paa b/TO_MERGE/cse/gui/radialmenu/data/radial_background_bottomleft_w.paa deleted file mode 100644 index bcc441512b..0000000000 Binary files a/TO_MERGE/cse/gui/radialmenu/data/radial_background_bottomleft_w.paa and /dev/null differ diff --git a/TO_MERGE/cse/gui/radialmenu/data/radial_background_bottomright_w.paa b/TO_MERGE/cse/gui/radialmenu/data/radial_background_bottomright_w.paa deleted file mode 100644 index bd7746a142..0000000000 Binary files a/TO_MERGE/cse/gui/radialmenu/data/radial_background_bottomright_w.paa and /dev/null differ diff --git a/TO_MERGE/cse/gui/radialmenu/data/radial_background_centerleft_w.paa b/TO_MERGE/cse/gui/radialmenu/data/radial_background_centerleft_w.paa deleted file mode 100644 index ab4dea1e5f..0000000000 Binary files a/TO_MERGE/cse/gui/radialmenu/data/radial_background_centerleft_w.paa and /dev/null differ diff --git a/TO_MERGE/cse/gui/radialmenu/data/radial_background_centerright_w.paa b/TO_MERGE/cse/gui/radialmenu/data/radial_background_centerright_w.paa deleted file mode 100644 index 9f36be9c30..0000000000 Binary files a/TO_MERGE/cse/gui/radialmenu/data/radial_background_centerright_w.paa and /dev/null differ diff --git a/TO_MERGE/cse/gui/radialmenu/data/radial_background_top_w.paa b/TO_MERGE/cse/gui/radialmenu/data/radial_background_top_w.paa deleted file mode 100644 index f1695ce4da..0000000000 Binary files a/TO_MERGE/cse/gui/radialmenu/data/radial_background_top_w.paa and /dev/null differ diff --git a/TO_MERGE/cse/gui/radialmenu/data/radial_background_topleft_w.paa b/TO_MERGE/cse/gui/radialmenu/data/radial_background_topleft_w.paa deleted file mode 100644 index ac8e507323..0000000000 Binary files a/TO_MERGE/cse/gui/radialmenu/data/radial_background_topleft_w.paa and /dev/null differ diff --git a/TO_MERGE/cse/gui/radialmenu/data/radial_background_topright_w.paa b/TO_MERGE/cse/gui/radialmenu/data/radial_background_topright_w.paa deleted file mode 100644 index 57204f2116..0000000000 Binary files a/TO_MERGE/cse/gui/radialmenu/data/radial_background_topright_w.paa and /dev/null differ diff --git a/TO_MERGE/cse/gui/radialmenu/data/radial_center_background.paa b/TO_MERGE/cse/gui/radialmenu/data/radial_center_background.paa deleted file mode 100644 index 9f468feee7..0000000000 Binary files a/TO_MERGE/cse/gui/radialmenu/data/radial_center_background.paa and /dev/null differ diff --git a/TO_MERGE/cse/gui/radialmenu/data/radial_center_background_512.paa b/TO_MERGE/cse/gui/radialmenu/data/radial_center_background_512.paa deleted file mode 100644 index de28c44dad..0000000000 Binary files a/TO_MERGE/cse/gui/radialmenu/data/radial_center_background_512.paa and /dev/null differ diff --git a/TO_MERGE/cse/gui/radialmenu/data/radial_center_background_full_512.paa b/TO_MERGE/cse/gui/radialmenu/data/radial_center_background_full_512.paa deleted file mode 100644 index af1c2f97cc..0000000000 Binary files a/TO_MERGE/cse/gui/radialmenu/data/radial_center_background_full_512.paa and /dev/null differ diff --git a/TO_MERGE/cse/gui/radialmenu/data/radial_center_info_background.paa b/TO_MERGE/cse/gui/radialmenu/data/radial_center_info_background.paa deleted file mode 100644 index 51e5ea0e18..0000000000 Binary files a/TO_MERGE/cse/gui/radialmenu/data/radial_center_info_background.paa and /dev/null differ diff --git a/TO_MERGE/cse/gui/radialmenu/data/radial_submenu.paa b/TO_MERGE/cse/gui/radialmenu/data/radial_submenu.paa deleted file mode 100644 index 1fe76a1086..0000000000 Binary files a/TO_MERGE/cse/gui/radialmenu/data/radial_submenu.paa and /dev/null differ diff --git a/TO_MERGE/cse/gui/radialmenu/data/radial_submenu_bottomleft.paa b/TO_MERGE/cse/gui/radialmenu/data/radial_submenu_bottomleft.paa deleted file mode 100644 index b1dcf36875..0000000000 Binary files a/TO_MERGE/cse/gui/radialmenu/data/radial_submenu_bottomleft.paa and /dev/null differ diff --git a/TO_MERGE/cse/gui/radialmenu/data/radial_submenu_bottomright.paa b/TO_MERGE/cse/gui/radialmenu/data/radial_submenu_bottomright.paa deleted file mode 100644 index de5763a4bf..0000000000 Binary files a/TO_MERGE/cse/gui/radialmenu/data/radial_submenu_bottomright.paa and /dev/null differ diff --git a/TO_MERGE/cse/gui/radialmenu/data/radial_submenu_topleft.paa b/TO_MERGE/cse/gui/radialmenu/data/radial_submenu_topleft.paa deleted file mode 100644 index a888959e5a..0000000000 Binary files a/TO_MERGE/cse/gui/radialmenu/data/radial_submenu_topleft.paa and /dev/null differ diff --git a/TO_MERGE/cse/gui/radialmenu/data/radial_submenu_topright.paa b/TO_MERGE/cse/gui/radialmenu/data/radial_submenu_topright.paa deleted file mode 100644 index b612277b25..0000000000 Binary files a/TO_MERGE/cse/gui/radialmenu/data/radial_submenu_topright.paa and /dev/null differ diff --git a/TO_MERGE/cse/gui/radialmenu/fn_addCategoryEntryRadialMenu_F.sqf b/TO_MERGE/cse/gui/radialmenu/fn_addCategoryEntryRadialMenu_F.sqf deleted file mode 100644 index 38f901cb8d..0000000000 --- a/TO_MERGE/cse/gui/radialmenu/fn_addCategoryEntryRadialMenu_F.sqf +++ /dev/null @@ -1,26 +0,0 @@ -/** - * fn_addCategoryEntryRadialMenu_F.sqf - * @Descr: Addes a new category entry to a radial menu - * @Author: Glowbal - * - * @Arguments: [menuName STRING, categoryName STRING, displayName STRING, condition CODE, icon STRING, onPressed CODE, toolTip STRING] - * @Return: BOOL True if succesfully added - * @PublicAPI: true - */ - -#define DEFAULT_ENTRY ["","",{}, false, ""] - -private ["_menuName","_condition","_icon","_onOpened", "_position","_toolTip","_currentEntries", "_categoryName"]; -_menuName = [_this, 0, "",[""]] call BIS_fnc_Param; -_categoryName = [_this, 1, "",[""]] call BIS_fnc_Param; -_displayNameEntry = [_this, 2, "",[""]] call BIS_fnc_Param; -_condition = [_this, 3, {true;}, [{}]] call BIS_fnc_Param; -_icon = [_this, 4, "", [""]] call BIS_fnc_Param; -_onOpened = [_this, 5, {}, [{}]] call BIS_fnc_Param; -_toolTip = [_this, 6, _displayNameEntry, [""]] call BIS_fnc_Param; - - // TODO parse menu name for correct value - _currentEntries = missionNamespace getvariable ["cse_radiusInteraction_f_category_entries_"+_menuName + _categoryName, []]; - _currentEntries pushback [_displayNameEntry,_icon,_onOpened,_condition, _toolTip]; - missionNamespace setvariable ["cse_radiusInteraction_f_category_entries_"+_menuName + _categoryName, _currentEntries]; - true; \ No newline at end of file diff --git a/TO_MERGE/cse/gui/radialmenu/fn_addEntryToMenuSorter_f.sqf b/TO_MERGE/cse/gui/radialmenu/fn_addEntryToMenuSorter_f.sqf deleted file mode 100644 index 8ab6e03f9a..0000000000 --- a/TO_MERGE/cse/gui/radialmenu/fn_addEntryToMenuSorter_f.sqf +++ /dev/null @@ -1,26 +0,0 @@ -/** - * fn_addEntryToMenuSorter_f.sqf - * @Descr: N/A - * @Author: Glowbal - * - * @Arguments: [] - * @Return: - * @PublicAPI: false - */ - -private ["_menuName","_condition","_icon","_onOpened", "_priority","_toolTip","_currentEntries"]; -_menuName = [_this, 0, "",[""]] call BIS_fnc_Param; -_displayNameEntry = [_this, 1, "",[""]] call BIS_fnc_Param; -_condition = [_this, 2, {true;}, [{}]] call BIS_fnc_Param; -_icon = [_this, 3, "", [""]] call BIS_fnc_Param; -_onOpened = [_this, 4, {}, [{}]] call BIS_fnc_Param; -_priority = [_this, 5, 0, [0]] call BIS_fnc_Param; -_toolTip = [_this, 6, _displayNameEntry, [""]] call BIS_fnc_Param; - - - -_currentEntries = missionNamespace getvariable ["cse_radiusInteraction_f_entries_sorter_"+_menuName, []]; -_currentEntries pushback [_displayNameEntry,_icon,_onOpened,_condition, _toolTip]; -missionNamespace setvariable ["cse_radiusInteraction_f_entries_sorter_"+_menuName, _currentEntries]; - -// [[1,-80,0,480,15,-40],[],{_x},"ASCEND"] call BIS_fnc_sortBy; diff --git a/TO_MERGE/cse/gui/radialmenu/fn_addEntryToRadialInteraction_f.sqf b/TO_MERGE/cse/gui/radialmenu/fn_addEntryToRadialInteraction_f.sqf deleted file mode 100644 index 5f98b2664a..0000000000 --- a/TO_MERGE/cse/gui/radialmenu/fn_addEntryToRadialInteraction_f.sqf +++ /dev/null @@ -1,30 +0,0 @@ -/** - * fn_addEntryToRadialInteraction_f.sqf - * @Descr: N/A - * @Author: Glowbal - * - * @Arguments: [] - * @Return: - * @PublicAPI: false - */ - -#define DEFAULT_ENTRY ["","",{}, false, ""] - -private ["_menuName","_condition","_icon","_onOpened", "_position","_toolTip","_currentEntries"]; -_menuName = [_this, 0, "",[""]] call BIS_fnc_Param; -_displayNameEntry = [_this, 1, "",[""]] call BIS_fnc_Param; -_condition = [_this, 2, {true;}, [{}]] call BIS_fnc_Param; -_icon = [_this, 3, "", [""]] call BIS_fnc_Param; -_onOpened = [_this, 4, {}, [{}]] call BIS_fnc_Param; -_position = [_this, 5, 0, [0]] call BIS_fnc_Param; -_toolTip = [_this, 6, _displayNameEntry, [""]] call BIS_fnc_Param; - -if (_position < 8) then { - // TODO parse menu name for correct value - _currentEntries = missionNamespace getvariable ["cse_radiusInteraction_f_entries_"+_menuName, [DEFAULT_ENTRY, DEFAULT_ENTRY, DEFAULT_ENTRY, DEFAULT_ENTRY, DEFAULT_ENTRY , DEFAULT_ENTRY, DEFAULT_ENTRY, DEFAULT_ENTRY]]; - _currentEntries set [ _position, [_displayNameEntry,_icon,_onOpened,_condition, _toolTip]]; - missionNamespace setvariable ["cse_radiusInteraction_f_entries_"+_menuName, _currentEntries]; - true; -} else { - false; -}; \ No newline at end of file diff --git a/TO_MERGE/cse/gui/radialmenu/fn_addMultipleEntriesToRadialCategory_f.sqf b/TO_MERGE/cse/gui/radialmenu/fn_addMultipleEntriesToRadialCategory_f.sqf deleted file mode 100644 index 4dadd9e205..0000000000 --- a/TO_MERGE/cse/gui/radialmenu/fn_addMultipleEntriesToRadialCategory_f.sqf +++ /dev/null @@ -1,25 +0,0 @@ -/** - * fn_addMultipleEntriesToRadialCategory_f.sqf - * @Descr: Addes multiple entries to a specific category for a radial menu - * @Author: Glowbal - * - * @Arguments: [menuName STRING, categoryName STRING, entries ARRAY (Format in [menuName STRING, categoryName STRING, displayName STRING, condition CODE, icon STRING, onPressed CODE, toolTip STRING])] - * @Return: void - * @PublicAPI: true - */ - -private ["_menuName","_condition","_icon","_onOpened", "_position","_toolTip","_currentEntries", "_categoryName", "_entries"]; -_menuName = [_this, 0, "",[""]] call BIS_fnc_Param; -_categoryName = [_this, 1, "",[""]] call BIS_fnc_Param; -_entries = [ _this, 2, [], [[]]] call BIS_fnc_Param; - -{ - if (typeName _x == typeName []) then { - _displayNameEntry = [_x, 0, "",[""]] call BIS_fnc_Param; - _condition = [_x, 1, {false;}, [{}]] call BIS_fnc_Param; - _icon = [_x, 2, "", [""]] call BIS_fnc_Param; - _onOpened = [_x, 3, {}, [{}]] call BIS_fnc_Param; - _toolTip = [_x, 4, _displayNameEntry, [""]] call BIS_fnc_Param; - [_menuName,_categoryName, _displayNameEntry, _condition,_icon,_onOpened,_toolTip] call cse_fnc_addCategoryEntryRadialMenu_F; - }; -}foreach _entries; \ No newline at end of file diff --git a/TO_MERGE/cse/gui/radialmenu/fn_categoryHasActionsAvailable_f.sqf b/TO_MERGE/cse/gui/radialmenu/fn_categoryHasActionsAvailable_f.sqf deleted file mode 100644 index acf99521d1..0000000000 --- a/TO_MERGE/cse/gui/radialmenu/fn_categoryHasActionsAvailable_f.sqf +++ /dev/null @@ -1,34 +0,0 @@ -/** - * fn_categoryHasActionsAvailable_f.sqf - * @Descr: Checks if a category has any actions available. - * @Author: Glowbal - * - * @Arguments: [menuName STRING, categoryName STRING, target OBJECT (The target object for which conditions will be parsed)] - * @Return: BOOL True if actions are available - * @PublicAPI: true - */ - -#define DEFAULT_ENTRY ["","",{}, false, ""] - - -private ["_menuName","_categoryName", "_entries", "_entriesAvailable", "_entry", "_target"]; -_menuName = [_this, 0, "",[""]] call BIS_fnc_Param; -_categoryName = [_this, 1, "",[""]] call BIS_fnc_Param; -_target = [_this, 2, objNull, [objNull]] call BIS_fnc_Param; -_entriesAvailable = false; -_entries = [_menuName, _categoryName] call cse_fnc_getAllCategoryEntriesRadialMenu_f; - { - _entry = + ([_entries, _foreachIndex, DEFAULT_ENTRY,[[]],[4,5]] call BIS_fnc_Param); - if (typeName (_entry select 3) == typeName {}) then { - if ([player, _target] call (_entry select 3)) then { - _entriesAvailable = true; - }; - } else { - if (_entry select 3) then { - _entriesAvailable = true; - }; - }; - if (_entriesAvailable) exitwith {}; - }foreach _entries; - -_entriesAvailable \ No newline at end of file diff --git a/TO_MERGE/cse/gui/radialmenu/fn_closeRadialSecondRing_gui.sqf b/TO_MERGE/cse/gui/radialmenu/fn_closeRadialSecondRing_gui.sqf deleted file mode 100644 index e17517788d..0000000000 --- a/TO_MERGE/cse/gui/radialmenu/fn_closeRadialSecondRing_gui.sqf +++ /dev/null @@ -1,30 +0,0 @@ -/** - * fn_closeRadialSecondRing_gui.sqf - * @Descr: Closes the second ring from the radial menu - * @Author: Glowbal - * - * @Arguments: [] - * @Return: void - * @PublicAPI: true - */ - -private ["_numberOf","_target","_menuName","_entryToSwitchTo", "_entries"]; - -[ObjNull, []] call cse_fnc_setRadialSecondRing_GUI; - -private ["_numberOf","_entries","_entryToSwitchTo","_target","_menuName"]; -if (isnil "CSE_RADIAL_SUB_MENU_GUI") then { - CSE_RADIAL_SUB_MENU_GUI = []; -}; -_numberOf = count CSE_RADIAL_SUB_MENU_GUI - 1; -if (_numberOf < 0) then { - _numberOf = 0; -}; -if (count CSE_RADIAL_SUB_MENU_GUI == 0) exitwith {}; -_entryToSwitchTo = CSE_RADIAL_SUB_MENU_GUI select _numberOf; -_target = _entryToSwitchTo select 0; -_menuName = _entryToSwitchTo select 1; -_entries = _entryToSwitchTo select 2; -[_target, _entries] call cse_fnc_setRadialMenuOptions_GUI; -[_menuName] call cse_fnc_setRadialMenuName_GUI; -[-1, false] call cse_fnc_setRadialOptionSelected_GUI; \ No newline at end of file diff --git a/TO_MERGE/cse/gui/radialmenu/fn_createCategoryRadialMenu_f.sqf b/TO_MERGE/cse/gui/radialmenu/fn_createCategoryRadialMenu_f.sqf deleted file mode 100644 index 501839ca07..0000000000 --- a/TO_MERGE/cse/gui/radialmenu/fn_createCategoryRadialMenu_f.sqf +++ /dev/null @@ -1,40 +0,0 @@ -/** - * fn_createCategoryRadialMenu_f.sqf - * @Descr: Creates a category for a radial menu (Inner cycle) - * @Author: Glowbal - * - * @Arguments: [menuName STRING, categoryName STRING, displayName STRING, condition CODE, icon STRING, position NUMBER (0 to 7), toolTip STRING] - * @Return: BOOL True if succesfully created - * @PublicAPI: true - */ - -#define DEFAULT_ENTRY ["","",{}, false, ""] - - -private ["_menuName","_condition","_icon","_onOpened", "_position","_toolTip","_currentEntries", "_categorycode", "_displayNameEntry","_categoryName","_icon"]; -_menuName = [_this, 0, "",[""]] call BIS_fnc_Param; -_categoryName = [_this, 1, "",[""]] call BIS_fnc_Param; -_displayNameEntry = [_this, 2, "",[""]] call BIS_fnc_Param; -_condition = [_this, 3, {true;}, [{}]] call BIS_fnc_Param; -_icon = [_this, 4, "", [""]] call BIS_fnc_Param; -_position = [_this, 5, 0, [0]] call BIS_fnc_Param; -_toolTip = [_this, 6, _displayNameEntry, [""]] call BIS_fnc_Param; - -if (_position < 8) then { - _onOpened = compile format[" - [ _this select 3, - ['%1', '%2'] call cse_fnc_getAllCategoryEntriesRadialMenu_f, - _this select 1, _this select 2 - ] call cse_fnc_openRadialSecondRing_GUI;",_menuName, _categoryName]; - - // TODO parse menu name for correct value - _currentEntries = missionNamespace getvariable ["cse_radiusInteraction_f_entries_"+_menuName, [DEFAULT_ENTRY, DEFAULT_ENTRY, DEFAULT_ENTRY, DEFAULT_ENTRY, DEFAULT_ENTRY , DEFAULT_ENTRY, DEFAULT_ENTRY, DEFAULT_ENTRY]]; - _currentEntries set [ _position, [_displayNameEntry, _icon,_onOpened,_condition, _toolTip]]; - missionNamespace setvariable ["cse_radiusInteraction_f_entries_"+_menuName, _currentEntries]; - - missionNamespace setvariable ["cse_radiusInteraction_f_category_entries_"+_menuName+_categoryName, []]; - - true; -} else { - false; -}; \ No newline at end of file diff --git a/TO_MERGE/cse/gui/radialmenu/fn_createRadialInteraction_f.sqf b/TO_MERGE/cse/gui/radialmenu/fn_createRadialInteraction_f.sqf deleted file mode 100644 index 0ec48b353b..0000000000 --- a/TO_MERGE/cse/gui/radialmenu/fn_createRadialInteraction_f.sqf +++ /dev/null @@ -1,30 +0,0 @@ -/** - * fn_createRadialInteraction_f.sqf - * @Descr: Creates a radial interaction menu - * @Author: Glowbal - * - * @Arguments: [menuName STRING, displayName STRING, condition CODE, type NUMBER (0 = self, 1 = other, 2 = combined), icon STRING, onOpened CODE] - * @Return: BOOL. True if menu has succesfully been created - * @PublicAPI: true - */ - - -private ["_menuName","_condition","_typeOfMenu","_icon","_onOpened", "_currentEntries" , "_useSorter"]; -_menuName = [_this, 0, "",[""]] call BIS_fnc_Param; -_displayName = [_this, 1, "",[""]] call BIS_fnc_Param; -_condition = [_this, 2, {false},[{}]] call BIS_fnc_Param; -_typeOfMenu = [_this, 3, 0, [0]] call BIS_fnc_Param; -_icon = [_this, 4, "", [""]] call BIS_fnc_Param; -_onOpened = [_this, 5, {}, [{}]] call BIS_fnc_Param; -_useSorter = [_this, 6, false, [false]] call BIS_fnc_Param; - -_currentEntries = missionNamespace getvariable ["cse_radiusInteraction_f_allMenuNames", []]; -missionNamespace setvariable ["cse_radiusInteraction_f_"+_menuName, [_menuName,_displayName,_condition,_typeOfMenu,_icon,_onOpened, _useSorter]]; // if it exist, we want to overwrite it with new values - -if (!(_menuName in _currentEntries)) then { - _currentEntries pushback _menuName; - missionNamespace setvariable ["cse_radiusInteraction_f_allMenuNames", _currentEntries]; - true; -} else { - false; -}; \ No newline at end of file diff --git a/TO_MERGE/cse/gui/radialmenu/fn_findTargetName_gui.sqf b/TO_MERGE/cse/gui/radialmenu/fn_findTargetName_gui.sqf deleted file mode 100644 index dc5386a09e..0000000000 --- a/TO_MERGE/cse/gui/radialmenu/fn_findTargetName_gui.sqf +++ /dev/null @@ -1,20 +0,0 @@ -/** - * fn_findTargetName_gui.sqf - * @Descr: Get the target name - * @Author: Glowbal - * - * @Arguments: [target OBJECT] - * @Return: STRING name of Target - * @PublicAPI: true - */ - -private ["_target","_targetName"]; -_target = [_this, 0, ObjNull, [ObjNull]] call BIS_fnc_Param; - -_targetName = switch (true) do { - case (_target isKindOf "CaManBase"): {([_target] call cse_fnc_getName)}; - case ((_target isKindOf "All")): {(getText(configFile >> "Cfgvehicles" >> typeof _target >> "displayName"))}; - default {"Object"}; -}; - -_targetName \ No newline at end of file diff --git a/TO_MERGE/cse/gui/radialmenu/fn_findTargetOfMenu_gui.sqf b/TO_MERGE/cse/gui/radialmenu/fn_findTargetOfMenu_gui.sqf deleted file mode 100644 index 9a5ca534ef..0000000000 --- a/TO_MERGE/cse/gui/radialmenu/fn_findTargetOfMenu_gui.sqf +++ /dev/null @@ -1,46 +0,0 @@ -/** - * fn_findTargetOfMenu_gui.sqf - * @Descr: N/A - * @Author: Glowbal - * - * @Arguments: [] - * @Return: - * @PublicAPI: false - */ - -private ["_type", "_target","_carriedObj","_allowed"]; -_type = [_this, 0, 0,[0]] call BIS_fnc_Param; -_allowedClasses = [_this, 1, ["all"],[[]]] call BIS_fnc_Param; - -if (vehicle player != player) exitwith { - vehicle player; -}; - -_target = switch (_type) do { - case 2: {if (isNull cursortarget) then {player} else{cursortarget};}; - case 1: {cursortarget}; - case 0: {player}; - default {ObjNull}; -}; - - - -if ((_target distance player) > 10 && {(_type == 2)}) then { - _target = player; -}; -if (_target != player) then { - _carriedObj = [player] call cse_fnc_getCarriedObj; - if (!isNull _carriedObj) then { - _target = _carriedObj; - }; -}; -_allowed = false; -{ - if (_target isKindOf _x) exitwith { - _allowed = true; - }; -}foreach _allowedClasses; -if (!_allowed) then { - _target = ObjNull; -}; -_target \ No newline at end of file diff --git a/TO_MERGE/cse/gui/radialmenu/fn_getAllCategoryEntriesRadialMenu_f.sqf b/TO_MERGE/cse/gui/radialmenu/fn_getAllCategoryEntriesRadialMenu_f.sqf deleted file mode 100644 index d9cb1763d7..0000000000 --- a/TO_MERGE/cse/gui/radialmenu/fn_getAllCategoryEntriesRadialMenu_f.sqf +++ /dev/null @@ -1,15 +0,0 @@ -/** - * fn_getAllCategoryEntriesRadialMenu_f.sqf - * @Descr: N/A - * @Author: Glowbal - * - * @Arguments: [] - * @Return: - * @PublicAPI: false - */ - -private ["_menuName","_categoryName"]; -_menuName = [_this, 0, "",[""]] call BIS_fnc_Param; -_categoryName = [_this, 1, "",[""]] call BIS_fnc_Param; - -(missionNamespace getvariable ["cse_radiusInteraction_f_category_entries_"+_menuName+_categoryName, []]) \ No newline at end of file diff --git a/TO_MERGE/cse/gui/radialmenu/fn_getCurrentRadialTarget_gui.sqf b/TO_MERGE/cse/gui/radialmenu/fn_getCurrentRadialTarget_gui.sqf deleted file mode 100644 index 47e8e6fb60..0000000000 --- a/TO_MERGE/cse/gui/radialmenu/fn_getCurrentRadialTarget_gui.sqf +++ /dev/null @@ -1,23 +0,0 @@ -/** - * fn_getCurrentRadialTarget_gui.sqf - * @Descr: N/A - * @Author: Glowbal - * - * @Arguments: [] - * @Return: - * @PublicAPI: false - */ - -private ["_target"]; -if (isnil "CSE_interactionTarget") then { - _target = objNull; -} else { - disableSerialization; - - if (isNull (uiNamespace getvariable "CSE_RADIAL_MENU")) then { - _target = objNull; - } else { - _target = CSE_interactionTarget; - }; -}; -_target \ No newline at end of file diff --git a/TO_MERGE/cse/gui/radialmenu/fn_getEntryToMenuSorter_f.sqf b/TO_MERGE/cse/gui/radialmenu/fn_getEntryToMenuSorter_f.sqf deleted file mode 100644 index 175520ffd5..0000000000 --- a/TO_MERGE/cse/gui/radialmenu/fn_getEntryToMenuSorter_f.sqf +++ /dev/null @@ -1,31 +0,0 @@ -/** - * fn_getEntryToMenuSorter_f.sqf - * @Descr: N/A - * @Author: Glowbal - * - * @Arguments: [] - * @Return: - * @PublicAPI: false - */ - -private ["_menuName","_currentEntries", "_returnEntries", "_target", "_toAddEntry"]; -_menuName = [_this, 0, "",[""]] call BIS_fnc_Param; -_target = [_this, 1, ObjNull, [ObjNull]] call BIS_fnc_Param; - -_currentEntries = missionNamespace getvariable ["cse_radiusInteraction_f_entries_sorter_"+_menuName, []]; -_returnEntries = []; -{ - _entry = _x; - if (typeName (_entry select 3) == typeName {}) then { - if ([player, _target] call (_entry select 3)) then { - _toAddEntry = +_entry; - _toAddEntry set [ 3, true]; - _returnEntries pushback _toAddEntry; - }; - } else { - if (_entry select 3) then { - _returnEntries pushback (+ _x); - }; - }; -}foreach _currentEntries; -_returnEntries; \ No newline at end of file diff --git a/TO_MERGE/cse/gui/radialmenu/fn_getIcon_f.sqf b/TO_MERGE/cse/gui/radialmenu/fn_getIcon_f.sqf deleted file mode 100644 index 03236d36b8..0000000000 --- a/TO_MERGE/cse/gui/radialmenu/fn_getIcon_f.sqf +++ /dev/null @@ -1,20 +0,0 @@ -/** - * fn_getIcon_f.sqf - * @Descr: Grab an icon from the CSE Icon collection - * @Author: Glowbal - * - * @Arguments: [name STRING] - * @Return: STRING Path to icon. Returns empty path if icon does not exist - * @PublicAPI: true - */ - -#define CSE_ICON_PATH "cse\cse_gui\radialmenu\data\icons\" - -private ["_iconName","_return"]; -_iconName = [_this, 0, "",[""]] call bis_fnc_param; -if (_iconName == "") then { - _iconName = "icon_cse"; -}; -_return = CSE_ICON_PATH + _iconName + ".paa"; - -_return \ No newline at end of file diff --git a/TO_MERGE/cse/gui/radialmenu/fn_getRadialInteractionEntries_f.sqf b/TO_MERGE/cse/gui/radialmenu/fn_getRadialInteractionEntries_f.sqf deleted file mode 100644 index 02d295621b..0000000000 --- a/TO_MERGE/cse/gui/radialmenu/fn_getRadialInteractionEntries_f.sqf +++ /dev/null @@ -1,16 +0,0 @@ -/** - * fn_getRadialInteractionEntries_f.sqf - * @Descr: N/A - * @Author: Glowbal - * - * @Arguments: [] - * @Return: - * @PublicAPI: false - */ - -private ["_menuName","_currentEntries"]; -_menuName = [_this, 0, "",[""]] call BIS_fnc_Param; - -_currentEntries = missionNamespace getvariable ["cse_radiusInteraction_f_entries_"+_menuName, []]; - -_currentEntries; \ No newline at end of file diff --git a/TO_MERGE/cse/gui/radialmenu/fn_hasEntriesRadialInteraction_f.sqf b/TO_MERGE/cse/gui/radialmenu/fn_hasEntriesRadialInteraction_f.sqf deleted file mode 100644 index 7813a497d1..0000000000 --- a/TO_MERGE/cse/gui/radialmenu/fn_hasEntriesRadialInteraction_f.sqf +++ /dev/null @@ -1,37 +0,0 @@ -/** - * fn_hasEntriesRadialInteraction_f.sqf - * @Descr: N/A - * @Author: Glowbal - * - * @Arguments: [] - * @Return: - * @PublicAPI: false - */ - - -private ["_menuName","_entries", "_hasEntriesAvailable", "_target"]; -_menuName = [_this, 0, "",[""]] call BIS_fnc_Param; -_target = [_this, 1, ObjNull, [ObjNull]] call BIS_fnc_Param; - -if ([_menuName, _target] call cse_fnc_radialUsesSorter_F) then { - _entries = missionNamespace getvariable ["cse_radiusInteraction_f_entries_sorter_"+_menuName, []]; // getting the direct list, otherwise it will call the conditions first -} else { - _entries = [_menuName] call cse_fnc_getRadialInteractionEntries_F; // FORMAT [ [_menuName,_icon,_onOpened,_condition] , .. ] -}; -_hasEntriesAvailable = false; -{ - _entry = _x; - if (typeName (_entry select 3) == typeName {}) then { - if ([player, _target] call (_entry select 3)) then { - _hasEntriesAvailable = true; - }; - } else { - if (_entry select 3) then { - _hasEntriesAvailable = true; - }; - }; - - if (_hasEntriesAvailable) exitwith {}; -}count _entries; - -_hasEntriesAvailable; \ No newline at end of file diff --git a/TO_MERGE/cse/gui/radialmenu/fn_isOpenSecondRing_gui.sqf b/TO_MERGE/cse/gui/radialmenu/fn_isOpenSecondRing_gui.sqf deleted file mode 100644 index 9907647f16..0000000000 --- a/TO_MERGE/cse/gui/radialmenu/fn_isOpenSecondRing_gui.sqf +++ /dev/null @@ -1,35 +0,0 @@ -/** - * fn_isOpenSecondRing_gui.sqf - * @Descr: N/A - * @Author: Glowbal - * - * @Arguments: [] - * @Return: - * @PublicAPI: false - */ - -#define OPTION_BOTTOM_LEFT_ONE 300 -#define OPTION_BOTTOM_LEFT_TWO 301 -#define OPTION_BOTTOM_LEFT_THREE 302 -#define OPTION_TOP_LEFT_ONE 303 -#define OPTION_TOP_LEFT_TWO 304 -#define OPTION_TOP_LEFT_THREE 305 -#define OPTION_TOP_RIGHT_ONE 306 -#define OPTION_TOP_RIGHT_TWO 307 -#define OPTION_TOP_RIGHT_THREE 308 -#define OPTION_BOTTOM_RIGHT_ONE 309 -#define OPTION_BOTTOM_RIGHT_TWO 310 -#define OPTION_BOTTOM_RIGHT_THREE 311 - - -private ["_return", "_availableOptionSpots"]; -_availableOptionSpots = [OPTION_BOTTOM_LEFT_ONE, OPTION_BOTTOM_LEFT_TWO, OPTION_BOTTOM_LEFT_THREE, OPTION_TOP_LEFT_ONE, OPTION_TOP_LEFT_TWO, OPTION_TOP_LEFT_THREE, OPTION_BOTTOM_RIGHT_ONE, OPTION_BOTTOM_RIGHT_TWO, OPTION_BOTTOM_RIGHT_THREE, OPTION_TOP_RIGHT_ONE, OPTION_TOP_RIGHT_TWO, OPTION_TOP_RIGHT_THREE]; - -_return = false; -{ - if (ctrlEnabled _x) exitwith { - _return = true; - }; -}foreach _availableOptionSpots; - -_return \ No newline at end of file diff --git a/TO_MERGE/cse/gui/radialmenu/fn_isRadialOptionSelected_gui.sqf b/TO_MERGE/cse/gui/radialmenu/fn_isRadialOptionSelected_gui.sqf deleted file mode 100644 index b8dcc39bc1..0000000000 --- a/TO_MERGE/cse/gui/radialmenu/fn_isRadialOptionSelected_gui.sqf +++ /dev/null @@ -1,18 +0,0 @@ -/** - * fn_isRadialOptionSelected_gui.sqf - * @Descr: N/A - * @Author: Glowbal - * - * @Arguments: [] - * @Return: - * @PublicAPI: false - */ - -private ["_number","_return"]; -_number = [_this, 0, 0, [0]] call BIS_fnc_Param; -if (isnil "CSE_SELECTED_RADIAL_OPTION_N_GUI") then { - _return = false; -} else { - _return = (CSE_SELECTED_RADIAL_OPTION_N_GUI == _number); -}; -_return \ No newline at end of file diff --git a/TO_MERGE/cse/gui/radialmenu/fn_openRadialInteractionMenu_f.sqf b/TO_MERGE/cse/gui/radialmenu/fn_openRadialInteractionMenu_f.sqf deleted file mode 100644 index 3536bc929f..0000000000 --- a/TO_MERGE/cse/gui/radialmenu/fn_openRadialInteractionMenu_f.sqf +++ /dev/null @@ -1,37 +0,0 @@ -/** - * fn_openRadialInteractionMenu_f.sqf - * @Descr: Opens a radial menu that has been registered if condition is met - * @Author: Glowbal - * - * @Arguments: [menuName STRING] - * @Return: void - * @PublicAPI: true - */ - - -#define DEFAULT_ENTRY ["","",{}, false, ""] - -private ["_menuName", "_entries", "_menu", "_target"]; -_menuName = [_this, 0, "",[""]] call BIS_fnc_Param; - -_menu = missionNamespace getvariable "cse_radiusInteraction_f_"+_menuName; // [ _menuName, _displayNameMenu, _condition,_typeOfMenu,_icon,_onOpened ] -if (!isnil "_menu") then { - _menuName = _menu select 0; - _displayNameMenu = _menu select 1; - _conditionOfMenu = _menu select 2; - _typeOfMenu = _menu select 3; - _icon = _menu select 4; - _onOpened = _menu select 5; - _target = [_typeOfMenu] call cse_fnc_findTargetOfMenu_GUI; - if (isNull _target) exitwith {}; - if (!([player, _target, _menuName] call _conditionOfMenu)) exitwith {}; - if (!([_menuName,_target] call cse_fnc_hasEntriesRadialInteraction_F) && (_target != player)) then {_target = player;}; - if (isNull _target) exitwith {}; - if !([_menuName,_target] call cse_fnc_hasEntriesRadialInteraction_F) exitwith {}; - if ([_menuName, _target] call cse_fnc_radialUsesSorter_F) then { - _entries = [_menuName] call cse_fnc_getEntryToMenuSorter_F; - } else { - _entries = [_menuName] call cse_fnc_getRadialInteractionEntries_F; // FORMAT [ [_menuName,_icon,_onOpened,_condition] , .. ] - }; - [_displayNameMenu, _entries, _target] call cse_fnc_openRadialMenu_GUI; -}; \ No newline at end of file diff --git a/TO_MERGE/cse/gui/radialmenu/fn_openRadialMenu_gui.sqf b/TO_MERGE/cse/gui/radialmenu/fn_openRadialMenu_gui.sqf deleted file mode 100644 index b62bf87e68..0000000000 --- a/TO_MERGE/cse/gui/radialmenu/fn_openRadialMenu_gui.sqf +++ /dev/null @@ -1,22 +0,0 @@ -/** - * fn_openRadialMenu_gui.sqf - * @Descr: N/A - * @Author: Glowbal - * - * @Arguments: [] - * @Return: - * @PublicAPI: false - */ - -private ["_entries", "_menuName","_target"]; -disableSerialization; -createDialog "CSE_RADIAL_MENU"; -CSE_RADIAL_SUB_MENU_GUI = []; - -_menuName = [_this, 0, "Main Menu", [""]] call BIS_fnc_Param; -_entries = [_this, 1, [], [[]]] call BIS_fnc_Param; -_target = [_this, 2, ObjNull, [ObjNull]] call BIS_fnc_Param; -setMousePosition [ 0.5, 0.6 ]; -[_menuName,_entries, _target] call cse_fnc_openRadialSubMenu_GUI; - -[[_menuName, _entries, _target],"openRadialMenu"] call cse_fnc_customEventHandler_F; \ No newline at end of file diff --git a/TO_MERGE/cse/gui/radialmenu/fn_openRadialSecondRing_gui.sqf b/TO_MERGE/cse/gui/radialmenu/fn_openRadialSecondRing_gui.sqf deleted file mode 100644 index c5f1577a57..0000000000 --- a/TO_MERGE/cse/gui/radialmenu/fn_openRadialSecondRing_gui.sqf +++ /dev/null @@ -1,41 +0,0 @@ -/** - * fn_openRadialSecondRing_gui.sqf - * @Descr: N/A - * @Author: Glowbal - * - * @Arguments: [] - * @Return: - * @PublicAPI: false - */ - -#define DEFAULT_ENTRY ["","",{}, false, ""] - - -private ["_entries","_menuName", "_target", "_from", "_passEntries", "_force"]; -_menuName = [_this, 0, "Main Menu",[""]] call BIS_fnc_Param; -_entries = [_this, 1, [],[[]]] call BIS_fnc_Param; -_target = [_this, 2, ObjNull, [ObjNull]] call BIS_fnc_Param; -_from = [_this, 3, 10, [0]] call BIS_fnc_Param; -_force = [_This, 4, false, [false]] call BIS_fnc_Param; - -if (([_from] call cse_fnc_isRadialOptionSelected_GUI) && !_force) then { - [] call cse_fnc_closeRadialSecondRing_GUI; -} else { - _passEntries = []; - - { - _entry = + ([_entries, _foreachIndex, DEFAULT_ENTRY,[[]],[4,5]] call BIS_fnc_Param); - if (typeName (_entry select 3) == typeName {}) then { - if ([player, _target] call (_entry select 3)) then { - _entry set [ 3, true]; - _passEntries pushback _entry; - }; - } else { - if (_entry select 3) then { - _passEntries pushback _entry; - }; - }; - }foreach _entries; - [_target, _passEntries, _from] call cse_fnc_setRadialSecondRing_GUI; - [_from, true] call cse_fnc_setRadialOptionSelected_GUI; -}; \ No newline at end of file diff --git a/TO_MERGE/cse/gui/radialmenu/fn_openRadialSubMenu_gui.sqf b/TO_MERGE/cse/gui/radialmenu/fn_openRadialSubMenu_gui.sqf deleted file mode 100644 index 245cdf00a5..0000000000 --- a/TO_MERGE/cse/gui/radialmenu/fn_openRadialSubMenu_gui.sqf +++ /dev/null @@ -1,20 +0,0 @@ -/** - * fn_openRadialSubMenu_gui.sqf - * @Descr: N/A - * @Author: Glowbal - * - * @Arguments: [] - * @Return: - * @PublicAPI: false - */ - -private ["_entries","_menuName", "_target"]; -_menuName = [_this, 0, "Main Menu",[""]] call BIS_fnc_Param; -_entries = [_this, 1, [],[[]]] call BIS_fnc_Param; -_target = [_this, 2, ObjNull, [ObjNull]] call BIS_fnc_Param; -[] call cse_fnc_closeRadialSecondRing_GUI; -CSE_RADIAL_SUB_MENU_GUI pushback [_target, _menuName, _entries]; -[_target, _entries] call cse_fnc_setRadialMenuOptions_GUI; -[_menuName] call cse_fnc_setRadialMenuName_GUI; -[-1, false] call cse_fnc_setRadialOptionSelected_GUI; -[ ([_target] call cse_fnc_findTargetName_GUI) ] call cse_fnc_setRadialMenuTargetName_GUI; \ No newline at end of file diff --git a/TO_MERGE/cse/gui/radialmenu/fn_radialUsesSorter_f.sqf b/TO_MERGE/cse/gui/radialmenu/fn_radialUsesSorter_f.sqf deleted file mode 100644 index 8ae3b84e7b..0000000000 --- a/TO_MERGE/cse/gui/radialmenu/fn_radialUsesSorter_f.sqf +++ /dev/null @@ -1,17 +0,0 @@ -/** - * fn_radialUsesSorter_f.sqf - * @Descr: N/A - * @Author: Glowbal - * - * @Arguments: [] - * @Return: - * @PublicAPI: false - */ - -private ["_menuName","_currentEntries"]; -_menuName = [_this, 0, "",[""]] call BIS_fnc_Param; - -_currentEntries = missionNamespace getvariable ["cse_radiusInteraction_f_"+_menuName, []]; -if (_currentEntries isEqualTo []) exitwith { false }; - -(_currentEntries select 6); \ No newline at end of file diff --git a/TO_MERGE/cse/gui/radialmenu/fn_returnToPreviousSubMenu_gui.sqf b/TO_MERGE/cse/gui/radialmenu/fn_returnToPreviousSubMenu_gui.sqf deleted file mode 100644 index b7166aff2f..0000000000 --- a/TO_MERGE/cse/gui/radialmenu/fn_returnToPreviousSubMenu_gui.sqf +++ /dev/null @@ -1,29 +0,0 @@ -/** - * fn_returnToPreviousSubMenu_gui.sqf - * @Descr: N/A - * @Author: Glowbal - * - * @Arguments: [] - * @Return: - * @PublicAPI: false - */ - -private ["_numberOf","_entries","_entryToSwitchTo","_target","_menuName"]; -if (isnil "CSE_RADIAL_SUB_MENU_GUI") then { - CSE_RADIAL_SUB_MENU_GUI = []; -}; -_numberOf = count CSE_RADIAL_SUB_MENU_GUI - 1; -if (_numberOf < 0) then { - _numberOf = 0; -}; -if (count CSE_RADIAL_SUB_MENU_GUI == 0 || ((_numberOf - 1) < 0)) exitwith { - closedialog 432341; -}; -_entryToSwitchTo = CSE_RADIAL_SUB_MENU_GUI select (_numberOf - 1); -CSE_RADIAL_SUB_MENU_GUI resize _numberOf; -_target = _entryToSwitchTo select 0; -_menuName = _entryToSwitchTo select 1; -_entries = _entryToSwitchTo select 2; - -[_target, _entries] call cse_fnc_setRadialMenuOptions_GUI; -[_menuName] call cse_fnc_setRadialMenuName_GUI; \ No newline at end of file diff --git a/TO_MERGE/cse/gui/radialmenu/fn_setRadialMenuName_gui.sqf b/TO_MERGE/cse/gui/radialmenu/fn_setRadialMenuName_gui.sqf deleted file mode 100644 index 7ac2cf648b..0000000000 --- a/TO_MERGE/cse/gui/radialmenu/fn_setRadialMenuName_gui.sqf +++ /dev/null @@ -1,24 +0,0 @@ -/** - * fn_setRadialMenuName_gui.sqf - * @Descr: N/A - * @Author: Glowbal - * - * @Arguments: [] - * @Return: - * @PublicAPI: false - */ - -private ["_menuName", "_buttonName", "_display", "_countOf"]; -_menuName = [_this, 0, "Main Menu",[""]] call BIS_fnc_Param; -ctrlSetText [1, _menuName]; - -if (count CSE_RADIAL_SUB_MENU_GUI > 1) then { - _countOf = (count CSE_RADIAL_SUB_MENU_GUI) - 2; - _buttonName = "Return to " + ((CSE_RADIAL_SUB_MENU_GUI select _countOf) select 1); -} else { - _buttonName = "Close Menu"; -}; - -disableSerialization; -_display = uiNamespace getvariable "CSE_RADIAL_MENU"; -(_display displayCtrl 2315) ctrlSetTooltip _buttonName; \ No newline at end of file diff --git a/TO_MERGE/cse/gui/radialmenu/fn_setRadialMenuOptions_gui.sqf b/TO_MERGE/cse/gui/radialmenu/fn_setRadialMenuOptions_gui.sqf deleted file mode 100644 index dc151cc954..0000000000 --- a/TO_MERGE/cse/gui/radialmenu/fn_setRadialMenuOptions_gui.sqf +++ /dev/null @@ -1,86 +0,0 @@ -/** - * fn_setRadialMenuOptions_gui.sqf - * @Descr: N/A - * @Author: Glowbal - * - * @Arguments: [] - * @Return: - * @PublicAPI: false - */ - -#define DEFAULT_ENTRY ["","",{}, false, ""] - -private ["_display","_availableOptions","_buttonCtrl","_iconCtrl","_textCtrl","_entry","_textCtrl", "_entries", "_target", "_title", "_backgroundCtrl"]; - -_target = [_this, 0, ObjNull, [ObjNull]] call BIS_fnc_Param; -_entries = [_this, 1, [], [[]]] call BIS_fnc_Param; -CSE_interactionTarget = _target; - - -disableSerialization; -_display = uiNamespace getvariable "CSE_RADIAL_MENU"; -_availableOptions = [10, 11, 12, 13, 14, 15, 16, 17]; -{ - _buttonCtrl = _display displayCtrl _x; - _iconCtrl = _display displayCtrl (_x + 90); - _textCtrl = _display displayCtrl (_x + 190); - _backgroundCtrl = _display displayCtrl (_x + 790); - _buttonCtrl ctrlEnable true; - _entry = [_entries, _foreachIndex, DEFAULT_ENTRY,[[]],[4,5]] call BIS_fnc_Param; - if (typeName (_entry select 3) == typeName {}) then { - if ([player, _target] call (_entry select 3)) then { - _textCtrl ctrlSetText (_entry select 0); - _iconCtrl ctrlSetText (_entry select 1); - _title = _entry select 4; - if (isnil "_title") then { - _title = _entry select 0; - }; - missionnamespace setvariable ["CSE_RADIAL_MENU_CODE_ON_MOUSE_IN_BUTTON_"+ str _x, format["if (!([] call cse_fnc_isOpenSecondRing_GUI) && CSE_ALLOW_ON_MOUSE_OVER_OPEN_RADIALMENU) then {[player,CSE_interactionTarget, %1, '%3'] call %2; }; true;",_x, _entry select 2, _title]]; - _buttonCtrl ctrlSetEventHandler ["ButtonClick", format["[player,CSE_interactionTarget, %1, '%3'] call %2; true;",_x, _entry select 2, _title]]; - _buttonCtrl ctrlSetTooltip (_entry select 4); - _backgroundCtrl ctrlSetTextColor [0,0,0,0.66]; - _iconCtrl ctrlSetTextColor [1,1,1,0.66]; - _textCtrl ctrlSetTextColor [1,1,1,0.66]; - } else { - _buttonCtrl ctrlEnable false; - _textCtrl ctrlSetText (_entry select 0); - _iconCtrl ctrlSetText (_entry select 1); - _iconCtrl ctrlSetTextColor [1,1,1,0.2]; - _textCtrl ctrlSetTextColor [1,1,1,0.2]; - _buttonCtrl ctrlSetTooltip ""; - _backgroundCtrl ctrlSetTextColor [0,0,0,0.66]; - - missionnamespace setvariable ["CSE_RADIAL_MENU_CODE_ON_MOUSE_IN_BUTTON_"+ str _x, ""]; - }; - } else { - if (_entry select 3) then { - _textCtrl ctrlSetText (_entry select 0); - _iconCtrl ctrlSetText (_entry select 1); - - _iconCtrl ctrlSetTextColor [1,1,1,0.66]; - _textCtrl ctrlSetTextColor [1,1,1,0.66]; - _title = _entry select 4; - if (isnil "_title") then { - _title = _entry select 0; - }; - missionnamespace setvariable ["CSE_RADIAL_MENU_CODE_ON_MOUSE_IN_BUTTON_"+ str _x, format["if (!([] call cse_fnc_isOpenSecondRing_GUI) && CSE_ALLOW_ON_MOUSE_OVER_OPEN_RADIALMENU) then {[player,CSE_interactionTarget, %1, '%3'] call %2; }; true;",_x, _entry select 2, _title]]; - _buttonCtrl ctrlSetEventHandler ["ButtonClick", format["[player,CSE_interactionTarget,%1 , '%3'] call %2; true;",_x, _entry select 2, _title]]; - _buttonCtrl ctrlSetTooltip (_entry select 4); - _backgroundCtrl ctrlSetTextColor [0,0,0,0.66]; - } else { - _buttonCtrl ctrlEnable false; - _textCtrl ctrlSetText (_entry select 0); - _iconCtrl ctrlSetText (_entry select 1); - _iconCtrl ctrlSetTextColor [1,1,1,0.2]; - _textCtrl ctrlSetTextColor [1,1,1,0.2]; - missionnamespace setvariable ["CSE_RADIAL_MENU_CODE_ON_MOUSE_IN_BUTTON_"+ str _x, ""]; - _buttonCtrl ctrlSetTooltip ""; - _backgroundCtrl ctrlSetTextColor [0,0,0,0.66]; - }; - }; - - _textCtrl ctrlCommit 0; - _iconCtrl ctrlCommit 0; - _backgroundCtrl ctrlCommit 0; - _buttonCtrl ctrlCommit 0; -}foreach _availableOptions; \ No newline at end of file diff --git a/TO_MERGE/cse/gui/radialmenu/fn_setRadialMenuTargetName_gui.sqf b/TO_MERGE/cse/gui/radialmenu/fn_setRadialMenuTargetName_gui.sqf deleted file mode 100644 index 9eb7cc903e..0000000000 --- a/TO_MERGE/cse/gui/radialmenu/fn_setRadialMenuTargetName_gui.sqf +++ /dev/null @@ -1,13 +0,0 @@ -/** - * fn_setRadialMenuTargetName_gui.sqf - * @Descr: N/A - * @Author: Glowbal - * - * @Arguments: [] - * @Return: - * @PublicAPI: false - */ - -private ["_menuName"]; -_menuName = [_this, 0, "",[""]] call BIS_fnc_Param; -ctrlSetText [2, _menuName]; \ No newline at end of file diff --git a/TO_MERGE/cse/gui/radialmenu/fn_setRadialOptionSelected_gui.sqf b/TO_MERGE/cse/gui/radialmenu/fn_setRadialOptionSelected_gui.sqf deleted file mode 100644 index 5cf550a48b..0000000000 --- a/TO_MERGE/cse/gui/radialmenu/fn_setRadialOptionSelected_gui.sqf +++ /dev/null @@ -1,34 +0,0 @@ -/** - * fn_setRadialOptionSelected_gui.sqf - * @Descr: N/A - * @Author: Glowbal - * - * @Arguments: [] - * @Return: - * @PublicAPI: false - */ - -private ["_number","_selected","_display","_backgroundCtrl"]; -_number = [_this, 0, 10, [0]] call BIS_fnc_Param; -_selected = [_this, 1, false, [false]] call BIS_fnc_Param; - -if (_number > 9 && _number < 18 || _number == -1) then { - disableSerialization; - _display = uiNamespace getvariable "CSE_RADIAL_MENU"; - - for "_i" from 800 to 808 do { - _backgroundCtrl = _display displayCtrl _i; - _backgroundCtrl ctrlSetTextColor [ 0, 0, 0, 0.66]; - }; - CSE_SELECTED_RADIAL_OPTION_N_GUI = _number; - if (_number != -1) then { - _backgroundCtrl = _display displayCtrl (_number + 790); - if (_selected) then { - _backgroundCtrl ctrlSetTextColor [ 0.77, 0.5, 0.0, 0.66]; - } else { - _backgroundCtrl ctrlSetTextColor [ 0, 0, 0, 0.66]; - }; - _backgroundCtrl ctrlCommit 0; - }; - -}; \ No newline at end of file diff --git a/TO_MERGE/cse/gui/radialmenu/fn_setRadialSecondRing_gui.sqf b/TO_MERGE/cse/gui/radialmenu/fn_setRadialSecondRing_gui.sqf deleted file mode 100644 index 64694cde61..0000000000 --- a/TO_MERGE/cse/gui/radialmenu/fn_setRadialSecondRing_gui.sqf +++ /dev/null @@ -1,180 +0,0 @@ -/** - * fn_setRadialSecondRing_gui.sqf - * @Descr: N/A - * @Author: Glowbal - * - * @Arguments: [] - * @Return: - * @PublicAPI: false - */ - -#define DEFAULT_ENTRY ["","",{}, false, ""] - -#define ACTION_TOP 10 -#define ACTION_TOP_LEFT 11 -#define ACTION_TOP_RIGHT 12 -#define ACTION_CENTER_LEFT 13 -#define ACTION_CENTER_RIGHT 14 -#define ACTION_BOTTOM_LEFT 15 -#define ACTION_BOTTOM_RIGHT 16 -#define ACTION_BOTTOM 17 - -#define OPTION_BOTTOM_LEFT_ONE 300 -#define OPTION_BOTTOM_LEFT_TWO 301 -#define OPTION_BOTTOM_LEFT_THREE 302 -#define OPTION_TOP_LEFT_ONE 303 -#define OPTION_TOP_LEFT_TWO 304 -#define OPTION_TOP_LEFT_THREE 305 -#define OPTION_TOP_RIGHT_ONE 306 -#define OPTION_TOP_RIGHT_TWO 307 -#define OPTION_TOP_RIGHT_THREE 308 -#define OPTION_BOTTOM_RIGHT_ONE 309 -#define OPTION_BOTTOM_RIGHT_TWO 310 -#define OPTION_BOTTOM_RIGHT_THREE 311 - -private ["_entries","_fromInnerRing","_display","_entry","_actionFillOrder","_availableSpots","_availableOptionSpots","_buttonCtrl","_iconCtrl", "_textCtrl","_title"]; -_target = [_this, 0, ObjNull, [ObjNull]] call BIS_fnc_Param; -_entries = [_this, 1, [], [[]]] call BIS_fnc_Param; -_fromInnerRing = [_this, 2, ACTION_TOP, [0]] call BIS_fnc_Param; - -_availableOptionSpots = [OPTION_BOTTOM_LEFT_ONE, OPTION_BOTTOM_LEFT_TWO, OPTION_BOTTOM_LEFT_THREE, OPTION_TOP_LEFT_ONE, OPTION_TOP_LEFT_TWO, OPTION_TOP_LEFT_THREE, OPTION_BOTTOM_RIGHT_ONE, OPTION_BOTTOM_RIGHT_TWO, OPTION_BOTTOM_RIGHT_THREE, OPTION_TOP_RIGHT_ONE, OPTION_TOP_RIGHT_TWO, OPTION_TOP_RIGHT_THREE]; - -_bottomLeftCollection = [OPTION_BOTTOM_LEFT_ONE, OPTION_BOTTOM_LEFT_TWO, OPTION_BOTTOM_LEFT_THREE]; -_topLeftCollection = [OPTION_TOP_LEFT_THREE, OPTION_TOP_LEFT_TWO, OPTION_TOP_LEFT_ONE]; -_bottomRightCollection = [OPTION_BOTTOM_RIGHT_ONE, OPTION_BOTTOM_RIGHT_TWO, OPTION_BOTTOM_RIGHT_THREE]; -_topRightCollection = [OPTION_TOP_RIGHT_ONE, OPTION_TOP_RIGHT_TWO, OPTION_TOP_RIGHT_THREE]; - -_actionFillOrder = switch (_fromInnerRing) do { - case ACTION_TOP: { [ OPTION_TOP_LEFT_THREE, OPTION_TOP_LEFT_TWO, OPTION_TOP_LEFT_ONE, OPTION_TOP_RIGHT_ONE, OPTION_TOP_RIGHT_TWO, OPTION_TOP_RIGHT_THREE , OPTION_BOTTOM_LEFT_THREE, OPTION_BOTTOM_LEFT_TWO , OPTION_BOTTOM_LEFT_ONE, OPTION_BOTTOM_RIGHT_ONE, OPTION_BOTTOM_RIGHT_TWO, OPTION_BOTTOM_RIGHT_THREE]}; - - case ACTION_TOP_LEFT: {[OPTION_TOP_LEFT_THREE, OPTION_TOP_LEFT_TWO, OPTION_TOP_LEFT_ONE, OPTION_BOTTOM_LEFT_THREE, OPTION_BOTTOM_LEFT_TWO , OPTION_BOTTOM_LEFT_ONE, OPTION_TOP_RIGHT_ONE, OPTION_TOP_RIGHT_TWO, OPTION_TOP_RIGHT_THREE, OPTION_BOTTOM_RIGHT_ONE, OPTION_BOTTOM_RIGHT_TWO, OPTION_BOTTOM_RIGHT_THREE ]}; - - case ACTION_TOP_RIGHT: { [OPTION_TOP_RIGHT_ONE, OPTION_TOP_RIGHT_TWO, OPTION_TOP_RIGHT_THREE, OPTION_BOTTOM_RIGHT_ONE, OPTION_BOTTOM_RIGHT_TWO, OPTION_BOTTOM_RIGHT_THREE, OPTION_TOP_LEFT_THREE, OPTION_TOP_LEFT_TWO, OPTION_TOP_LEFT_ONE, OPTION_BOTTOM_LEFT_THREE, OPTION_BOTTOM_LEFT_TWO , OPTION_BOTTOM_LEFT_ONE ]}; - - case ACTION_CENTER_LEFT: {[OPTION_BOTTOM_LEFT_THREE, OPTION_BOTTOM_LEFT_TWO , OPTION_BOTTOM_LEFT_ONE, OPTION_TOP_LEFT_ONE, OPTION_TOP_LEFT_TWO, OPTION_TOP_LEFT_THREE, OPTION_TOP_RIGHT_ONE, OPTION_TOP_RIGHT_TWO, OPTION_TOP_RIGHT_THREE, OPTION_BOTTOM_RIGHT_ONE, OPTION_BOTTOM_RIGHT_TWO, OPTION_BOTTOM_RIGHT_THREE]}; - - case ACTION_CENTER_RIGHT: {[OPTION_BOTTOM_RIGHT_ONE, OPTION_BOTTOM_RIGHT_TWO, OPTION_BOTTOM_RIGHT_THREE, OPTION_TOP_RIGHT_THREE, OPTION_TOP_RIGHT_TWO, OPTION_TOP_RIGHT_ONE, OPTION_TOP_LEFT_THREE, OPTION_TOP_LEFT_TWO, OPTION_TOP_LEFT_ONE, OPTION_BOTTOM_LEFT_THREE, OPTION_BOTTOM_LEFT_TWO, OPTION_BOTTOM_LEFT_ONE]}; - - case ACTION_BOTTOM_LEFT: {[OPTION_BOTTOM_LEFT_ONE, OPTION_BOTTOM_LEFT_TWO, OPTION_BOTTOM_LEFT_THREE, OPTION_TOP_LEFT_ONE, OPTION_TOP_LEFT_TWO, OPTION_TOP_LEFT_THREE, OPTION_TOP_RIGHT_ONE, OPTION_TOP_RIGHT_TWO, OPTION_TOP_RIGHT_THREE, OPTION_BOTTOM_RIGHT_ONE, OPTION_BOTTOM_RIGHT_TWO, OPTION_BOTTOM_RIGHT_THREE]}; - - case ACTION_BOTTOM_RIGHT: {[OPTION_BOTTOM_RIGHT_THREE, OPTION_BOTTOM_RIGHT_TWO, OPTION_BOTTOM_RIGHT_ONE, OPTION_TOP_RIGHT_THREE, OPTION_TOP_RIGHT_TWO, OPTION_TOP_RIGHT_ONE, OPTION_TOP_LEFT_THREE, OPTION_TOP_LEFT_TWO, OPTION_TOP_LEFT_ONE, OPTION_BOTTOM_LEFT_THREE, OPTION_BOTTOM_LEFT_TWO, OPTION_BOTTOM_LEFT_ONE ] }; - - case ACTION_BOTTOM: {[OPTION_BOTTOM_LEFT_ONE, OPTION_BOTTOM_LEFT_TWO, OPTION_BOTTOM_LEFT_THREE, OPTION_TOP_LEFT_ONE, OPTION_TOP_LEFT_TWO, OPTION_TOP_LEFT_THREE, OPTION_BOTTOM_RIGHT_ONE, OPTION_BOTTOM_RIGHT_TWO, OPTION_BOTTOM_RIGHT_THREE, OPTION_TOP_RIGHT_ONE, OPTION_TOP_RIGHT_TWO, OPTION_TOP_RIGHT_THREE]}; - - default {[OPTION_BOTTOM_LEFT_ONE, OPTION_BOTTOM_LEFT_TWO, OPTION_BOTTOM_LEFT_THREE, OPTION_TOP_LEFT_ONE, OPTION_TOP_LEFT_TWO, OPTION_TOP_LEFT_THREE, OPTION_BOTTOM_RIGHT_ONE, OPTION_BOTTOM_RIGHT_TWO, OPTION_BOTTOM_RIGHT_THREE, OPTION_TOP_RIGHT_ONE, OPTION_TOP_RIGHT_TWO, OPTION_TOP_RIGHT_THREE]}; -}; - -_showBottomLeft = false; -_showTopLeft = false; -_showTopRight = false; -_showBottomRight = false; - -_determineShowBackGroundVariables = { - private ["_idc"]; - _idc = (_this select 0); - if (_idc in _bottomLeftCollection) then { - _showBottomLeft = true; - } else { - if (_idc in _topLeftCollection) then { - _showTopLeft = true; - } else { - if (_idc in _topRightCollection) then { - _showTopRight = true; - } else { - if (_idc in _bottomRightCollection) then { - _showBottomRight = true; - }; - }; - }; - }; -}; - - - - -disableSerialization; -_display = uiNamespace getvariable "CSE_RADIAL_MENU"; - -{ - _buttonCtrl = _display displayCtrl _x; - _iconCtrl = _display displayCtrl (_x + 50); - _textCtrl = _display displayCtrl (_x + 100); - _buttonCtrl ctrlEnable true; - _entry = [_entries, _foreachIndex, DEFAULT_ENTRY,[[]],[4,5]] call BIS_fnc_Param; - if (typeName (_entry select 3) == typeName {}) then { - if ([player, _target] call (_entry select 3)) then { - _textCtrl ctrlSetText (_entry select 0); - _iconCtrl ctrlSetText (_entry select 1); - if (count _entry < 5) then { - _title = _entry select 0; - } else { - _title = _entry select 4; - }; - _buttonCtrl ctrlSetEventHandler ["ButtonClick", format["[player,CSE_interactionTarget,%1 , '%3'] call %2; true;",_x, _entry select 2, _title]]; - _buttonCtrl ctrlSetTooltip _title; - - [_x] call _determineShowBackGroundVariables; - } else { - _buttonCtrl ctrlEnable false; - _iconCtrl ctrlSetText ""; - _textCtrl ctrlSetText ""; - _buttonCtrl ctrlSetTooltip ""; - }; - } else { - if (_entry select 3) then { - _textCtrl ctrlSetText (_entry select 0); - _iconCtrl ctrlSetText (_entry select 1); - - if (count _entry < 5) then { - _title = _entry select 0; - } else { - _title = _entry select 4; - }; - _buttonCtrl ctrlSetEventHandler ["ButtonClick", format["[player,CSE_interactionTarget,%1 , '%3'] call %2; true;",_x, _entry select 2, _title]]; - _buttonCtrl ctrlSetTooltip _title; - [_x] call _determineShowBackGroundVariables; - } else { - _buttonCtrl ctrlEnable false; - _iconCtrl ctrlSetText ""; - _textCtrl ctrlSetText ""; - _buttonCtrl ctrlSetTooltip ""; - }; - }; - - _textCtrl ctrlCommit 0; - _iconCtrl ctrlCommit 0; - _buttonCtrl ctrlCommit 0; -}foreach _actionFillOrder; - - -if (_showBottomLeft) then { - (_display displayCtrl 702) ctrlSetTextColor [0,0,0,0.66]; -} else { - (_display displayCtrl 702) ctrlSetTextColor [0,0,0,0.0]; -}; -(_display displayCtrl 702) ctrlCommit 0; - - -if (_showTopLeft) then { - (_display displayCtrl 700) ctrlSetTextColor [0,0,0,0.66]; -} else { - (_display displayCtrl 700) ctrlSetTextColor [0,0,0,0.0]; -}; -(_display displayCtrl 700) ctrlCommit 0; - - -if (_showTopRight) then { - (_display displayCtrl 701) ctrlSetTextColor [0,0,0,0.66]; -} else { - (_display displayCtrl 701) ctrlSetTextColor [0,0,0,0.0]; -}; -(_display displayCtrl 701) ctrlCommit 0; - - -if (_showBottomRight) then { - (_display displayCtrl 703) ctrlSetTextColor [0,0,0,0.66]; -} else { - (_display displayCtrl 703) ctrlSetTextColor [0,0,0,0.0]; -}; -(_display displayCtrl 703) ctrlCommit 0; - diff --git a/TO_MERGE/cse/gui/stringtable.xml b/TO_MERGE/cse/gui/stringtable.xml deleted file mode 100644 index 9a22f46ff3..0000000000 --- a/TO_MERGE/cse/gui/stringtable.xml +++ /dev/null @@ -1,7 +0,0 @@ - - - - - - - \ No newline at end of file diff --git a/TO_MERGE/cse/gui/weaponSelector/fn_onWeaponSelectorOpened_GUI.sqf b/TO_MERGE/cse/gui/weaponSelector/fn_onWeaponSelectorOpened_GUI.sqf deleted file mode 100644 index e7ad59a6ee..0000000000 --- a/TO_MERGE/cse/gui/weaponSelector/fn_onWeaponSelectorOpened_GUI.sqf +++ /dev/null @@ -1,20 +0,0 @@ -private ["_display", "_currentWeapon", "_primaryWeapon", "_secondairyWeapon", "_pistol"]; -_display = _this select 0; - -_currentWeapon = currentWeapon player; -_primaryWeapon = primaryWeapon player; -_secondairyWeapon = secondaryWeapon player; -_pistol = handgunWeapon player; - -// getText(configFile >> "CfgMagazines" >> "%1" >> "displayName"), getText(configFile >> "CfgMagazines" >> "%1" >> "picture"); - - -(_display displayCtrl 710) ctrlSetText (getText(configFile >> "CfgWeapons" >> _currentWeapon >> "picture")); - -(_display displayCtrl 100) ctrlSetText (getText(configFile >> "CfgWeapons" >> _currentWeapon >> "picture")); - -(_display displayCtrl 103) ctrlSetText (getText(configFile >> "CfgWeapons" >> _secondairyWeapon >> "picture")); - -(_display displayCtrl 104) ctrlSetText (getText(configFile >> "CfgWeapons" >> _pistol >> "picture")); - -// (_display displayCtrl 107) ctrlSetText (getText(configFile >> "CfgWeapons" >> _currentWeapon >> "picture")); \ No newline at end of file diff --git a/TO_MERGE/cse/main/CfgFactionClasses.h b/TO_MERGE/cse/main/CfgFactionClasses.h deleted file mode 100644 index 6dce67e747..0000000000 --- a/TO_MERGE/cse/main/CfgFactionClasses.h +++ /dev/null @@ -1,22 +0,0 @@ -class CfgFactionClasses -{ - class NO_CATEGORY; - class cseModules: NO_CATEGORY { - displayName = "CSE Modules"; - }; - class cseDebug: NO_CATEGORY { - displayName = "CSE Debug"; - }; - class cseMisc: NO_CATEGORY { - displayName = "CSE Misc"; - }; - class cse_equipment: NO_CATEGORY { - displayName = "CSE Equipment"; - }; - class cse_medical: NO_CATEGORY { - displayName = "CSE Medical"; - }; - class cseCCModule: NO_CATEGORY { - displayName = "CSE Command & Control"; - }; -}; \ No newline at end of file diff --git a/TO_MERGE/cse/main/CfgFunctions.h b/TO_MERGE/cse/main/CfgFunctions.h deleted file mode 100644 index 29cb3d875e..0000000000 --- a/TO_MERGE/cse/main/CfgFunctions.h +++ /dev/null @@ -1,154 +0,0 @@ -class CfgFunctions { - class CSE { - class Strings { - file = "cse\cse_main\strings\functions"; - class stringCompare { recompile = 1; }; - class string_removeWhiteSpace { recompile = 1; }; - }; - class HC { - file = "cse\cse_main\hc\functions"; - class isHC { recompile = 1; }; - }; - class Requests { - file = "cse\cse_main\requests\functions"; - class sendRequest_f { recompile = 1; }; - class requestCallback { recompile = 1; }; - class receiveRequest { recompile = 1; }; - class onAnswerRequest { recompile = 1; }; - }; - - class Debug { - file = "cse\cse_main\debug\functions"; - class debug { recompile = 1; }; - class debugModule { recompile = 1; }; - class traceModule { recompile = 1; }; - }; - - class TaskPool { - file = "cse\cse_main\tasks\functions"; - class addTaskToPool_f { recompile = 1; }; - class removeTaskFromPool_f { recompile = 1; }; - class loopThroughPool_f { recompile = 1; }; - }; - - class Mutex { - file = "cse\cse_main\mutex\functions"; - class createMutex { recompile = 1; }; - class releaseMutex { recompile = 1; }; - class waitForSingleMutex { recompile = 1; }; - class waitForMultipleMutex { recompile = 1; }; - class lockMutex { recompile = 1; }; - }; - - class Variables { - file = "cse\cse_main\variables\functions"; - class defineVariable { recompile = 1; }; - class setVariable { recompile = 1; }; - class getVariable { recompile = 1; }; - class getAllSetVariables { recompile = 1; }; - class getVariableInfo { recompile = 1; }; - class getVariableDefault { recompile = 1; }; - }; - - class Messages { - file = "cse\cse_main\messages\functions"; - class sendHintTo { recompile = 1; }; - class sendMessageTo { recompile = 1; }; - class sendDisplayInformationTo { recompile = 1; }; - class sendDisplayMessageTo { recompile = 1; }; - }; - - class Anim { - file = "cse\cse_main\anim\functions"; - class broadcastAnim { recompile = 1; }; - class getDeathAnim { recompile = 1; }; - class switchAnim { recompile = 1; }; - class playMoveNow { recompile = 1; }; - class localAnim { recompile = 1; }; - }; - - class Arrays { - file = "cse\cse_main\arrays\functions"; - class insertionSort { recompile = 1; }; - class findIf { recompile = 1; }; - class findIn { recompile = 1; }; - class findAll { recompile = 1; }; - class uniqueElementsOnly { recompile = 1; }; - class foreachDo { recompile = 1; }; - class sortAlphabeticallyBy { recompile = 1; }; - }; - - class EquipmentLib { - file = "cse\cse_main\equipment\functions"; - class hasMagazine { recompile = 1; }; - class useMagazine { recompile = 1; }; - class findMagazine { recompile = 1; }; - class hasItem { recompile = 1; }; - class useItem { recompile = 1; }; - class findItem { recompile = 1; }; - class getNumberMagazinesIn { recompile = 1; }; - }; - - class Interaction { - file = "cse\cse_main\interaction\functions"; - class registerInteractingWith { recompile = 1; }; - class getInteractionTarget { recompile = 1; }; - class isRegisteredInteractingWith { recompile = 1; }; - class unregisterInteractingWith { recompile = 1; }; - class getAllMonitoredVariables { recompile = 1; }; - class registerVariableMonitor { recompile = 1; }; - class setOnUpdateVariableEH { recompile = 1; }; - class getOnUpdateVariableEH { recompile = 1; }; - class getRegisteredMonitorVariablesOwners { recompile = 1; }; - class getMonitoredVariableName { recompile = 1; }; - class getMonitoredVariableValue { recompile = 1; }; - class setMonitoredVariableValue { recompile = 1; }; - class broadcastMonitoredVariable { recompile = 1; }; - class setCanInteract { recompile = 1; }; - class getCanInteract { recompile = 1; }; - class canInteract { recompile = 1; }; - }; - class Misc { - file = "cse\cse_main\misc\functions"; - class resetAllDefaults_f { recompile = 1; }; - class broadcastSound3D_f { recompile = 1; }; - class getName { recompile = 1; }; - class setDead { recompile = 1; }; - class isAwake { recompile = 1; }; - class setProne { recompile = 1; }; - class isInBuilding { recompile = 1; }; - class disableKeyInput_f { recompile = 1; }; - class disableUserInput_f { recompile = 1; }; - class dropWeapon_f { recompile = 1; }; - class inWater_f { recompile = 1; }; - class setVolume_f { recompile = 1; }; - class lockVehicleOfUnitUntil { recompile = 1; }; - class closeAllDialogs_f { recompile = 1; }; - class disableAI_f { recompile = 1; }; - class moduleEnableBasicRevive { recompile = 1; }; - class switchToGroupSide_f { recompile = 1; }; - class hasItem_f { recompile = 1; }; - class getFirstObjectIntersection { recompile = 1; }; - class getFirstTerrainIntersection { recompile = 1; }; - class setHearingCapability { recompile = 1; }; - class revealObject_f { recompile = 1; }; - class getWeaponItems_f { recompile = 1; }; - }; - class Mods { - file = "cse\cse_main\mods\functions"; - class ALiVE_Bus_Mod { recompile = 1; }; - class isLoaded_ALiVE_Mod { recompile = 1; }; - class isModLoaded_f { recompile = 1; }; - }; - - - class Config { - file = "cse\cse_main\config\functions"; - class inheritsFrom; - }; - class Version { - file = "cse\cse_main\version\functions"; - class getVersion; - }; - }; -}; diff --git a/TO_MERGE/cse/main/CfgHints.h b/TO_MERGE/cse/main/CfgHints.h deleted file mode 100644 index 23611db6cc..0000000000 --- a/TO_MERGE/cse/main/CfgHints.h +++ /dev/null @@ -1,27 +0,0 @@ -class CfgHints -{ - class Combat_Space_Enhancement - { - displayName = "Combat Space Enhancement"; - class Main - { - displayName = "Combat Space Enhancement"; - displayNameShort = "Combat Space Enhancement"; - description = "Combat Space Enhancement is a standalone modification for the game Arma III and is developed by the team behind Combat Medical System. All features from CSE are build on top of our in house developed framework, allowing for compatibility between various modules/features with ease by both our in house created modules and any third party made content."; - tip = ""; - arguments[] = {}; - image = ""; - noImage = true; - }; - class Credits - { - displayName = "Credits"; - displayNameShort = "Credits"; - description = "Glowbal, Project Lead & lead developer (Scripting, Graphics, Design) %2Kieran, Webmaster %2Rye, PR & Testing %1%1Contributions by:%2Aposky, Artist (Graphics & Models)%2Janus, Artist (Graphics & Models)%2DocScarle (Medical Knowledge)%2-FM- (Medical Knowledge)%2Carrot (Medical Knowledge)%2Ogirdor (Graphics)%2Beardmoresam (Medical Knowledge)%2Raptor 6 Actual (Medical Knowledge)%2Bovine3dom (Some script contributions & assistance with calculations)%2Donny (Models)%2Deadman (Graphics & Models)%1%1Additional:%2This project contains some free icons by http://icons8.com/%2ALIVE Team (ALiVE & CSE integration)%2LondonLad (Allowing use of dedicated server for testing)%2bodybag.p3d file and textures by Bohemia Interactive."; - tip = ""; - arguments[] = {}; - image = ""; - noImage = true; - }; - }; -}; \ No newline at end of file diff --git a/TO_MERGE/cse/main/CfgVehicles.h b/TO_MERGE/cse/main/CfgVehicles.h deleted file mode 100644 index e717a10d4f..0000000000 --- a/TO_MERGE/cse/main/CfgVehicles.h +++ /dev/null @@ -1,115 +0,0 @@ -#include "CfgFactionClasses.h" - -class CfgVehicles { - class Logic; - class Module_F: Logic { - class ArgumentsBaseUnits { - }; - }; - class cse_enableLogging: Module_F { - scope = 2; - displayName = "Logging [CSE]"; - icon = "\cse\cse_main\data\cse_logging_icon.paa"; - category = "cseDebug"; - function = "cse_fnc_debugModule"; - functionPriority = 1; - isGlobal = 1; - isTriggerActivated = 0; - class Arguments { - class logLevel { - displayName = "Enable Logging at"; - description = "The maximum level of logging"; - typeName = "STRING"; - class values { - class NONE {name="None"; value=4; default=1; }; - class INFO {name="Information"; value=3; }; - class DEBUG {name="Debug"; value=2; }; - class WARN {name="Warnings"; value=1; }; - class ERROR {name="Errors"; value=0; }; - }; - }; - class logDisplayLevel { - displayName = "Show in chat"; - description = "The maximum level of log messages to be shown in chat"; - typeName = "STRING"; - class values { - class NONE {name="None"; value=4; default=1; }; - class INFO {name="Information"; value=3; }; - class DEBUG {name="Debug"; value=2; }; - class WARN {name="Warnings"; value=1; }; - class ERROR {name="Errors"; value=0; }; - }; - }; - }; - class ModuleDescription { - description = "Lets you modify the logging settings within CSE."; // Short description, will be formatted as structured text - sync[] = {}; - }; - }; - class cse_traceValuesObject: Module_F { - - scope = 2; - displayName = "Trace variables [CSE]"; - icon = "\cse\cse_main\data\cse_debug_icon.paa"; - category = "cseDebug"; - function = "cse_fnc_traceModule"; - functionPriority = 1; - isGlobal = 1; - isTriggerActivated = 1; - class Arguments { - class enableFor { - displayName = "Trace player variables"; - description = "Whatever or not a debug message will be printed when a value for a player changes"; - typeName = "STRING"; - class values { - class DISABLED {name="Disable"; value=0; default=1; }; - class ENABLE {name="Enable"; value=1; }; - }; - }; - }; - class ModuleDescription { - description = "Trace variables of given object"; // Short description, will be formatted as structured text - sync[] = {}; - }; - }; - - - class cse_basicRevive: Module_F { - scope = 2; - displayName = "Basic Revive [CSE]"; - icon = "\cse\cse_main\data\cse_medical_module.paa"; - category = "cse_medical"; - function = "cse_fnc_initalizeModule_F"; - functionPriority = 1; - isGlobal = 1; - isTriggerActivated = 0; - class Arguments { - class enableFor { - displayName = "Enable for"; - description = "Should the basic revive be enabled for players, AI or both?"; - typeName = "NUMBER"; - class values { - class disable {name="Disable"; value=0; default=1; }; - class playersOnly {name="Players only"; value=1; }; - class playersAndAI { name="Players and AI"; value = 2; }; - }; - }; - class timer { - displayName = "Timer"; - description = "How long can a unit spend in unconscious mode (In seconds)"; - typeName = "NUMBER"; - defaultValue = 600; - }; - class amountOf { - displayName = "Hits while unconscious"; - description = "number of times a unit can be hit/killed before being force killed. -1 is disabled."; - typeName = "NUMBER"; - defaultValue = -1; - }; - }; - class ModuleDescription { - description = "Enables the basic revive script for all damage done through CSE.
Any unit that is killed, will be put in an unconscious state until their timer runs out."; - sync[] = {}; - }; - }; -}; \ No newline at end of file diff --git a/TO_MERGE/cse/main/Combat_Space_Enhancement.h b/TO_MERGE/cse/main/Combat_Space_Enhancement.h deleted file mode 100644 index 9046550f26..0000000000 --- a/TO_MERGE/cse/main/Combat_Space_Enhancement.h +++ /dev/null @@ -1,60 +0,0 @@ -#define MENU_KEYBINDING 1 -#define ACTION_KEYBINDING 2 -#define CLIENT_SETTING 3 - -class Combat_Space_Enhancement -{ - class EventHandlers { - class PostInit_EventHandlers { - class cse_main { - init = " call compile preprocessFile 'cse\cse_main\init.sqf';"; - }; - }; - }; - class cfgModules { - class cse_main { - init = ""; - name = "Main"; - class EventHandlers { - class CAManBase { - respawn = "_this call cse_fnc_resetAllDefaults_F;"; - }; - }; - - class Configurations { - class ActionAcceptRequest_f { - type = ACTION_KEYBINDING; - title = $STR_CSE_ACTION_ACCEPT_REQUEST_KEY_TITLE; - description = $STR_CSE_ACTION_ACCEPT_REQUEST_KEY_TOOLTIP; - value[] = {0,0,0,0}; - onPressed = "if (!isnil 'CSE_RECIEVE_REQUEST_ID_KEY_BINDING') then {[player,CSE_RECIEVE_REQUEST_ID_KEY_BINDING, true] call cse_fnc_onAnswerRequest;};"; - }; - class ActionDeclineRequest_f { - type = ACTION_KEYBINDING; - title = $STR_CSE_ACTION_DECLINE_REQUEST_KEY_TITLE; - description = $STR_CSE_ACTION_DECLINE_REQUEST_KEY_TOOLTIP; - value[] = {0,0,0,0}; - onPressed = "if (!isnil 'CSE_RECIEVE_REQUEST_ID_KEY_BINDING') then {[player,CSE_RECIEVE_REQUEST_ID_KEY_BINDING, false] call cse_fnc_onAnswerRequest;};"; - }; - }; - }; - - class cse_basicRevive { - init = "_this call cse_fnc_moduleEnableBasicRevive;"; - name = "Basic Revive"; - }; - - class cse_basic_revive : cse_basicRevive { - init = "_this call cse_fnc_moduleEnableBasicRevive; ['Incorrect basic revive classname. Please change cse_basic_revive to cse_basicRevive in your enabledModules_sample.hpp file.'] call BIS_fnc_error; "; - }; - }; - class CustomEventHandlers { - class variableDefined {}; // [_name,_value,_defaultGlobal,_catagory,_code, _persistent] - class AddedTotaskPool {}; // [_args, _code] - class killed {}; // [unit, bool] - class setVolume {}; // [bool] - class disableKeyInput {}; // [bool] - class switchToGroupSide {}; // [unit, bool, id (String), side] - class resetToDefaults {}; // [unit] - }; -}; \ No newline at end of file diff --git a/TO_MERGE/cse/main/anim/functions/fn_broadcastAnim.sqf b/TO_MERGE/cse/main/anim/functions/fn_broadcastAnim.sqf deleted file mode 100644 index 82a9535799..0000000000 --- a/TO_MERGE/cse/main/anim/functions/fn_broadcastAnim.sqf +++ /dev/null @@ -1,21 +0,0 @@ -/** - * fn_broadcastAnim.sqf - * @Descr: Broadcast an animation across the network using switchMove - * @Author: Glowbal - * - * @Arguments: [unit OBJECt, animation STRING] - * @Return: void - * @PublicAPI: true - */ - - -private ["_unit","_anim","_persistent"]; -_unit = [_this, 0, ObjNull,[ObjNull]] call BIS_fnc_Param; -_anim = [_this, 1, "",[""]] call BIS_fnc_Param; - - if (count _this >2) then { - _persistent = [_this, 2, false, [false]] call BIS_fnc_Param; - [[_unit,_anim], "cse_fnc_switchAnim", true, _persistent] spawn BIS_fnc_MP; - } else { - [[_unit,_anim], "cse_fnc_switchAnim", true, false] spawn BIS_fnc_MP; - }; diff --git a/TO_MERGE/cse/main/anim/functions/fn_getDeathAnim.sqf b/TO_MERGE/cse/main/anim/functions/fn_getDeathAnim.sqf deleted file mode 100644 index 2722e16ffb..0000000000 --- a/TO_MERGE/cse/main/anim/functions/fn_getDeathAnim.sqf +++ /dev/null @@ -1,33 +0,0 @@ -/** - * fn_getDeathAnim.sqf - * @Descr: Get the death animation for the unit at current time - * @Author: Glowbal - * - * @Arguments: [unit OBJECT] - * @Return: STRING animation - * @PublicAPI: true - */ - - -private ["_unit", "_curAnim", "_animation", "_cfg","_unitAnimation", "_animationState"]; -_unit = _this select 0; -_animation = ""; -_animationState = (animationState _unit); -_unitAnimation = (configFile >> "CfgMovesMaleSdr" >> "States" >> _animationState); -if (isText (_unitAnimation >> "actions")) then { - if ((vehicle _unit) != _unit) then { - _cfg = (configFile >> "CfgMovesMaleSdr" >> "States" >> _animationState); - if (isArray (_cfg >> "interpolateTo")) then { - _animation = getArray (_cfg >> "interpolateTo") select 0; - }; - } else { - _cfg = (configFile >> "CfgMovesBasic" >> "Actions" >> (getText (_unitAnimation >> "actions")) >> "die"); - if (isText _cfg) then { - _animation = getText _cfg; - }; - }; -}; -if (isnil "_animation") then { - _animation = ""; -}; -_animation \ No newline at end of file diff --git a/TO_MERGE/cse/main/anim/functions/fn_localAnim.sqf b/TO_MERGE/cse/main/anim/functions/fn_localAnim.sqf deleted file mode 100644 index 919a7176c6..0000000000 --- a/TO_MERGE/cse/main/anim/functions/fn_localAnim.sqf +++ /dev/null @@ -1,24 +0,0 @@ -/** - * fn_localAnim.sqf - * @Descr: Play an animation on a local machine using playMoveNow - * @Author: Glowbal - * - * @Arguments: [unit OBJECT, animation STRING] - * @Return: void - * @PublicAPI: true - */ - -private ["_unit","_anim","_persistent"]; -_unit = [_this, 0, ObjNull,[ObjNull]] call BIS_fnc_Param; -_anim = [_this, 1, "",[""]] call BIS_fnc_Param; - -if (!local _unit) then { - if (count _this >2) then { - _persistent = [_this, 2, false, [false]] call BIS_fnc_Param; - [[_unit,_anim], "cse_fnc_playMoveNow", _unit, _persistent] spawn BIS_fnc_MP; - } else { - [[_unit,_anim], "cse_fnc_playMoveNow", _unit, false] spawn BIS_fnc_MP; - }; -} else { - [_unit,_anim] call cse_fnc_playMoveNow; -}; \ No newline at end of file diff --git a/TO_MERGE/cse/main/anim/functions/fn_playMoveNow.sqf b/TO_MERGE/cse/main/anim/functions/fn_playMoveNow.sqf deleted file mode 100644 index 03ffda17fb..0000000000 --- a/TO_MERGE/cse/main/anim/functions/fn_playMoveNow.sqf +++ /dev/null @@ -1,14 +0,0 @@ -/** - * fn_playMoveNow.sqf - * @Descr: N/A - * @Author: Glowbal - * - * @Arguments: [] - * @Return: - * @PublicAPI: false - */ - -private ["_unit", "_anim"]; -_unit = [_this,0,objNull,[objNull]] call BIS_fnc_Param; -_anim = [_this,1,"",[""]] call BIS_fnc_Param; -_unit playMoveNow _anim; \ No newline at end of file diff --git a/TO_MERGE/cse/main/anim/functions/fn_switchAnim.sqf b/TO_MERGE/cse/main/anim/functions/fn_switchAnim.sqf deleted file mode 100644 index 73a0260ef6..0000000000 --- a/TO_MERGE/cse/main/anim/functions/fn_switchAnim.sqf +++ /dev/null @@ -1,15 +0,0 @@ -/** - * fn_switchAnim.sqf - * @Descr: N/A - * @Author: Glowbal - * - * @Arguments: [] - * @Return: - * @PublicAPI: false - */ - -private ["_unit", "_anim"]; -_unit = [_this,0,objNull,[objNull]] call BIS_fnc_Param; -_anim = [_this,1,"",[""]] call BIS_fnc_Param; -_unit switchMove _anim; -_unit playMove _anim; \ No newline at end of file diff --git a/TO_MERGE/cse/main/arrays/functions/fn_findAll.sqf b/TO_MERGE/cse/main/arrays/functions/fn_findAll.sqf deleted file mode 100644 index 9a2255f45b..0000000000 --- a/TO_MERGE/cse/main/arrays/functions/fn_findAll.sqf +++ /dev/null @@ -1,22 +0,0 @@ -/** - * fn_findAll.sqf - * @Descr: Find all elements for which the code returns true - * @Author: Glowbal - * - * @Arguments: [array ARRAY, if CODE (Code called for each element. Should return a bool)] - * @Return: ARRAY Array with elements for which the if code returned true. - * @PublicAPI: true - */ - -private ["_array", "_if", "_return"]; -_array = _this select 0; -_if = _this select 1; - -_return = []; -{ - if (_x call _if) then { - _return pushback _x; - }; -}foreach _array; - -_return; \ No newline at end of file diff --git a/TO_MERGE/cse/main/arrays/functions/fn_findIf.sqf b/TO_MERGE/cse/main/arrays/functions/fn_findIf.sqf deleted file mode 100644 index 9fe7c57869..0000000000 --- a/TO_MERGE/cse/main/arrays/functions/fn_findIf.sqf +++ /dev/null @@ -1,22 +0,0 @@ -/** - * fn_findIf.sqf - * @Descr: Get the first element that returns true. - * @Author: Glowbal - * - * @Arguments: [array ARRAY, if CODE (Code called for each element. Should return a bool)] - * @Return: ANY. Any element. Default return is an empty array ([]) - * @PublicAPI: true - */ - -private ["_array", "_if"]; -_array = _this select 0; -_if = _this select 1; - -_return = []; -{ - if (_x call _if) exitwith { - _return = _array select _foreachIndex; - }; -}foreach _array; - -_return; \ No newline at end of file diff --git a/TO_MERGE/cse/main/arrays/functions/fn_findIn.sqf b/TO_MERGE/cse/main/arrays/functions/fn_findIn.sqf deleted file mode 100644 index d8001d03c2..0000000000 --- a/TO_MERGE/cse/main/arrays/functions/fn_findIn.sqf +++ /dev/null @@ -1,22 +0,0 @@ -/** - * fn_findIn.sqf - * @Descr: Get the index of the first element that is equal to compare value - * @Author: Glowbal - * - * @Arguments: [array ARRAY, value ANY (The compared value)] - * @Return: NUMBER (-1 is not found. Else index of element in array) - * @PublicAPI: true - */ - -private ["_array", "_value", "_return"]; -_array = _this select 0; -_value = _this select 1; - -_return = -1; -{ - if (_x isEqualTo _value) exitwith { - _return = _foreachIndex; - }; -}foreach _array; - -_return; \ No newline at end of file diff --git a/TO_MERGE/cse/main/arrays/functions/fn_foreachDo.sqf b/TO_MERGE/cse/main/arrays/functions/fn_foreachDo.sqf deleted file mode 100644 index 1c18a746eb..0000000000 --- a/TO_MERGE/cse/main/arrays/functions/fn_foreachDo.sqf +++ /dev/null @@ -1,21 +0,0 @@ -/** - * fn_foreachDo.sqf - * @Descr: Execute code for each element in an array and collect the return values. - * @Author: Glowbal - * - * @Arguments: [array ARRAY, do CODE (Code executed for each element)] - * @Return: ARRAY Array with return values. - * @PublicAPI: true - */ - -private ["_array", "_do", "_return"]; -_array = _this select 0; -_do = _this select 1; - -_return = []; -{ - _return pushback(_x call _do); - false; -}count _array; - -_return; \ No newline at end of file diff --git a/TO_MERGE/cse/main/arrays/functions/fn_insertionSort.sqf b/TO_MERGE/cse/main/arrays/functions/fn_insertionSort.sqf deleted file mode 100644 index 5653256621..0000000000 --- a/TO_MERGE/cse/main/arrays/functions/fn_insertionSort.sqf +++ /dev/null @@ -1,32 +0,0 @@ -/** - * fn_insertionSort.sqf - * @Descr: Sorts an array of numbers - * @Author: Ruthberg - * - * @Arguments: [array ARRAY, (optional) ascending BOOL] - * @Return: sortedArray ARRAY - * @PublicAPI: true - */ - -private ["_list", "_ascending", "_tmp", "_i", "_j"]; -_list = +(_this select 0); -_ascending = true; -if (count _this > 1) then { - _ascending = _this select 1; -}; - -for "_i" from 1 to (count _list) - 1 do { - _tmp = _list select _i; - _j = _i; - while {_j >= 1 && {_tmp < _list select (_j - 1)}} do { - _list set [_j, _list select (_j - 1)]; - _j = _j - 1; - }; - _list set[_j, _tmp]; -}; - -if (!_ascending) then { - reverse _list; -}; - -_list \ No newline at end of file diff --git a/TO_MERGE/cse/main/arrays/functions/fn_sortAlphabeticallyBy.sqf b/TO_MERGE/cse/main/arrays/functions/fn_sortAlphabeticallyBy.sqf deleted file mode 100644 index 91f4c837e5..0000000000 --- a/TO_MERGE/cse/main/arrays/functions/fn_sortAlphabeticallyBy.sqf +++ /dev/null @@ -1,42 +0,0 @@ -/** - * fn_sortAlphabeticallyBy.sqf - * @Descr: - * @Author: Glowbal - * - * @Arguments: [] - * @Return: - * @PublicAPI: true - */ - -private ["_array", "_elements", "_elementN", "_indexes", "_theElement", "_tmp", "_tempIndex", "_j", "_i", "_returnArray"]; -_array = _this select 0; -_elementN = _this select 1; - -_indexes = []; -_elements = []; - -{ - _theElement = toArray (_x select _elementN); - _indexes pushback _foreachIndex; - _elements pushback _theElement; -}foreach _array; - -for "_i" from 1 to (count _elements) - 1 do { - _tmp = _elements select _i; - _tempIndex = _indexes select _i; - _j = _i; - while {_j >= 1 && {_tmp < _elements select (_j - 1)}} do { - _elements set [_j, _elements select (_j - 1)]; - _indexes set [_j, _indexes select (_j - 1)]; - _j = _j - 1; - }; - _elements set[_j, _tmp]; - _indexes set [_j, _tempIndex]; -}; - -_returnArray = []; -{ - _returnArray pushback (_array select _x); -}foreach _indexes; - -_returnArray; \ No newline at end of file diff --git a/TO_MERGE/cse/main/arrays/functions/fn_uniqueElementsOnly.sqf b/TO_MERGE/cse/main/arrays/functions/fn_uniqueElementsOnly.sqf deleted file mode 100644 index 3bf40595e6..0000000000 --- a/TO_MERGE/cse/main/arrays/functions/fn_uniqueElementsOnly.sqf +++ /dev/null @@ -1,22 +0,0 @@ -/** - * fn_uniqueElementsOnly.sqf - * @Descr: Make a copy of an array with only the unique elements. - * @Author: Glowbal - * - * @Arguments: [array ARRAY] - * @Return: ARRAY Copy of original array - * @PublicAPI: true - */ - -private ["_array", "_result", "_value"]; -_array = _this select 0; - -_result = []; -{ - _value = _x; - if ({_x isEqualTo _value} count _result == 0) then { - _result pushback _x; - }; -}foreach _array; - -_result; \ No newline at end of file diff --git a/TO_MERGE/cse/main/config.cpp b/TO_MERGE/cse/main/config.cpp deleted file mode 100644 index 3620b37e7a..0000000000 --- a/TO_MERGE/cse/main/config.cpp +++ /dev/null @@ -1,33 +0,0 @@ -class CfgPatches -{ - class cse_main - { - units[] = {}; - weapons[] = {}; - requiredVersion = 0.1; - requiredAddons[] = {"A3_Modules_F", "cse_f_eh"}; - version = "0.10.0_rc"; - author[] = {"Combat Space Enhancement"}; - authorUrl = "http://csemod.com"; - }; -}; -class CfgAddons { - class PreloadAddons { - class cse_main { - list[] = {"cse_main"}; - }; - }; -}; -class CfgUnitInsignia { - class CSE { - displayName = "Combat Space Enhancement"; // Name displayed in Arsenal - author = "Combat Space Enhancement"; // Author displayed in Arsenal - texture = "\cse\cse_main\data\cse_insignia.paa"; // Image path - textureVehicle = ""; // Does nothing currently, reserved for future use - }; -}; - -#include "Combat_Space_Enhancement.h" -#include "CfgVehicles.h" -#include "CfgFunctions.h" -#include "CfgHints.h" \ No newline at end of file diff --git a/TO_MERGE/cse/main/config/functions/fn_inheritsFrom.sqf b/TO_MERGE/cse/main/config/functions/fn_inheritsFrom.sqf deleted file mode 100644 index e0c942c40d..0000000000 --- a/TO_MERGE/cse/main/config/functions/fn_inheritsFrom.sqf +++ /dev/null @@ -1,24 +0,0 @@ -/** - * fn_inheritsFrom.sqf - * @Descr: Checks whether a given configuration name appears in the inheritance tree of a specific configuration entry. - * @Author: Ruthberg - * - * @Arguments: [configEntry CONFIG, configname STRING] - * @Return: BOOL - * @PublicAPI: true - */ - - private ["_configEntry","_configMatch", "_match"]; -_configEntry = _this select 0; -_configMatch = _this select 1; - -if (configName _configEntry == _configMatch) exitWith { true }; -if (configName _configEntry == ",") exitWith { false }; - -_match = false; -while {configName _configEntry != ""} do { - if (configName _configEntry == _configMatch) exitWith { _match = true }; - _configEntry = inheritsFrom(_configEntry); -}; - -_match \ No newline at end of file diff --git a/TO_MERGE/cse/main/data/cse_aim_module.paa b/TO_MERGE/cse/main/data/cse_aim_module.paa deleted file mode 100644 index 0bd682d3d2..0000000000 Binary files a/TO_MERGE/cse/main/data/cse_aim_module.paa and /dev/null differ diff --git a/TO_MERGE/cse/main/data/cse_backblast_module.paa b/TO_MERGE/cse/main/data/cse_backblast_module.paa deleted file mode 100644 index 527c516c22..0000000000 Binary files a/TO_MERGE/cse/main/data/cse_backblast_module.paa and /dev/null differ diff --git a/TO_MERGE/cse/main/data/cse_ballistics_module.paa b/TO_MERGE/cse/main/data/cse_ballistics_module.paa deleted file mode 100644 index 4be1f5869f..0000000000 Binary files a/TO_MERGE/cse/main/data/cse_ballistics_module.paa and /dev/null differ diff --git a/TO_MERGE/cse/main/data/cse_basic_module.paa b/TO_MERGE/cse/main/data/cse_basic_module.paa deleted file mode 100644 index 8ef2af6867..0000000000 Binary files a/TO_MERGE/cse/main/data/cse_basic_module.paa and /dev/null differ diff --git a/TO_MERGE/cse/main/data/cse_cc_module.paa b/TO_MERGE/cse/main/data/cse_cc_module.paa deleted file mode 100644 index 4833873c60..0000000000 Binary files a/TO_MERGE/cse/main/data/cse_cc_module.paa and /dev/null differ diff --git a/TO_MERGE/cse/main/data/cse_debug_icon.paa b/TO_MERGE/cse/main/data/cse_debug_icon.paa deleted file mode 100644 index e5cbceeebb..0000000000 Binary files a/TO_MERGE/cse/main/data/cse_debug_icon.paa and /dev/null differ diff --git a/TO_MERGE/cse/main/data/cse_earmuffs_module.paa b/TO_MERGE/cse/main/data/cse_earmuffs_module.paa deleted file mode 100644 index d0d571112c..0000000000 Binary files a/TO_MERGE/cse/main/data/cse_earmuffs_module.paa and /dev/null differ diff --git a/TO_MERGE/cse/main/data/cse_explosive_module.paa b/TO_MERGE/cse/main/data/cse_explosive_module.paa deleted file mode 100644 index 5837932776..0000000000 Binary files a/TO_MERGE/cse/main/data/cse_explosive_module.paa and /dev/null differ diff --git a/TO_MERGE/cse/main/data/cse_groups_module.paa b/TO_MERGE/cse/main/data/cse_groups_module.paa deleted file mode 100644 index 067eb7ef0c..0000000000 Binary files a/TO_MERGE/cse/main/data/cse_groups_module.paa and /dev/null differ diff --git a/TO_MERGE/cse/main/data/cse_logging_icon.paa b/TO_MERGE/cse/main/data/cse_logging_icon.paa deleted file mode 100644 index 7339a44899..0000000000 Binary files a/TO_MERGE/cse/main/data/cse_logging_icon.paa and /dev/null differ diff --git a/TO_MERGE/cse/main/data/cse_medical_module.paa b/TO_MERGE/cse/main/data/cse_medical_module.paa deleted file mode 100644 index 9cb6c4782d..0000000000 Binary files a/TO_MERGE/cse/main/data/cse_medical_module.paa and /dev/null differ diff --git a/TO_MERGE/cse/main/data/cse_nvg_module.paa b/TO_MERGE/cse/main/data/cse_nvg_module.paa deleted file mode 100644 index 3d0a8bc050..0000000000 Binary files a/TO_MERGE/cse/main/data/cse_nvg_module.paa and /dev/null differ diff --git a/TO_MERGE/cse/main/data/cse_rifle_module.paa b/TO_MERGE/cse/main/data/cse_rifle_module.paa deleted file mode 100644 index f386713736..0000000000 Binary files a/TO_MERGE/cse/main/data/cse_rifle_module.paa and /dev/null differ diff --git a/TO_MERGE/cse/main/data/cse_tags_module.paa b/TO_MERGE/cse/main/data/cse_tags_module.paa deleted file mode 100644 index 1710ef74c9..0000000000 Binary files a/TO_MERGE/cse/main/data/cse_tags_module.paa and /dev/null differ diff --git a/TO_MERGE/cse/main/debug/Debug.h b/TO_MERGE/cse/main/debug/Debug.h deleted file mode 100644 index 16095b6db1..0000000000 --- a/TO_MERGE/cse/main/debug/Debug.h +++ /dev/null @@ -1,9 +0,0 @@ -// debug constants - -#define ERROR 0 -#define WARN 1 -#define DEBUG 2 -#define INFO 3 -#define NONE 4 - -#define DEFAULTLOGLEVEL INFO diff --git a/TO_MERGE/cse/main/debug/functions/fn_debug.sqf b/TO_MERGE/cse/main/debug/functions/fn_debug.sqf deleted file mode 100644 index 3c87285e10..0000000000 --- a/TO_MERGE/cse/main/debug/functions/fn_debug.sqf +++ /dev/null @@ -1,66 +0,0 @@ -/** - * fn_debug.sqf - * @Descr: Print logging messages through the CSE framework. - * @Author: Glowbal - * - * @Arguments: [message ANY, level NUMBER (Optional)] - * @Return: BOOL True if message has been printed - * @PublicAPI: true - */ - -#define ERROR 0 -#define WARN 1 -#define DEBUG 2 -#define INFO 3 -#define NONE 4 - -#define DEFAULTLOGLEVEL NONE -#define DEFAULTTEXTDISPLAY WARN - -private ["_msg", "_level", "_prefix", "_defaultLoglevel","_defaultLogDisplayLevel", "_message", "_from"]; -_msg = _this select 0; -_level = _this select 1; - -if (isNil "CSE_LOGLEVEL") then { - _defaultLoglevel = DEFAULTLOGLEVEL; -} else { - _defaultLoglevel = CSE_LOGLEVEL; -}; - -if (isnil "CSE_LOGDISPLAY_LEVEL") then { - _defaultLogDisplayLevel = DEFAULTTEXTDISPLAY; -} else { - _defaultLogDisplayLevel = CSE_LOGDISPLAY_LEVEL; -}; - -if (isNil "_level") then { - _level = DEBUG; -}; -if (_defaultLoglevel == 4) exitwith {false}; -if (_level <= _defaultLoglevel) then { - switch (_level) do { - case ERROR: { _prefix = "CSE Error" }; - case WARN: { _prefix = "CSE Warn" }; - case DEBUG: { _prefix = "CSE Debug" }; - case INFO: { _prefix = "CSE Info" }; - default { _prefix = "CSE Unknown" }; - }; - _message = format["[%1] %2",_prefix,_msg]; - - if (isnil "CSE_LOGIC_OBJECT") then { - _group = createGroup sideLogic; - CSE_LOGIC_OBJECT = _group createUnit ["logic", [1,1,1], [], 0, "FORM"]; - }; - if (isNull CSE_LOGIC_OBJECT) then { - _group = createGroup sideLogic; - CSE_LOGIC_OBJECT = _group createUnit ["logic", [1,1,1], [], 0, "FORM"]; - }; - - - if (_level <= _defaultLogDisplayLevel) then { - showChat true; - CSE_LOGIC_OBJECT globalChat _message; - }; - diag_log _message; -}; -true \ No newline at end of file diff --git a/TO_MERGE/cse/main/debug/functions/fn_debugModule.sqf b/TO_MERGE/cse/main/debug/functions/fn_debugModule.sqf deleted file mode 100644 index f0a9902ef8..0000000000 --- a/TO_MERGE/cse/main/debug/functions/fn_debugModule.sqf +++ /dev/null @@ -1,15 +0,0 @@ -/** - * fn_debugModule.sqf - * @Descr: N/A - * @Author: Glowbal - * - * @Arguments: [] - * @Return: - * @PublicAPI: false - */ - -private ["_entity"]; -_entity = _this select 0; - -CSE_LOGDISPLAY_LEVEL = call compile (_entity getvariable ["logDisplayLevel","4"]); -CSE_LOGLEVEL = call compile (_entity getvariable ["logLevel","4"]); diff --git a/TO_MERGE/cse/main/debug/functions/fn_traceModule.sqf b/TO_MERGE/cse/main/debug/functions/fn_traceModule.sqf deleted file mode 100644 index ef64fa09f8..0000000000 --- a/TO_MERGE/cse/main/debug/functions/fn_traceModule.sqf +++ /dev/null @@ -1,23 +0,0 @@ -/** - * fn_traceModule.sqf - * @Descr: N/A - * @Author: Glowbal - * - * @Arguments: [] - * @Return: - * @PublicAPI: false - */ - -private ["_entity"]; -_entity = _this select 0; - -_enableForPlayer = call compile (_entity getvariable ["logDisplayLevel","0"]); -if (isnil "CSE_OBJECTS_TRACING") then { - CSE_OBJECTS_TRACING = []; -}; - -if (!isDedicated) then { - if (_enableForPlayer==1) then { - CSE_OBJECTS_TRACING set [count CSE_OBJECTS_TRACING, PLAYER]; - }; -}; \ No newline at end of file diff --git a/TO_MERGE/cse/main/equipment/functions/fn_findItem.sqf b/TO_MERGE/cse/main/equipment/functions/fn_findItem.sqf deleted file mode 100644 index b53adb3315..0000000000 --- a/TO_MERGE/cse/main/equipment/functions/fn_findItem.sqf +++ /dev/null @@ -1,25 +0,0 @@ -/** - * fn_findItem.sqf - * @Descr: - * @Author: Glowbal - * - * @Arguments: [] - * @Return: - * @PublicAPI: true - */ - -private ["_unit","_magazine","_return"]; -_unit = _this select 0; -_item = _this select 1; - -if (_item in (uniformItems _unit)) exitwith {1}; -if (_item in (vestItems _unit)) exitwith {2}; -if (_item in (backpackItems _unit)) exitwith {3}; -if (_item in (assignedItems _unit)) exitwith {4}; -if (_item in (primaryWeaponItems _unit)) exitwith {5}; -if (_item in (secondaryWeaponItems _unit)) exitwith {6}; -if (_item in (handgunItems _unit)) exitwith {7}; -if (_item in (items _unit)) exitwith {8}; // in case it is in items but cannot be found in any other container (should never reach this) - -// If we cannot find the item, return 0. -0; \ No newline at end of file diff --git a/TO_MERGE/cse/main/equipment/functions/fn_findMagazine.sqf b/TO_MERGE/cse/main/equipment/functions/fn_findMagazine.sqf deleted file mode 100644 index 14d6a455ec..0000000000 --- a/TO_MERGE/cse/main/equipment/functions/fn_findMagazine.sqf +++ /dev/null @@ -1,21 +0,0 @@ -/** - * fn_findMagazine.sqf - * @Descr: Find where the current magazines are. Order: uniform, vest, backpack, any. - * @Author: Glowbal - * - * @Arguments: [unit OBJECT, magazine STRING (Classname of magazine)] - * @Return: NUMBER 0 = none, 1 = in uniform, 2 = in vest, 3 = in backpack, 4 = found outside container - * @PublicAPI: true - */ - -private ["_unit","_magazine"]; -_unit = _this select 0; -_magazine = _this select 1; - -if (_magazine in (getMagazineCargo uniformContainer _unit)) exitwith {1}; -if (_magazine in (getMagazineCargo vestContainer _unit)) exitwith {2}; -if (_magazine in (getMagazineCargo backpackContainer _unit)) exitwith {3}; -if (_magazine in (magazines _unit)) exitwith {4}; // in case it cannot be found in any other container. Most likely loaded in a weapon. - -// If we cannot find the item, return 0. -0; \ No newline at end of file diff --git a/TO_MERGE/cse/main/equipment/functions/fn_getNumberMagazinesIn.sqf b/TO_MERGE/cse/main/equipment/functions/fn_getNumberMagazinesIn.sqf deleted file mode 100644 index 0b470c1a20..0000000000 --- a/TO_MERGE/cse/main/equipment/functions/fn_getNumberMagazinesIn.sqf +++ /dev/null @@ -1,26 +0,0 @@ -/** - * fn_getNumberMagazinesIn.sqf - * @Descr: - * @Author: Glowbal - * - * @Arguments: [] - * @Return: - * @PublicAPI: true - */ - -private ["_unit","_magazine"]; -_unit = _this select 0; -_magazine = _this select 1; - -_return = 0; -if (_unit isKindOf "CAManBase") then { - _return = {_x == _magazine} count magazines _unit; -} else { - { - _return = _return + {_x == _magazine} count magazines _x; - }foreach (crew _unit); - - _return = _return + ({_x == _magazine} count getMagazineCargo _unit); -}; - -_return \ No newline at end of file diff --git a/TO_MERGE/cse/main/equipment/functions/fn_hasItem.sqf b/TO_MERGE/cse/main/equipment/functions/fn_hasItem.sqf deleted file mode 100644 index a0b07f1852..0000000000 --- a/TO_MERGE/cse/main/equipment/functions/fn_hasItem.sqf +++ /dev/null @@ -1,11 +0,0 @@ -/** - * fn_hasItem.sqf - * @Descr: Check if unit has item - * @Author: Glowbal - * - * @Arguments: [unit OBJECT, item STRING (Classname of item)] - * @Return: BOOL - * @PublicAPI: true - */ -// item classname in items unit -((_this select 1) in items (_this select 0)); \ No newline at end of file diff --git a/TO_MERGE/cse/main/equipment/functions/fn_hasMagazine.sqf b/TO_MERGE/cse/main/equipment/functions/fn_hasMagazine.sqf deleted file mode 100644 index 468c955290..0000000000 --- a/TO_MERGE/cse/main/equipment/functions/fn_hasMagazine.sqf +++ /dev/null @@ -1,21 +0,0 @@ -/** - * fn_hasMagazine.sqf - * @Descr: Check if given unit has a magazine of given classname - * @Author: Glowbal - * - * @Arguments: [unit OBJECT, magazine STRING] - * @Return: BOOL True if unith as given magazine - * @PublicAPI: true - */ - -private ["_unit","_magazine","_return"]; -_unit = _this select 0; -_magazine = _this select 1; - -if (_magazine != "") then { - _return = (_magazine in magazines _unit); -} else { - _return = false; -}; -//[format["fnc_hasMagazine: %1 | %2",_this,_return]] call cse_fnc_debug; -_return \ No newline at end of file diff --git a/TO_MERGE/cse/main/equipment/functions/fn_useItem.sqf b/TO_MERGE/cse/main/equipment/functions/fn_useItem.sqf deleted file mode 100644 index fd07398aad..0000000000 --- a/TO_MERGE/cse/main/equipment/functions/fn_useItem.sqf +++ /dev/null @@ -1,36 +0,0 @@ -/** - * fn_useItem.sqf - * @Descr: - * @Author: Glowbal - * - * @Arguments: [] - * @Return: - * @PublicAPI: true - */ - -private ["_unit","_item","_return"]; -_unit = _this select 0; -_item = _this select 1; -_vehicleUsage = [_this, 2, false, [false]] call BIS_fnc_Param; - -if (!_vehicleUsage) then { - if (_item != "") then { - if (_item in (items _unit)) then { - _unit removeItem _item; - _return = true; - } else { - if (_item in (assignedItems _unit)) then { - _unit unassignItem _item; - _unit removeItem _item; - _return = true; - }; - }; - } else { - _return = false; - }; - [format["fnc_useItem: %1 | %2",_this,_return]] call cse_fnc_debug; -_return -} else -{ - // TODO implement shared item functionality -}; \ No newline at end of file diff --git a/TO_MERGE/cse/main/equipment/functions/fn_useMagazine.sqf b/TO_MERGE/cse/main/equipment/functions/fn_useMagazine.sqf deleted file mode 100644 index 0a356aabc5..0000000000 --- a/TO_MERGE/cse/main/equipment/functions/fn_useMagazine.sqf +++ /dev/null @@ -1,28 +0,0 @@ -/** - * fn_useMagazine.sqf - * @Descr: Use magazine - * @Author: Glowbal - * - * @Arguments: [unit OBJECt, magazine STRING] - * @Return: BOOL True if magazine has been used. - * @PublicAPI: true - */ - -private ["_unit","_magazine","_return"]; -_unit = _this select 0; -_magazine = _this select 1; -_vehicleUsage = [_this, 2, false, [false]] call BIS_fnc_Param; - -if (!_vehicleUsage) then { - if (_magazine != "") then { - _unit removeMagazine _magazine; - _return = true; - } else { - _return = false; - }; - [format["fnc_useMagazine: %1 | %2",_this,_return]] call cse_fnc_debug; -_return -} else -{ - // TODO implement shared magazine functionality -}; \ No newline at end of file diff --git a/TO_MERGE/cse/main/hc/functions/fn_isHC.sqf b/TO_MERGE/cse/main/hc/functions/fn_isHC.sqf deleted file mode 100644 index 443e6d48f2..0000000000 --- a/TO_MERGE/cse/main/hc/functions/fn_isHC.sqf +++ /dev/null @@ -1,22 +0,0 @@ -/** - * fn_isHC.sqf - * @Descr: Check if current locality is a headless client - * @Author: Glowbal - * - * @Arguments: [] - * @Return: BOOL True if locality is headless client OR is not in multiplayer - * @PublicAPI: true - */ - -private ["_return"]; - -if (!isMultiplayer) then { - _return = true; -} else { - if (isServer && !isDedicated) then { - _return = true; - } else { - _return = !(hasInterface || isDedicated); - }; -}; -_return \ No newline at end of file diff --git a/TO_MERGE/cse/main/init.sqf b/TO_MERGE/cse/main/init.sqf deleted file mode 100644 index 3ab0f5f3c4..0000000000 --- a/TO_MERGE/cse/main/init.sqf +++ /dev/null @@ -1,81 +0,0 @@ -CSE_AI_COLLECTION_LOOP = [[]]; -if (isnil "CSE_OBJECTS_TRACING") then { - CSE_OBJECTS_TRACING = []; -}; - -["cse_interactionRegister",[],true,"cse_framework"] call cse_fnc_defineVariable; -["cse_interactionTarget",objNull,true,"cse_framework"] call cse_fnc_defineVariable; -["cse_variableMonitor",[],false,"cse_framework"] call cse_fnc_defineVariable; -["CSE_ENABLE_REVIVE_COUNTER",0,false,"cse_framework"] call cse_fnc_defineVariable; -["cse_inReviveState", false, true, "cse_framework"] call cse_fnc_defineVariable; - -cse_main = true; - -if (isnil "CSE_F_MODULE_OBJ_EH") then { - CSE_F_MODULE_OBJ_EH = []; -}; -CSE_F_MODULE_OBJ_EH pushback "cse_main"; -if (isnil "CSE_TASK_POOL_COLLECTION_F") then { - CSE_TASK_POOL_COLLECTION_F = []; -}; -if (isNil "CSE_ENABLE_REVIVE_F") then { - CSE_ENABLE_REVIVE_F = 0; -}; -if (hasInterface) then{ - [] spawn { - - sleep 1; - waitUntil {!isNull player && !(isNull (findDisplay 46))}; - player setvariable ["cse_name", name player, true]; - player addEventHandler ["respawn", {_this call cse_fnc_resetAllDefaults_F;}]; - 11401 cutRsc ["cse_gui_iconsDisplay","PLAIN"]; - - if (["cse_sys_vehicles"] call cse_fnc_isModLoaded_F) then { - call compile preprocessFile "cse\cse_sys_vehicles\init.sqf"; - }; - }; -}; - -["Task Loop is starting"] call cse_fnc_debug; -["cse_main_taskPool_f", "oneachframe", cse_fnc_loopThroughPool_f] call BIS_fnc_addStackedEventHandler; - -if (["cse_sys_ieds"] call cse_fnc_isModLoaded_F) then { - ["cse_sys_ieds", []] call cse_fnc_enableModule_f; -}; - -if ([] call cse_fnc_isLoaded_ALiVE_Mod) then { - // integrate ALiVE menu with CSE Radial Action menu - // call compile preprocessFile "cse\cse_main\integration\alive\alive_gui_integration.sqf"; - // call compile preprocessFile "cse\cse_main\integration\alive\alive_flexiMenu_integration.sqf"; -}; - -// version checks -if !(isServer) exitwith {}; -if (isnil "cse_fnc_getVersion") exitwith {}; - -_versionCheckCode = compile format[' - if (isServer) exitwith {}; - sleep 5; - _serverVersion = "%1"; - CSE_SERVER_VERSION = _serverVersion; - if (!isnil "cse_fnc_getVersion") then { - _clientVersion = [] call cse_fnc_getVersion; - if (_serverVersion != _clientVersion) then { - // incorrect version - _warningMessage = format["WARNING: CSE Version mismatch. Server version: %1 Client version: %2", _serverVersion, _clientVersion]; - diag_log _warningMessage; - systemChat _warningMessage; - - [[{sysemChat format["%1" has an incorrect version of CSE", _this];}, player], "BIS_fnc_spawn", true, true] call BIS_fnc_MP; - } else { - ["Passed version check - same as server"] call cse_fnc_debug; - }; - } else { - // incorrect version - _warningMessage = format["WARNING: CSE Version mismatch: Server version: %1 Client version: unknown"]; - diag_log _warningMessage; - systemChat _warningMessage; - }; -', call cse_fnc_getVersion]; - -[_versionCheckCode, "BIS_fnc_spawn", true, true] call BIS_fnc_MP; diff --git a/TO_MERGE/cse/main/integration/alive/alive_flexiMenu_integration.sqf b/TO_MERGE/cse/main/integration/alive/alive_flexiMenu_integration.sqf deleted file mode 100644 index 51804eec13..0000000000 --- a/TO_MERGE/cse/main/integration/alive/alive_flexiMenu_integration.sqf +++ /dev/null @@ -1,182 +0,0 @@ - -#include "\x\alive\addons\ui\script_component.hpp" -#define ALiVE_ICON "cse\cse_gui\radialmenu\data\icons\icon_alive_mod.paa" - -/* - [ - "player", - [SELF_INTERACTION_KEY], - -9500, - [ - "call ALIVE_fnc_adminActionsMenuDef", - "main" - ] - ] -*/ - - - [ - ["player",[[221,[false,false,false]]],-9500,["call ALIVE_fnc_newsFeedMenuDef","main"],true], - ["player",[[221,[false,false,false]]],-9500,["call ALIVE_fnc_adminActionsMenuDef","main"],true] - ]; - -/* - 4 [ - 5 "caption", - 6 "action", - 7 "icon", - 8 "tooltip", - 9 {"submenu"|["menuName", "", {0|1} (optional - use embedded list menu)]}, -10 -1 (shortcut DIK code), -11 {0|1/"0"|"1"/false|true} (enabled), -12 {-1|0|1/"-1"|"0"|"1"/false|true} (visible) -13 ] -*/ - -[format["ALIVE FlexiMenu integration started"]] call cse_fnc_debug; -_menusources = GVAR(typeMenuSources); -{ - - // This is a string. defines classnames ? - _type = _x select 0; - - // not relevant for us - _keybindings = _x select 1; - - // not relevant for us - _priority = _x select 2; - - // array format: [code STRING, name STRING] - _details = _x select 3; - _code = _details select 0; - _menuName = _details select 1; - - // condition. BOOL or CODE ? - _condition = _x select 4; - - // TODO figure out parsing - [format["ALiVE FlexiMenu entry: %1", _x]] call cse_fnc_debug; - - if (_type == "player") then { - - if (typeName _condition == typeName true) then { - - } else { - // calling condition - }; - - _target = player; - _params = [_menuName, "popup"]; - - if (typeName _code == typeName "") then { - - // this has to be called upon menu open. - _res = [_target, _params] call compile _code; - [format["ALIVE FlexiMenu call res: %1", _res]] call cse_fnc_debug; - // [["main","ALiVE","popup"],[["Player Combat Support",{["radio"] call ALIVE_fnc_radioAction},"","ALiVE Combat Support System (CAS/Artillery/Transport)","",-1,1,false]] - if (_res isEqualTo []) exitwith {}; - _entryDetails = _res select 1 select 0; - - - // [["main","ALiVE","popup"],[["Admin Actions >","","","Server admin functions",["call ALiVE_fnc_adminActionsMenuDef","adminActions",1],-1,1,true]]] - //_menuName = _entryDetails select 4 select 1; - _compiledCode = compile format['[_this, "%1"] call cse_fnc_aliveFlexiMenuDisplayOptions', _menuName]; - [format["compiled code: %1", _compiledCode]] call cse_fnc_debug; - _entries = [ - [_entryDetails select 0, {true /* Condition should check for activation of ALiVE menu entries */}, ALiVE_ICON, _compiledCode, _entryDetails select 3] - ]; - ["ActionMenu","alive_actions", _entries ] call cse_fnc_addMultipleEntriesToRadialCategory_F; - - /*{ - if (_foreachIndex > 0) then { - [format["BUTTON FORMAT: %1",_x]] call cse_fnc_debug; - _info = _x select 0; - _title = _info select 0; - _code = _info select 1; - _toolTip = _info select 2; - _allow = _info select 7; - [format["Showing button: %1", _info]] call cse_fnc_debug - }; - }foreach _res;*/ - }; - - }; -}foreach _menusources; - - - -cse_fnc_aliveFlexiMenuDisplayOptions = { - _args = _this select 0; - _checkMenuName = _this select 1; - [format["cse_fnc_aliveFlexiMenuDisplayOptions %1",_this]] call cse_fnc_debug; - _menusources = GVAR(typeMenuSources); - { - // This is a string. defines classnames ? - _type = _x select 0; - - // not relevant for us - _keybindings = _x select 1; - - // not relevant for us - _priority = _x select 2; - - // array format: [code STRING, name STRING] - _details = _x select 3; - _code = _details select 0; - _menuName = _details select 1; - - // condition. BOOL or CODE ? - _condition = _x select 4; - - if (_menuName == _checkMenuName) exitwith { - [format["ALiVE FlexiMenu entry: %1", _x]] call cse_fnc_debug; - if (_type == "player") then { - _continue = false; - if (typeName _condition == typeName true) then { - _continue = _condition; - }; - if (!_continue) exitwith {}; - - _target = player; - _params = [_menuName, "popup"]; - - if (typeName _code == typeName "") then { - // this has to be called upon menu open. - _res = [_target, _params] call compile _code; - // [["main","ALiVE","popup"],[["Player Combat Support",{["radio"] call ALIVE_fnc_radioAction},"","ALiVE Combat Support System (CAS/Artillery/Transport)","",-1,1,false]] - - if (_res isEqualTo []) exitwith {}; - _entryDetails = _res select 1; - - _cse_menu_entries = []; - { - _info = _x select 0; - if (_foreachIndex > 0) then { - _title = _info select 0; - _code = _info select 1; - _toolTip = _info select 2; - _allow = _info select 7; - - if (_allow) then { - _cse_menu_entries pushback [_title, ALiVE_ICON, _code, true, _toolTip]; - }; - }; - }foreach _res; - [format["Showing entries: %1 - %2", _cse_menu_entries, _res]] call cse_fnc_debug; - - if !(_cse_menu_entries isEqualTo []) then { - hintSilent "displaying alive entries"; - [ _args select 3, - _cse_menu_entries, - _args select 1, CSE_SELECTED_RADIAL_OPTION_N_GUI, true - ] call cse_fnc_openRadialSecondRing_GUI; - }; - - }; - - }; - - }; - }foreach _menusources; - -}; \ No newline at end of file diff --git a/TO_MERGE/cse/main/integration/alive/alive_gui_integration.sqf b/TO_MERGE/cse/main/integration/alive/alive_gui_integration.sqf deleted file mode 100644 index 1ecbbe1767..0000000000 --- a/TO_MERGE/cse/main/integration/alive/alive_gui_integration.sqf +++ /dev/null @@ -1,72 +0,0 @@ -/** - * alive_gui_integration.sqf - * @Descr: N/A - * @Author: Glowbal - * - * @Arguments: [] - * @Return: - * @PublicAPI: false - */ - -#include <\x\alive\addons\sys_adminactions\script_component.hpp> -#include <\x\cba\addons\ui_helper\script_dikCodes.hpp> - -#define ALiVE_ICON "cse\cse_gui\radialmenu\data\icons\icon_alive_mod.paa" - -private ["_entries", "_openAdminActions"]; - -waitUntil{!isnil "cse_gui"}; - -// ALiVE Admin Actions - -_alive_openAdminActions = { - private ["_entries"]; - _entries = []; - if ((MOD(adminActions) getVariable ["ghost", 0]) == "1") then { - _entries set [ count _entries, [localize "STR_ALIVE_ADMINACTIONS_GHOST_ENABLE", ALiVE_ICON, {player setCaptive true; _this call cse_alive_openAdminActions; }, (!captive player), localize "STR_ALIVE_ADMINACTIONS_GHOST_COMMENT"]]; - - _entries set [ count _entries, [localize "STR_ALIVE_ADMINACTIONS_GHOST_DISABLE", ALiVE_ICON, {player setCaptive false; _this call cse_alive_openAdminActions; }, (captive player), localize "STR_ALIVE_ADMINACTIONS_GHOST_COMMENT"]]; - }; - if ((MOD(adminActions) getVariable ["teleport", 0]) == "1") then { - _entries set [ count _entries, [localize "STR_ALIVE_ADMINACTIONS_TELEPORT_ENABLE", ALiVE_ICON, { MOD(adminActions) setVariable ["teleport_enabled", true]; onMapSingleClick {vehicle player setPos _pos;}; _this call cse_alive_openAdminActions; }, !(MOD(adminActions) getVariable ["teleport_enabled", false]), localize "STR_ALIVE_ADMINACTIONS_TELEPORT_COMMENT"]]; - - _entries set [ count _entries, [localize "STR_ALIVE_ADMINACTIONS_TELEPORT_DISABLE",ALiVE_ICON, { MOD(adminActions) setVariable ["teleport_enabled", false]; onMapSingleClick DEFAULT_MAPCLICK; _this call cse_alive_openAdminActions; }, (MOD(adminActions) getVariable ["teleport_enabled", false]), localize "STR_ALIVE_ADMINACTIONS_TELEPORT_COMMENT"]]; - - _entries set [ count _entries, [localize "STR_ALIVE_ADMINACTIONS_TELEPORTUNITS", ALiVE_ICON, { ["CAManBase"] spawn ALiVE_fnc_AdminActionsTeleportUnits; _this call cse_alive_openAdminActions; }, true, localize "STR_ALIVE_ADMINACTIONS_TELEPORTUNITS_COMMENT"]]; - }; - if ((MOD(adminActions) getVariable ["mark_units", 0]) == "1") then { - _entries set [ count _entries, [localize "STR_ALIVE_ADMINACTIONS_MARK_UNITS_ENABLE", ALiVE_ICON, { [] call ALIVE_fnc_markUnits; _this call cse_alive_openAdminActions; }, true, localize "STR_ALIVE_ADMINACTIONS_MARK_UNITS_COMMENT"]]; - }; - if (["ALiVE_mil_CQB"] call ALiVE_fnc_isModuleAvailable) then { - _entries set [ count _entries, [localize "STR_ALIVE_ADMINACTIONS_CQB_ENABLE", ALiVE_ICON, { {MOD(adminActions) setVariable ["CQB_enabled", true]; [_x,"debug",true] call ALiVE_fnc_CQB} foreach (MOD(CQB) getVariable ["instances",[]]); _this call cse_alive_openAdminActions; }, !(MOD(adminActions) getVariable ["CQB_enabled", false]), localize "STR_ALIVE_ADMINACTIONS_CQB_ENABLE_COMMENT"]]; - - _entries set [ count _entries, [localize "STR_ALIVE_ADMINACTIONS_CQB_DISABLE", ALiVE_ICON,{ MOD(adminActions) setVariable ["CQB_enabled", false]; {[_x,"debug",false] call ALiVE_fnc_CQB} foreach (MOD(CQB) getVariable ["instances",[]]); _this call cse_alive_openAdminActions; }, (MOD(adminActions) getVariable ["CQB_enabled", false]), localize "STR_ALIVE_ADMINACTIONS_CQB_DISABLE_COMMENT"]]; - }; - if (["ALiVE_sys_profile"] call ALiVE_fnc_isModuleAvailable) then { - _entries set [ count _entries, [localize "STR_ALIVE_ADMINACTIONS_PROFILES_DEBUG_ENABLE", ALiVE_ICON,{ MOD(adminActions) setVariable ["PROFILES_enabled", true]; [] call ALIVE_fnc_profileSystemDebug;_this call cse_alive_openAdminActions; }, !(MOD(adminActions) getVariable ["PROFILES_enabled", false]), localize "STR_ALIVE_ADMINACTIONS_PROFILES_DEBUG_COMMENT"]]; - - _entries set [ count _entries, [localize "STR_ALIVE_ADMINACTIONS_PROFILES_DEBUG_DISABLE", ALiVE_ICON,{ MOD(adminActions) setVariable ["PROFILES_enabled", false]; [] call ALIVE_fnc_profileSystemDebug; _this call cse_alive_openAdminActions; }, (MOD(adminActions) getVariable ["PROFILES_enabled", false]), localize "STR_ALIVE_ADMINACTIONS_PROFILES_DEBUG_COMMENT"]]; - }; - if ((MOD(adminActions) getVariable ["profiles_create", 0]) == "1") then { - _entries set [ count _entries, [localize "STR_ALIVE_ADMINACTIONS_CREATE_PROFILES_ENABLE", ALiVE_ICON,{ [] call ALIVE_fnc_adminCreateProfiles; _this call cse_alive_openAdminActions; }, true, localize "STR_ALIVE_ADMINACTIONS_CREATE_PROFILES_COMMENT"]]; - }; - if (["ALiVE_amb_civ_population"] call ALiVE_fnc_isModuleAvailable) then { - _entries set [ count _entries, [localize "STR_ALIVE_ADMINACTIONS_AGENTS_DEBUG_ENABLE", ALiVE_ICON,{MOD(adminActions) setVariable ["AGENTS_enabled", true]; [] call ALIVE_fnc_agentSystemDebug; _this call cse_alive_openAdminActions; }, !(MOD(adminActions) getVariable ["AGENTS_enabled", false]), localize "STR_ALIVE_ADMINACTIONS_AGENTS_DEBUG_COMMENT"]]; - - _entries set [ count _entries, [localize "STR_ALIVE_ADMINACTIONS_AGENTS_DEBUG_DISABLE", ALiVE_ICON,{ MOD(adminActions) setVariable ["AGENTS_enabled", false]; [] call ALIVE_fnc_agentSystemDebug;_this call cse_alive_openAdminActions; }, (MOD(adminActions) getVariable ["AGENTS_enabled", false]), localize "STR_ALIVE_ADMINACTIONS_PROFILES_DEBUG_COMMENT"]]; - }; - if ((MOD(adminActions) getVariable ["console", 0]) == "1") then { - _entries set [ count _entries, [localize "STR_ALIVE_ADMINACTIONS_CONSOLE_ENABLE", ALiVE_ICON,{ closeDialog 0; createDialog "RscDisplayDebugPublic"; }, true, localize "STR_ALIVE_ADMINACTIONS_CONSOLE_COMMENT"]]; - }; - - [ _this select 3, - _entries, - _this select 1, CSE_SELECTED_RADIAL_OPTION_N_GUI, true - ] call cse_fnc_openRadialSecondRing_GUI; -}; - -_entries = [ - [localize "STR_ALIVE_ADMINACTIONS", {true /* Condition should check for activation of ALiVE Admin */}, ALiVE_ICON, _alive_openAdminActions, localize "STR_ALIVE_ADMINACTIONS"] -]; -["ActionMenu","alive_actions", _entries ] call cse_fnc_addMultipleEntriesToRadialCategory_F; - diff --git a/TO_MERGE/cse/main/interaction/functions/fn_broadcastMonitoredVariable.sqf b/TO_MERGE/cse/main/interaction/functions/fn_broadcastMonitoredVariable.sqf deleted file mode 100644 index 4ddb76b131..0000000000 --- a/TO_MERGE/cse/main/interaction/functions/fn_broadcastMonitoredVariable.sqf +++ /dev/null @@ -1,23 +0,0 @@ -/** - * fn_broadcastMonitoredVariable.sqf - * @Descr: N/A - * @Author: Glowbal - * - * @Arguments: [] - * @Return: - * @PublicAPI: false - */ - -private ["_unit","_target","_variable","_owners"]; -_target = [_this,0,ObjNull,[ObjNull]] call BIS_fnc_Param; -_variable = [_this,1,"",[""]] call BIS_fnc_Param; - -if (_variable == "cse_variableMonitor" || _variable == "cse_interactionRegister") exitwith{}; - -if (!local _target) exitwith { - [_this, "cse_fnc_broadcastMonitoredVariable",owner _target, false] spawn BIS_fnc_MP; -}; -_owners = ([_target,_variable] call cse_fnc_getRegisteredMonitorVariablesOwners); -{ - [_this, "cse_fnc_setMonitoredVariableValue",owner _x, false] spawn BIS_fnc_MP; -}foreach _owners; \ No newline at end of file diff --git a/TO_MERGE/cse/main/interaction/functions/fn_canInteract.sqf b/TO_MERGE/cse/main/interaction/functions/fn_canInteract.sqf deleted file mode 100644 index 496c0a43e5..0000000000 --- a/TO_MERGE/cse/main/interaction/functions/fn_canInteract.sqf +++ /dev/null @@ -1,13 +0,0 @@ -/** - * fn_canInteract.sqf - * @Descr: Check if unit can interact with enviroment. Unit has to be awake and not be in arrested state. - * @Author: Glowbal - * - * @Arguments: [unit OBJECT] - * @Return: BOOL True if unit can interact with enviroment. - * @PublicAPI: true - */ - -private ["_unit","_return"]; -_unit = _this select 0; -(((_unit getvariable ["cse_canInteract",0]) < 1) && ([_unit] call cse_fnc_isAwake) && !([_unit] call cse_fnc_isArrested)) \ No newline at end of file diff --git a/TO_MERGE/cse/main/interaction/functions/fn_getAllMonitoredVariables.sqf b/TO_MERGE/cse/main/interaction/functions/fn_getAllMonitoredVariables.sqf deleted file mode 100644 index 62d3e2a989..0000000000 --- a/TO_MERGE/cse/main/interaction/functions/fn_getAllMonitoredVariables.sqf +++ /dev/null @@ -1,14 +0,0 @@ -/** - * fn_getAllMonitoredVariables.sqf - * @Descr: N/A - * @Author: Glowbal - * - * @Arguments: [] - * @Return: - * @PublicAPI: false - */ - -if (isnil "CSE_REGISTERED_MONITORED_VARIABLES") then { - CSE_REGISTERED_MONITORED_VARIABLES = []; -}; -CSE_REGISTERED_MONITORED_VARIABLES \ No newline at end of file diff --git a/TO_MERGE/cse/main/interaction/functions/fn_getCanInteract.sqf b/TO_MERGE/cse/main/interaction/functions/fn_getCanInteract.sqf deleted file mode 100644 index f90af6758c..0000000000 --- a/TO_MERGE/cse/main/interaction/functions/fn_getCanInteract.sqf +++ /dev/null @@ -1,13 +0,0 @@ -/** - * fn_getCanInteract.sqf - * @Descr: N/A - * @Author: Glowbal - * - * @Arguments: [] - * @Return: - * @PublicAPI: false - */ - -private ["_unit","_return"]; -_unit = [_this, 0, objNull, [objNull]] call BIS_fnc_param; -(_unit getvariable ["cse_canInteract",0]) \ No newline at end of file diff --git a/TO_MERGE/cse/main/interaction/functions/fn_getInteractionTarget.sqf b/TO_MERGE/cse/main/interaction/functions/fn_getInteractionTarget.sqf deleted file mode 100644 index d81bfdc24a..0000000000 --- a/TO_MERGE/cse/main/interaction/functions/fn_getInteractionTarget.sqf +++ /dev/null @@ -1,14 +0,0 @@ -/** - * fn_getInteractionTarget.sqf - * @Descr: N/A - * @Author: Glowbal - * - * @Arguments: [] - * @Return: - * @PublicAPI: false - */ - -private ["_unit","_prevTarget"]; -_unit = [_this,0,ObjNull,[ObjNull]] call BIS_fnc_Param; -_prevTarget = [_unit,"cse_interactionTarget"] call cse_fnc_getVariable; -_prevTarget \ No newline at end of file diff --git a/TO_MERGE/cse/main/interaction/functions/fn_getMonitoredVariableName.sqf b/TO_MERGE/cse/main/interaction/functions/fn_getMonitoredVariableName.sqf deleted file mode 100644 index 7a721e4c54..0000000000 --- a/TO_MERGE/cse/main/interaction/functions/fn_getMonitoredVariableName.sqf +++ /dev/null @@ -1,20 +0,0 @@ -/** - * fn_getMonitoredVariableName.sqf - * @Descr: N/A - * @Author: Glowbal - * - * @Arguments: [] - * @Return: - * @PublicAPI: false - */ - -private ["_unit","_target","_stagingName","_name","_variableName"]; -_target = [_this,0,ObjNull,[ObjNull]] call BIS_fnc_Param; -_variableName = [_this,1,"",[""]] call BIS_fnc_Param; -//_name = ""; -//{ -// _name = _name + _x; -//}foreach ([format["%",_target], " "] call BIS_fnc_splitString); - -_stagingName = format["CSE_MONITORED_VARIABLE_%1", _variableName]; -_stagingName \ No newline at end of file diff --git a/TO_MERGE/cse/main/interaction/functions/fn_getMonitoredVariableValue.sqf b/TO_MERGE/cse/main/interaction/functions/fn_getMonitoredVariableValue.sqf deleted file mode 100644 index 7f2658afec..0000000000 --- a/TO_MERGE/cse/main/interaction/functions/fn_getMonitoredVariableValue.sqf +++ /dev/null @@ -1,39 +0,0 @@ -/** - * fn_getMonitoredVariableValue.sqf - * @Descr: N/A - * @Author: Glowbal - * - * @Arguments: [] - * @Return: - * @PublicAPI: false - */ - -private ["_unit","_target","_returnValue","_stagingName","_variable"]; -_target = [_this,0,ObjNull,[ObjNull]] call BIS_fnc_Param; -_variable = [_this,1,"",[""]] call BIS_fnc_Param; - -_returnValue = ""; -_stagingName = [_target,_variable] call cse_fnc_getMonitoredVariableName; -_unknown = false; -if (isnil _stagingName) then { - // default value for variable, else "" - _returnValue = [_variable] call cse_fnc_getVariableDefault; - [_target,_variable,_returnValue] call cse_fnc_setMonitoredVariableValue; - _unknown = true; -} else { - _returnValue = call compile _stagingName; - if (isnil "_returnValue") then { - _returnValue = [_variable] call cse_fnc_getVariableDefault; - _unknown = true; - } else { - if (typeName _returnValue == typeName "") then { - if (_returnValue == "") then { - call compile format["%1 = '';",_stagingName]; - player sidechat format["Return didnt function propery"]; - }; - _returnValue = [_variable] call cse_fnc_getVariableDefault; - _unknown = true; - }; - }; -}; -_returnValue \ No newline at end of file diff --git a/TO_MERGE/cse/main/interaction/functions/fn_getOnUpdateVariableEH.sqf b/TO_MERGE/cse/main/interaction/functions/fn_getOnUpdateVariableEH.sqf deleted file mode 100644 index 8ecae2ba6a..0000000000 --- a/TO_MERGE/cse/main/interaction/functions/fn_getOnUpdateVariableEH.sqf +++ /dev/null @@ -1,23 +0,0 @@ -/** - * fn_getOnUpdateVariableEH.sqf - * @Descr: N/A - * @Author: Glowbal - * - * @Arguments: [] - * @Return: - * @PublicAPI: false - */ - -private ["_target","_variable","_name","_return","_variableName"]; -_target = [_this,0,ObjNull,[ObjNull]] call BIS_fnc_Param; -_variableName = [_this,1,"",[""]] call BIS_fnc_Param; -_name = [_target,_variableName] call cse_fnc_getMonitoredVariableName; -_name = _name + "_UPDATE_EH"; -_return = ""; -if (isnil _name) then { - -} else { - _return = call compile _name; - //[format["cse_fnc_getOnUpdateVariableEH %1 | %2",_return, _name]] call cse_fnc_debug; -}; -_return \ No newline at end of file diff --git a/TO_MERGE/cse/main/interaction/functions/fn_getRegisteredMonitorVariablesOwners.sqf b/TO_MERGE/cse/main/interaction/functions/fn_getRegisteredMonitorVariablesOwners.sqf deleted file mode 100644 index 90eeed1aa1..0000000000 --- a/TO_MERGE/cse/main/interaction/functions/fn_getRegisteredMonitorVariablesOwners.sqf +++ /dev/null @@ -1,25 +0,0 @@ -/** - * fn_getRegisteredMonitorVariablesOwners.sqf - * @Descr: N/A - * @Author: Glowbal - * - * @Arguments: [] - * @Return: - * @PublicAPI: false - */ - -private ["_unit","_target","_returnOwners","_register","_variableName","_registerMonitorCol"]; -_target = [_this,0,ObjNull,[ObjNull]] call BIS_fnc_Param; -_variableName = [_this,1,"",[""]] call BIS_fnc_Param; -_returnOwners = []; - -_registerMonitorCol = + ([_target,"cse_variableMonitor",[]] call cse_fnc_getVariable); - -//if (count _registerMonitor > 0) then { - { - if ((_x select 1) == _variableName) then { - _returnOwners pushback (_x select 0); - }; - }foreach _registerMonitorCol; -//}; -_returnOwners \ No newline at end of file diff --git a/TO_MERGE/cse/main/interaction/functions/fn_isRegisteredInteractingWith.sqf b/TO_MERGE/cse/main/interaction/functions/fn_isRegisteredInteractingWith.sqf deleted file mode 100644 index 436979399f..0000000000 --- a/TO_MERGE/cse/main/interaction/functions/fn_isRegisteredInteractingWith.sqf +++ /dev/null @@ -1,22 +0,0 @@ -/** - * fn_isRegisteredInteractingWith.sqf - * @Descr: N/A - * @Author: Glowbal - * - * @Arguments: [] - * @Return: - * @PublicAPI: false - */ - -private ["_unit","_target","_register"]; -_unit = [_this,0,ObjNull,[ObjNull]] call BIS_fnc_Param; -_target = [_this,1,ObjNull,[ObjNull]] call BIS_fnc_Param; -_register = [_target,"cse_interactionRegister",[]] call cse_fnc_getVariable; -_return = false; -{ - if (_x == _unit) exitwith { - _return = true; - }; -}foreach _register; - -_return \ No newline at end of file diff --git a/TO_MERGE/cse/main/interaction/functions/fn_registerInteractingWith.sqf b/TO_MERGE/cse/main/interaction/functions/fn_registerInteractingWith.sqf deleted file mode 100644 index bb48949687..0000000000 --- a/TO_MERGE/cse/main/interaction/functions/fn_registerInteractingWith.sqf +++ /dev/null @@ -1,30 +0,0 @@ -/** - * fn_registerInteractingWith.sqf - * @Descr: N/A - * @Author: Glowbal - * - * @Arguments: [] - * @Return: - * @PublicAPI: false - */ - -private ["_unit","_target","_prevTarget","_register"]; -_unit = [_this,0,ObjNull,[ObjNull]] call BIS_fnc_Param; -_target = [_this,1,ObjNull,[ObjNull]] call BIS_fnc_Param; - -if (local _unit) then { - _prevTarget = [_unit,"cse_interactionTarget"] call cse_fnc_getVariable; - if (!isNull _prevTarget) then { - [_unit,_prevTarget] call cse_fnc_unregisterInteractingWith; - //waituntil {sleep 0.1; !([_unit,_prevTarget] call cse_fnc_isRegisteredInteractingWith)}; - }; - [_unit,"cse_interactionTarget",_target] call cse_fnc_setVariable; -}; -if (!local _target) exitwith { - [_this, "cse_fnc_registerInteractingWith",owner _target, false] spawn BIS_fnc_MP; -}; - -// local on target ! -_register = [_target,"cse_interactionRegister",[]] call cse_fnc_getVariable; -_register pushback _unit; -[_target,"cse_interactionRegister",_register] call cse_fnc_setVariable; \ No newline at end of file diff --git a/TO_MERGE/cse/main/interaction/functions/fn_registerVariableMonitor.sqf b/TO_MERGE/cse/main/interaction/functions/fn_registerVariableMonitor.sqf deleted file mode 100644 index 51f273faa6..0000000000 --- a/TO_MERGE/cse/main/interaction/functions/fn_registerVariableMonitor.sqf +++ /dev/null @@ -1,34 +0,0 @@ -/** - * fn_registerVariableMonitor.sqf - * @Descr: N/A - * @Author: Glowbal - * - * @Arguments: [] - * @Return: - * @PublicAPI: false - */ - -private ["_unit","_target","_varName","_register","_onUpdate","_registerMonitor"]; -_unit = [_this,0,ObjNull,[ObjNull]] call BIS_fnc_Param; -_target = [_this,1,ObjNull,[ObjNull]] call BIS_fnc_Param; -_varName = _this select 2; -_onUpdate = ""; -if (count _this >3) then { - _onUpdate = _this select 3; - [_target,_varName,_onUpdate] call cse_fnc_setOnUpdateVariableEH; -}; -if (local _unit) then { - if (isnil "CSE_REGISTERED_MONITORED_VARIABLES") then { - CSE_REGISTERED_MONITORED_VARIABLES = []; - }; - CSE_REGISTERED_MONITORED_VARIABLES pushback _varName; - [_target,_varName] call cse_fnc_getMonitoredVariableValue; -}; - -if (!local _target) exitwith { - [_this, "cse_fnc_registerVariableMonitor",owner _target, false] spawn BIS_fnc_MP; -}; -_registerMonitor = [_target,"cse_variableMonitor",[]] call cse_fnc_getVariable; -_registerMonitor pushback [_unit,_varName]; -[_target,"cse_variableMonitor",_registerMonitor] call cse_fnc_setVariable; -// [[_target,_varName,([_target,_varName] call cse_fnc_getVariable)], "cse_fnc_setMonitoredVariableValue", _unit, false] spawn BIS_fnc_MP; \ No newline at end of file diff --git a/TO_MERGE/cse/main/interaction/functions/fn_setCanInteract.sqf b/TO_MERGE/cse/main/interaction/functions/fn_setCanInteract.sqf deleted file mode 100644 index 2d7ca320b5..0000000000 --- a/TO_MERGE/cse/main/interaction/functions/fn_setCanInteract.sqf +++ /dev/null @@ -1,26 +0,0 @@ -/** - * fn_setCanInteract.sqf - * @Descr: N/A - * @Author: Glowbal - * - * @Arguments: [] - * @Return: - * @PublicAPI: false - */ - -private ["_unit","_to","_return"]; -_unit = [_this, 0, objNull, [objNull]] call BIS_fnc_param; -_to = _this select 1; -_return = false; -if (((typeName _to) == "SCALAR")) then { - if (_to <-1) then { - _to = -1; - } else { - if (_to > 1) then { - _to = 1; - }; - }; - _unit setvariable ["cse_canInteract", ([_unit] call cse_fnc_getCanInteract) + _to,false]; - _return = true; -}; -_return \ No newline at end of file diff --git a/TO_MERGE/cse/main/interaction/functions/fn_setMonitoredVariableValue.sqf b/TO_MERGE/cse/main/interaction/functions/fn_setMonitoredVariableValue.sqf deleted file mode 100644 index c0da8c58f6..0000000000 --- a/TO_MERGE/cse/main/interaction/functions/fn_setMonitoredVariableValue.sqf +++ /dev/null @@ -1,35 +0,0 @@ -/** - * fn_setMonitoredVariableValue.sqf - * @Descr: N/A - * @Author: Glowbal - * - * @Arguments: [] - * @Return: - * @PublicAPI: false - */ - -_this spawn { - private ["_unit","_target","_variable","_eh"]; - _target = [_this,0,ObjNull,[ObjNull]] call BIS_fnc_Param; - _variable = [_this,1,"",[""]] call BIS_fnc_Param; 1; - - _stagingName = [_target,_variable] call cse_fnc_getMonitoredVariableName; - if (count _this >2) then { - call compile format["%1 = %2;",_stagingName,_this select 2]; - } else { - call compile format["%1 = nil;",_stagingName]; - }; - - - _eh = [_target,_variable] call cse_fnc_getOnUpdateVariableEH; - if (!isnil _eh) then { - if (typeName _eh == typeName "") then { - [_target,_variable,_this select 2] spawn compile _eh; - } else { - if (typeName _eh == typeName {}) then { - [_target,_variable,_this select 2] spawn _eh; - }; - }; - }; - -}; \ No newline at end of file diff --git a/TO_MERGE/cse/main/interaction/functions/fn_setOnUpdateVariableEH.sqf b/TO_MERGE/cse/main/interaction/functions/fn_setOnUpdateVariableEH.sqf deleted file mode 100644 index 63021c0287..0000000000 --- a/TO_MERGE/cse/main/interaction/functions/fn_setOnUpdateVariableEH.sqf +++ /dev/null @@ -1,17 +0,0 @@ -/** - * fn_setOnUpdateVariableEH.sqf - * @Descr: N/A - * @Author: Glowbal - * - * @Arguments: [] - * @Return: - * @PublicAPI: false - */ - -private ["_target","_name","_eh","_variableName"]; -_target = [_this,0,ObjNull,[ObjNull]] call BIS_fnc_Param; -_variableName = [_this,1,"",[""]] call BIS_fnc_Param; -_eh = _this select 2; // what data type? -_name = [_target,_variableName] call cse_fnc_getMonitoredVariableName; -_name = _name + "_UPDATE_EH"; -[_eh] call compile format["%1 = (_this select 0);",_name,_eh]; \ No newline at end of file diff --git a/TO_MERGE/cse/main/interaction/functions/fn_unregisterInteractingWith.sqf b/TO_MERGE/cse/main/interaction/functions/fn_unregisterInteractingWith.sqf deleted file mode 100644 index d3621d1462..0000000000 --- a/TO_MERGE/cse/main/interaction/functions/fn_unregisterInteractingWith.sqf +++ /dev/null @@ -1,38 +0,0 @@ -/** - * fn_unregisterInteractingWith.sqf - * @Descr: N/A - * @Author: Glowbal - * - * @Arguments: [] - * @Return: - * @PublicAPI: false - */ - -private ["_unit","_target","_register","_toRemove","_newRegister","_registerMonitor"]; -_unit = [_this,0,ObjNull,[ObjNull]] call BIS_fnc_Param; -_target = [_this,1,ObjNull,[ObjNull]] call BIS_fnc_Param; - -if (local _unit) then { - [_unit,"cse_interactionTarget"] call cse_fnc_setVariable; - { - _name = [_target, _x] call cse_fnc_getMonitoredVariableName; - call compile format["%1 = nil;",_name]; - }foreach (call cse_fnc_getAllMonitoredVariables); -}; -if (!local _target) exitwith { - [_this, "cse_fnc_unregisterInteractingWith",owner _target, false] spawn BIS_fnc_MP; -}; -_register = [_target,"cse_interactionRegister",[]] call cse_fnc_getVariable; -_register = _register - [_unit]; -[_target,"cse_interactionRegister",_register] call cse_fnc_setVariable; - -_registerMonitor = [_target,"cse_variableMonitor",[]] call cse_fnc_getVariable; -_newRegister = []; -{ - if ((_x select 0) == _unit) then { - - } else { - _newRegister pushback _x; - }; -}foreach _registerMonitor; -[_target,"cse_variableMonitor",_newRegister] call cse_fnc_setVariable; \ No newline at end of file diff --git a/TO_MERGE/cse/main/messages/functions/fn_sendDisplayInformationTo.sqf b/TO_MERGE/cse/main/messages/functions/fn_sendDisplayInformationTo.sqf deleted file mode 100644 index b8a47455ce..0000000000 --- a/TO_MERGE/cse/main/messages/functions/fn_sendDisplayInformationTo.sqf +++ /dev/null @@ -1,46 +0,0 @@ -/** - * fn_sendDisplayInformationTo.sqf - * @Descr: Sends a display information hint to a receiver - * @Author: Glowbal - * - * @Arguments: [receiver OBJECT, title STRING, content ARRAY (An array with strings), type NUMBER (Optional)] - * @Return: void - * @PublicAPI: true - */ - -private ["_reciever","_title","_content","_type", "_parameters", "_localizationArray"]; -_reciever = [_this, 0, ObjNull,[ObjNull]] call BIS_fnc_Param; -_title = [_this, 1, "",[""]] call BIS_fnc_Param; -_content = [_this, 2, [""],[[""]]] call BIS_fnc_Param; -_type = [_this, 3, 0,[0]] call BIS_fnc_Param; -_parameters = [_this, 4, [], [[]]] call BIS_fnc_Param; - -if (isPlayer _reciever) then { - if (!local _reciever) then { - [_this, "cse_fnc_sendDisplayInformationTo", _reciever, false] spawn BIS_fnc_MP; - } else { - - if (isLocalized _title) then { - _title = localize _title; - }; - _localizationArray = [_title]; - { - _localizationArray pushback _x; - }foreach _parameters; - _title = format _localizationArray; - - { - if (isLocalized _x) then { - _localizationArray = [localize _x]; - { - _localizationArray pushback _x; - }foreach _parameters; - - _content set [_foreachIndex, format _localizationArray]; - }; - - }foreach _content; - - [_title,_content,_type] call cse_fnc_gui_displayInformation; - }; -}; \ No newline at end of file diff --git a/TO_MERGE/cse/main/messages/functions/fn_sendDisplayMessageTo.sqf b/TO_MERGE/cse/main/messages/functions/fn_sendDisplayMessageTo.sqf deleted file mode 100644 index da02f48dbc..0000000000 --- a/TO_MERGE/cse/main/messages/functions/fn_sendDisplayMessageTo.sqf +++ /dev/null @@ -1,46 +0,0 @@ -/** - * fn_sendDisplayMessageTo.sqf - * @Descr: Displays a message on locality of receiver - * @Author: Glowbal - * - * @Arguments: [receiver OBJECT, title STRING, content STRING, type NUMBER (Optional)] - * @Return: void - * @PublicAPI: true - */ - -private ["_reciever","_title","_content","_type", "_parameters", "_localizationArray"]; -_reciever = [_this, 0, ObjNull,[ObjNull]] call BIS_fnc_Param; -_title = [_this, 1, "",[""]] call BIS_fnc_Param; -_content = [_this, 2, "",[""]] call BIS_fnc_Param; -_type = [_this, 3, 0,[0]] call BIS_fnc_Param; -_parameters = [_this, 4, [], [[]]] call BIS_fnc_Param; - -[_this] call cse_fnc_debug; - -if (isPlayer _reciever) then { - if (!local _reciever) then { - [_this, "cse_fnc_sendDisplayMessageTo", _reciever, false] spawn BIS_fnc_MP; - } else { - - if (isLocalized _title) then { - _title = localize _title; - }; - if (isLocalized _content) then { - _content = localize _content; - }; - - _localizationArray = [_title]; - { - _localizationArray pushback _x; - }foreach _parameters; - _title = format _localizationArray; - - _localizationArray = [_content]; - { - _localizationArray pushback _x; - }foreach _parameters; - _content = format _localizationArray; - - [_title,_content,_type] call cse_fnc_gui_displayMessage; - }; -}; \ No newline at end of file diff --git a/TO_MERGE/cse/main/messages/functions/fn_sendHintTo.sqf b/TO_MERGE/cse/main/messages/functions/fn_sendHintTo.sqf deleted file mode 100644 index a86bc0bc2d..0000000000 --- a/TO_MERGE/cse/main/messages/functions/fn_sendHintTo.sqf +++ /dev/null @@ -1,23 +0,0 @@ -/** - * fn_sendHintTo.sqf - * @Descr: Sends a hint to player unit across network - * @Author: Glowbal - * - * @Arguments: [reciever OBJECT, message STRING] - * @Return: void - * @PublicAPI: true - */ - - -private ["_reciever","_message"]; -_reciever = _this select 0; -_message = _this select 1; -//[_reciever,_message] call cms_fnc_sendChatMessageTo; - -if (isPlayer _reciever) then { - if (!local _reciever) then { - [_this, "cse_fnc_sendHintTo", _reciever, false] spawn BIS_fnc_MP; - } else { - hintsilent format ["%1",_message]; - }; -}; \ No newline at end of file diff --git a/TO_MERGE/cse/main/messages/functions/fn_sendMessageTo.sqf b/TO_MERGE/cse/main/messages/functions/fn_sendMessageTo.sqf deleted file mode 100644 index f54d49d6d5..0000000000 --- a/TO_MERGE/cse/main/messages/functions/fn_sendMessageTo.sqf +++ /dev/null @@ -1,22 +0,0 @@ -/** - * fn_sendMessageTo.sqf - * @Descr: Sends a chat message to player unit across the network - * @Author: Glowbal - * - * @Arguments: [reciever OBJECT, message STRING] - * @Return: void - * @PublicAPI: true - */ - -private ["_reciever","_message"]; -_reciever = _this select 0; -_message = _this select 1; - - -if (isPlayer _reciever) then { - if (!local _reciever) then { - [_this, "cse_fnc_sendMessageTo", _reciever, false] spawn BIS_fnc_MP; - } else { - CSE_LOGIC_OBJECT globalChat format ["%1",_message]; - }; -}; diff --git a/TO_MERGE/cse/main/misc/functions/fn_broadcastSound3D_f.sqf b/TO_MERGE/cse/main/misc/functions/fn_broadcastSound3D_f.sqf deleted file mode 100644 index b44904ae10..0000000000 --- a/TO_MERGE/cse/main/misc/functions/fn_broadcastSound3D_f.sqf +++ /dev/null @@ -1,16 +0,0 @@ -/** - * fn_broadcastSound3D_f.sqf - * @Descr: Plays a sound in 3D - * @Author: Glowbal - * - * @Arguments: [unit OBJECT, sound STRING] - * @Return: void - * @PublicAPI: true - */ - - - -if (isDedicated) exitwith{}; -_unit = [_this, 0, ObjNull,[ObjNull]] call BIS_fnc_Param; -_sound = [_this, 1, "",[""]] call BIS_fnc_Param; -_unit say3D _sound; \ No newline at end of file diff --git a/TO_MERGE/cse/main/misc/functions/fn_closeAllDialogs_f.sqf b/TO_MERGE/cse/main/misc/functions/fn_closeAllDialogs_f.sqf deleted file mode 100644 index 4d9cb33837..0000000000 --- a/TO_MERGE/cse/main/misc/functions/fn_closeAllDialogs_f.sqf +++ /dev/null @@ -1,14 +0,0 @@ -/** - * fn_closeAllDialogs_f.sqf - * @Descr: Close all dialogs - * @Author: Glowbal - * - * @Arguments: [] - * @Return: void - * @PublicAPI: true - */ - - -while {dialog} do { - closeDialog 0; -}; \ No newline at end of file diff --git a/TO_MERGE/cse/main/misc/functions/fn_disableAI_f.sqf b/TO_MERGE/cse/main/misc/functions/fn_disableAI_f.sqf deleted file mode 100644 index d2ad392559..0000000000 --- a/TO_MERGE/cse/main/misc/functions/fn_disableAI_f.sqf +++ /dev/null @@ -1,23 +0,0 @@ -/** - * fn_disableAI_f.sqf - * @Descr: N/A - * @Author: Glowbal - * - * @Arguments: [] - * @Return: - * @PublicAPI: false - */ - -private ["_unit","_disable"]; -_unit = [_this, 0,ObjNull,[ObjNull]] call BIS_fnc_Param; -_disable = [_this, 1,false,[false]] call BIS_fnc_Param; - -if (local _unit && !(IsPlayer _unit)) then { - if (_disable) then { - _unit disableAI "Move"; - _unit disableAI "TARGET"; - } else { - _unit enableAI "Move"; - _unit enableAI "TARGET"; - }; -}; \ No newline at end of file diff --git a/TO_MERGE/cse/main/misc/functions/fn_disableKeyInput_f.sqf b/TO_MERGE/cse/main/misc/functions/fn_disableKeyInput_f.sqf deleted file mode 100644 index 679ca870a1..0000000000 --- a/TO_MERGE/cse/main/misc/functions/fn_disableKeyInput_f.sqf +++ /dev/null @@ -1,77 +0,0 @@ -/** - * fn_disableKeyInput_f.sqf - * @Descr: Disable the keyinput - * @Author: Glowbal - * - * @Arguments: [disable BOOL] - * @Return: void - * @PublicAPI: false - */ - - - -private["_disable"]; -_disable = [_this, 0, false, [false]] call BIS_fnc_Param; -if (!hasInterface) exitwith {}; -CSE_DISABLE_KEY_INPUT_F = _disable; - -[format["Disable Key input: %1",_disable]] call cse_fnc_debug; -if (_disable) then { - if (isNil "CSE_DISABLE_KEY_UP_INPUT_DISPLAY_EH_F") then { - [format["Keyinput has not yet been disabled, now disabling",_disable]] call cse_fnc_debug; - - CSE_DISABLE_USER_INPUT_SCREEN = true; - createDialog 'cse_empty_screen'; - disableSerialization; - _display = uiNamespace getvariable "cse_empty_screen"; - CSE_DISABLE_KEY_UP_INPUT_DISPLAY_EH_F = _display displayAddEventHandler ["KeyDown", { - _return = true; - if ((_this select 1) == 1) then { - if (isNull finddisplay 49) then { - [format["Assigning ctrlEventhandlers to buttons"]] call cse_fnc_debug; - if (isMultiplayer) then { - createDialog "RscDisplayMPInterrupt"; - _ctrl = (finddisplay 49) displayctrl 103; - _ctrl ctrlSetEventHandler ["buttonClick", "closeDialog 0; [false] call cse_fnc_disableKeyInput_f; failMission 'LOSER';"]; - - _ctrl = (finddisplay 49) displayctrl 104; - _ctrl ctrlSetEventHandler ["buttonClick", "closeDialog 0; [false] call cse_fnc_disableKeyInput_f; player setDamage 1;"]; - } else { - createDialog "RscDisplayInterrupt"; - _ctrl = (finddisplay 49) displayctrl 104; - _ctrl ctrlSetEventHandler ["buttonClick", "closeDialog 0; [false] call cse_fnc_disableKeyInput_f; failMission 'LOSER';"]; - }; - } else { - closeDialog 49; - }; - }; - - if ((_this select 1) in actionKeys "CuratorInterface" && {player in allCurators}) then { - openCuratorInterface - }; - if (serverCommandAvailable "#missions") then { - }; - [format["Returning %1 for disable key input keyDown handler", _return]] call cse_fnc_debug; - _return; - }]; - CSE_DISABLE_KEY_DOWN_INPUT_DISPLAY_EH_F = _display displayAddEventHandler ["KeyUp", {true;}]; - }; -} else { - if (!isNil "CSE_DISABLE_KEY_UP_INPUT_DISPLAY_EH_F") then { - [format["Keyinput has been disabled, now enabling",_disable]] call cse_fnc_debug; - CSE_DISABLE_USER_INPUT_SCREEN = false; - disableSerialization; - _display = uiNamespace getvariable "cse_empty_screen"; - if (isnil "_display") then { - _display = displayNull; - }; - closeDialog 679123; - _display closeDisplay 1; - _display displayRemoveEventHandler ["KeyDown", CSE_DISABLE_KEY_UP_INPUT_DISPLAY_EH_F]; - _display displayRemoveEventHandler ["KeyUp", CSE_DISABLE_KEY_DOWN_INPUT_DISPLAY_EH_F]; - CSE_DISABLE_KEY_DOWN_INPUT_DISPLAY_EH_F = nil; - CSE_DISABLE_KEY_UP_INPUT_DISPLAY_EH_F = nil; - }; -}; - -[[_disable], "disableKeyInput"] call cse_fnc_customEventHandler_F; \ No newline at end of file diff --git a/TO_MERGE/cse/main/misc/functions/fn_disableUserInput_f.sqf b/TO_MERGE/cse/main/misc/functions/fn_disableUserInput_f.sqf deleted file mode 100644 index a2832cfebc..0000000000 --- a/TO_MERGE/cse/main/misc/functions/fn_disableUserInput_f.sqf +++ /dev/null @@ -1,28 +0,0 @@ -/** - * fn_disableUserInput_f.sqf - * @Descr: Disables the user input. Works stacked. - * @Author: Glowbal - * - * @Arguments: [id STRING, disable BOOL] - * @Return: void - * @PublicAPI: true - */ - -private ["_id","_disable"]; -_id = _this select 0; -_disable = _this select 1; - - -if (isnil "CSE_DISABLE_USER_INPUT_COLLECTION_F") then { - CSE_DISABLE_USER_INPUT_COLLECTION_F = []; -}; - -if (_disable) then { - CSE_DISABLE_USER_INPUT_COLLECTION_F pushback _id; - [true] call cse_fnc_disableKeyInput_f; -} else { - CSE_DISABLE_USER_INPUT_COLLECTION_F = CSE_DISABLE_USER_INPUT_COLLECTION_F - [_id]; - if (CSE_DISABLE_USER_INPUT_COLLECTION_F isEqualTo []) then { - [false] call cse_fnc_disableKeyInput_f; - }; -}; \ No newline at end of file diff --git a/TO_MERGE/cse/main/misc/functions/fn_dropWeapon_f.sqf b/TO_MERGE/cse/main/misc/functions/fn_dropWeapon_f.sqf deleted file mode 100644 index 4a23b214b5..0000000000 --- a/TO_MERGE/cse/main/misc/functions/fn_dropWeapon_f.sqf +++ /dev/null @@ -1,39 +0,0 @@ -/** - * fn_dropWeapon_f.sqf - * @Descr: N/A - * @Author: Glowbal - * - * @Arguments: [] - * @Return: - * @PublicAPI: false - */ - -private ["_unit","_currentWeapon","_currentAnimation", "_WeaponHolder"]; -_unit = [_this, 0, ObjNull,[ObjNull]] call BIS_fnc_Param; - -_currentWeapon = currentWeapon _unit; -_currentAnimation = animationState _unit; -_WeaponHolder = "GroundWeaponHolder" createVehicle position _unit; - -_unit removeWeapon _currentWeapon; -_weaponHolder addWeaponCargoGlobal [_currentWeapon, 1]; -//_unit action [ "DropWeapon", _WeaponHolder, _currentWeapon ]; -_WeaponHolder setPos (getPos _unit); -//_unit switchMove _currentAnimation; - -_primairyWeapon = primaryWeapon _unit; -_secondairyWeapon = secondaryWeapon _unit; -_handGunWeapon = handgunWeapon _unit; - -switch (_currentWeapon) do { - case _primairyWeapon: { - - }; - case _secondairyWeapon: { - - }; - case _handGunWeapon: { - - }; - default {}; -}; \ No newline at end of file diff --git a/TO_MERGE/cse/main/misc/functions/fn_endRadioTransmission_f.sqf b/TO_MERGE/cse/main/misc/functions/fn_endRadioTransmission_f.sqf deleted file mode 100644 index 86457e708c..0000000000 --- a/TO_MERGE/cse/main/misc/functions/fn_endRadioTransmission_f.sqf +++ /dev/null @@ -1,29 +0,0 @@ -/** - * fn_endRadioTransmission_f.sqf - * @Descr: force end all radio transmissions by TFAR or ACRE - * @Author: Glowbal - * - * @Arguments: [] - * @Return: nil - * @PublicAPI: true - */ - - -if (["acre_api"] call cse_fnc_isModLoaded_F) then { - [-1] call acre_sys_core_fnc_handleMultiPttKeyPressUp; - [0] call acre_sys_core_fnc_handleMultiPttKeyPressUp; - [1] call acre_sys_core_fnc_handleMultiPttKeyPressUp; - [2] call acre_sys_core_fnc_handleMultiPttKeyPressUp; -}; - -if (["task_force_radio"] call cse_fnc_isModLoaded_F) then { - call TFAR_fnc_onSwTangentReleased; - call TFAR_fnc_onAdditionalSwTangentReleased; - - call TFAR_fnc_onLRTangentReleased; - call TFAR_fnc_onAdditionalLRTangentReleased; - - call TFAR_fnc_onDDTangentReleased; -}; - -nil; \ No newline at end of file diff --git a/TO_MERGE/cse/main/misc/functions/fn_getFirstObjectIntersection.sqf b/TO_MERGE/cse/main/misc/functions/fn_getFirstObjectIntersection.sqf deleted file mode 100644 index 9d57ea57a1..0000000000 --- a/TO_MERGE/cse/main/misc/functions/fn_getFirstObjectIntersection.sqf +++ /dev/null @@ -1,44 +0,0 @@ -/** - * fn_getFirstIntersection.sqf - * @Descr: Returns the the first intersection with an object between two positions - * @Author: Ruthberg - * - * @Arguments: [position PositionASL, position PositionASL, accuracy FLOAT] - * @Return: [intersects BOOL, intersection PositionASL] - * @PublicAPI: true - */ - - -private ["_source", "_destination", "_accuracy", "_distance", "_lower", "_upper", "_mid", "_intersections", "_result"]; -_source = _this select 0; -_destination = _this select 1; -_accuracy = _this select 2; - -_result = [false, [0, 0, 0]]; - -_distance = _source vectorDistance _destination; - -if (count (lineIntersectsWith [_source, _destination]) > 0) then { - _lower = 0; - _upper = 1; - _mid = 0.5; - - _dir = _source vectorFromTo _destination; - - while {(_upper - _lower) * _distance > _accuracy} do { - _mid = _lower + (_upper - _lower) / 2; - - _intersections = count (lineIntersectsWith [_source, _source vectorAdd (_dir vectorMultiply (_mid * _distance))]); - - if (_intersections > 0) then { - _upper = _mid; - } else { - _lower = _mid; - }; - }; - - _mid = _lower + (_upper - _lower) / 2; - _result = [true, _source vectorAdd (_dir vectorMultiply (_mid * _distance))]; -}; - -_result diff --git a/TO_MERGE/cse/main/misc/functions/fn_getFirstTerrainIntersection.sqf b/TO_MERGE/cse/main/misc/functions/fn_getFirstTerrainIntersection.sqf deleted file mode 100644 index 57ff80fa60..0000000000 --- a/TO_MERGE/cse/main/misc/functions/fn_getFirstTerrainIntersection.sqf +++ /dev/null @@ -1,44 +0,0 @@ -/** - * fn_getFirstIntersection.sqf - * @Descr: Returns the the first intersection with an object between two positions - * @Author: Ruthberg - * - * @Arguments: [position PositionASL, position PositionASL, accuracy FLOAT] - * @Return: [intersects BOOL, intersection PositionASL] - * @PublicAPI: true - */ - - -private ["_source", "_destination", "_accuracy", "_distance", "_lower", "_upper", "_mid", "_intersection", "_result"]; -_source = _this select 0; -_destination = _this select 1; -_accuracy = _this select 2; - -_result = [false, [0, 0, 0]]; - -_distance = _source vectorDistance _destination; - -if (terrainIntersectASL [_source, _destination]) then { - _lower = 0; - _upper = 1; - _mid = 0.5; - - _dir = _source vectorFromTo _destination; - - while {(_upper - _lower) * _distance > _accuracy} do { - _mid = _lower + (_upper - _lower) / 2; - - _intersection = terrainIntersectASL [_source, _source vectorAdd (_dir vectorMultiply (_mid * _distance))]; - - if (_intersection) then { - _upper = _mid; - } else { - _lower = _mid; - }; - }; - - _mid = _lower + (_upper - _lower) / 2; - _result = [true, _source vectorAdd (_dir vectorMultiply (_mid * _distance))]; -}; - -_result diff --git a/TO_MERGE/cse/main/misc/functions/fn_getName.sqf b/TO_MERGE/cse/main/misc/functions/fn_getName.sqf deleted file mode 100644 index b7b4c9bda8..0000000000 --- a/TO_MERGE/cse/main/misc/functions/fn_getName.sqf +++ /dev/null @@ -1,26 +0,0 @@ -/** - * fn_getName.sqf - * @Descr: Get the name of unit - * @Author: Glowbal - * - * @Arguments: [unit OBJECT] - * @Return: STRING Name of object - * @PublicAPI: true - */ - -private["_unit","_return"]; -_unit = _this select 0; -_return = "Unknown"; - -if (alive _unit) then { - if (_unit iskindof "CAManBase") then { - if (_unit getvariable ["cse_isDead",false]) then { - _return = _unit getvariable ["cse_name","Unknown"]; - } else { - _return = name _unit; - }; - }; -} else { - _return = _unit getvariable ["cse_name","Unknown"]; -}; -_return \ No newline at end of file diff --git a/TO_MERGE/cse/main/misc/functions/fn_getWeaponItems_f.sqf b/TO_MERGE/cse/main/misc/functions/fn_getWeaponItems_f.sqf deleted file mode 100644 index 7128ceb09c..0000000000 --- a/TO_MERGE/cse/main/misc/functions/fn_getWeaponItems_f.sqf +++ /dev/null @@ -1,14 +0,0 @@ -/** - * fn_getWeaponItems_f.sqf - * @Descr: Get the weapon items from the unit. - * @Author: Glowbal - * - * @Arguments: [unit OBJECT] - * @Return: - * @PublicAPI: false - */ - -private "_unit"; -_unit = _this select 0; - -[primaryWeaponItems _unit, secondaryWeaponItems _unit, handgunItems _unit]; \ No newline at end of file diff --git a/TO_MERGE/cse/main/misc/functions/fn_hasItem_f.sqf b/TO_MERGE/cse/main/misc/functions/fn_hasItem_f.sqf deleted file mode 100644 index 6091895503..0000000000 --- a/TO_MERGE/cse/main/misc/functions/fn_hasItem_f.sqf +++ /dev/null @@ -1,16 +0,0 @@ -/** - * fn_hasItem_f.sqf - * @Descr: Check if a unit has item - * @Author: Glowbal - * - * @Arguments: [unit OBJECT, item STRING (Classname of item)] - * @Return: BOOL True if unit has the item in it's inventory - * @PublicAPI: true - */ - - -private ["_unit","_item"]; -_unit = [_this, 0, objNull, [objNull]] call BIS_fnc_Param; -_item = [_this, 1, "", [""]] call BIS_fnc_Param; - -(_item in items _unit); \ No newline at end of file diff --git a/TO_MERGE/cse/main/misc/functions/fn_inWater_f.sqf b/TO_MERGE/cse/main/misc/functions/fn_inWater_f.sqf deleted file mode 100644 index 93027ffe7d..0000000000 --- a/TO_MERGE/cse/main/misc/functions/fn_inWater_f.sqf +++ /dev/null @@ -1,20 +0,0 @@ -/** - * fn_inWater_f.sqf - * @Descr: Check if unit is underwater - * @Author: Glowbal - * - * @Arguments: [unit OBJECT] - * @Return: BOOL True if unit is in the water - * @PublicAPI: true - */ - -private ["_unit","_return","_aslPos"]; -_unit = _this select 0; -_return = false; -if ((surfaceIsWater getPos _unit)) then { - _aslPos = _unit modelToWorld (_unit selectionPosition "head"); - if ((_aslPos select 2) <= 0) then { - _return = true; - }; -}; -_return; \ No newline at end of file diff --git a/TO_MERGE/cse/main/misc/functions/fn_isAwake.sqf b/TO_MERGE/cse/main/misc/functions/fn_isAwake.sqf deleted file mode 100644 index a8afe16aa6..0000000000 --- a/TO_MERGE/cse/main/misc/functions/fn_isAwake.sqf +++ /dev/null @@ -1,13 +0,0 @@ -/** - * fn_isAwake.sqf - * @Descr: Check if unit is awake. Will be false when death or unit is unconscious. - * @Author: Glowbal - * - * @Arguments: [unit OBJECT] - * @Return: BOOL True if unit is awake - * @PublicAPI: true - */ - -private ["_unit","_return"]; -_unit = _this select 0; -(!([_unit] call cse_fnc_isUnconscious)) && alive _unit && !(_unit getvariable ["cse_isDead",false]); diff --git a/TO_MERGE/cse/main/misc/functions/fn_isInBuilding.sqf b/TO_MERGE/cse/main/misc/functions/fn_isInBuilding.sqf deleted file mode 100644 index 6b08e969f0..0000000000 --- a/TO_MERGE/cse/main/misc/functions/fn_isInBuilding.sqf +++ /dev/null @@ -1,23 +0,0 @@ -/** - * fn_isInBuilding.sqf - * @Descr: Check is unit is within a building - * @Author: Glowbal - * - * @Arguments: [unit OBJECT] - * @Return: BOOL True if unit is under a roof - * @PublicAPI: true - */ - -private ["_unit","_eyePos","_obj","_isInBuilding"]; -_unit = _this select 0; - -_eyePos = eyePos _unit; -_isInBuilding = false; -_obj = (lineIntersectsWith [_unit modelToWorld [0, 0, (_eyePos select 2)], _unit modelToWorld [0, 0, (_eyePos select 2) +10], _unit]); -{ - if (_x isKindOf "Building") exitwith { - _isInBuilding = true; - }; -}foreach _obj; - -_isInBuilding \ No newline at end of file diff --git a/TO_MERGE/cse/main/misc/functions/fn_lockVehicleOfUnitUntil.sqf b/TO_MERGE/cse/main/misc/functions/fn_lockVehicleOfUnitUntil.sqf deleted file mode 100644 index adf55eed55..0000000000 --- a/TO_MERGE/cse/main/misc/functions/fn_lockVehicleOfUnitUntil.sqf +++ /dev/null @@ -1,38 +0,0 @@ -/** - * fn_lockVehicleOfUnitUntil.sqf - * @Descr: N/A - * @Author: Glowbal - * - * @Arguments: [] - * @Return: - * @PublicAPI: false - */ - -private ["_unit","_vehicleOfUnit","_lockSwitch"]; -_unit = [_this, 0,ObjNull,[ObjNull]] call BIS_fnc_Param; -_vehicleOfUnit = vehicle _unit; -_lockSwitch = false; -waituntil{ - if (!_lockSwitch) then { - if (_vehicleOfUnit != _unit) then { - if (locked _vehicleOfUnit != 0) then { - _lockSwitch = true; - _vehicleOfUnit lock true; - [format["VEHICLE LOCKED %1", _vehicleOfUnit]] call cse_fnc_debug; - }; - }; - } else { - if (vehicle _unit == _unit) then { - _vehicleOfUnit lock false; - _lockSwitch = false; - [format["VEHICLE UNLOCKED %1", _vehicleOfUnit]] call cse_fnc_debug; - }; - }; - (!(_unit getvariable ["cse_state_unconscious", false]) || !alive _unit)}; - -if (_lockSwitch) then { - _vehicleOfUnit lock false; - [format["VEHICLE UNLOCKED %1", _vehicleOfUnit]] call cse_fnc_debug; -} else { - [format["NO VEHICLE TO UNLOCKED %1", _unit]] call cse_fnc_debug; -}; \ No newline at end of file diff --git a/TO_MERGE/cse/main/misc/functions/fn_moduleEnableBasicRevive.sqf b/TO_MERGE/cse/main/misc/functions/fn_moduleEnableBasicRevive.sqf deleted file mode 100644 index f7541e4d58..0000000000 --- a/TO_MERGE/cse/main/misc/functions/fn_moduleEnableBasicRevive.sqf +++ /dev/null @@ -1,36 +0,0 @@ -/** - * fn_moduleEnableBasicRevive.sqf - * @Descr: N/A - * @Author: Glowbal - * - * @Arguments: [] - * @Return: - * @PublicAPI: false - */ - -private ["_args", "_units", "_activated"]; -_args = _this; - -CSE_ENABLE_REVIVE_F = 0; -CSE_REVIVE_TIMER_F = 600; -CSE_REVIVE_NUMBER_MAX_F = -1; -{ - _value = _x select 1; - if (!isnil "_value") then { - if (_x select 0 == "enableFor") then { - CSE_ENABLE_REVIVE_F = _x select 1; - }; - if (_x select 0 == "timer") then { - CSE_REVIVE_TIMER_F = _x select 1; - }; - if (_x select 0 == "amountOf") then { - CSE_REVIVE_NUMBER_MAX_F = _x select 1; - }; - }; -}foreach _args; - -[ - {(((_this select 0) getvariable["CSE_ENABLE_REVIVE_SETDEAD_F",0]) > 0)} -] call cse_fnc_registerUnconsciousCondition; - -[format["Enabled Basic Revive Module - ENABLED FOR: %1. TIMER: %2. NUMBER: %3", CSE_ENABLE_REVIVE_F, CSE_REVIVE_TIMER_F, CSE_REVIVE_NUMBER_MAX_F]] call cse_fnc_debug; \ No newline at end of file diff --git a/TO_MERGE/cse/main/misc/functions/fn_resetAllDefaults_f.sqf b/TO_MERGE/cse/main/misc/functions/fn_resetAllDefaults_f.sqf deleted file mode 100644 index 7937c359a2..0000000000 --- a/TO_MERGE/cse/main/misc/functions/fn_resetAllDefaults_f.sqf +++ /dev/null @@ -1,51 +0,0 @@ -/** - * fn_resetAllDefaults_f.sqf - * @Descr: reset all variables that have been defined - * @Author: Glowbal - * - * @Arguments: [] - * @Return: - * @PublicAPI: false - */ - -private ["_unit","_oldUnit","_sets","_CSEFadingBlackUI","_ctrlFadingBlackUI"]; -_unit = [_this, 0, objNull, [objNull]] call BIS_fnc_param; -_oldUnit = [_this, 1, objNull, [objNull]] call BIS_fnc_param; - -//_unit setvariable["cse_unconscious_non_captive_f",nil]; -if (missionNamespace getvariable ["cse_unconscious_non_captive_f",false]) then { - _unit setCaptive false; - missionNamespace setvariable["cse_unconscious_non_captive_f",nil]; - [format["Detected unit as a non captive but in captive state. RESETTING"]] call cse_fnc_debug; -} else { - [format["didn't trigger but unit is: %1 - %2", captive _unit, (missionNamespace getvariable ["cse_unconscious_non_captive_f",false])]] call cse_fnc_debug; -}; - -_unit setvariable ["cse_isDead",nil,true]; -_unit setvariable ["cse_state_unconscious", nil, true]; - -if (isPlayer _unit) then { - [true] call cse_fnc_setVolume_f; - [false] call cse_fnc_disableKeyInput_f; - [false] call cse_fnc_effectBlackOut; - [player, -1] call cse_fnc_limitSpeed; - if (isnil "CSE_DISABLE_USER_INPUT_COLLECTION_F") then { - CSE_DISABLE_USER_INPUT_COLLECTION_F = []; - }; - { - [_X, false] call cse_fnc_disableUserInput_f; - }foreach CSE_DISABLE_USER_INPUT_COLLECTION_F; -}; -_sets = [_unit] call cse_fnc_getAllSetVariables; -[format["defaults for %1 : %2",_unit,_sets]] call cse_fnc_debug; -if ((count _sets) > 0) then { - { - if (!(_x select 4)) then { - _unit setvariable [(_x select 0),nil,_x select 3]; - [format["RESETTING: %1",[(_x select 0),_unit, _x select 1, (_unit getvariable (_x select 0))]]] call cse_fnc_debug; - }; - }foreach _sets; -} else { - ["No defaults have been set"] call cse_fnc_debug; -}; -[[_unit],"resetToDefaults"] call cse_fnc_customEventHandler_F; \ No newline at end of file diff --git a/TO_MERGE/cse/main/misc/functions/fn_revealObject_f.sqf b/TO_MERGE/cse/main/misc/functions/fn_revealObject_f.sqf deleted file mode 100644 index e711fe6c91..0000000000 --- a/TO_MERGE/cse/main/misc/functions/fn_revealObject_f.sqf +++ /dev/null @@ -1,4 +0,0 @@ - -if (hasInterface) then { - player reveal (_this select 0); -}; \ No newline at end of file diff --git a/TO_MERGE/cse/main/misc/functions/fn_setDead.sqf b/TO_MERGE/cse/main/misc/functions/fn_setDead.sqf deleted file mode 100644 index dd85ecea06..0000000000 --- a/TO_MERGE/cse/main/misc/functions/fn_setDead.sqf +++ /dev/null @@ -1,101 +0,0 @@ -/** - * fn_setDead.sqf - * @Descr: Kills a unit - * @Author: Glowbal - * - * @Arguments: [unit OBJECT] - * @Return: void - * @PublicAPI: true - */ - -private ["_unit"]; -_unit = _this select 0; -_force = false; -if (count _this >= 2) then { - _force = _this select 1; -}; - -if (!alive _unit) exitwith{}; -if (!local _unit) exitwith { - [[_unit, _force], "cse_fnc_setDead", _unit, false] spawn BIS_fnc_MP; - diag_log format["WARNING: cse_fnc_setDead triggered on non local unit %1", _unit]; -}; -if (isnil "CSE_ENABLE_REVIVE_F") then { - CSE_ENABLE_REVIVE_F = 0; -}; -_name = _unit getvariable "cse_name"; -if (isnil "_name") then { - _unit setvariable ["cse_name", name _unit, true]; -}; - -if (((CSE_ENABLE_REVIVE_F == 1 && isPlayer _unit) || (CSE_ENABLE_REVIVE_F == 2)) && !_force) then { - [format["CSE_ENABLE_REVIVE_F %1",_unit]] call cse_fnc_debug; - _unit spawn { - private ["_unit","_counter"]; - _unit = _this; - _playerDead = isPlayer _unit; - - if ((_unit getvariable["CSE_ENABLE_REVIVE_SETDEAD_F",0]) > 0) exitwith { - _unit setvariable["CSE_ENABLE_REVIVE_SETDEAD_F",(_unit getvariable["CSE_ENABLE_REVIVE_SETDEAD_F",0]) + 1]; - }; - _unit setvariable["CSE_ENABLE_REVIVE_SETDEAD_F",1]; - [_unit] call cse_fnc_setUnconsciousState; - if (isnil "CSE_REVIVE_TIMER_F") then { - CSE_REVIVE_TIMER_F = 10; - }; - if (isnil "CSE_REVIVE_NUMBER_MAX_F") then { - CSE_REVIVE_NUMBER_MAX_F = -1; - }; - waituntil {([_unit] call cse_fnc_isUnconscious)}; - _counter = 0; - if (alive (vehicle _unit)) then { - _unit setvariable ["cse_inReviveState", true, true]; - while {([_unit] call cse_fnc_isUnconscious)} do { - _counter = _unit getvariable ["CSE_ENABLE_REVIVE_COUNTER",_counter]; - if (_counter > CSE_REVIVE_TIMER_F || (((_unit getvariable["CSE_ENABLE_REVIVE_SETDEAD_F",0]) > CSE_REVIVE_NUMBER_MAX_F) && (CSE_REVIVE_NUMBER_MAX_F > 0))) exitwith{ - if (_counter > CSE_REVIVE_TIMER_F) then { - [format["Timer ran out for %1",_unit]] call cse_fnc_debug; - }; - if (((_unit getvariable["CSE_ENABLE_REVIVE_SETDEAD_F",0]) > CSE_REVIVE_NUMBER_MAX_F) && (CSE_REVIVE_NUMBER_MAX_F > 0)) then { - [format["amount of calls for setDead ran out for %1",_unit]] call cse_fnc_debug; - }; - if (isPlayer _unit) then { - titleText ["You died..","PLAIN DOWN"]; - }; - [format["cse_isDead %1",_unit]] call cse_fnc_debug; - [_unit,"cse_isDead",true,true] call cse_fnc_setVariable; - if (_playerDead) then { - [_unit,"cse_isDeadPlayer",true,true] call cse_fnc_setVariable; - }; - _unit setdamage 1; - [[_unit, true],"killed"] call cse_fnc_customEventHandler_F; - }; - sleep 1; - _unit setvariable ["CSE_ENABLE_REVIVE_COUNTER",_counter + 1]; - _counter = _counter + 1; - }; - _unit setvariable ["cse_inReviveState", nil, true]; - [format["no longer unconscious %1",_unit]] call cse_fnc_debug; - } else { - if (isPlayer _unit) then { - titleText ["You died..","PLAIN DOWN"]; - }; - [_unit,"cse_isDead",true,true] call cse_fnc_setVariable; - _unit setdamage 1; - [[_unit, false],"killed"] call cse_fnc_customEventHandler_F; - }; - }; -} else { - [format["INSTANT KILL %1",_unit]] call cse_fnc_debug; - _unit setvariable ["cse_isUnconscious", true, true]; - if (isPlayer _unit) then { - titleText ["You died..","PLAIN DOWN"]; - }; - if (isPLayer _unit) then { - [_unit,"cse_isDeadPlayer",true,true] call cse_fnc_setVariable; - }; - _unit setdamage 1; - [_unit,"cse_isDead",true,true] call cse_fnc_setVariable; - - [[_unit, false],"killed"] call cse_fnc_customEventHandler_F; -}; \ No newline at end of file diff --git a/TO_MERGE/cse/main/misc/functions/fn_setHearingCapability.sqf b/TO_MERGE/cse/main/misc/functions/fn_setHearingCapability.sqf deleted file mode 100644 index b1e29dc68f..0000000000 --- a/TO_MERGE/cse/main/misc/functions/fn_setHearingCapability.sqf +++ /dev/null @@ -1,53 +0,0 @@ -/** - * fn_setHearingCapability.sqf - * @Descr: Handle set volume calls. Will use the lowest available volume setting. - * @Author: Glowbal - * - * @Arguments: [id STRING, settings NUMBER, add BOOL (Optional. True will add, false will remove. Default value is true)] - * @Return: nil - * @PublicAPI: true - */ - -private ["_id", "_settings", "_add", "_exists", "_map", "_lowestVolume"]; -_id = _this select 0; -_settings = _this select 1; -_add = true; -if (count _this > 2) then { - _add = _this select 2; -}; - -_map = missionNamespace getVariable ["cse_setHearingCapabilityMap",[]]; - -_exists = false; -{ - if (_id == _x select 0) exitWith { - _exists = true; - if (_add) then { - _x set [1, _settings]; - } else { - _map set [_forEachIndex, 0]; - _map = _map - [0]; - }; - }; -} forEach _map; - -if (!_exists && _add) then { - _map pushBack [_id, _settings]; -}; - -missionNamespace setVariable ["cse_setHearingCapabilityMap", _map]; - -// find lowest volume -_lowestVolume = 1; -{ - _lowestVolume = (_x select 1) min _lowestVolume; -} forEach _map; - -// in game sounds -0 fadeSound _lowestVolume; -0 fadeRadio _lowestVolume; -0 fadeMusic _lowestVolume; - -// Set Radio mod variables. -player setVariable ["tf_globalVolume", _lowestVolume]; -player setVariable ["acre_sys_core_globalVolume", _lowestVolume]; diff --git a/TO_MERGE/cse/main/misc/functions/fn_setProne.sqf b/TO_MERGE/cse/main/misc/functions/fn_setProne.sqf deleted file mode 100644 index 0ad2a231eb..0000000000 --- a/TO_MERGE/cse/main/misc/functions/fn_setProne.sqf +++ /dev/null @@ -1,26 +0,0 @@ -/** - * fn_setProne.sqf - * @Descr: Force a unit to go prone - * @Author: Glowbal - * - * @Arguments: [unit OBJECT] - * @Return: void - * @PublicAPI: true - */ - -private ["_unit"]; -_unit = [_this,0, ObjNull,[ObjNull]] call BIS_fnc_Param; -switch (currentWeapon _unit) do { - case (primaryWeapon _unit): { - [_unit,"amovppnemstpsraswrfldnon"] call cse_fnc_localAnim; - }; - case (secondaryWeapon _unit): { - [_unit,"amovppnemstpsraswlnrdnon"] call cse_fnc_localAnim; - }; - case (handgunWeapon _unit): { - [_unit,"AmovPpneMstpSrasWpstDnon"] call cse_fnc_localAnim; - }; - default { - [_unit,"amovppnemstpsnonwnondnon"] call cse_fnc_localAnim; - }; -}; \ No newline at end of file diff --git a/TO_MERGE/cse/main/misc/functions/fn_setVolume_f.sqf b/TO_MERGE/cse/main/misc/functions/fn_setVolume_f.sqf deleted file mode 100644 index 44d4179091..0000000000 --- a/TO_MERGE/cse/main/misc/functions/fn_setVolume_f.sqf +++ /dev/null @@ -1,45 +0,0 @@ -/** - * fn_setVolume_f.sqf - * @Descr: Sets the volume of the game, including third party radio modifications such as TFAR and ACRE. - * @Author: Glowbal - * - * @Arguments: [setVolume BOOL] - * @Return: void - * @PublicAPI: true - */ -#define MUTED_LEVEL 0.2 -#define NORMAL_LEVEL 1 -#define NO_SOUND 0 - -private ["_setVolume"]; -_setVolume = [_this, 0, false, [false]] call BIS_fnc_Param; - -if (_setVolume) then { - // Vanilla Game - 2 fadeSound NORMAL_LEVEL; - - // TFAR - player setVariable ["tf_voiceVolume", NORMAL_LEVEL, true]; - player setVariable ["tf_globalVolume", NORMAL_LEVEL]; - player setVariable ["tf_unable_to_use_radio", false]; - - // ACRE2 - player setVariable ["acre_sys_core_globalVolume", NORMAL_LEVEL]; - player setVariable ["acre_sys_core_isDisabled", false, true]; - -} else { - // Vanilla Game - 2 fadeSound MUTED_LEVEL; - - // TFAR - player setVariable ["tf_voiceVolume", NO_SOUND, true]; - player setVariable ["tf_globalVolume", MUTED_LEVEL]; - player setVariable ["tf_unable_to_use_radio", true]; - - // ACRE2 - player setVariable ["acre_sys_core_globalVolume", MUTED_LEVEL]; - player setVariable ["acre_sys_core_isDisabled", true, true]; - -}; - -[[_setVolume],"setVolume"] call cse_fnc_customEventHandler_F; \ No newline at end of file diff --git a/TO_MERGE/cse/main/misc/functions/fn_switchToGroupSide_f.sqf b/TO_MERGE/cse/main/misc/functions/fn_switchToGroupSide_f.sqf deleted file mode 100644 index 6a28fa473a..0000000000 --- a/TO_MERGE/cse/main/misc/functions/fn_switchToGroupSide_f.sqf +++ /dev/null @@ -1,65 +0,0 @@ -/** - * fn_switchToGroupSide_f.sqf - * @Descr: Stack group switches. Will always trace back to original group. - * @Author: Glowbal - * - * @Arguments: [unit OBJECT, switch BOOL, id STRING, side SIDE] - * @Return: void - * @PublicAPI: true - */ - - -private ["_unit","_side","_previousGroup","_newGroup", "_currentGroup", "_switch", "_originalSide", "_previousGroupsList", "_id"]; -_unit = [_this, 0,ObjNull,[ObjNull]] call BIS_fnc_Param; -_switch = [_this, 1, false,[false]] call BIS_fnc_Param; -_id = [_this, 2, "", [""]] call BIS_fnc_Param; -_side = [_this, 3, side _unit,[west]] call BIS_fnc_Param; - -_previousGroupsList = _unit getvariable ["cse_previous_group_switchTo_f",[]]; -if (_switch) then { - // go forward - _previousGroup = group _unit; - _originalSide = side group _unit; - - if (count units _previousGroup == 1 && _originalSide == _side) exitwith { - [format["Current group has only 1 member and is of same side as switch. Not switching unit %1", _id]] call cse_fnc_debug; - }; - - _newGroup = createGroup _side; - [_unit] joinSilent _newGroup; - - _previousGroupsList pushback [_previousGroup, _originalSide, _id, true]; - _unit setvariable ["cse_previous_group_switchTo_f", _previousGroupsList, true]; -} else { - // go one back - { - if (_id == (_x select 2)) exitwith { - _x set [ 3, false]; - _previousGroupsList set [_foreachIndex, _x]; - [format["found group with ID: %1", _id]] call cse_fnc_debug; - }; - }foreach _previousGroupsList; - reverse _previousGroupsList; - - { - if (_x select 3) exitwith {}; // stop at first id set to true - if !(_x select 3) then { - _currentGroup = group _unit; - if (!isNull (_x select 0)) then { - [_unit] joinSilent (_x select 0); - } else { - _newGroup = createGroup (_x select 1); - [_unit] joinSilent _newGroup; - }; - if (count units _currentGroup == 0) then { - deleteGroup _currentGroup; - }; - _previousGroupsList set [_foreachIndex, ObjNull]; - }; - }foreach _previousGroupsList; - _previousGroupsList = _previousGroupsList - [objNull]; - reverse _previousGroupsList; // we have to reverse again, to ensure the list is in the right order. - _unit setvariable ["cse_previous_group_switchTo_f", _previousGroupsList, true]; -}; - -[[_unit, _switch, _id, _side],"switchToGroupSide"] call cse_fnc_customEventHandler_F; \ No newline at end of file diff --git a/TO_MERGE/cse/main/mods/functions/fn_ALiVE_BUS_Mod.sqf b/TO_MERGE/cse/main/mods/functions/fn_ALiVE_BUS_Mod.sqf deleted file mode 100644 index 7ccf6c5d27..0000000000 --- a/TO_MERGE/cse/main/mods/functions/fn_ALiVE_BUS_Mod.sqf +++ /dev/null @@ -1,16 +0,0 @@ -/** - * fn_ALiVE_BUS_Mod.sqf - * @Descr: N/A - * @Author: Glowbal - * - * @Arguments: [] - * @Return: - * @PublicAPI: false - */ - -private ["_busArguments","_return"]; -_busArguments = [_this, 0, [], [[]]] call BIS_fnc_Param; -if ([] call cse_fnc_isLoaded_ALiVE_Mod) then { - _return = _busArguments call ALiVE_fnc_BUS; -}; -_return \ No newline at end of file diff --git a/TO_MERGE/cse/main/mods/functions/fn_isLoaded_ALiVE_Mod.sqf b/TO_MERGE/cse/main/mods/functions/fn_isLoaded_ALiVE_Mod.sqf deleted file mode 100644 index 12a37391ae..0000000000 --- a/TO_MERGE/cse/main/mods/functions/fn_isLoaded_ALiVE_Mod.sqf +++ /dev/null @@ -1,12 +0,0 @@ -/** - * fn_isLoaded_ALiVE_Mod.sqf - * Descr: Check if the ALiVE Modification is loaded - * Author: Glowbal - * - * Arguments: [] - * Return: BOOL true if ALiVE is loaded - * PublicAPI: true - */ - - -(["ALIVE_main"] call cse_fnc_isModLoaded_f) \ No newline at end of file diff --git a/TO_MERGE/cse/main/mods/functions/fn_isModLoaded_f.sqf b/TO_MERGE/cse/main/mods/functions/fn_isModLoaded_f.sqf deleted file mode 100644 index 3be56bff11..0000000000 --- a/TO_MERGE/cse/main/mods/functions/fn_isModLoaded_f.sqf +++ /dev/null @@ -1,14 +0,0 @@ -/** - * fn_isModLoaded_f.sqf - * Descr: Check in cfgPatches if modification is loaded - * Author: Glowbal - * - * Arguments: [modName STRING (Classname of the mod in cfgPatches)] - * Return: BOOL true if modification is loaded - * PublicAPI: true - */ - -private ["_modName"]; -_modName = [_this, 0, "",[""]] call BIS_fnc_Param; - -(isClass (configFile >> "cfgPatches" >> _modName)) \ No newline at end of file diff --git a/TO_MERGE/cse/main/mutex/functions/fn_createMutex.sqf b/TO_MERGE/cse/main/mutex/functions/fn_createMutex.sqf deleted file mode 100644 index 895687082f..0000000000 --- a/TO_MERGE/cse/main/mutex/functions/fn_createMutex.sqf +++ /dev/null @@ -1,24 +0,0 @@ -/** - * fn_createMutex.sqf - * @Descr: Create a Mutex - * @Author: Glowbal - * - * @Arguments: [mutexName STRING, intialStatus BOOL (True if initial status is locked)] - * @Return: BOOL True if mutex has been created. - * @PublicAPI: true - */ - -private ["_mutexName","_initalStatus","_return"]; -_mutexName = [_this, 0, "", [""]] call BIS_fnc_param; -_initalStatus = [_this, 1, false, [false]] call BIS_fnc_param; -_return = false; -if (_mutexName != "") then { - private["_mutexCombinedName"]; - _mutexCombinedName = format["CSE_FRAMEWORK_MUTEX_%1",_mutexName]; - if (isnil _mutexCombinedName) then { - missionNamespace setvariable [_mutexCombinedName, _initalStatus]; - _return = true; - }; -}; - -_return \ No newline at end of file diff --git a/TO_MERGE/cse/main/mutex/functions/fn_lockMutex.sqf b/TO_MERGE/cse/main/mutex/functions/fn_lockMutex.sqf deleted file mode 100644 index 536176bcba..0000000000 --- a/TO_MERGE/cse/main/mutex/functions/fn_lockMutex.sqf +++ /dev/null @@ -1,24 +0,0 @@ -/** - * fn_lockMutex.sqf - * @Descr: Lock a mutex. If mutex exists and is locked, will wait until mutex becomes free, before locking it again. - * @Author: Glowbal - * - * @Arguments: [mutexName STRING] - * @Return: BOOL True if succesfullly locked. - * @PublicAPI: true - */ - -private ["_mutexName","_initalStatus","_return"]; -_mutexName = [_this, 0, "", [""]] call BIS_fnc_param; - -_return = false; -if (_mutexName != "")then { - private["_mutexCombinedName"]; - _mutexCombinedName = format["CSE_FRAMEWORK_MUTEX_%1",_mutexName]; - if !(isnil _mutexCombinedName) then { - [_mutexName] call cse_fnc_waitForSingleMutex; - missionNamespace setvariable [_mutexCombinedName, 1]; - _return = true; - }; -}; -_return \ No newline at end of file diff --git a/TO_MERGE/cse/main/mutex/functions/fn_releaseMutex.sqf b/TO_MERGE/cse/main/mutex/functions/fn_releaseMutex.sqf deleted file mode 100644 index 8e29633dc5..0000000000 --- a/TO_MERGE/cse/main/mutex/functions/fn_releaseMutex.sqf +++ /dev/null @@ -1,24 +0,0 @@ -/** - * fn_releaseMutex.sqf - * @Descr: Releases or unlocks a mutex. - * @Author: Glowbal - * - * @Arguments: [mutexName STRING] - * @Return: True if succesfully unlocked or mutex was never locked. - * @PublicAPI: true - */ - - -private ["_mutexName","_initalStatus","_return"]; -_mutexName = [_this, 0, "", [""]] call BIS_fnc_param; - -_return = false; -if (_mutexName != "")then { - private["_mutexCombinedName"]; - _mutexCombinedName = format["CSE_FRAMEWORK_MUTEX_%1",_mutexName]; - if !(isnil _mutexCombinedName) then { - missionNamespace setvariable [_mutexCombinedName, 0]; - _return = true; - }; -}; -_return \ No newline at end of file diff --git a/TO_MERGE/cse/main/mutex/functions/fn_waitForMultipleMutex.sqf b/TO_MERGE/cse/main/mutex/functions/fn_waitForMultipleMutex.sqf deleted file mode 100644 index 4e626cc6c1..0000000000 --- a/TO_MERGE/cse/main/mutex/functions/fn_waitForMultipleMutex.sqf +++ /dev/null @@ -1,18 +0,0 @@ -/** - * fn_waitForMultipleMutex.sqf - * @Descr: N/A - * @Author: Glowbal - * - * @Arguments: [] - * @Return: - * @PublicAPI: false - */ - - -private ["_mutexes"]; -_mutexes = _this; -{ - if (typeName _x == typeName "") then { - [_x, -1] call cse_fnc_waitForSingleMutex; - }; -}foreach _mutexes; \ No newline at end of file diff --git a/TO_MERGE/cse/main/mutex/functions/fn_waitForSingleMutex.sqf b/TO_MERGE/cse/main/mutex/functions/fn_waitForSingleMutex.sqf deleted file mode 100644 index 5d04a60968..0000000000 --- a/TO_MERGE/cse/main/mutex/functions/fn_waitForSingleMutex.sqf +++ /dev/null @@ -1,28 +0,0 @@ -/** - * fn_waitForSingleMutex.sqf - * @Descr: N/A - * @Author: Glowbal - * - * @Arguments: [] - * @Return: - * @PublicAPI: false - */ - - -private ["_mutexName","_timeout","_return"]; -_mutexName = [_this, 0, "", [""]] call BIS_fnc_param; -if (count _this > 1) then { - _timeout = [_this, 1, -1, [-1]] call BIS_fnc_param; -}; - -_return = false; -if (_mutexName != "") then { - private["_mutexCombinedName"]; - _mutexCombinedName = format["CSE_FRAMEWORK_MUTEX_%1",_mutexName]; - if !(isnil _mutexCombinedName) then { - _startTime = time; - waituntil {((missionNamespace getvariable [_mutexCombinedName, 0]) == 0) || ((time - _startTime > (_timeout*accTime)) && _timeout > 0)}; - _return = (missionNamespace getvariable [_mutexCombinedName, 0]) == 0; - }; -}; -_return \ No newline at end of file diff --git a/TO_MERGE/cse/main/ragdoll/functions/fn_ragdoll_f.sqf b/TO_MERGE/cse/main/ragdoll/functions/fn_ragdoll_f.sqf deleted file mode 100644 index 2e2710509b..0000000000 --- a/TO_MERGE/cse/main/ragdoll/functions/fn_ragdoll_f.sqf +++ /dev/null @@ -1,11 +0,0 @@ -/** - * fn_ragdoll_f.sqf - * @Descr: N/A - * @Author: Glowbal - * - * @Arguments: [] - * @Return: - * @PublicAPI: false - */ - -// Deleted. \ No newline at end of file diff --git a/TO_MERGE/cse/main/requests/functions/fn_onAnswerRequest.sqf b/TO_MERGE/cse/main/requests/functions/fn_onAnswerRequest.sqf deleted file mode 100644 index 8f2420f7ba..0000000000 --- a/TO_MERGE/cse/main/requests/functions/fn_onAnswerRequest.sqf +++ /dev/null @@ -1,37 +0,0 @@ -/** - * fn_onAnswerRequest.sqf - * @Descr: N/A - * @Author: Glowbal - * - * @Arguments: [] - * @Return: - * @PublicAPI: false - */ - -private ["_unit","_requestID", "_id", "_accepted", "_info", "_callBack", "_caller", "_replyParams", "_requestMessage", "_target"]; -_unit = _this select 0; -_id = _this select 1; -_accepted = _this select 2; - -_info = _unit getvariable _id; -if (!isnil "_info") then { - _caller = _info select 0; - _target = _info select 1; - _requestID = _info select 2; - _requestMessage = _info select 3; - _callBack = _info select 4; - _replyParams = [_info, _accepted]; - [_replyParams, "cse_fnc_requestCallback", _caller, false] spawn BIS_fnc_MP; - _unit setvariable [_id, nil]; -}; - -CSE_RECIEVE_REQUEST_ID_KEY_BINDING = nil; - -if (!isnil "CSE_RECIEVE_REQUEST_ADD_ACTION_ACCEPT") then { - _unit removeAction CSE_RECIEVE_REQUEST_ADD_ACTION_ACCEPT; - CSE_RECIEVE_REQUEST_ADD_ACTION_ACCEPT = nil; -}; -if (!isnil "CSE_RECIEVE_REQUEST_ADD_ACTION_DECLINE") then { - _unit removeAction CSE_RECIEVE_REQUEST_ADD_ACTION_DECLINE; - CSE_RECIEVE_REQUEST_ADD_ACTION_DECLINE = nil; -}; diff --git a/TO_MERGE/cse/main/requests/functions/fn_receiveRequest.sqf b/TO_MERGE/cse/main/requests/functions/fn_receiveRequest.sqf deleted file mode 100644 index 8e1502edc1..0000000000 --- a/TO_MERGE/cse/main/requests/functions/fn_receiveRequest.sqf +++ /dev/null @@ -1,67 +0,0 @@ -/** - * fn_recieveRequest.sqf - * @Descr: N/A - * @Author: Glowbal - * - * @Arguments: [] - * @Return: - * @PublicAPI: false - */ - -private ["_caller", "_target", "_requestID", "_requestMessage", "_callBack"]; -_caller = _this select 0; -_target = _this select 1; -_requestID = _this select 2; -_requestMessage = _this select 3; -_callBack = _this select 4; - -_requestID = ("cse_fnc_recieveRequest_f"+_requestID); - -_target setvariable [_requestID, _this]; - -if (isLocalized _requestMessage) then { - _requestMessage = format[localize _requestMessage,[_caller] call cse_fnc_getName]; -} else { - _requestMessage = format[_requestMessage,[_caller] call cse_fnc_getName]; -}; - -hint format["%1",_requestMessage]; -if !(isnil "CSE_RECIEVE_REQUEST_TIME_OUT_SCRIPT") then { - terminate CSE_RECIEVE_REQUEST_TIME_OUT_SCRIPT; -}; - -if (!isnil "CSE_RECIEVE_REQUEST_ADD_ACTION_ACCEPT") then { - _target removeAction CSE_RECIEVE_REQUEST_ADD_ACTION_ACCEPT; - CSE_RECIEVE_REQUEST_ADD_ACTION_ACCEPT = nil; -}; -if (!isnil "CSE_RECIEVE_REQUEST_ADD_ACTION_DECLINE") then { - _target removeAction CSE_RECIEVE_REQUEST_ADD_ACTION_DECLINE; - CSE_RECIEVE_REQUEST_ADD_ACTION_DECLINE = nil; -}; - -CSE_RECIEVE_REQUEST_ADD_ACTION_ACCEPT = _target addAction ["Accept", compile format["[player,'%1', true] call cse_fnc_onAnswerRequest;", _requestID]]; -CSE_RECIEVE_REQUEST_ADD_ACTION_DECLINE = _target addAction ["Decline", compile format["[player,'%1', false] call cse_fnc_onAnswerRequest;", _requestID]]; - -CSE_RECIEVE_REQUEST_ID_KEY_BINDING = _requestID; - -CSE_RECIEVE_REQUEST_TIME_OUT_SCRIPT = [time, _target, _requestID] spawn { - _t = (_this select 0) + 40; - _target = _this select 1; - _requestID = _this select 2; - _id = _target getvariable _requestID; - waituntil { - _id = _target getvariable _requestID; - - (time > _t || isnil "_id")}; - _target setvariable [_requestID, nil]; - CSE_RECIEVE_REQUEST_ID_KEY_BINDING = nil; - if (!isnil "CSE_RECIEVE_REQUEST_ADD_ACTION_ACCEPT") then { - _target removeAction CSE_RECIEVE_REQUEST_ADD_ACTION_ACCEPT; - CSE_RECIEVE_REQUEST_ADD_ACTION_ACCEPT = nil; - }; - if (!isnil "CSE_RECIEVE_REQUEST_ADD_ACTION_DECLINE") then { - _target removeAction CSE_RECIEVE_REQUEST_ADD_ACTION_DECLINE; - CSE_RECIEVE_REQUEST_ADD_ACTION_DECLINE = nil; - }; - -}; \ No newline at end of file diff --git a/TO_MERGE/cse/main/requests/functions/fn_requestCallback.sqf b/TO_MERGE/cse/main/requests/functions/fn_requestCallback.sqf deleted file mode 100644 index 1896f8b3dc..0000000000 --- a/TO_MERGE/cse/main/requests/functions/fn_requestCallback.sqf +++ /dev/null @@ -1,21 +0,0 @@ -/** - * fn_requestCallback.sqf - * @Descr: N/A - * @Author: Glowbal - * - * @Arguments: [] - * @Return: - * @PublicAPI: false - */ - -private ["_info", "_accepted", "_caller", "_target", "_requestID", "_requestMessage", "_callBack"]; -_info = _this select 0; -_accepted = _this select 1; - -_caller = _info select 0; -_target = _info select 1; -_requestID = _info select 2; -_requestMessage = _info select 3; -_callBack = _info select 4; - -[_caller, _target, _accepted] call compile _callBack; \ No newline at end of file diff --git a/TO_MERGE/cse/main/requests/functions/fn_sendRequest_f.sqf b/TO_MERGE/cse/main/requests/functions/fn_sendRequest_f.sqf deleted file mode 100644 index 2ba9cbc9f1..0000000000 --- a/TO_MERGE/cse/main/requests/functions/fn_sendRequest_f.sqf +++ /dev/null @@ -1,26 +0,0 @@ -/** - * fn_sendRequest_f.sqf - * @Descr: Send a request to an unit and execute code based upon results. - * @Author: Glowbal - * - * @Arguments: [caller OBJECT, target OBJECT, requestID STRING, requestMessage STRING (Will be localized for other target object), callback CODE (Code called upon accept or decline.)] - * @Return: void - * @PublicAPI: true - */ - -private ["_caller", "_target", "_requestMessage", "_requestID", "_callBack"]; -_caller = _this select 0; -_target = _this select 1; -_requestID = _this select 2; -_requestMessage = _this select 3; -_callBack = _this select 4; - -if (isPlayer _target) then { - // Pass request on to target locality for player accept/decline. - [[_caller, _target, _requestID, _requestMessage, _callBack], "cse_fnc_receiveRequest", _target, false] spawn BIS_fnc_MP; -} else { - // accept it, since it's an AI. - [_caller, _target, true] spawn compile _callBack; -}; - -// [player, player, "myRequestTest", "Hello %1, how are you?", "hint 'it worked!';"] call cse_fnc_sendRequest_f; \ No newline at end of file diff --git a/TO_MERGE/cse/main/strings/functions/fn_stringCompare.sqf b/TO_MERGE/cse/main/strings/functions/fn_stringCompare.sqf deleted file mode 100644 index 75ae1ff3b7..0000000000 --- a/TO_MERGE/cse/main/strings/functions/fn_stringCompare.sqf +++ /dev/null @@ -1,33 +0,0 @@ -/** - * fn_stringCompare.sqf - * @Descr: Determines whether one string matches another and how many characters match. Case insensitive. - * @Author: bovine3dom - * - * @Arguments: [stringA STRING, stringB STRING] - * @Return: NUMBER Number of matching characters - * @PublicAPI: true - */ - -private ["_searchTerm", "_string", "_arraySearchTerm", "_arrayString", "_sizeSearchTerm", "_sizeString", "_matchingCharacters", "_searchIterator", "_targetIterator"]; -_string = toLower (_this select 0); // removes case sensitivity -_searchTerm = toLower (_this select 1); - - -_arraySearchTerm = toArray _searchTerm; // splits string into array of unicode decimals -_arrayString = toArray _string; -_sizeSearchTerm = count _arraySearchTerm; // We only measure the array once -_sizeString = count _arrayString; - - -_matchingCharacters = 0; -_targetIterator = 0; -_searchIterator = 0; -while {(_searchIterator < _sizeSearchTerm) && (_targetIterator < _sizeString)} do { // Prevents us from going out of bounds - if ((_arraySearchTerm select _searchIterator) == (_arrayString select _targetIterator)) then { // If we have a match, start looking for the next character in the search term - _matchingCharacters = _matchingCharacters + 1; - _searchIterator = _searchIterator + 1 - }; - _targetIterator = _targetIterator + 1; // Look at the next character in the string -}; - -_matchingCharacters \ No newline at end of file diff --git a/TO_MERGE/cse/main/strings/functions/fn_string_removeWhiteSpace.sqf b/TO_MERGE/cse/main/strings/functions/fn_string_removeWhiteSpace.sqf deleted file mode 100644 index b17a582697..0000000000 --- a/TO_MERGE/cse/main/strings/functions/fn_string_removeWhiteSpace.sqf +++ /dev/null @@ -1,19 +0,0 @@ -/** - * fn_stringTrim.sqf - * @Descr: Removes white spaces from string - * @Author: Glowbal - * - * @Arguments: [string STRING] - * @Return: STRING copy of string - * @PublicAPI: true - */ - -#define WHITE_SPACE [20] - -private ["_string", "_charArray", "_returnString"]; -_string = [_this, 0, "",[""]] call bis_fnc_param; -_charArray = toArray _string; -_charArray = _charArray - [((toArray " ") select 0)]; -_returnString = toString _charArray; - -_returnString; \ No newline at end of file diff --git a/TO_MERGE/cse/main/stringtable.xml b/TO_MERGE/cse/main/stringtable.xml deleted file mode 100644 index a0493c1ae5..0000000000 --- a/TO_MERGE/cse/main/stringtable.xml +++ /dev/null @@ -1,27 +0,0 @@ - - - - - - Accept Requests - Akceptuj prośby - Aceptar Peticiones - - - Decline Requests - Ignoruj prośby - Rechazar Peticiones - - - Accept Requests send by other players. These can be requests to use / share equipment, perform certain actions. - Akceptuj prośby wysłane przez innych graczy. Akceptacji wymagają między innymi akcje używania / współdzielenia wyposażenia, wykonywania określonych czynności. - Acepta Peticiones de otros jugadores. Pueden ser solicitudes para usar / compartir equipamiento, realizar ciertas acciones. - - - Decline Requests send by other players. These can be requests to use / share equipment, perform certain actions. - Ignoruj prośby wysłane przez innych graczy. Akceptacji wymagają między innymi akcje używania / współdzielenia wyposażenia, wykonywania określonych czynności. - Rechazar Peticiones de otros jugadores. Pueden ser solicitudes para usar / compartir equipamiento, realizar ciertas acciones. - - - - diff --git a/TO_MERGE/cse/main/tasks/functions/fn_addTaskToPool_f.sqf b/TO_MERGE/cse/main/tasks/functions/fn_addTaskToPool_f.sqf deleted file mode 100644 index d9d9776bed..0000000000 --- a/TO_MERGE/cse/main/tasks/functions/fn_addTaskToPool_f.sqf +++ /dev/null @@ -1,22 +0,0 @@ -/** - * fn_addTaskToPool_f.sqf - * @Descr: N/A - * @Author: Glowbal - * - * @Arguments: [id STRING, args ARRAY, code COE] - * @Return: nil; - * @PublicAPI: false - */ - -private ["_id", "_args","_code"]; -_id = _this select 0; -_args = _this select 1; -_code = [_this, 2, {}, [{}]] call BIS_fnc_Param; - -if (isnil "CSE_TASK_POOL_COLLECTION_F") then { - CSE_TASK_POOL_COLLECTION_F = []; -}; -CSE_TASK_POOL_COLLECTION_F pushback [_id, _args, _code ]; - -[format["Added task to task pool: %1", CSE_TASK_POOL_COLLECTION_F]] call cse_fnc_debug; -[[_id, _args, _code],"AddedTotaskPool"] call cse_fnc_customEventHandler_F; \ No newline at end of file diff --git a/TO_MERGE/cse/main/tasks/functions/fn_loopThroughPool_f.sqf b/TO_MERGE/cse/main/tasks/functions/fn_loopThroughPool_f.sqf deleted file mode 100644 index 5a44c14bdb..0000000000 --- a/TO_MERGE/cse/main/tasks/functions/fn_loopThroughPool_f.sqf +++ /dev/null @@ -1,17 +0,0 @@ -/** - * fn_loopThroughPool_f.sqf - * @Descr: - * @Author: Glowbal - * - * @Arguments: [] - * @Return: - * @PublicAPI: false - */ - -#define TASK_PARAMETERS (_x select 1) -#define TASK_CODE (_x select 2) - -{ - TASK_PARAMETERS call TASK_CODE; - false; -}count CSE_TASK_POOL_COLLECTION_F; diff --git a/TO_MERGE/cse/main/tasks/functions/fn_removeTaskFromPool_f.sqf b/TO_MERGE/cse/main/tasks/functions/fn_removeTaskFromPool_f.sqf deleted file mode 100644 index 0699208043..0000000000 --- a/TO_MERGE/cse/main/tasks/functions/fn_removeTaskFromPool_f.sqf +++ /dev/null @@ -1,25 +0,0 @@ -/** - * fn_removeTaskFromPool_f.sqf - * @Descr: Remove a task from the task pool. - * @Author: Glowbal - * - * @Arguments: [id STRING] - * @Return: nil - * @PublicAPI: true - */ - -private ["_id", "_index"]; -_id = _this select 0; -_index = -1; - -if (isnil "CSE_TASK_POOL_COLLECTION_F") exitwith {nil}; - -{ - if ((_x select 0) == _id) exitwith { - _index = _foreachIndex; - CSE_TASK_POOL_COLLECTION_F set [ _foreachIndex, objNull]; - }; -}foreach CSE_TASK_POOL_COLLECTION_F; -CSE_TASK_POOL_COLLECTION_F = CSE_TASK_POOL_COLLECTION_F - [objNull]; - -nil; \ No newline at end of file diff --git a/TO_MERGE/cse/main/variables/functions/fn_defineVariable.sqf b/TO_MERGE/cse/main/variables/functions/fn_defineVariable.sqf deleted file mode 100644 index da83e326fc..0000000000 --- a/TO_MERGE/cse/main/variables/functions/fn_defineVariable.sqf +++ /dev/null @@ -1,39 +0,0 @@ -/** - * fn_defineVariable.sqf - * @Descr: Define a variable for the CSE variable framework - * @Author: Glowbal - * - * @Arguments: [name STRING, defaultValue ANY, publicFlag BOOL, category STRING, type NUMBER, persistentFlag BOOL] - * @Return: - * @PublicAPI: true - */ - -private ["_name","_value","_defaultGlobal","_catagory","_code","_persistent"]; -_name = _this select 0; -_value = _this select 1; -_defaultGlobal = _this select 2; -_catagory = _this select 3; -_code = 0; -_persistent = false; - -if (count _this < 3) exitwith {}; -if (count _this > 4) then { - _code = _this select 4; - if (count _this > 5) then { - _persistent = _this select 5; - }; -}; - -if (typeName _name != typeName "") then { - throw "IllegalArgument"; -}; - -if (isnil 'CSE_OBJECT_VARIABLES_STORAGE') then { - CSE_OBJECT_VARIABLES_STORAGE = []; -}; - -CSE_OBJECT_VARIABLES_STORAGE pushback [_name,_value,_defaultGlobal,_catagory,_code, _persistent]; - -missionNamespace setvariable ["cse_object_variables_storage_" + _name, [_name,_value,_defaultGlobal,_catagory,_code, _persistent]]; - -[[_name,_value,_defaultGlobal,_catagory,_code, _persistent],"variableDefined"] call cse_fnc_customEventHandler_F; \ No newline at end of file diff --git a/TO_MERGE/cse/main/variables/functions/fn_getAllSetVariables.sqf b/TO_MERGE/cse/main/variables/functions/fn_getAllSetVariables.sqf deleted file mode 100644 index 52ffe02a36..0000000000 --- a/TO_MERGE/cse/main/variables/functions/fn_getAllSetVariables.sqf +++ /dev/null @@ -1,27 +0,0 @@ -/** - * fn_getAllSetVariables.sqf - * @Descr: Returns an 2d array of all variables that have been set on the object - * @Author: Glowbal - * - * @Arguments: [unit OBJECT, category STRING (Optional. Only get the variables from the specified category. Default is "" == all)] - * @Return: ARRAY REturns an array with the format [ [name STRING, typeName STRING, value ANY, publicFlag BOOL, peristentFlag BOOL] ] - * @PublicAPI: true - */ - -private ["_object", "_return", "_val", "_category"]; -_object = _this select 0; -_category = if (count _this > 1) then { _this select 1 } else { "" }; - -if (isnil 'CSE_OBJECT_VARIABLES_STORAGE') then { - CSE_OBJECT_VARIABLES_STORAGE = []; -}; -_return = []; -{ - _val = _object getvariable (_x select 0); - if (!isnil "_val") then { - if (_category == "" || _category == _x select 3) then { - _return pushback [_x select 0, typeName _val, _val, _x select 2, _x select 5]; - }; - }; -}foreach CSE_OBJECT_VARIABLES_STORAGE; -_return \ No newline at end of file diff --git a/TO_MERGE/cse/main/variables/functions/fn_getVariable.sqf b/TO_MERGE/cse/main/variables/functions/fn_getVariable.sqf deleted file mode 100644 index 84f37c9387..0000000000 --- a/TO_MERGE/cse/main/variables/functions/fn_getVariable.sqf +++ /dev/null @@ -1,31 +0,0 @@ -/** - * fn_getVariable.sqf - * @Descr: Grabs a variable. If variable has not been set, attempts to use default defined value - * @Author: Glowbal - * - * @Arguments: [unit OBJECT, variableName STRING] - * @Return: ANY - * @PublicAPI: true - */ - -#define UNIT (_this select 0) -#define VARIABLE (_this select 1) - -private "_value"; - -_value = UNIT getvariable VARIABLE; -if (isnil "_value") then { - if (count _this >2) then { - _value = _this select 2; - } else { - private "_definedVariable"; - _definedVariable = ([VARIABLE] call cse_fnc_getVariableInfo); - if (count _definedVariable > 1) then { - _value = _definedVariable select 1; - }; - }; - if (isnil "_value") then { - _value = 0; - }; -}; -_value \ No newline at end of file diff --git a/TO_MERGE/cse/main/variables/functions/fn_getvariableDefault.sqf b/TO_MERGE/cse/main/variables/functions/fn_getvariableDefault.sqf deleted file mode 100644 index f187f3b05a..0000000000 --- a/TO_MERGE/cse/main/variables/functions/fn_getvariableDefault.sqf +++ /dev/null @@ -1,18 +0,0 @@ -/** - * fn_getvariableDefault.sqf - * @Descr: Get the variable default value - * @Author: Glowbal - * - * @Arguments: [variableName STRING] - * @Return: ANY - * @PublicAPI: true - */ - -private ["_name","_return"]; -_name = _this select 0; -_variableDefinition = ([_name] call cse_fnc_getVariableInfo); -if (count _variableDefinition > 0) then { - _return = _variableDefinition select 1; -}; - -_return \ No newline at end of file diff --git a/TO_MERGE/cse/main/variables/functions/fn_getvariableInfo.sqf b/TO_MERGE/cse/main/variables/functions/fn_getvariableInfo.sqf deleted file mode 100644 index 0909925f17..0000000000 --- a/TO_MERGE/cse/main/variables/functions/fn_getvariableInfo.sqf +++ /dev/null @@ -1,11 +0,0 @@ -/** - * fn_getvariableInfo.sqf - * @Descr: N/A - * @Author: Glowbal - * - * @Arguments: [] - * @Return: - * @PublicAPI: false - */ - -+(missionNamespace getvariable ["cse_object_variables_storage_" + (_this select 0),[]]) \ No newline at end of file diff --git a/TO_MERGE/cse/main/variables/functions/fn_setVariable.sqf b/TO_MERGE/cse/main/variables/functions/fn_setVariable.sqf deleted file mode 100644 index e2119fcb37..0000000000 --- a/TO_MERGE/cse/main/variables/functions/fn_setVariable.sqf +++ /dev/null @@ -1,29 +0,0 @@ -/** - * fn_setVariable.sqf - * @Descr: Setvariable value - * @Author: Glowbal - * - * @Arguments: [unit OBJECT, variableName STRING, value ANY] - * @Return: void - * @PublicAPI: true - */ - -private ["_unit","_variable","_value","_update","_global","_definedVariable","_defaultGlobal","_currentValue"]; -_unit = _this select 0; -_variable = _this select 1; -_value = _this select 2; -_global = false; - -if (count _this > 3) then { - _global = _this select 3; -} else { - _definedVariable = ([_variable] call cse_fnc_getVariableInfo); - if (count _definedVariable > 2) then { - _global = _definedVariable select 2; - }; -}; - -if (!isNil "_value") exitwith { - _unit setvariable [_variable, _value, _global]; -}; -_unit setvariable [_variable, nil, _global]; \ No newline at end of file diff --git a/TO_MERGE/cse/main/version/functions/fn_getVersion.sqf b/TO_MERGE/cse/main/version/functions/fn_getVersion.sqf deleted file mode 100644 index c3953426f0..0000000000 --- a/TO_MERGE/cse/main/version/functions/fn_getVersion.sqf +++ /dev/null @@ -1,11 +0,0 @@ -/** - * fn_getVersion.sqf - * @Descr: Get the version number of the current CSE Build - * @Author: Glowbal - * - * @Arguments: [] - * @Return: STRING String containing the version - * @PublicAPI: true - */ - -getText (configFile >> "cfgPatches" >> "cse_main" >> "version"); \ No newline at end of file diff --git a/addons/common/XEH_postInit.sqf b/addons/common/XEH_postInit.sqf index 91c586c43d..6cabbcd3bf 100644 --- a/addons/common/XEH_postInit.sqf +++ b/addons/common/XEH_postInit.sqf @@ -1,6 +1,16 @@ // ACE - Common #include "script_component.hpp" +// hack to get PFH to work in briefing +[QGVAR(onBriefingPFH), "onEachFrame", { + if (time > 0) exitWith { + [QGVAR(onBriefingPFH), "onEachFrame"] call BIS_fnc_removeStackedEventHandler; + }; + + call cba_common_fnc_onFrame; +}] call BIS_fnc_addStackedEventHandler; +///// + QGVAR(remoteFnc) addPublicVariableEventHandler { (_this select 1) call FUNC(execRemoteFnc); }; diff --git a/addons/fcs/XEH_preInit.sqf b/addons/fcs/XEH_preInit.sqf index ce6f5c99dd..18729ca54f 100644 --- a/addons/fcs/XEH_preInit.sqf +++ b/addons/fcs/XEH_preInit.sqf @@ -1,5 +1,7 @@ #include "script_component.hpp" +ADDON = false; + PREP(adjustRange); PREP(canResetFCS); PREP(canUseFCS); @@ -11,3 +13,5 @@ PREP(keyDown); PREP(keyUp); PREP(reset); PREP(vehicleInit); + +ADDON = true; diff --git a/addons/goggles/$PBOPREFIX$ b/addons/goggles/$PBOPREFIX$ new file mode 100644 index 0000000000..877aa261c5 --- /dev/null +++ b/addons/goggles/$PBOPREFIX$ @@ -0,0 +1 @@ +z\ace\addons\goggles diff --git a/addons/goggles/CfgEventHandlers.hpp b/addons/goggles/CfgEventHandlers.hpp new file mode 100644 index 0000000000..8c7edda20f --- /dev/null +++ b/addons/goggles/CfgEventHandlers.hpp @@ -0,0 +1,10 @@ +class Extended_PreInit_EventHandlers { + class ADDON { + init = QUOTE(call COMPILE_FILE(XEH_preInit)); + }; +}; +class Extended_PostInit_EventHandlers { + class ADDON { + init = QUOTE(call COMPILE_FILE(XEH_postInit)); + }; +}; diff --git a/TO_MERGE/agm/Goggles/RscTitles.hpp b/addons/goggles/RscTitles.hpp similarity index 50% rename from TO_MERGE/agm/Goggles/RscTitles.hpp rename to addons/goggles/RscTitles.hpp index 15a83a71ce..57975e052f 100644 --- a/TO_MERGE/agm/Goggles/RscTitles.hpp +++ b/addons/goggles/RscTitles.hpp @@ -1,21 +1,21 @@ class RscTitles{ #include "define.hpp" - class RscAGM_Goggles_BaseTitle{ + class RscACE_Goggles_BaseTitle{ idd = -1; - onLoad = "uiNamespace setVariable ['AGM_Goggles_Display', _this select 0]"; - onUnload = "uiNamespace setVariable ['AGM_Goggles_Display', displayNull]"; + onLoad = "uiNamespace setVariable ['ACE_Goggles_Display', _this select 0]"; + onUnload = "uiNamespace setVariable ['ACE_Goggles_Display', displayNull]"; fadeIn=0.5; fadeOut=0.5; movingEnable = false; duration = 10e10; - name = "RscAGM_Goggles_BaseTitle"; + name = "RscACE_Goggles_BaseTitle"; class controls; }; - class RscAGM_Goggles:RscAGM_Goggles_BaseTitle{ + class RscACE_Goggles:RscACE_Goggles_BaseTitle{ idd = 1044; - name = "RscAGM_Goggles"; + name = "RscACE_Goggles"; class controls{ class gogglesImage: RscPicture{ idc = 10650; @@ -23,11 +23,11 @@ class RscTitles{ }; }; - class RscAGM_GogglesEffects:RscAGM_Goggles_BaseTitle{ + class RscACE_GogglesEffects:RscACE_Goggles_BaseTitle{ idd = 1045; - onLoad = "uiNamespace setVariable ['AGM_Goggles_DisplayEffects', _this select 0]"; - onUnload = "uiNamespace setVariable ['AGM_Goggles_DisplayEffects', displayNull]"; - name = "RscAGM_GogglesEffects"; + onLoad = "uiNamespace setVariable ['ACE_Goggles_DisplayEffects', _this select 0]"; + onUnload = "uiNamespace setVariable ['ACE_Goggles_DisplayEffects', displayNull]"; + name = "RscACE_GogglesEffects"; fadeIn=0; fadeOut=0.5; class controls{ diff --git a/addons/goggles/XEH_postInit.sqf b/addons/goggles/XEH_postInit.sqf new file mode 100644 index 0000000000..a7c40bb4b5 --- /dev/null +++ b/addons/goggles/XEH_postInit.sqf @@ -0,0 +1,125 @@ +/* + Name: XEH_postInit.sqf + + Author: Garth de Wet (LH) + + Description: + Sets up the glasses mod for usage. Initialises variables and event handlers. + Shouldn't be called by a user/modder ever. Done by the engine. + + Parameters: + Nothing + + Returns: + Nothing +*/ +#include "script_component.hpp" +if (!hasInterface) exitWith {}; + +["ACE3", localize "STR_ACE_Goggles_WipeGlasses", +{ + if (!(GETVAR(ace_player,ACE_isUnconscious,false))) exitWith { + call FUNC(clearGlasses); + true + }; + false +}, [20, true, true, false], false, "keydown"] call CALLSTACK(cba_fnc_registerKeybind); + +if isNil(QGVAR(UsePP)) then { + GVAR(UsePP) = true; +}; + +GVAR(PostProcess) = ppEffectCreate ["ColorCorrections", 1995]; +GVAR(PostProcessEyes) = ppEffectCreate ["ColorCorrections", 1992]; +GVAR(PostProcessEyes) ppEffectAdjust[1, 1, 0, [0,0,0,0], [0,0,0,1],[1,1,1,0]]; +GVAR(PostProcessEyes) ppEffectCommit 0; +GVAR(PostProcessEyes) ppEffectEnable false; +GVAR(EffectsActive) = false; +SETGLASSES(ace_player,GLASSESDEFAULT); +GVAR(Current) = "None"; +GVAR(EyesDamageScript) = -1; +GVAR(FrameEvent) = [false, [false,20]]; +GVAR(PostProcessEyes_Enabled) = false; +GVAR(DustHandler) = -1; +GVAR(RainDrops) = objNull; +GVAR(RainActive) = false; +GVAR(RainLastLevel) = 0; + +FUNC(CheckGlasses) = { + if (GVAR(Current) != (goggles ace_player)) then { + GVAR(Current) = (goggles ace_player); + ["GlassesChanged",[GVAR(Current)]] call EFUNC(common,localEvent); + }; +}; + +player addEventHandler ["Explosion", { + if (alive ace_player) then { + call FUNC(ApplyDirtEffect); + if (GETBROKEN) exitWith {}; + if (((_this select 1) call FUNC(GetExplosionIndex)) < getNumber(ConfigFile >> "CfgGlasses" >> GVAR(Current) >> "ACE_Resistance")) exitWith {}; + if !(ace_player call FUNC(isGogglesVisible)) exitWith {["GlassesCracked",[ace_player]] call EFUNC(common,localEvent);}; + _effects = GETGLASSES(ace_player,GLASSESDEFAULT); + _effects set [BROKEN, true]; + SETGLASSES(ace_player,_effects); + if (getText(ConfigFile >> "CfgGlasses" >> GVAR(Current) >> "ACE_OverlayCracked") != "" && {cameraOn == ace_player}) then { + if (call FUNC(ExternalCamera)) exitWith {}; + if (isNull(GLASSDISPLAY)) then { + 150 cutRsc["RscACE_Goggles", "PLAIN",1, false]; + }; + (GLASSDISPLAY displayCtrl 10650) ctrlSetText getText(ConfigFile >> "CfgGlasses" >> GVAR(Current) >> "ACE_OverlayCracked"); + }; + ["GlassesCracked",[ace_player]] call EFUNC(common,localEvent); + }; +}]; +player addEventHandler ["Killed",{ + GVAR(PostProcessEyes) ppEffectEnable false; + SETGLASSES(ace_player,GLASSESDEFAULT); + call FUNC(removeGlassesEffect); + GVAR(EffectsActive)=false; + ace_player setVariable ["ACE_EyesDamaged", false]; + if (GVAR(EyesDamageScript) != -1) then { + [GVAR(EyesDamageScript)] call CALLSTACK(cba_fnc_removePreFrameHandler); + }; + if (GVAR(DustHandler) != -1) then { + [GVAR(DustHandler)] call CALLSTACK(cba_fnc_removePerFrameHandler); + GVAR(DustHandler) = -1; + }; +}]; +player addEventHandler ["Fired",{[_this select 0, _this select 1] call FUNC(dustHandler);}]; +player AddEventHandler ["Take",{call FUNC(checkGlasses);}]; +player AddEventHandler ["Put", {call FUNC(checkGlasses);}]; + +["GlassesChanged",{ + SETGLASSES(ace_player,GLASSESDEFAULT); + + if (call FUNC(ExternalCamera)) exitWith {call FUNC(RemoveGlassesEffect)}; + + if (ace_player call FUNC(isGogglesVisible)) then { + (_this select 0) call FUNC(applyGlassesEffect); + } else { + call FUNC(removeGlassesEffect); + }; +}] call EFUNC(common,addEventHandler); +["GlassesCracked",{ + if (_this select 0 != ace_player) exitWith {}; + ace_player setVariable ["ACE_EyesDamaged", true]; + if (GVAR(EyesDamageScript) != -1) then { + [GVAR(EyesDamageScript)] call CALLSTACK(cba_fnc_removePreFrameHandler); + }; + GVAR(PostProcessEyes) ppEffectAdjust[1, 1, 0, [0,0,0,0], [0.5,0.5,0.5,0.5],[1,1,1,0]]; + GVAR(PostProcessEyes) ppEffectCommit 0; + GVAR(PostProcessEyes) ppEffectEnable true; + GVAR(EyesDamageScript) = [{ + GVAR(PostProcessEyes) ppEffectAdjust[1, 1, 0, [0,0,0,0], [1,1,1,1],[1,1,1,0]]; + GVAR(PostProcessEyes) ppEffectCommit 5; + GVAR(EyesDamageScript) = [{ + GVAR(PostProcessEyes) ppEffectEnable false; + ace_player setVariable ["ACE_EyesDamaged", false]; + GVAR(EyesDamageScript) = -1; + }, [], 5, 1] call EFUNC(common,waitAndExecute); + }, [], 25, 5] call EFUNC(common,waitAndExecute); +}] call EFUNC(common,addEventHandler); +call FUNC(checkGlasses); +[FUNC(CheckGoggles), 1, []] call CBA_fnc_addPerFrameHandler; +[FUNC(rainEffect), 0.5, []] call CBA_fnc_addPerFrameHandler; +[FUNC(onEachFrame), 0, []] call CBA_fnc_addPerFrameHandler; diff --git a/addons/goggles/XEH_preInit.sqf b/addons/goggles/XEH_preInit.sqf new file mode 100644 index 0000000000..c2878f3721 --- /dev/null +++ b/addons/goggles/XEH_preInit.sqf @@ -0,0 +1,23 @@ +#include "script_component.hpp" + +PREP(applyDirtEffect); +PREP(applyDust); +PREP(applyGlassesEffect); + +PREP(checkGoggles); +PREP(clearGlasses); +PREP(dustHandler); +PREP(externalCamera); +PREP(getExplosionIndex); + +PREP(isDivingGoggles); +PREP(isGogglesVisible); +PREP(isInRotorWash); + +PREP(onEachFrame); +PREP(rainEffect); + +PREP(removeDirtEffect); +PREP(removeDustEffect); +PREP(removeGlassesEffect); +PREP(removeRainEffect); diff --git a/TO_MERGE/agm/Goggles/anim/WipeGlasses.rtm b/addons/goggles/anim/WipeGlasses.rtm similarity index 100% rename from TO_MERGE/agm/Goggles/anim/WipeGlasses.rtm rename to addons/goggles/anim/WipeGlasses.rtm diff --git a/TO_MERGE/agm/Goggles/anim/model.cfg b/addons/goggles/anim/model.cfg similarity index 100% rename from TO_MERGE/agm/Goggles/anim/model.cfg rename to addons/goggles/anim/model.cfg diff --git a/addons/goggles/config.cpp b/addons/goggles/config.cpp new file mode 100644 index 0000000000..16bb0f9e0f --- /dev/null +++ b/addons/goggles/config.cpp @@ -0,0 +1,279 @@ +#include "script_component.hpp" + +#define COLOUR 8.0 +class CfgPatches { + class ADDON { + units[] = {}; + weapons[] = {}; + requiredVersion = REQUIRED_VERSION; + requiredAddons[] = {"ace_common"}; + author[] = {"Garth 'L-H' de Wet"}; + authorUrl = "http://garth.snakebiteink.co.za/"; + VERSION_CONFIG; + }; +}; + +#include "CfgEventHandlers.hpp" + +#define COMBAT_GOGGLES ACE_Overlay = QUOTE(PATHTOF(textures\HUD\CombatGoggles.paa)); \ + ACE_OverlayCracked = QUOTE(PATHTOF(textures\HUD\CombatGogglesCracked.paa)); \ + ACE_Resistance = 2; \ + ACE_Protection = 1; + +class CfgGlasses { + class None { + ACE_Color[] = {0,0,0}; + ACE_TintAmount=0; + ACE_Overlay = ""; + ACE_OverlayDirt = "A3\Ui_f\data\igui\rsctitles\HealthTextures\dust_upper_ca.paa"; + ACE_OverlayCracked = QUOTE(PATHTOF(textures\HUD\Cracked.paa)); + ACE_Resistance = 0; + ACE_Protection = 0; + ACE_DustPath = QUOTE(PATHTOF(textures\fx\dust\%1.paa)); + }; + + class G_Combat:None { + COMBAT_GOGGLES + }; + + class G_Diving { + ACE_Overlay = QUOTE(PATHTOF(textures\HUD\DivingGoggles.paa)); + ACE_OverlayCracked = QUOTE(PATHTOF(textures\HUD\DivingGogglesCracked.paa)); + ACE_Resistance = 2; + ACE_Protection = 1; + }; + + class G_Lowprofile:None { + ACE_TintAmount=COLOUR*2; + ACE_Resistance = 2; + ACE_Protection = 1; + }; + + class G_Shades_Black:None { + ACE_TintAmount=COLOUR*2; + ACE_Resistance = 1; + }; + + class G_Shades_Blue:None{ + ACE_Color[] = {0,0,1}; + ACE_TintAmount=COLOUR; + ACE_Resistance = 1; + }; + + class G_Shades_Green:None{ + ACE_Color[] = {0,1,0}; + ACE_TintAmount=COLOUR; + ACE_Resistance = 1; + }; + + class G_Shades_Red:None{ + ACE_Color[] = {1,0,0}; + ACE_TintAmount=COLOUR; + ACE_Resistance = 1; + }; + + class G_Spectacles:None{ + ACE_TintAmount=COLOUR; + ACE_Resistance = 1; + }; + + class G_Spectacles_Tinted:None{ + ACE_TintAmount=COLOUR*2; + ACE_Resistance = 1; + }; + + class G_Sport_Blackred:None{ + ACE_Color[] = {1,0,0}; + ACE_TintAmount=COLOUR; + ACE_Resistance = 1; + }; + + class G_Sport_BlackWhite:None{ + ACE_Color[] = {0,0,1}; + ACE_TintAmount=COLOUR; + ACE_Resistance = 1; + }; + + class G_Sport_Blackyellow:None{ + ACE_TintAmount=COLOUR*2; + ACE_Resistance = 1; + }; + + class G_Sport_Checkered:None{ + ACE_TintAmount=COLOUR*2; + ACE_Resistance = 1; + }; + + class G_Sport_Greenblack:None{ + ACE_TintAmount=COLOUR*2; + ACE_Resistance = 1; + }; + + class G_Sport_Red:None{ + ACE_TintAmount=COLOUR*2; + ACE_Color[] = {0,0,0}; + ACE_Resistance = 1; + }; + + class G_Squares:None{ + ACE_TintAmount=COLOUR; + ACE_Resistance = 1; + }; + + class G_Squares_Tinted:None{ + ACE_TintAmount=COLOUR; + ACE_Resistance = 1; + }; + + class G_Tactical_Black:None{ + ACE_TintAmount=COLOUR; + ACE_Color[] = {0,0,-1.5}; + ACE_Resistance = 1; + }; + + class G_Tactical_Clear:None{ + ACE_TintAmount=COLOUR; + ACE_Color[] = {0,0,-1}; + ACE_Resistance = 1; + }; + + class G_Aviator:None{ + ACE_Color[] = {0,0,-1}; + ACE_TintAmount=COLOUR; + ACE_Resistance = 1; + }; + + class G_Lady_Blue:None{ + ACE_Color[] = {0,0,1}; + ACE_TintAmount=COLOUR; + ACE_Resistance = 1; + }; + + class G_Lady_Red:None{ + ACE_Color[] = {1,0,0}; + ACE_TintAmount=COLOUR; + ACE_Resistance = 1; + }; + + class G_Lady_Dark:None{ + ACE_TintAmount=COLOUR*2; + ACE_Resistance = 1; + }; + + class G_Lady_Mirror:None{ + ACE_TintAmount=COLOUR; + ACE_Resistance = 1; + }; + + class AV_ESS_blk:None{ + COMBAT_GOGGLES + }; + + class G_Balaclava_blk; + + class G_Balaclava_combat:G_Balaclava_blk { + COMBAT_GOGGLES + }; + + class G_Balaclava_lowprofile:G_Balaclava_blk { + ACE_TintAmount=COLOUR*2; + ACE_Resistance = 2; + ACE_Protection = 1; + }; + + class G_Bandanna_blk; + class G_Bandanna_shades:G_Bandanna_blk { + ACE_TintAmount=COLOUR*2; + ACE_Resistance = 1; + ACE_Protection = 1; + }; + class G_Bandanna_sport:G_Bandanna_blk { + ACE_Color[] = {1,0,0}; + ACE_TintAmount=COLOUR; + ACE_Resistance = 1; + ACE_Protection = 1; + }; + class G_Bandanna_aviator:G_Bandanna_blk { + ACE_Color[] = {0,0,-1}; + ACE_TintAmount=COLOUR; + ACE_Resistance = 1; + ACE_Protection = 1; + }; +}; + +#include "RscTitles.hpp" + +class CfgMovesBasic { + class ManActions { + GestureWipeFace[] = {"GestureWipeFace", "gesture"}; + }; +}; + +class CfgGesturesMale { + class States { + class GestureFreezeStand; + class GestureWipeFace: GestureFreezeStand { + file = QUOTE(PATHTOF(anim\WipeGlasses.rtm)); + canPullTrigger = 0; + }; + }; +}; + +class CfgWeapons { + class H_HelmetB; + + class H_CrewHelmetHeli_B:H_HelmetB { + ACE_Protection = 1; + }; + class H_PilotHelmetHeli_B:H_HelmetB { + ACE_Protection = 1; + }; + class H_PilotHelmetFighter_B:H_HelmetB { + ACE_Protection = 1; + }; +}; + +class RifleAssaultCloud { + ACE_Goggles_BulletCount = 4; +}; +class MachineGunCloud { + ACE_Goggles_BulletCount = 3; +}; +class SniperCloud { + ACE_Goggles_BulletCount = 1; +}; + +class ACE_Options { + class showInThirdPerson { + displayName = $STR_ACE_Goggles_ShowInThirdPerson; + default = 0; + }; +}; + +class CfgCloudlets { + class Default; + class ACERainEffect:Default { + interval = 0.001; + particleShape = "\A3\data_f\ParticleEffects\Universal\Refract"; + particleFSNtieth = 1; + particleFSIndex = 0; + particleFSFrameCount = 1; + particleFSLoop = 1; + + particleType = "Billboard"; + lifeTime = 0.5; + rotationVelocity = 1; + weight = 100; + volume = 0.000; + rubbing = 1.7; + size[] = {0.1}; + color[] = {{1,1,1,1}}; + animationSpeed[] = {0,1}; + randomDirectionPeriod = 0.2; + randomDirectionIntensity = 1.2; + positionVar[] = {2, 2, 2.5}; + sizeVar = 0.01; + colorVar[] = {0, 0, 0, 0.1}; + destroyOnWaterSurface = 1; + }; +}; diff --git a/addons/goggles/define.hpp b/addons/goggles/define.hpp new file mode 100644 index 0000000000..34c207bd20 --- /dev/null +++ b/addons/goggles/define.hpp @@ -0,0 +1,26 @@ +// Control types +#define CT_STATIC 0 +#define ST_PICTURE 0x30 + +//////////////// +//Base Classes// +//////////////// + +class RscPicture { + access = 0; + idc = -1; + type = CT_STATIC; + style = ST_PICTURE; + colorBackground[] = {0,0,0,0}; + colorText[] = {1,1,1,1}; + font = "puristaMedium"; + sizeEx = 0; + lineSpacing = 0; + fixedWidth = 0; + shadow = 0; + text = ""; + x = safezoneX; + y = safezoneY; + w = safezoneW; + h = safezoneH; +}; diff --git a/addons/goggles/functions/fnc_applyDirtEffect.sqf b/addons/goggles/functions/fnc_applyDirtEffect.sqf new file mode 100644 index 0000000000..50d7748818 --- /dev/null +++ b/addons/goggles/functions/fnc_applyDirtEffect.sqf @@ -0,0 +1,35 @@ +/* + ApplyDirtEffect + + Author: Garth de Wet (LH) + + Description: + Adds dirt effect to the glasses. + + Parameters: + Nothing + + Returns: + BOOLEAN - True if succeeded false if not + + Example: + call FUNC(ApplyDirtEffect); +*/ +#include "script_component.hpp" + +if (cameraOn != ace_player || {call FUNC(externalCamera)}) exitWith{false}; +private "_dirtImage"; +_effects = GETGLASSES(ace_player,GLASSESDEFAULT); +_effects set [DIRT, true]; +SETGLASSES(ace_player,_effects); + +if (ace_player call FUNC(isGogglesVisible)) then{ + _dirtImage = getText(ConfigFile >> "CfgGlasses" >> (goggles ace_player) >> "ACE_OverlayDirt"); + if (_dirtImage != "") then { + 100 cutRsc["RscACE_GogglesEffects", "PLAIN",0.1, false]; + + (GETUVAR(GVAR(DisplayEffects),displayNull) displayCtrl 10660) ctrlSetText _dirtImage; + }; +}; + +true diff --git a/addons/goggles/functions/fnc_applyDust.sqf b/addons/goggles/functions/fnc_applyDust.sqf new file mode 100644 index 0000000000..53e75ba274 --- /dev/null +++ b/addons/goggles/functions/fnc_applyDust.sqf @@ -0,0 +1,61 @@ +/* + Name: fnc_applyDust.sqf + + Author: Garth de Wet (LH) + + Description: + Applies dust to screen. + + Parameters: + Nothing + + Returns: + Nothing + + Example 1: + call FUNC(ApplyDust); +*/ +#include "script_component.hpp" +if (call FUNC(ExternalCamera)) exitWith {}; +if (ace_player call FUNC(isGogglesVisible)) exitWith { + 100 cutRsc["RscACE_GogglesEffects", "PLAIN",2,false]; + (uiNamespace getVariable ["ACE_Goggles_DisplayEffects", displayNull] displayCtrl 10662) ctrlSetText format[getText(ConfigFile >> "CfgGlasses" >> GVAR(Current) >> "ACE_DustPath"), GETDUSTT(DAMOUNT)+1]; + SETDUST(DAMOUNT,CLAMP(GETDUSTT(DAMOUNT)+1,0,1)); + SETDUST(DBULLETS,0); +}; + +if (GETVAR(ace_player,ACE_EyesDamaged,false)) exitWith {SETDUST(DACTIVE,false);SETDUST(DBULLETS,0);SETDUST(DAMOUNT,0);}; +SETDUST(DAMOUNT,CLAMP(GETDUSTT(DAMOUNT)+1,0,2)); + +private "_amount"; +_amount = 1 - (GETDUSTT(DAMOUNT) * 0.125); + +GVAR(PostProcessEyes) ppEffectAdjust[1, 1, 0, [0,0,0,0], [_amount,_amount,_amount,_amount],[1,1,1,0]]; +GVAR(PostProcessEyes) ppEffectCommit 1; +GVAR(PostProcessEyes) ppEffectEnable true; +SETDUST(DBULLETS,0); + +if (GVAR(DustHandler) != -1) then { // should be fixed in dev CBA + [GVAR(DustHandler)] call CALLSTACK(cba_fnc_removePerFrameHandler); + GVAR(DustHandler) = -1; +}; +GVAR(DustHandler) = [{ + if (diag_tickTime >= GETDUSTT(DTIME) + 3) then { + SETDUST(DAMOUNT,CLAMP(GETDUSTT(DAMOUNT)-1,0,2)); + private "_amount"; + _amount = 1 - (GETDUSTT(DAMOUNT) * 0.125); + if !(ace_player getVariable ["ACE_EyesDamaged", false]) then { + GVAR(PostProcessEyes) ppEffectAdjust[1, 1, 0, [0,0,0,0], [_amount,_amount,_amount,_amount],[1,1,1,0]]; + GVAR(PostProcessEyes) ppEffectCommit 0.5; + }; + if (GETDUSTT(DAMOUNT) <= 0) then { + GVAR(PostProcessEyes) ppEffectAdjust[1, 1, 0, [0,0,0,0], [1,1,1,1],[1,1,1,0]]; + GVAR(PostProcessEyes) ppEffectCommit 2; + [{GVAR(PostProcessEyes) ppEffectEnable false;}, [], 2, 0.5] call EFUNC(common,waitAndExecute); + SETDUST(DACTIVE,false); + SETDUST(DBULLETS,0); + [GVAR(DustHandler)] call CALLSTACK(cba_fnc_removePerFrameHandler); + GVAR(DustHandler) = -1; + }; + }; +},0,[]] call CALLSTACK(cba_fnc_addPerFrameHandler); diff --git a/TO_MERGE/agm/Goggles/functions/fn_ApplyGlassesEffect.sqf b/addons/goggles/functions/fnc_applyGlassesEffect.sqf similarity index 51% rename from TO_MERGE/agm/Goggles/functions/fn_ApplyGlassesEffect.sqf rename to addons/goggles/functions/fnc_applyGlassesEffect.sqf index df535485d9..496f73d4b0 100644 --- a/TO_MERGE/agm/Goggles/functions/fn_ApplyGlassesEffect.sqf +++ b/addons/goggles/functions/fnc_applyGlassesEffect.sqf @@ -1,53 +1,56 @@ /* - Name: AGM_Goggles_fnc_ApplyGlassesEffect - + Name: fnc_ApplyGlassesEffect.sqf + Author: Garth de Wet (LH) - + Description: Sets screen tint for glasses. Sets screen overlay for glasses. (broken/fixed) Sets dirt/rain overlay for glasses. - - Parameters: + + Parameters: 0: STRING - Glasses class name to be applied. - + Returns: Nothing - + Example: - (goggles player) call AGM_Goggles_fnc_ApplyGlassesEffect; + (goggles ace_player) call FUNC(ApplyGlassesEffect); */ -#include "\AGM_Goggles\script.sqf" +#include "script_component.hpp" private["_postProcessColour", "_postProcessTintAmount", "_glassesClassname", "_glassImagePath"]; _glassesClassname = _this; -_postProcessColour = getArray(configFile >> "CfgGlasses" >> _glassesClassname >> "AGM_Color"); -_postProcessTintAmount = getNumber(configFile >> "CfgGlasses" >> _glassesClassname >> "AGM_TintAmount"); +_postProcessColour = getArray(configFile >> "CfgGlasses" >> _glassesClassname >> "ACE_Color"); +_postProcessTintAmount = getNumber(configFile >> "CfgGlasses" >> _glassesClassname >> "ACE_TintAmount"); -call AGM_Goggles_fnc_RemoveGlassesEffect; -AGM_Goggles_EffectsActive = true; +call FUNC(removeGlassesEffect); +GVAR(EffectsActive) = true; -if (_postProcessTintAmount != 0 && {AGM_Goggles_UsePP}) then { +if (_postProcessTintAmount != 0 && {GVAR(UsePP)}) then { _postProcessColour set [3, _postProcessTintAmount/100]; - AGM_Goggles_PostProcess ppEffectAdjust[0.9, 1.1, 0.004, _postProcessColour, [0,0,0,1],[0,0,0,0]]; - AGM_Goggles_PostProcess ppEffectCommit 0; - AGM_Goggles_PostProcess ppEffectEnable true; + GVAR(PostProcess) ppEffectAdjust[0.9, 1.1, 0.004, _postProcessColour, [0,0,0,1],[0,0,0,0]]; + GVAR(PostProcess) ppEffectCommit 0; + GVAR(PostProcess) ppEffectEnable true; + _postProcessColour set [3, _postProcessTintAmount/250]; + GVAR(PostProcess) ppEffectAdjust[0.9, 1.1, 0.004, _postProcessColour, [0,0,0,1],[0,0,0,0]]; + GVAR(PostProcess) ppEffectCommit 30; }; -_glassImagePath = getText(configFile >> "CfgGlasses" >> _glassesClassname >> "AGM_Overlay"); +_glassImagePath = getText(configFile >> "CfgGlasses" >> _glassesClassname >> "ACE_Overlay"); if GETBROKEN then { - _glassImagePath = getText(configFile >> "CfgGlasses" >> _glassesClassname >> "AGM_OverlayCracked"); + _glassImagePath = getText(configFile >> "CfgGlasses" >> _glassesClassname >> "ACE_OverlayCracked"); }; if (_glassImagePath != "") then { - 150 cutRsc["RscAGM_Goggles", "PLAIN",1, false]; + 150 cutRsc["RscACE_Goggles", "PLAIN",1, false]; (GLASSDISPLAY displayCtrl 10650) ctrlSetText _glassImagePath; }; if GETDIRT then { - call AGM_Goggles_fnc_ApplyDirtEffect; + call FUNC(applyDirtEffect); }; if GETDUSTT(DACTIVE) then { SETDUST(DAMOUNT,CLAMP(GETDUSTT(DAMOUNT)-1,0,2)); - call AGM_Goggles_fnc_ApplyDust; + call FUNC(applyDust); }; diff --git a/addons/goggles/functions/fnc_checkGoggles.sqf b/addons/goggles/functions/fnc_checkGoggles.sqf new file mode 100644 index 0000000000..a00b7371d8 --- /dev/null +++ b/addons/goggles/functions/fnc_checkGoggles.sqf @@ -0,0 +1,37 @@ +/* + Author: Garth de Wet (LH) + + Description: + Performs rain checks and checks to see whether glasses effects have been applied or not. + Checks for external camera and removes effects. +*/ +#include "script_component.hpp" +if (!alive ace_player) exitWith {}; +if (true) then { + // Detect if curator interface is open and disable effects + if (!isNull(findDisplay 312)) exitWith { + if (GVAR(EffectsActive)) then { + call FUNC(removeGlassesEffect); + }; + }; + call FUNC(checkGlasses); + if !(ace_player call FUNC(isGogglesVisible)) exitWith { + if (GVAR(EffectsActive)) then { + call FUNC(removeGlassesEffect); + }; + }; + if (call FUNC(externalCamera)) exitWith { + if (GVAR(EffectsActive)) then { + call FUNC(removeGlassesEffect); + }; + }; + if !(GVAR(EffectsActive)) then { + (goggles ace_player) call FUNC(applyGlassesEffect); + } else { + if ((goggles ace_player) call FUNC(isDivingGoggles) && {underwater ace_player}) then { + call FUNC(removeRainEffect); + call FUNC(removeDirtEffect); + call FUNC(removeDustEffect); + }; + }; +}; diff --git a/addons/goggles/functions/fnc_clearGlasses.sqf b/addons/goggles/functions/fnc_clearGlasses.sqf new file mode 100644 index 0000000000..4072e7c68a --- /dev/null +++ b/addons/goggles/functions/fnc_clearGlasses.sqf @@ -0,0 +1,38 @@ +/* + Name: fnc_clearGlasses.sqf + + Author: Garth de Wet (LH) + + Description: + Clears all dirt, rain, dust from glasses. + Removes glasses effect (PP, overlay) and then puts it back. + + Parameters: + Nothing + + Returns: + Nothing + + Example: + call FUNC(ClearGlasses); +*/ +#include "script_component.hpp" + +private "_broken"; +_broken = GETBROKEN; +_effects = GLASSESDEFAULT; +_effects set [BROKEN, _broken]; +SETGLASSES(ace_player,_effects); + +if ((stance ace_player) != "PRONE") then { + ace_player playActionNow "gestureWipeFace"; +}; +[{ + if (cameraView == "INTERNAL") then { + addCamShake [5, 1.75, 2]; + }; +}, [], 0.3, 0] call EFUNC(common,waitAndExecute); + +call FUNC(removeDirtEffect); +call FUNC(removeRainEffect); +call FUNC(removeDustEffect); diff --git a/TO_MERGE/agm/Goggles/functions/fn_DustHandler.sqf b/addons/goggles/functions/fnc_dustHandler.sqf similarity index 72% rename from TO_MERGE/agm/Goggles/functions/fn_DustHandler.sqf rename to addons/goggles/functions/fnc_dustHandler.sqf index a4457815e1..aae722d50f 100644 --- a/TO_MERGE/agm/Goggles/functions/fn_DustHandler.sqf +++ b/addons/goggles/functions/fnc_dustHandler.sqf @@ -1,29 +1,30 @@ /* - Name: AGM_Goggles_fnc_DustHandler - + fnc_DustHandler.sqf + Author: Garth de Wet (LH) - + Description: Determines whether to place dust on the goggles, based on calibre of weapon fired and other requirements. - - Parameters: + + Parameters: 0: Object - unit - eventhandler was attached to. (Used) 1: String - weapon - Weapon fired (Used) - + Returns: Nothing - + Example: - player addEventHandler ["Fired", {[_this select 0, _this select 1] call AGM_Goggles_fnc_DustHandler;}]; + ace_player addEventHandler ["Fired", {[_this select 0, _this select 1] call FUNC(DustHandler;}]; See http://community.bistudio.com/wiki/ArmA_3:_Event_Handlers#Fired */ -#include "\AGM_Goggles\script.sqf" - -private ["_bullets", "_position", "_surface", "_found", "_weapon", "_cloudType"]; -_weapon = _this select 1; +#include "script_component.hpp" +private ["_bullets", "_position", "_surface", "_found", "_weapon", "_cloudType", "_unit"]; +EXPLODE_2_PVT(_this,_unit,_weapon); +if (_unit != ace_player) exitWith {true}; _cloudType = ""; -if ((_this select 0) != player) exitWith {true}; +if (rain > 0.1) exitWith {true}; +if ((stance _unit) != "PRONE") exitWith {true}; if (isClass(configFile >> "CfgWeapons" >> _weapon >> "GunParticles" >> "FirstEffect")) then { _cloudType = getText(configFile >> "CfgWeapons" >> _weapon >> "GunParticles" >> "FirstEffect" >> "effectName"); @@ -34,10 +35,8 @@ if (isClass(configFile >> "CfgWeapons" >> _weapon >> "GunParticles" >> "FirstEff }; if (_cloudType == "") exitWith {true}; -if (rain > 0.1) exitWith {true}; -if ((stance player) != "PRONE") exitWith {true}; -_position = getPosATL player; +_position = getPosATL _unit; if (surfaceIsWater _position) exitWith {}; if ((_position select 2) > 0.2) exitWith {}; @@ -52,24 +51,24 @@ if (!_found) exitWith {}; _bullets = GETDUSTT(DBULLETS); -if ((time - GETDUSTT(DTIME)) > 1) then { +if ((diag_tickTime - GETDUSTT(DTIME)) > 1) then { _bullets = 0; }; _bullets = _bullets + 1; SETDUST(DBULLETS,_bullets); -SETDUST(DTIME,time); +SETDUST(DTIME,diag_tickTime); if (GETDUSTT(DAMOUNT) < 2) then { private "_bulletsRequired"; _bulletsRequired = 100; - if (isNumber (ConfigFile >> _cloudType >> "AGM_Goggles_BulletCount")) then { - _bulletsRequired = getNumber (ConfigFile >> _cloudType >> "AGM_Goggles_BulletCount"); + if (isNumber (ConfigFile >> _cloudType >> "ACE_Goggles_BulletCount")) then { + _bulletsRequired = getNumber (ConfigFile >> _cloudType >> "ACE_Goggles_BulletCount"); }; if (_bulletsRequired <= _bullets) then { SETDUST(DACTIVE,true); - call AGM_Goggles_fnc_ApplyDust; + call FUNC(applyDust); }; }; true diff --git a/TO_MERGE/agm/Goggles/functions/fn_ExternalCamera.sqf b/addons/goggles/functions/fnc_externalCamera.sqf similarity index 52% rename from TO_MERGE/agm/Goggles/functions/fn_ExternalCamera.sqf rename to addons/goggles/functions/fnc_externalCamera.sqf index d3e3f98366..66e1ae6b3d 100644 --- a/TO_MERGE/agm/Goggles/functions/fn_ExternalCamera.sqf +++ b/addons/goggles/functions/fnc_externalCamera.sqf @@ -1,19 +1,20 @@ /* - Name: AGM_Goggles_fnc_ExternalCamera - + fnc_ExternalCamera.sqf + Author: Garth de Wet (LH) - + Description: Returns if the camera is external or not. - - Parameters: + + Parameters: Nothing - + Returns: Boolean - whether the camera is in external view or not. - + Example: - call AGM_Goggles_fnc_ExternalCamera; + call FUNC(ExternalCamera); */ -if (profileNamespace getVariable ["AGM_showInThirdPerson", false]) exitWith { false }; +#include "script_component.hpp" +if (GETVAR(profileNamespace,ACE_showInThirdPerson,false)) exitWith { false }; (cameraView == "External") diff --git a/addons/goggles/functions/fnc_getExplosionIndex.sqf b/addons/goggles/functions/fnc_getExplosionIndex.sqf new file mode 100644 index 0000000000..92d79f4992 --- /dev/null +++ b/addons/goggles/functions/fnc_getExplosionIndex.sqf @@ -0,0 +1,27 @@ +/* + fnc_getExplosionIndex.sqf + + Author: Garth de Wet (LH) + + Description: + Turns 0-1 damage into a rating system of 0-3 + + Parameters: + 0: NUMBER - The amount of damage + + Returns: + NUMBER (the rating) [0-3] + + Example: + _rating = 0.05 call FUNC(GetExplosionIndex); +*/ +private ["_effectIndex"]; + +_effectIndex = switch true do { + case (_this <= 0.04): {0}; + case (_this <= 0.06): {1}; + case (_this <= 0.09): {2}; + default {3}; +}; + +_effectIndex diff --git a/TO_MERGE/agm/Goggles/functions/fn_isDivingGoggles.sqf b/addons/goggles/functions/fnc_isDivingGoggles.sqf similarity index 79% rename from TO_MERGE/agm/Goggles/functions/fn_isDivingGoggles.sqf rename to addons/goggles/functions/fnc_isDivingGoggles.sqf index d4b73ff5b7..d6b97fb80a 100644 --- a/TO_MERGE/agm/Goggles/functions/fn_isDivingGoggles.sqf +++ b/addons/goggles/functions/fnc_isDivingGoggles.sqf @@ -1,20 +1,21 @@ /* - Name: AGM_Goggles_fnc_isDivingGoggles - + fnc_isDivingGoggles.sqf + Author: Garth de Wet (LH) - + Description: Determines whether current goggles worn by passed unit is diving goggles or a variant of them. - - Parameters: + + Parameters: 0: String - Glasses classname - + Returns: Boolean - whether diving goggles are worn - + Example: - (goggles player) call AGM_Goggles_fnc_isDivingGoggles; + (goggles ace_player) call FUNC(isDivingGoggles); */ +#include "script_component.hpp" private ["_result", "_glasses"]; _glasses = _this; _result = _glasses == "G_Diving"; diff --git a/TO_MERGE/agm/Goggles/functions/fn_isGogglesVisible.sqf b/addons/goggles/functions/fnc_isGogglesVisible.sqf similarity index 69% rename from TO_MERGE/agm/Goggles/functions/fn_isGogglesVisible.sqf rename to addons/goggles/functions/fnc_isGogglesVisible.sqf index d694d18c26..a663554b60 100644 --- a/TO_MERGE/agm/Goggles/functions/fn_isGogglesVisible.sqf +++ b/addons/goggles/functions/fnc_isGogglesVisible.sqf @@ -1,20 +1,21 @@ /* - Name: AGM_Goggles_fnc_isGogglesVisible - + fnc_isGogglesVisible.sqf + Author: Garth de Wet (LH) - + Description: Determines if goggles are visible on passed unit (Also checks if unit is in vehicle and cameraView is set to GUNNER) - - Parameters: + + Parameters: 0: Object - unit to check for visible goggles - + Returns: BOOL - Whether the goggles are visible or not. - + Example: - _visible = player call AGM_Goggles_fnc_isGogglesVisible; + _visible = ace_player call FUNC(isGogglesVisible); */ +#include "script_component.hpp" private ["_currentGlasses", "_result", "_unit"]; _unit = _this; @@ -26,12 +27,12 @@ if ((vehicle _unit) != _unit) exitWith {(cameraView != "GUNNER")}; if (_currentGlasses != "") then { _position =(getPosASLW _unit); if (surfaceIsWater _position && {((_position select 2) < 0.25)}) exitWith { - _result = (_currentGlasses call AGM_Goggles_fnc_isDivingGoggles); + _result = (_currentGlasses call FUNC(isDivingGoggles)); }; - if (getNumber (ConfigFile >> "CfgGlasses" >> _currentGlasses >> "AGM_Resistance") == 0) exitWith { + if (getNumber (ConfigFile >> "CfgGlasses" >> _currentGlasses >> "ACE_Resistance") == 0) exitWith { _result = false; }; - _result = !(_currentGlasses call AGM_Goggles_fnc_isDivingGoggles); + _result = !(_currentGlasses call FUNC(isDivingGoggles)); }; -_result \ No newline at end of file +_result diff --git a/TO_MERGE/agm/Goggles/functions/fn_isInRotorWash.sqf b/addons/goggles/functions/fnc_isInRotorWash.sqf similarity index 78% rename from TO_MERGE/agm/Goggles/functions/fn_isInRotorWash.sqf rename to addons/goggles/functions/fnc_isInRotorWash.sqf index f1e69c9345..f8bad1a10f 100644 --- a/TO_MERGE/agm/Goggles/functions/fn_isInRotorWash.sqf +++ b/addons/goggles/functions/fnc_isInRotorWash.sqf @@ -1,24 +1,25 @@ /* - Name: AGM_Goggles_fnc_isInRotorWash - + fnc_isInRotorWash.sqf + Author: Garth de Wet (LH) - + Description: Checks for nearby helicopters (within 15m) - + Parameters: 0: Object - Unit 1: NUMBER - (optional) Radius to check for helicopter Default: 15 - + Returns: Array: 0 - boolean - If in rotorwash 1 - number - Amount of rotor wash. - + Example: - if (([player, 10] call AGM_Goggles_fnc_isInRotorWash) select 0) then { hint "Rotor wash"; }; - if (([player] call AGM_Goggles_fnc_isInRotorWash) select 0) then { hint "Rotor wash"; }; + if (([ace_player, 10] call FUNC(isInRotorWash)) select 0) then { hint "Rotor wash"; }; + if (([ace_player] call FUNC(isInRotorWash)) select 0) then { hint "Rotor wash"; }; */ +#include "script_component.hpp" private ["_heli", "_unit", "_result", "_radius"]; _unit = _this select 0; _radius = 15; @@ -41,6 +42,7 @@ _heli = (getPosATL _unit) nearEntities [["Helicopter"], _radius]; }; }; }; + false } count _heli; _result diff --git a/addons/goggles/functions/fnc_onEachFrame.sqf b/addons/goggles/functions/fnc_onEachFrame.sqf new file mode 100644 index 0000000000..cd361e38cf --- /dev/null +++ b/addons/goggles/functions/fnc_onEachFrame.sqf @@ -0,0 +1,80 @@ +/* + fnc_onEachFrame.sqf + + Author: Garth de Wet (LH) + + Description: + Runs every frame checking for helicopters. + + Parameters: + Nothing + + Returns: + Nothing + + Example: + ["ACE_Goggles_RotorWash", "OnEachFrame", "call FUNC(OnEachFrame);"] call BIS_fnc_addStackedEventHandler; +*/ +#include "script_component.hpp" +if (isNull(ace_player)) exitWith {}; +GVAR(FrameEvent) set [0, !(GVAR(FrameEvent) select 0)]; +if (GVAR(FrameEvent) select 0) exitWith { + if (vehicle ace_player != ace_player && {!([ace_player] call EFUNC(common,isTurnedOut))}) exitWith {(GVAR(FrameEvent) select 1) set [0, false]; }; + GVAR(FrameEvent) set [1, ([ace_player] call FUNC(isInRotorWash))]; +}; +private ["_rotorWash","_safe"]; +_rotorWash = GVAR(FrameEvent) select 1; +_safe = false; +if !(_rotorWash select 0) exitWith { + if (GVAR(PostProcessEyes_Enabled)) then { + GVAR(PostProcessEyes_Enabled) = false; + if (GVAR(DustHandler) != -1) then { // should be fixed in dev CBA + [GVAR(DustHandler)] call CALLSTACK(cba_fnc_removePerFrameHandler); + GVAR(DustHandler) = -1; + }; + GVAR(PostProcessEyes) ppEffectAdjust [1, 1, 0, [0,0,0,0], [0,0,0,1],[1,1,1,0]]; + GVAR(PostProcessEyes) ppEffectCommit 2; + GVAR(DustHandler) = [{ + GVAR(PostProcessEyes) ppEffectEnable false; + GVAR(DustHandler) = -1; + }, [], 2, 0.5] call EFUNC(common,waitAndExecute); + }; +}; +if ((headgear ace_player) != "") then { + _safe = (getNumber (ConfigFile >> "CfgWeapons" >> (headgear ace_player) >> "ACE_Protection") == 1); +}; +if !(_safe) then { + if !(ace_player call FUNC(isGogglesVisible)) exitWith{}; + if (GETDUSTT(DAMOUNT) < 2) then { + if (!GETDUSTT(DACTIVE)) then { + SETDUST(DACTIVE,true); + call FUNC(ApplyDust); + } else { + if ((_rotorWash select 1) > 0.5) then { + call FUNC(ApplyDust); + }; + }; + }; + _safe = (getNumber (ConfigFile >> "CfgGlasses" >> GVAR(Current) >> "ACE_Protection") == 1); +}; +if (_safe) exitWith {}; +if ((_rotorWash select 1) <= 15) then { + private "_scale"; + _scale = 0.7; + if ((_rotorWash select 1) != 0) then { + _scale = CLAMP(0.3*(_rotorWash select 1),0.1,0.3); + } else { + _scale = 0.1; + }; + _scale = 1 - _scale; + if (GVAR(DustHandler) != -1) then { // should be fixed in dev CBA + [GVAR(DustHandler)] call CALLSTACK(cba_fnc_removePerFrameHandler); + GVAR(DustHandler) = -1; + }; + if !(ace_player getVariable ["ACE_EyesDamaged", false]) then { + GVAR(PostProcessEyes_Enabled) = true; + GVAR(PostProcessEyes) ppEffectAdjust [1, 1, 0, [0,0,0,0], [_scale,_scale,_scale,_scale],[1,1,1,0]]; + GVAR(PostProcessEyes) ppEffectCommit 0.5; + GVAR(PostProcessEyes) ppEffectEnable true; + }; +}; diff --git a/addons/goggles/functions/fnc_rainEffect.sqf b/addons/goggles/functions/fnc_rainEffect.sqf new file mode 100644 index 0000000000..030e60c149 --- /dev/null +++ b/addons/goggles/functions/fnc_rainEffect.sqf @@ -0,0 +1,55 @@ +/* + fnc_rainEffect.sqf + + Author: Garth de Wet (LH) + + Description: + + + Parameters: + Nothing + + Returns: + Nothing + + Example: + [] call FUNC(RainEffect); +*/ +#include "script_component.hpp" +private ["_fnc_underCover"]; +if (isNull(ace_player) || {!(alive ace_player)}) exitWith {}; +_fnc_underCover = { + private ["_pos", "_unit"]; + _unit = (_this select 0); + if (vehicle _unit != _unit && {!([_unit] call EFUNC(common,isTurnedOut))}) exitWith {true}; + _pos = eyePos _unit; + ((positionCameraToWorld [0,0,1] select 2) < ((positionCameraToWorld [0,0,0] select 2) - 0.4)) || {(lineIntersects [_pos, _pos vectorAdd [0,0,15], _unit])} +}; +if (!isNull(findDisplay 312)) exitWith { + if (GVAR(RainActive)) then { + call FUNC(RemoveRainEffect); + }; +}; +// Ignore if ace_player is under water +if (!GVAR(EffectsActive) || {underwater ace_player}) exitWith{call FUNC(RemoveRainEffect);}; +if (GVAR(RainLastLevel) != rain) then { + call FUNC(RemoveRainEffect); + GVAR(RainLastLevel) = rain; + // Rain is happening + if (GVAR(RainLastLevel) > 0.05 && {!([ace_player] call _fnc_underCover)}) then { + GVAR(RainActive) = true; + GVAR(RainDrops) = "#particlesource" createVehicleLocal GetPos ace_player; + GVAR(RainDrops) setParticleClass "ACERainEffect"; + GVAR(RainDrops) setDropInterval (0.07 * (1.1 - GVAR(RainLastLevel))); + GVAR(RainDrops) attachTo [vehicle ace_player,[0,0,0]]; + }; +}else{ + if (GVAR(RainLastLevel) > 0.05) then { + if (GVAR(RainActive) && {[ace_player] call _fnc_underCover}) exitWith { + call FUNC(RemoveRainEffect); + }; + if (!GVAR(RainActive)) then { + GVAR(RainLastLevel) = -1; + }; + }; +}; diff --git a/addons/goggles/functions/fnc_removeDirtEffect.sqf b/addons/goggles/functions/fnc_removeDirtEffect.sqf new file mode 100644 index 0000000000..5b58fad834 --- /dev/null +++ b/addons/goggles/functions/fnc_removeDirtEffect.sqf @@ -0,0 +1,21 @@ +/* + fnc_removeDirtEffect.sqf + + Author: Garth de Wet (LH) + + Description: + Removes dirt from the glasses. + + Parameters: + Nothing + + Returns: + Nothing + + Example: + call FUNC(RemoveDirtEffect); +*/ +#include "script_component.hpp" +if (!isNull(GETUVAR(GVAR(DisplayEffects),displayNull))) then { + (GETUVAR(GVAR(DisplayEffects),displayNull) displayCtrl 10660) ctrlSetText ""; +}; diff --git a/addons/goggles/functions/fnc_removeDustEffect.sqf b/addons/goggles/functions/fnc_removeDustEffect.sqf new file mode 100644 index 0000000000..c937fe2bd1 --- /dev/null +++ b/addons/goggles/functions/fnc_removeDustEffect.sqf @@ -0,0 +1,21 @@ +/* + fnc_removeDustEffect.sqf + + Author: Garth de Wet (LH) + + Description: + Removes dust from the glasses. + + Parameters: + Nothing + + Returns: + Nothing + + Example: + call FUNC(RemoveDustEffect); +*/ +#include "script_component.hpp" +if (!isNull(GETUVAR(GVAR(DisplayEffects),displayNull))) then { + (GETUVAR(GVAR(DisplayEffects),displayNull) displayCtrl 10662) ctrlSetText ""; +}; diff --git a/addons/goggles/functions/fnc_removeGlassesEffect.sqf b/addons/goggles/functions/fnc_removeGlassesEffect.sqf new file mode 100644 index 0000000000..dc7bbee45e --- /dev/null +++ b/addons/goggles/functions/fnc_removeGlassesEffect.sqf @@ -0,0 +1,29 @@ +/* + RemoveGlassesEffect + + Author: Garth de Wet (LH) + + Description: + Removes the glasses effect from the screen, removes dirt effect, removes rain effect, + removes dust effect. Does not reset array (glasses will still be broken, dirty, ect.) + + Parameters: + Nothing + + Returns: + Nothing + + Example: + call FUNC(RemoveGlassesEffect); +*/ +#include "script_component.hpp" +GVAR(EffectsActive) = false; +GVAR(PostProcess) ppEffectEnable false; + +if (!isNull(GLASSDISPLAY)) then { + GLASSDISPLAY closeDisplay 0; +}; + +call FUNC(removeDirtEffect); +call FUNC(removeRainEffect); +call FUNC(removeDustEffect); diff --git a/addons/goggles/functions/fnc_removeRainEffect.sqf b/addons/goggles/functions/fnc_removeRainEffect.sqf new file mode 100644 index 0000000000..bcef82dc81 --- /dev/null +++ b/addons/goggles/functions/fnc_removeRainEffect.sqf @@ -0,0 +1,23 @@ +/* + RemoveRainEffect + + Author: Garth de Wet (LH) + + Description: + Removes rain effects from the screen. Resets the rain array. + + Parameters: + Nothing + + Returns: + Nothing + + Example: + call FUNC(RemoveRainEffect); +*/ +#include "script_component.hpp" +if (!isNull (GVAR(RainDrops))) then { + deleteVehicle (GVAR(RainDrops)); +}; +GVAR(RainActive) = false; +GVAR(RainLastLevel) = 0; diff --git a/addons/goggles/functions/script_component.hpp b/addons/goggles/functions/script_component.hpp new file mode 100644 index 0000000000..d8624df3b2 --- /dev/null +++ b/addons/goggles/functions/script_component.hpp @@ -0,0 +1 @@ +#include "\z\ace\addons\goggles\script_component.hpp" diff --git a/addons/goggles/script_component.hpp b/addons/goggles/script_component.hpp new file mode 100644 index 0000000000..711a314160 --- /dev/null +++ b/addons/goggles/script_component.hpp @@ -0,0 +1,37 @@ +#define COMPONENT goggles +#include "\z\ace\addons\main\script_mod.hpp" + +#ifdef DEBUG_ENABLED_GOGGLES + #define DEBUG_MODE_FULL +#endif + +#ifdef DEBUG_SETTINGS_GOGGLES + #define DEBUG_SETTINGS DEBUG_SETTINGS_GOGGLES +#endif + +#include "\z\ace\addons\main\script_macros.hpp" + +// MACROS +#define GLASSESDEFAULT [false,[false,0,0,0],false] +#define GETGLASSES(unit) GETVAR(unit,GVAR(Condition),GLASSESDEFAULT) +#define SETGLASSES(unit,value) SETVAR(unit,GVAR(Condition),value) + +#define DIRT 0 +#define DUST 1 +#define BROKEN 2 + +#define GETDIRT (GETGLASSES(ace_player) select DIRT) +#define GETDUST (GETGLASSES(ace_player) select DUST) +#define GETBROKEN (GETGLASSES(ace_player) select BROKEN) +#define GETDUSTT(type) ((GETGLASSES(ace_player) select DUST) select type) + +#define SETDUST(type,value) (GETGLASSES(ace_player) select DUST) set [type,value] + +#define DACTIVE 0 +#define DTIME 1 +#define DBULLETS 2 +#define DAMOUNT 3 + +#define GLASSDISPLAY (GETUVAR(GVAR(Display),displayNull)) + +#define CLAMP(x,low,high) (if(x > high)then{high}else{if(x < low)then{low}else{x}}) diff --git a/TO_MERGE/agm/Goggles/stringtable.xml b/addons/goggles/stringtable.xml similarity index 91% rename from TO_MERGE/agm/Goggles/stringtable.xml rename to addons/goggles/stringtable.xml index 0d079a4063..1756442176 100644 --- a/TO_MERGE/agm/Goggles/stringtable.xml +++ b/addons/goggles/stringtable.xml @@ -1,8 +1,8 @@  - + - + Show Goggle Effects in Third Person Brilleneffekt in dritter Person anzeigen Mostrar efectos de las gafas en tercera persona @@ -14,7 +14,7 @@ Mostrar efeitos de óculos em Terceira Pessoa Attiva l'effetto degli occhiali in terza persona - + Wipe Goggles Brille abwischen Limpiar gafas @@ -27,4 +27,4 @@ Pulisci gli occhiali - \ No newline at end of file + diff --git a/TO_MERGE/agm/Goggles/textures/HUD/CombatGoggles.paa b/addons/goggles/textures/HUD/CombatGoggles.paa similarity index 100% rename from TO_MERGE/agm/Goggles/textures/HUD/CombatGoggles.paa rename to addons/goggles/textures/HUD/CombatGoggles.paa diff --git a/TO_MERGE/agm/Goggles/textures/HUD/CombatGogglesCracked.paa b/addons/goggles/textures/HUD/CombatGogglesCracked.paa similarity index 100% rename from TO_MERGE/agm/Goggles/textures/HUD/CombatGogglesCracked.paa rename to addons/goggles/textures/HUD/CombatGogglesCracked.paa diff --git a/TO_MERGE/agm/Goggles/textures/HUD/Cracked.paa b/addons/goggles/textures/HUD/Cracked.paa similarity index 100% rename from TO_MERGE/agm/Goggles/textures/HUD/Cracked.paa rename to addons/goggles/textures/HUD/Cracked.paa diff --git a/TO_MERGE/agm/Goggles/textures/HUD/DivingGoggles.paa b/addons/goggles/textures/HUD/DivingGoggles.paa similarity index 100% rename from TO_MERGE/agm/Goggles/textures/HUD/DivingGoggles.paa rename to addons/goggles/textures/HUD/DivingGoggles.paa diff --git a/TO_MERGE/agm/Goggles/textures/HUD/DivingGogglesCracked.paa b/addons/goggles/textures/HUD/DivingGogglesCracked.paa similarity index 100% rename from TO_MERGE/agm/Goggles/textures/HUD/DivingGogglesCracked.paa rename to addons/goggles/textures/HUD/DivingGogglesCracked.paa diff --git a/TO_MERGE/agm/Goggles/textures/fx/dust/1.paa b/addons/goggles/textures/fx/dust/1.paa similarity index 100% rename from TO_MERGE/agm/Goggles/textures/fx/dust/1.paa rename to addons/goggles/textures/fx/dust/1.paa diff --git a/TO_MERGE/agm/Goggles/textures/fx/dust/2.paa b/addons/goggles/textures/fx/dust/2.paa similarity index 100% rename from TO_MERGE/agm/Goggles/textures/fx/dust/2.paa rename to addons/goggles/textures/fx/dust/2.paa diff --git a/addons/kestrel/$PBOPREFIX$ b/addons/kestrel/$PBOPREFIX$ new file mode 100644 index 0000000000..ca3fac2e96 --- /dev/null +++ b/addons/kestrel/$PBOPREFIX$ @@ -0,0 +1 @@ +z\ace\addons\kestrel \ No newline at end of file diff --git a/addons/kestrel/CfgEventHandlers.hpp b/addons/kestrel/CfgEventHandlers.hpp new file mode 100644 index 0000000000..f0a9f14d91 --- /dev/null +++ b/addons/kestrel/CfgEventHandlers.hpp @@ -0,0 +1,6 @@ + +class Extended_PreInit_EventHandlers { + class ADDON { + init = QUOTE(call COMPILE_FILE(XEH_preInit)); + }; +}; diff --git a/addons/kestrel/CfgVehicles.hpp b/addons/kestrel/CfgVehicles.hpp new file mode 100644 index 0000000000..906e3a9e22 --- /dev/null +++ b/addons/kestrel/CfgVehicles.hpp @@ -0,0 +1,53 @@ + +#define MACRO_ADDITEM(ITEM,COUNT) class _xx_##ITEM { \ + name = #ITEM; \ + count = COUNT; \ +} + +class CfgVehicles { + class Man; + class CAManBase: Man { + class ACE_SelfActions { + class ACE_OpenKestrel { + displayName = "$STR_ACE_Wind_OpenKestrel"; + condition = QUOTE('ACE_Kestrel' in items _player && {!GVAR(isKestrel)}); + statement = QUOTE(call FUNC(openKestrel)); + showDisabled = 0; + priority = 2; + icon = PATHTOF(data\4500NV1.paa); + hotkey = "K"; + }; + class ACE_CloseKestrel { + displayName = "$STR_ACE_Wind_CloseKestrel"; + condition = QUOTE(GVAR(isKestrel)); + statement = QUOTE(call FUNC(closeKestrel)); + showDisabled = 0; + priority = 2; + icon = PATHTOF(data\4500NV1.paa); + hotkey = "K"; + }; + }; + }; + + class Item_Base_F; + class ACE_Item_Kestrel: Item_Base_F { + author = "$STR_ACE_Common_ACETeam"; + scope = 2; + scopeCurator = 2; + displayName = "$STR_ACE_Kestrel_Name"; + vehicleClass = "Items"; + class TransportItems { + class ACE_Kestrel { + name = "ACE_Kestrel"; + count = 1; + }; + }; + }; + + class Box_NATO_Support_F; + class ACE_Box_Misc: Box_NATO_Support_F { + class TransportItems { + MACRO_ADDITEM(ACE_Kestrel,6); + }; + }; +}; diff --git a/addons/kestrel/CfgWeapons.hpp b/addons/kestrel/CfgWeapons.hpp new file mode 100644 index 0000000000..6db0e4b7d4 --- /dev/null +++ b/addons/kestrel/CfgWeapons.hpp @@ -0,0 +1,20 @@ + +class CfgWeapons { + class ACE_ItemCore; + class InventoryItem_Base_F; + + class ACE_Kestrel: ACE_ItemCore { + author = "$STR_ACE_Common_ACETeam"; + scope = 2; + displayName = "$STR_ACE_Kestrel_Name"; + descriptionShort = "$STR_ACE_Kestrel_Description"; + model = PATHTOF(kestrel4500.p3d); + picture = PATHTOF(data\4500NV.paa); + icon = "iconObject_circle"; + mapSize = 0.034; + + class ItemInfo: InventoryItem_Base_F { + mass = 2; + }; + }; +}; diff --git a/addons/kestrel/RscTitles.hpp b/addons/kestrel/RscTitles.hpp new file mode 100644 index 0000000000..2530dbcda7 --- /dev/null +++ b/addons/kestrel/RscTitles.hpp @@ -0,0 +1,125 @@ + +class RscPicture; +class RscText; + +class RscTitles { + class ACE_Kestrel { + onload = QUOTE(_this call FUNC(onLoadKestrel)); + //onunload = ""; + idd = -1; + movingEnable = 0; + enableDisplay = 1; + duration = 1e+011; + fadein = 0; + fadeout = 0; + enablesimulation = 1; + + class controls { + // has to be first to be in the background + class Wheel: RscPicture { + idc = 3; + type = 0; + style = "48 + 0x800"; + text = ""; + x = "safeZoneX + 0.07"; + y = "safeZoneY + safeZoneH - 0.76"; + h = "0.15"; + w = "0.15"; + }; + + class Kestrel1: RscPicture { + idc = 1; + text = PATHTOF(data\4500NV1.paa); + style = "48 + 0x800"; + x = "safeZoneX - 0.25"; + y = "safeZoneY + safeZoneH - 0.8"; + h = "0.75"; + w = "0.75"; + }; + class Kestrel2: Kestrel1 { + idc = 2; + text = PATHTOF(data\4500NV2.paa); + colorText[] = {0,0,0,1-(sunOrMoon*sunOrMoon+(moonIntensity/5))}; + }; + + class HUD1: RscText { + idc = 11; + type = 0; + style = 1; + text = ""; + x = "safeZoneX + 0.08"; + y = "safeZoneY + safeZoneH - 0.51"; + h = "0.09"; + w = "0.108"; + shadow = 0; + font = "PuristaMedium"; + sizeEx = 0.04; + colorText[] = {0.0745,0.2196,0.1216,0.7}; + colorBackground[] = {0,0,0,0}; + lineSpacing = 1; + }; + class HUD2: HUD1 { + idc = 12; + y = "safeZoneY + safeZoneH - 0.48"; + }; + class HUD3: HUD1 { + idc = 13; + y = "safeZoneY + safeZoneH - 0.45"; + }; + class HUD4: HUD1 { + idc = 14; + y = "safeZoneY + safeZoneH - 0.418"; + }; + }; + }; + + // helper class to prevent flickering. Used together with preloadTitleRsc command. + class ACE_Kestrel_Preload { + idd = -1; + movingEnable = 0; + duration = 1e+011; + fadein = 0; + fadeout = 0; + class controls { + class Preload_0: RscPicture { + text = PATHTOF(data\kestrel_0.paa); + }; + class Preload_1: Preload_0 { + text = PATHTOF(data\kestrel_1.paa); + }; + class Preload_2: Preload_0 { + text = PATHTOF(data\kestrel_2.paa); + }; + class Preload_3: Preload_0 { + text = PATHTOF(data\kestrel_3.paa); + }; + class Preload_4: Preload_0 { + text = PATHTOF(data\kestrel_4.paa); + }; + class Preload_5: Preload_0 { + text = PATHTOF(data\kestrel_5.paa); + }; + class Preload_6: Preload_0 { + text = PATHTOF(data\kestrel_6.paa); + }; + class Preload_7: Preload_0 { + text = PATHTOF(data\kestrel_7.paa); + }; + class Preload_8: Preload_0 { + text = PATHTOF(data\kestrel_8.paa); + }; + class Preload_9: Preload_0 { + text = PATHTOF(data\kestrel_9.paa); + }; + /*class Preload_A: Preload_0 { + text = PATHTOF(data\4500NV.paa); + }; + class Preload_B: Preload_0 { + text = PATHTOF(data\4500NV1.paa); + }; + class Preload_C: Preload_0 { + text = PATHTOF(data\4500NV2.paa); + };*/ + }; + }; +}; diff --git a/addons/kestrel/XEH_preInit.sqf b/addons/kestrel/XEH_preInit.sqf new file mode 100644 index 0000000000..d5e9174489 --- /dev/null +++ b/addons/kestrel/XEH_preInit.sqf @@ -0,0 +1,12 @@ +#include "script_component.hpp" + +ADDON = false; + +PREP(onLoadKestrel); +PREP(openKestrel); +PREP(closeKestrel); + +GVAR(isKestrel) = false; +GVAR(isKestrelWheel) = false; + +ADDON = true; diff --git a/addons/kestrel/config.cpp b/addons/kestrel/config.cpp new file mode 100644 index 0000000000..61735f1697 --- /dev/null +++ b/addons/kestrel/config.cpp @@ -0,0 +1,18 @@ +#include "script_component.hpp" + +class CfgPatches { + class ADDON { + units[] = {"ACE_Item_Kestrel"}; + weapons[] = {"ACE_Kestrel"}; + requiredVersion = REQUIRED_VERSION; + requiredAddons[] = {"ace_common","ace_interaction"}; + author[] = {"Falke","commy2","KoffeinFlummi","CAA-Picard"}; + authorUrl = "https://github.com/KoffeinFlummi/"; + VERSION_CONFIG; + }; +}; + +#include "CfgEventHandlers.hpp" +#include "CfgVehicles.hpp" +#include "CfgWeapons.hpp" +#include "RscTitles.hpp" diff --git a/addons/kestrel/data/4500NV.paa b/addons/kestrel/data/4500NV.paa new file mode 100644 index 0000000000..fd72433b9e Binary files /dev/null and b/addons/kestrel/data/4500NV.paa differ diff --git a/addons/kestrel/data/4500NV1.paa b/addons/kestrel/data/4500NV1.paa new file mode 100644 index 0000000000..9a29b346fb Binary files /dev/null and b/addons/kestrel/data/4500NV1.paa differ diff --git a/addons/kestrel/data/4500NV2.paa b/addons/kestrel/data/4500NV2.paa new file mode 100644 index 0000000000..992743a3a6 Binary files /dev/null and b/addons/kestrel/data/4500NV2.paa differ diff --git a/addons/kestrel/data/arrow1.paa b/addons/kestrel/data/arrow1.paa new file mode 100644 index 0000000000..8edb257ead Binary files /dev/null and b/addons/kestrel/data/arrow1.paa differ diff --git a/addons/kestrel/data/body.paa b/addons/kestrel/data/body.paa new file mode 100644 index 0000000000..bec55bb418 Binary files /dev/null and b/addons/kestrel/data/body.paa differ diff --git a/addons/kestrel/data/gpstemp.paa b/addons/kestrel/data/gpstemp.paa new file mode 100644 index 0000000000..ef45fe406c Binary files /dev/null and b/addons/kestrel/data/gpstemp.paa differ diff --git a/addons/kestrel/data/kestrel_0.paa b/addons/kestrel/data/kestrel_0.paa new file mode 100644 index 0000000000..190c25f100 Binary files /dev/null and b/addons/kestrel/data/kestrel_0.paa differ diff --git a/addons/kestrel/data/kestrel_1.paa b/addons/kestrel/data/kestrel_1.paa new file mode 100644 index 0000000000..fe757888e4 Binary files /dev/null and b/addons/kestrel/data/kestrel_1.paa differ diff --git a/addons/kestrel/data/kestrel_2.paa b/addons/kestrel/data/kestrel_2.paa new file mode 100644 index 0000000000..1b0fda0a65 Binary files /dev/null and b/addons/kestrel/data/kestrel_2.paa differ diff --git a/addons/kestrel/data/kestrel_3.paa b/addons/kestrel/data/kestrel_3.paa new file mode 100644 index 0000000000..659f4597a3 Binary files /dev/null and b/addons/kestrel/data/kestrel_3.paa differ diff --git a/addons/kestrel/data/kestrel_4.paa b/addons/kestrel/data/kestrel_4.paa new file mode 100644 index 0000000000..abb1ed6580 Binary files /dev/null and b/addons/kestrel/data/kestrel_4.paa differ diff --git a/addons/kestrel/data/kestrel_5.paa b/addons/kestrel/data/kestrel_5.paa new file mode 100644 index 0000000000..800ed80d8b Binary files /dev/null and b/addons/kestrel/data/kestrel_5.paa differ diff --git a/addons/kestrel/data/kestrel_6.paa b/addons/kestrel/data/kestrel_6.paa new file mode 100644 index 0000000000..784e441c21 Binary files /dev/null and b/addons/kestrel/data/kestrel_6.paa differ diff --git a/addons/kestrel/data/kestrel_7.paa b/addons/kestrel/data/kestrel_7.paa new file mode 100644 index 0000000000..9452286c2d Binary files /dev/null and b/addons/kestrel/data/kestrel_7.paa differ diff --git a/addons/kestrel/data/kestrel_8.paa b/addons/kestrel/data/kestrel_8.paa new file mode 100644 index 0000000000..31fe71ce84 Binary files /dev/null and b/addons/kestrel/data/kestrel_8.paa differ diff --git a/addons/kestrel/data/kestrel_9.paa b/addons/kestrel/data/kestrel_9.paa new file mode 100644 index 0000000000..978506ef5d Binary files /dev/null and b/addons/kestrel/data/kestrel_9.paa differ diff --git a/addons/kestrel/data/rad.paa b/addons/kestrel/data/rad.paa new file mode 100644 index 0000000000..13a3ffe6f7 Binary files /dev/null and b/addons/kestrel/data/rad.paa differ diff --git a/addons/kestrel/data/tasten.paa b/addons/kestrel/data/tasten.paa new file mode 100644 index 0000000000..8a140ec5f0 Binary files /dev/null and b/addons/kestrel/data/tasten.paa differ diff --git a/addons/kestrel/data/tasten1.paa b/addons/kestrel/data/tasten1.paa new file mode 100644 index 0000000000..af441a51de Binary files /dev/null and b/addons/kestrel/data/tasten1.paa differ diff --git a/addons/kestrel/functions/fnc_closeKestrel.sqf b/addons/kestrel/functions/fnc_closeKestrel.sqf new file mode 100644 index 0000000000..cfec327da6 --- /dev/null +++ b/addons/kestrel/functions/fnc_closeKestrel.sqf @@ -0,0 +1,6 @@ +// by commy2 +#include "script_component.hpp" + +GVAR(isKestrel) = false; + +(["ACE_Kestrel"] call BIS_fnc_rscLayer) cutText ["", "PLAIN", 0, false]; diff --git a/addons/kestrel/functions/fnc_onLoadKestrel.sqf b/addons/kestrel/functions/fnc_onLoadKestrel.sqf new file mode 100644 index 0000000000..223fc9e74b --- /dev/null +++ b/addons/kestrel/functions/fnc_onLoadKestrel.sqf @@ -0,0 +1,153 @@ +// by Falke, commy2 +#include "script_component.hpp" + +GVAR(windHead) = 0; +GVAR(wheelState) = 1; + +[{ + + // exit loop + if (!GVAR(isKestrel) || {!("ACE_Kestrel" in items ACE_player)}) exitWith { + call FUNC(closeKestrel); + + [_this select 1] call CBA_fnc_removePerFrameHandler; + }; + + // get controls + private ["_dlgKestrel", "_ctrlKestrel1", "_ctrlKestrelWheel", "_ctrlKestrel2", "_ctrlHUD1", "_ctrlHUD2", "_ctrlHUD3", "_ctrlHUD4"]; + + disableSerialization; + _dlgKestrel = _this select 0; + _ctrlKestrel1 = _dlgKestrel displayCtrl 1; + _ctrlKestrel2 = _dlgKestrel displayCtrl 2; + _ctrlKestrelWheel = _dlgKestrel displayCtrl 3; + _ctrlHUD1 = _dlgKestrel displayCtrl 11; + _ctrlHUD2 = _dlgKestrel displayCtrl 12; + _ctrlHUD3 = _dlgKestrel displayCtrl 13; + _ctrlHUD4 = _dlgKestrel displayCtrl 14; + + // don't show the kestrel in gunner view + private "_show"; + _show = cameraView != "GUNNER"; + + _ctrlKestrel1 ctrlShow _show; + _ctrlKestrel2 ctrlShow _show; + _ctrlKestrelWheel ctrlShow _show; + _ctrlHUD1 ctrlShow _show; + _ctrlHUD2 ctrlShow _show; + _ctrlHUD3 ctrlShow _show; + _ctrlHUD4 ctrlShow _show; + + if !(_show) exitWith {}; + + // handle shown values + private ["_position", "_directon", "_windC", "_windD", "_windR", "_windB", "_windA"]; + + _position = eyePos ACE_player; + _directon = direction ACE_player; + + _windC = sqrt ((wind select 0) ^ 2 + (wind select 1) ^ 2); + _windD = (wind select 0) atan2 (wind select 1); + + _windR = _directon - _windD; + + if (_windR < 0) then { + _windR = _windR + 360; + }; + + _windB = _windC * sin _windR; + _windA = sqrt (_windC ^ 2 - _windB ^ 2); + + if (_windR < 90) then { + _windA = _windA - 2 * _windA; + }; + + if (_windR > 270) then { + _windA = _windA - 2 * _windA; + }; + + // in building + _intersects = 0; + if (lineIntersects [_position, _position vectorAdd [0, 0, 15]]) then {_intersects = _intersects + 1}; + + if (lineIntersects [_position, _position vectorAdd [- 15 * sin windDir, - 15 * cos windDir, 0]]) then {_intersects = _intersects + 1}; + if (lineIntersects [_position, _position vectorAdd [- 15 * sin (windDir - 90), - 15 * cos (windDir - 90), 0]]) then {_intersects = _intersects + 1}; + if (lineIntersects [_position, _position vectorAdd [- 15 * sin (windDir + 90), - 15 * cos (windDir + 90), 0]]) then {_intersects = _intersects + 1}; + if (lineIntersects [_position, _position vectorAdd [- 15 * sin (windDir + 180), - 15 * cos (windDir + 180), 0]]) then {_intersects = _intersects + 1}; + + if (_intersects > 3) then { + _windA = 99.99; + _windB = 99.99; + }; + + // in wind direction + _intersects = 0; + if (lineIntersects [_position, _position vectorAdd [- 5 * sin windDir, - 5 * cos windDir, 0]]) then {_intersects = _intersects + 1}; + if (lineIntersects [_position, _position vectorAdd [- 5 * sin (windDir - 15), - 5 * cos (windDir - 15), 0]]) then {_intersects = _intersects + 1}; + if (lineIntersects [_position, _position vectorAdd [- 5 * sin (windDir + 15), - 5 * cos (windDir + 15), 0]]) then {_intersects = _intersects + 1}; + + if (_intersects > 2) then { + _windA = 99.99; + _windB = 99.99; + }; + + if (ACE_player != vehicle ACE_player) then { + _windA = 99.99; + _windB = 99.99; + }; + + if (_windA == 99.99) then { + + GVAR(windHead) = 0; + + _windA = "0.00"; + _windB = "0.00"; + + } else { + + GVAR(windHead) = _windA; + + if (_windA < 0) then { + _windA = format ["-%1", [-1 * _windA, 1, 2] call CBA_fnc_formatNumber]; + } else { + _windA = format [ "%1", [ _windA, 1, 2] call CBA_fnc_formatNumber]; + }; + + if (_windB < 0) then { + _windB = format ["-%1", [-1 * _windB, 1, 2] call CBA_fnc_formatNumber]; + } else { + _windB = format [ "%1", [ _windB, 1, 2] call CBA_fnc_formatNumber]; + }; + + }; + + _ctrlHUD1 ctrlSetText _windA; + _ctrlHUD2 ctrlSetText _windB; + _ctrlHUD3 ctrlSetText str round _directon; + _ctrlHUD4 ctrlSetText str ((round (0 * 10)) / 10); + + // adjust kestrel picture in the dark + private "_brightness"; + _brightness = call EFUNC(common,ambientBrightness); + + _ctrlKestrel2 ctrlSetTextColor [0, 0, 0, 1 - _brightness]; + + // handle wheel + private ["_wheelState", "_wheelStateAdd"]; + + _wheelState = GVAR(wheelState); + _wheelStateAdd = ((round GVAR(windHead) * 2) min 5) max -5; + + _wheelState = _wheelState + _wheelStateAdd; + + if (_wheelState < 0) then {_wheelState = _wheelState + 9}; + if (_wheelState > 9) then {_wheelState = _wheelState - 9}; + + GVAR(wheelState) = _wheelState; + + if (preloadTitleRsc ["ACE_Kestrel_Preload", "PLAIN"]) then { + _ctrlKestrelWheel ctrlSetText format [QUOTE(PATHTOF(data\kestrel_%1.paa)), _wheelState]; + _ctrlKestrelWheel ctrlSetTextColor [_brightness, _brightness, _brightness, 1]; + }; + +}, 0.01, _this select 0] call CBA_fnc_addPerFrameHandler; diff --git a/addons/kestrel/functions/fnc_openKestrel.sqf b/addons/kestrel/functions/fnc_openKestrel.sqf new file mode 100644 index 0000000000..25ec9eba67 --- /dev/null +++ b/addons/kestrel/functions/fnc_openKestrel.sqf @@ -0,0 +1,6 @@ +// by commy2 +#include "script_component.hpp" + +GVAR(isKestrel) = true; + +(["ACE_Kestrel"] call BIS_fnc_rscLayer) cutRsc ["ACE_Kestrel", "PLAIN", 0, false]; diff --git a/addons/kestrel/functions/script_component.hpp b/addons/kestrel/functions/script_component.hpp new file mode 100644 index 0000000000..528b26affc --- /dev/null +++ b/addons/kestrel/functions/script_component.hpp @@ -0,0 +1 @@ +#include "\z\ace\addons\kestrel\script_component.hpp" \ No newline at end of file diff --git a/addons/kestrel/kestrel4500.p3d b/addons/kestrel/kestrel4500.p3d new file mode 100644 index 0000000000..43cb6ce9d5 Binary files /dev/null and b/addons/kestrel/kestrel4500.p3d differ diff --git a/addons/kestrel/kestrel4500rad.p3d b/addons/kestrel/kestrel4500rad.p3d new file mode 100644 index 0000000000..7b2b62ccf5 Binary files /dev/null and b/addons/kestrel/kestrel4500rad.p3d differ diff --git a/addons/kestrel/script_component.hpp b/addons/kestrel/script_component.hpp new file mode 100644 index 0000000000..a38231c511 --- /dev/null +++ b/addons/kestrel/script_component.hpp @@ -0,0 +1,12 @@ +#define COMPONENT kestrel +#include "\z\ace\addons\main\script_mod.hpp" + +#ifdef DEBUG_ENABLED_KESTREL + #define DEBUG_MODE_FULL +#endif + +#ifdef DEBUG_ENABLED_KESTREL + #define DEBUG_SETTINGS DEBUG_ENABLED_KESTREL +#endif + +#include "\z\ace\addons\main\script_macros.hpp" \ No newline at end of file diff --git a/addons/kestrel/stringtable.xml b/addons/kestrel/stringtable.xml new file mode 100644 index 0000000000..5f54fd6489 --- /dev/null +++ b/addons/kestrel/stringtable.xml @@ -0,0 +1,64 @@ + + + + + + Approximate Temperature + Ungefähre Temperatur + Temperatura aproximada + Estimer la température + Przybliżona temperatura + Odhadovaná teplota + Hőmérséklet nagyábol + Примерная температура + + + Kestrel 4500NV + Kestrel 4500NV + Kestrel 4500NV + Kestrel 4500NV + Kestrel 4500NV + Kestrel 4500NV + Kestrel 4500NV + Kestrel 4500NV + Kestrel 4500NV + Kestrel 4500NV + + + Applied Ballistics Meter + Applied Ballistics Meter + Anemómetro balístico + Applied Ballistics Meter + Urządzenie do monitorowania pogody + Zařízení pro měření vítru + Monitoraggio Balistico Attivo + Applied Ballistics Meter + Medidor Balístico Ativo + метеостанция + + + Open Kestrel + Kestrel öffnen + Abrir Kestrel + Ouvrir Kestrel + Otwórz Kestrel + Otevřít Kestrel + Abrir Kestrel + Apri Kestrel + Kestrel bekapcsolása + Открыть Kestrel + + + Close Kestrel + Kestrel schließen + Cerrar Kestrel + Fermer Kestrel + Zamknij Kestrel + Zavřít Kestrel + Fechar Kestrel + Chiudi Kestrel + Kestrel kikapcsolása + Закрыть Kestrel + + + \ No newline at end of file diff --git a/addons/kestrel/ui/WindLight-01.paa b/addons/kestrel/ui/WindLight-01.paa new file mode 100644 index 0000000000..9865029c93 Binary files /dev/null and b/addons/kestrel/ui/WindLight-01.paa differ diff --git a/addons/kestrel/ui/WindLight-02.paa b/addons/kestrel/ui/WindLight-02.paa new file mode 100644 index 0000000000..a02147e6ee Binary files /dev/null and b/addons/kestrel/ui/WindLight-02.paa differ diff --git a/addons/kestrel/ui/WindLight-03.paa b/addons/kestrel/ui/WindLight-03.paa new file mode 100644 index 0000000000..340cfdcd6e Binary files /dev/null and b/addons/kestrel/ui/WindLight-03.paa differ diff --git a/addons/kestrel/ui/WindLight-04.paa b/addons/kestrel/ui/WindLight-04.paa new file mode 100644 index 0000000000..6d8404fb86 Binary files /dev/null and b/addons/kestrel/ui/WindLight-04.paa differ diff --git a/addons/kestrel/ui/WindLight-05.paa b/addons/kestrel/ui/WindLight-05.paa new file mode 100644 index 0000000000..2de5cdbd74 Binary files /dev/null and b/addons/kestrel/ui/WindLight-05.paa differ diff --git a/addons/kestrel/ui/WindLight-06.paa b/addons/kestrel/ui/WindLight-06.paa new file mode 100644 index 0000000000..c5e0a40af7 Binary files /dev/null and b/addons/kestrel/ui/WindLight-06.paa differ diff --git a/addons/kestrel/ui/WindLight-07.paa b/addons/kestrel/ui/WindLight-07.paa new file mode 100644 index 0000000000..4df57f7585 Binary files /dev/null and b/addons/kestrel/ui/WindLight-07.paa differ diff --git a/addons/kestrel/ui/WindLight-08.paa b/addons/kestrel/ui/WindLight-08.paa new file mode 100644 index 0000000000..8c5012502f Binary files /dev/null and b/addons/kestrel/ui/WindLight-08.paa differ diff --git a/addons/kestrel/ui/WindLight-09.paa b/addons/kestrel/ui/WindLight-09.paa new file mode 100644 index 0000000000..15173a56ab Binary files /dev/null and b/addons/kestrel/ui/WindLight-09.paa differ diff --git a/addons/kestrel/ui/WindLight-10.paa b/addons/kestrel/ui/WindLight-10.paa new file mode 100644 index 0000000000..83c860cecb Binary files /dev/null and b/addons/kestrel/ui/WindLight-10.paa differ diff --git a/addons/kestrel/ui/WindLight-11.paa b/addons/kestrel/ui/WindLight-11.paa new file mode 100644 index 0000000000..8beeb80d98 Binary files /dev/null and b/addons/kestrel/ui/WindLight-11.paa differ diff --git a/addons/kestrel/ui/WindLight-12.paa b/addons/kestrel/ui/WindLight-12.paa new file mode 100644 index 0000000000..d9a62f9e81 Binary files /dev/null and b/addons/kestrel/ui/WindLight-12.paa differ diff --git a/addons/kestrel/ui/WindLight-13.paa b/addons/kestrel/ui/WindLight-13.paa new file mode 100644 index 0000000000..87a8dfcca9 Binary files /dev/null and b/addons/kestrel/ui/WindLight-13.paa differ diff --git a/addons/kestrel/ui/WindLight-14.paa b/addons/kestrel/ui/WindLight-14.paa new file mode 100644 index 0000000000..f9200aaf2d Binary files /dev/null and b/addons/kestrel/ui/WindLight-14.paa differ diff --git a/addons/kestrel/ui/WindLight-15.paa b/addons/kestrel/ui/WindLight-15.paa new file mode 100644 index 0000000000..e3ee52d21e Binary files /dev/null and b/addons/kestrel/ui/WindLight-15.paa differ diff --git a/addons/kestrel/ui/WindLight-16.paa b/addons/kestrel/ui/WindLight-16.paa new file mode 100644 index 0000000000..9b835e62c4 Binary files /dev/null and b/addons/kestrel/ui/WindLight-16.paa differ diff --git a/addons/kestrel/ui/WindModerate-01.paa b/addons/kestrel/ui/WindModerate-01.paa new file mode 100644 index 0000000000..fd4d255c35 Binary files /dev/null and b/addons/kestrel/ui/WindModerate-01.paa differ diff --git a/addons/kestrel/ui/WindModerate-02.paa b/addons/kestrel/ui/WindModerate-02.paa new file mode 100644 index 0000000000..db6e8dcebc Binary files /dev/null and b/addons/kestrel/ui/WindModerate-02.paa differ diff --git a/addons/kestrel/ui/WindModerate-03.paa b/addons/kestrel/ui/WindModerate-03.paa new file mode 100644 index 0000000000..300934ff37 Binary files /dev/null and b/addons/kestrel/ui/WindModerate-03.paa differ diff --git a/addons/kestrel/ui/WindModerate-04.paa b/addons/kestrel/ui/WindModerate-04.paa new file mode 100644 index 0000000000..f7b8331dae Binary files /dev/null and b/addons/kestrel/ui/WindModerate-04.paa differ diff --git a/addons/kestrel/ui/WindModerate-05.paa b/addons/kestrel/ui/WindModerate-05.paa new file mode 100644 index 0000000000..a3b0a532ff Binary files /dev/null and b/addons/kestrel/ui/WindModerate-05.paa differ diff --git a/addons/kestrel/ui/WindModerate-06.paa b/addons/kestrel/ui/WindModerate-06.paa new file mode 100644 index 0000000000..495ec6bc15 Binary files /dev/null and b/addons/kestrel/ui/WindModerate-06.paa differ diff --git a/addons/kestrel/ui/WindModerate-07.paa b/addons/kestrel/ui/WindModerate-07.paa new file mode 100644 index 0000000000..d0471a4c4f Binary files /dev/null and b/addons/kestrel/ui/WindModerate-07.paa differ diff --git a/addons/kestrel/ui/WindModerate-08.paa b/addons/kestrel/ui/WindModerate-08.paa new file mode 100644 index 0000000000..967e9d8ef7 Binary files /dev/null and b/addons/kestrel/ui/WindModerate-08.paa differ diff --git a/addons/kestrel/ui/WindModerate-09.paa b/addons/kestrel/ui/WindModerate-09.paa new file mode 100644 index 0000000000..54ef3eabf9 Binary files /dev/null and b/addons/kestrel/ui/WindModerate-09.paa differ diff --git a/addons/kestrel/ui/WindModerate-10.paa b/addons/kestrel/ui/WindModerate-10.paa new file mode 100644 index 0000000000..e7608c2e02 Binary files /dev/null and b/addons/kestrel/ui/WindModerate-10.paa differ diff --git a/addons/kestrel/ui/WindModerate-11.paa b/addons/kestrel/ui/WindModerate-11.paa new file mode 100644 index 0000000000..6d1ce9418e Binary files /dev/null and b/addons/kestrel/ui/WindModerate-11.paa differ diff --git a/addons/kestrel/ui/WindModerate-12.paa b/addons/kestrel/ui/WindModerate-12.paa new file mode 100644 index 0000000000..2b853dca89 Binary files /dev/null and b/addons/kestrel/ui/WindModerate-12.paa differ diff --git a/addons/kestrel/ui/WindModerate-13.paa b/addons/kestrel/ui/WindModerate-13.paa new file mode 100644 index 0000000000..56443ab4f9 Binary files /dev/null and b/addons/kestrel/ui/WindModerate-13.paa differ diff --git a/addons/kestrel/ui/WindModerate-14.paa b/addons/kestrel/ui/WindModerate-14.paa new file mode 100644 index 0000000000..06cb4610fb Binary files /dev/null and b/addons/kestrel/ui/WindModerate-14.paa differ diff --git a/addons/kestrel/ui/WindModerate-15.paa b/addons/kestrel/ui/WindModerate-15.paa new file mode 100644 index 0000000000..5f548b6ac9 Binary files /dev/null and b/addons/kestrel/ui/WindModerate-15.paa differ diff --git a/addons/kestrel/ui/WindModerate-16.paa b/addons/kestrel/ui/WindModerate-16.paa new file mode 100644 index 0000000000..617e83193d Binary files /dev/null and b/addons/kestrel/ui/WindModerate-16.paa differ diff --git a/addons/kestrel/ui/WindStrong-01.paa b/addons/kestrel/ui/WindStrong-01.paa new file mode 100644 index 0000000000..87c2db663c Binary files /dev/null and b/addons/kestrel/ui/WindStrong-01.paa differ diff --git a/addons/kestrel/ui/WindStrong-02.paa b/addons/kestrel/ui/WindStrong-02.paa new file mode 100644 index 0000000000..8d29483635 Binary files /dev/null and b/addons/kestrel/ui/WindStrong-02.paa differ diff --git a/addons/kestrel/ui/WindStrong-03.paa b/addons/kestrel/ui/WindStrong-03.paa new file mode 100644 index 0000000000..fc08f14e1b Binary files /dev/null and b/addons/kestrel/ui/WindStrong-03.paa differ diff --git a/addons/kestrel/ui/WindStrong-04.paa b/addons/kestrel/ui/WindStrong-04.paa new file mode 100644 index 0000000000..3fbbd70302 Binary files /dev/null and b/addons/kestrel/ui/WindStrong-04.paa differ diff --git a/addons/kestrel/ui/WindStrong-05.paa b/addons/kestrel/ui/WindStrong-05.paa new file mode 100644 index 0000000000..2254b0d545 Binary files /dev/null and b/addons/kestrel/ui/WindStrong-05.paa differ diff --git a/addons/kestrel/ui/WindStrong-06.paa b/addons/kestrel/ui/WindStrong-06.paa new file mode 100644 index 0000000000..6054696d61 Binary files /dev/null and b/addons/kestrel/ui/WindStrong-06.paa differ diff --git a/addons/kestrel/ui/WindStrong-07.paa b/addons/kestrel/ui/WindStrong-07.paa new file mode 100644 index 0000000000..d62308dfc9 Binary files /dev/null and b/addons/kestrel/ui/WindStrong-07.paa differ diff --git a/addons/kestrel/ui/WindStrong-08.paa b/addons/kestrel/ui/WindStrong-08.paa new file mode 100644 index 0000000000..cce04ab099 Binary files /dev/null and b/addons/kestrel/ui/WindStrong-08.paa differ diff --git a/addons/kestrel/ui/WindStrong-09.paa b/addons/kestrel/ui/WindStrong-09.paa new file mode 100644 index 0000000000..e2c53aec6f Binary files /dev/null and b/addons/kestrel/ui/WindStrong-09.paa differ diff --git a/addons/kestrel/ui/WindStrong-10.paa b/addons/kestrel/ui/WindStrong-10.paa new file mode 100644 index 0000000000..609b54096a Binary files /dev/null and b/addons/kestrel/ui/WindStrong-10.paa differ diff --git a/addons/kestrel/ui/WindStrong-11.paa b/addons/kestrel/ui/WindStrong-11.paa new file mode 100644 index 0000000000..705cc5bd10 Binary files /dev/null and b/addons/kestrel/ui/WindStrong-11.paa differ diff --git a/addons/kestrel/ui/WindStrong-12.paa b/addons/kestrel/ui/WindStrong-12.paa new file mode 100644 index 0000000000..d8d585d6eb Binary files /dev/null and b/addons/kestrel/ui/WindStrong-12.paa differ diff --git a/addons/kestrel/ui/WindStrong-13.paa b/addons/kestrel/ui/WindStrong-13.paa new file mode 100644 index 0000000000..d903c832ab Binary files /dev/null and b/addons/kestrel/ui/WindStrong-13.paa differ diff --git a/addons/kestrel/ui/WindStrong-14.paa b/addons/kestrel/ui/WindStrong-14.paa new file mode 100644 index 0000000000..91153a801b Binary files /dev/null and b/addons/kestrel/ui/WindStrong-14.paa differ diff --git a/addons/kestrel/ui/WindStrong-15.paa b/addons/kestrel/ui/WindStrong-15.paa new file mode 100644 index 0000000000..d0a34d79e4 Binary files /dev/null and b/addons/kestrel/ui/WindStrong-15.paa differ diff --git a/addons/kestrel/ui/WindStrong-16.paa b/addons/kestrel/ui/WindStrong-16.paa new file mode 100644 index 0000000000..1be25039e4 Binary files /dev/null and b/addons/kestrel/ui/WindStrong-16.paa differ diff --git a/addons/kestrel/ui/WindVeryLight-01.paa b/addons/kestrel/ui/WindVeryLight-01.paa new file mode 100644 index 0000000000..561e52ec88 Binary files /dev/null and b/addons/kestrel/ui/WindVeryLight-01.paa differ diff --git a/addons/kestrel/ui/WindVeryLight-02.paa b/addons/kestrel/ui/WindVeryLight-02.paa new file mode 100644 index 0000000000..fbce91664a Binary files /dev/null and b/addons/kestrel/ui/WindVeryLight-02.paa differ diff --git a/addons/kestrel/ui/WindVeryLight-03.paa b/addons/kestrel/ui/WindVeryLight-03.paa new file mode 100644 index 0000000000..f20ced9770 Binary files /dev/null and b/addons/kestrel/ui/WindVeryLight-03.paa differ diff --git a/addons/kestrel/ui/WindVeryLight-04.paa b/addons/kestrel/ui/WindVeryLight-04.paa new file mode 100644 index 0000000000..6b104848da Binary files /dev/null and b/addons/kestrel/ui/WindVeryLight-04.paa differ diff --git a/addons/kestrel/ui/WindVeryLight-05.paa b/addons/kestrel/ui/WindVeryLight-05.paa new file mode 100644 index 0000000000..f8e30a0c64 Binary files /dev/null and b/addons/kestrel/ui/WindVeryLight-05.paa differ diff --git a/addons/kestrel/ui/WindVeryLight-06.paa b/addons/kestrel/ui/WindVeryLight-06.paa new file mode 100644 index 0000000000..3a11d94cba Binary files /dev/null and b/addons/kestrel/ui/WindVeryLight-06.paa differ diff --git a/addons/kestrel/ui/WindVeryLight-07.paa b/addons/kestrel/ui/WindVeryLight-07.paa new file mode 100644 index 0000000000..b956cb478b Binary files /dev/null and b/addons/kestrel/ui/WindVeryLight-07.paa differ diff --git a/addons/kestrel/ui/WindVeryLight-08.paa b/addons/kestrel/ui/WindVeryLight-08.paa new file mode 100644 index 0000000000..090f630d8f Binary files /dev/null and b/addons/kestrel/ui/WindVeryLight-08.paa differ diff --git a/addons/kestrel/ui/WindVeryLight-09.paa b/addons/kestrel/ui/WindVeryLight-09.paa new file mode 100644 index 0000000000..d8b8b7eff1 Binary files /dev/null and b/addons/kestrel/ui/WindVeryLight-09.paa differ diff --git a/addons/kestrel/ui/WindVeryLight-10.paa b/addons/kestrel/ui/WindVeryLight-10.paa new file mode 100644 index 0000000000..0151ad3779 Binary files /dev/null and b/addons/kestrel/ui/WindVeryLight-10.paa differ diff --git a/addons/kestrel/ui/WindVeryLight-11.paa b/addons/kestrel/ui/WindVeryLight-11.paa new file mode 100644 index 0000000000..241980a1e0 Binary files /dev/null and b/addons/kestrel/ui/WindVeryLight-11.paa differ diff --git a/addons/kestrel/ui/WindVeryLight-12.paa b/addons/kestrel/ui/WindVeryLight-12.paa new file mode 100644 index 0000000000..adcaf136fa Binary files /dev/null and b/addons/kestrel/ui/WindVeryLight-12.paa differ diff --git a/addons/kestrel/ui/WindVeryLight-13.paa b/addons/kestrel/ui/WindVeryLight-13.paa new file mode 100644 index 0000000000..d381f0cc9e Binary files /dev/null and b/addons/kestrel/ui/WindVeryLight-13.paa differ diff --git a/addons/kestrel/ui/WindVeryLight-14.paa b/addons/kestrel/ui/WindVeryLight-14.paa new file mode 100644 index 0000000000..0e77f697e2 Binary files /dev/null and b/addons/kestrel/ui/WindVeryLight-14.paa differ diff --git a/addons/kestrel/ui/WindVeryLight-15.paa b/addons/kestrel/ui/WindVeryLight-15.paa new file mode 100644 index 0000000000..ad283a4d76 Binary files /dev/null and b/addons/kestrel/ui/WindVeryLight-15.paa differ diff --git a/addons/kestrel/ui/WindVeryLight-16.paa b/addons/kestrel/ui/WindVeryLight-16.paa new file mode 100644 index 0000000000..b7ae70a989 Binary files /dev/null and b/addons/kestrel/ui/WindVeryLight-16.paa differ diff --git a/addons/kestrel/ui/noWind.paa b/addons/kestrel/ui/noWind.paa new file mode 100644 index 0000000000..8fa262c286 Binary files /dev/null and b/addons/kestrel/ui/noWind.paa differ diff --git a/addons/markers/$PBOPREFIX$ b/addons/markers/$PBOPREFIX$ new file mode 100644 index 0000000000..c385330d39 --- /dev/null +++ b/addons/markers/$PBOPREFIX$ @@ -0,0 +1 @@ +z\ace\addons\markers \ No newline at end of file diff --git a/addons/markers/CfgEventHandlers.hpp b/addons/markers/CfgEventHandlers.hpp new file mode 100644 index 0000000000..0cd959a047 --- /dev/null +++ b/addons/markers/CfgEventHandlers.hpp @@ -0,0 +1,12 @@ + +class Extended_PreInit_EventHandlers { + class ADDON { + init = QUOTE(call COMPILE_FILE(XEH_preInit)); + }; +}; + +class Extended_PostInit_EventHandlers { + class ADDON { + init = QUOTE(call COMPILE_FILE(XEH_postInit)); + }; +}; diff --git a/addons/markers/InsertMarker.hpp b/addons/markers/InsertMarker.hpp new file mode 100644 index 0000000000..3cf32943c4 --- /dev/null +++ b/addons/markers/InsertMarker.hpp @@ -0,0 +1,147 @@ + +class RscPicture; +class RscText; +class RscStructuredText; +class RscButtonMenuOK; +class RscButtonMenuCancel; +class RscButtonMenu; +class RscEdit; +class RscCombo; +class RscSlider; +class RscXSliderH; + +class RscDisplayInsertMarker { + onLoad = QUOTE(_this call DFUNC(initInsertMarker);); + onUnload = QUOTE(_this call DFUNC(placeMarker);); + idd = 54; + movingEnable = 1; + class controlsBackground { + class RscText_1000: RscText { + idc = 1000; + /*x = "0 * GUI_GRID_INSERTMARKER_W + GUI_GRID_INSERTMARKER_X"; + y = "0 * GUI_GRID_INSERTMARKER_H + GUI_GRID_INSERTMARKER_Y"; + w = "8 * GUI_GRID_INSERTMARKER_W"; + h = "2.5 * GUI_GRID_INSERTMARKER_H"; + colorBackground[] = {0,0,0,0.5};*/ + }; + class Description: RscStructuredText { + colorBackground[] = {0,0,0,0.7}; + idc = 1100; + x = "14 * ( ((safezoneW / safezoneH) min 1.2) / 40) + (safezoneX)"; + y = "9.5 * ( ( ((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + safezoneH - ( ((safezoneW / safezoneH) min 1.2) / 1.2))"; + w = "10 * ( ((safezoneW / safezoneH) min 1.2) / 40)"; + h = "1 * ( ( ((safezoneW / safezoneH) min 1.2) / 1.2) / 25)"; + }; + }; + class controls { + //delete ButtonOK; + class ButtonMenuOK: RscButtonMenuOK { + x = "14 * ( ((safezoneW / safezoneH) min 1.2) / 40) + (safezoneX)"; + y = "15.5 * ( ( ((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + safezoneH - ( ((safezoneW / safezoneH) min 1.2) / 1.2))"; + w = "8.9 * ( ((safezoneW / safezoneH) min 1.2) / 40)"; + h = "1 * ( ( ((safezoneW / safezoneH) min 1.2) / 1.2) / 25)"; + // size = "0.85 * ( ( ( ((safezoneW / safezoneH) min 1.2) / 1.2) / 25) * 1)"; + // sizeEx = "0.85 * ( ( ( ((safezoneW / safezoneH) min 1.2) / 1.2) / 25) * 1)"; + text = ""; + }; + class ButtonMenuCancel: RscButtonMenuCancel { + x = "23 * ( ((safezoneW / safezoneH) min 1.2) / 40) + (safezoneX)"; + y = "15.5 * ( ( ((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + safezoneH - ( ((safezoneW / safezoneH) min 1.2) / 1.2))"; + w = "1.1 * ( ((safezoneW / safezoneH) min 1.2) / 40)"; + h = "1 * ( ( ((safezoneW / safezoneH) min 1.2) / 1.2) / 25)"; + + text = "X"; + colorBackground[] = {0.75,0,0,0.5}; + colorBackgroundFocused[] = {0.75,0,0,0.5}; + colorBackground2[] = {1,0,0,0.5}; + }; + /*class ButtonMenuInfo: RscButtonMenu { + idc = 2400; + text = "$STR_A3_RscDisplayInsertMarker_ButtonMenuInfo"; + x = "14 * ( ((safezoneW / safezoneH) min 1.2) / 40) + (safezoneX)"; + y = "13.5 * ( ( ((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + safezoneH - ( ((safezoneW / safezoneH) min 1.2) / 1.2))"; + w = "10 * ( ((safezoneW / safezoneH) min 1.2) / 40)"; + h = "1 * ( ( ((safezoneW / safezoneH) min 1.2) / 1.2) / 25)"; + };*/ + delete ButtonMenuInfo; + class Title: RscText { + moving = 1; + colorBackground[] = {"(profilenamespace getvariable ['GUI_BCG_RGB_R',0.69])","(profilenamespace getvariable ['GUI_BCG_RGB_G',0.75])","(profilenamespace getvariable ['GUI_BCG_RGB_B',0.5])","(profilenamespace getvariable ['GUI_BCG_RGB_A',0.8])"}; + idc = 1001; + text = "$STR_A3_RscDisplayInsertMarker_Title"; + x = "14 * ( ((safezoneW / safezoneH) min 1.2) / 40) + (safezoneX)"; + y = "8.5 * ( ( ((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + safezoneH - ( ((safezoneW / safezoneH) min 1.2) / 1.2))"; + w = "10 * ( ((safezoneW / safezoneH) min 1.2) / 40)"; + h = "1 * ( ( ((safezoneW / safezoneH) min 1.2) / 1.2) / 25)"; + }; + delete Description; + /*class Info: RscStructuredText { + colorBackground[] = {0,0,0,0.7}; + idc = 1101; + x = "14 * ( ((safezoneW / safezoneH) min 1.2) / 40) + (safezoneX)"; + y = "11.5 * ( ( ((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + safezoneH - ( ((safezoneW / safezoneH) min 1.2) / 1.2))"; + w = "10 * ( ((safezoneW / safezoneH) min 1.2) / 40)"; + h = "1 * ( ( ((safezoneW / safezoneH) min 1.2) / 1.2) / 25)"; + };*/ + delete Info; + class Picture: RscPicture { + idc = 102; + x = 0.259984; + y = 0.4; + w = 0.05; + h = 0.0666667; + }; + class Text: RscEdit { + idc = 101; + x = "14 * ( ((safezoneW / safezoneH) min 1.2) / 40) + (safezoneX)"; + y = "10.5 * ( ( ((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + safezoneH - ( ((safezoneW / safezoneH) min 1.2) / 1.2))"; + w = "10 * ( ((safezoneW / safezoneH) min 1.2) / 40)"; + h = "1 * ( ( ((safezoneW / safezoneH) min 1.2) / 1.2) / 25)"; + }; + /*class SizeX: RscEdit { + idc = 1200; + text = "10"; + x = "14 * ( ((safezoneW / safezoneH) min 1.2) / 40) + (safezoneX)"; + y = "12.5 * ( ( ((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + safezoneH - ( ((safezoneW / safezoneH) min 1.2) / 1.2))"; + w = "5 * ( ((safezoneW / safezoneH) min 1.2) / 40)"; + h = "1 * ( ( ((safezoneW / safezoneH) min 1.2) / 1.2) / 25)"; + }; + class SizeY: RscEdit { + idc = 1201; + text = "10"; + x = "19 * ( ((safezoneW / safezoneH) min 1.2) / 40) + (safezoneX)"; + y = "12.5 * ( ( ((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + safezoneH - ( ((safezoneW / safezoneH) min 1.2) / 1.2))"; + w = "5 * ( ((safezoneW / safezoneH) min 1.2) / 40)"; + h = "1 * ( ( ((safezoneW / safezoneH) min 1.2) / 1.2) / 25)"; + };*/ + class MarkerShape: RscCombo { + idc = 1210; + x = "14 * ( ((safezoneW / safezoneH) min 1.2) / 40) + (safezoneX)"; + y = "11.5 * ( ( ((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + safezoneH - ( ((safezoneW / safezoneH) min 1.2) / 1.2))"; + w = "10 * ( ((safezoneW / safezoneH) min 1.2) / 40)"; + h = "1 * ( ( ((safezoneW / safezoneH) min 1.2) / 1.2) / 25)"; + }; + class MarkerColor: RscCombo { + idc = 1211; + x = "14 * ( ((safezoneW / safezoneH) min 1.2) / 40) + (safezoneX)"; + y = "12.5 * ( ( ((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + safezoneH - ( ((safezoneW / safezoneH) min 1.2) / 1.2))"; + w = "10 * ( ((safezoneW / safezoneH) min 1.2) / 40)"; + h = "1 * ( ( ((safezoneW / safezoneH) min 1.2) / 1.2) / 25)"; + }; + class MarkerAngle: RscXSliderH { + idc = 1220; + text = "10"; + x = "14 * ( ((safezoneW / safezoneH) min 1.2) / 40) + (safezoneX)"; + y = "13.5 * ( ( ((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + safezoneH - ( ((safezoneW / safezoneH) min 1.2) / 1.2))"; + w = "10 * ( ((safezoneW / safezoneH) min 1.2) / 40)"; + h = "1 * ( ( ((safezoneW / safezoneH) min 1.2) / 1.2) / 25)"; + }; + class MarkerAngleText: RscText { + idc = 1221; + x = "14 * ( ((safezoneW / safezoneH) min 1.2) / 40) + (safezoneX)"; + y = "14.5 * ( ( ((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + safezoneH - ( ((safezoneW / safezoneH) min 1.2) / 1.2))"; + w = "10 * ( ((safezoneW / safezoneH) min 1.2) / 40)"; + h = "1 * ( ( ((safezoneW / safezoneH) min 1.2) / 1.2) / 25)"; + }; + }; +}; diff --git a/addons/markers/XEH_postInit.sqf b/addons/markers/XEH_postInit.sqf new file mode 100644 index 0000000000..eea149f294 --- /dev/null +++ b/addons/markers/XEH_postInit.sqf @@ -0,0 +1,16 @@ +// by commy2 +#include "script_component.hpp" + +// recieve remote marker data +[QGVAR(setMarkerNetwork), {_this call DFUNC(setMarkerNetwork)}] call EFUNC(common,addEventHandler); + +// recieve marker data for JIP +[QGVAR(setMarkerJIP), {_this call DFUNC(setMarkerJIP)}] call EFUNC(common,addEventHandler); + +// request marker data for JIP +if (isMultiplayer && {!isServer} && {hasInterface}) then { + private "_logic"; + _logic = createGroup sideLogic createUnit ["Logic", [0,0,0], [], 0, "NONE"]; + + [QGVAR(sendMarkersJIP), _logic] call EFUNC(common,serverEvent); +}; diff --git a/addons/markers/XEH_preInit.sqf b/addons/markers/XEH_preInit.sqf new file mode 100644 index 0000000000..6ac258ed2a --- /dev/null +++ b/addons/markers/XEH_preInit.sqf @@ -0,0 +1,74 @@ +#include "script_component.hpp" + +PREP(initInsertMarker); +PREP(onLBSelChangedColor); +PREP(onLBSelChangedShape); +PREP(onSliderPosChangedAngle); +PREP(placeMarker); +PREP(sendMarkersJIP); +PREP(setMarkerJIP); +PREP(setMarkerNetwork); + +// init marker types +if (isNil QGVAR(MarkersCache)) then { + _config = configfile >> "CfgMarkers"; + _index = 0; + + GVAR(MarkersCache) = []; + + for "_a" from 0 to (count _config - 1) do { + _marker = _config select _a; + + _scope = getNumber (_marker >> "scope"); + _name = getText (_marker >> "name"); + _icon = getText (_marker >> "icon"); + + if (_scope == 2) then { + _shape lbAdd _name; + _shape lbSetValue [_index, _a]; + _shape lbSetPicture [_index, _icon]; + + GVAR(MarkersCache) pushBack [_name, _a, _icon]; + + _index = _index + 1; + }; + }; +}; + +// init marker colors +if (isNil QGVAR(MarkerColorsCache)) then { + _config = configfile >> "CfgMarkerColors"; + _index = 0; + + GVAR(MarkerColorsCache) = []; + + for "_a" from 0 to (count _config - 1) do { + _marker = _config select _a; + + _scope = getNumber (_marker >> "scope"); + _name = getText (_marker >> "name"); + + if (_scope == 2) then { + _color lbAdd _name; + _color lbSetValue [_index, _a]; + + _rgba = getArray (_marker >> "color"); + + { + if (typeName _x != "SCALAR") then { + _rgba set [_forEachIndex, call compile _x]; + }; + } forEach _rgba; + + _icon = format ["#(argb,8,8,3)color(%1,%2,%3,%4)", _rgba select 0, _rgba select 1, _rgba select 2, _rgba select 3]; + + _color lbSetPicture [_index, _icon]; + + GVAR(MarkerColorsCache) pushBack [_name, _a, _icon]; + + _index = _index + 1; + }; + }; +}; + +[QGVAR(sendMarkersJIP), FUNC(sendMarkersJIP)] call EFUNC(common,addEventHandler); diff --git a/addons/markers/config.cpp b/addons/markers/config.cpp new file mode 100644 index 0000000000..24d3c778d8 --- /dev/null +++ b/addons/markers/config.cpp @@ -0,0 +1,16 @@ +#include "script_component.hpp" + +class CfgPatches { + class ADDON { + units[] = {}; + weapons[] = {}; + requiredVersion = REQUIRED_VERSION; + requiredAddons[] = {"ace_common"}; + author[] = {"commy2"}; + authorUrl = "https://github.com/commy2/"; + VERSION_CONFIG; + }; +}; + +#include "CfgEventHandlers.hpp" +#include "InsertMarker.hpp" diff --git a/TO_MERGE/agm/Markers/scripts/initInsertMarker.sqf b/addons/markers/functions/fnc_initInsertMarker.sqf similarity index 58% rename from TO_MERGE/agm/Markers/scripts/initInsertMarker.sqf rename to addons/markers/functions/fnc_initInsertMarker.sqf index 37a5544bca..d172c6a532 100644 --- a/TO_MERGE/agm/Markers/scripts/initInsertMarker.sqf +++ b/addons/markers/functions/fnc_initInsertMarker.sqf @@ -1,18 +1,18 @@ // stuff taken from bohemia, edited by commy2 +#include "script_component.hpp" #define BORDER 0.005 -with uinamespace do { - _this spawn { +[{ disableserialization; _display = _this select 0; //Prevent Captive Players from placing markers - if (AGM_player getVariable ["AGM_isCaptive", false]) exitWith { - _display closeDisplay 2; //emulate "Cancel" button - }; + /*if (ACE_player getVariable ["ACE_isCaptive", false]) exitWith { + _display closeDisplay 2; //emulate "Cancel" button + };*/ - // display vanilla key input + // prevent vanilla key input _display displayAddEventHandler ["KeyDown", {(_this select 1) in [200, 208]}]; _text = _display displayctrl 101; @@ -31,47 +31,41 @@ with uinamespace do { ctrlSetFocus _text; //Change ok button's text based on current channel - [_buttonOK] spawn { - disableserialization; - private ["_buttonOK", "_channel", "_textColor"]; - _buttonOK = _this select 0; + //if (isNull _buttonOK) exitWith {true}; - waitUntil { - if (isNull _buttonOK) exitWith {true}; - _textColor = [1,1,1,1]; - switch (call AGM_Core_fnc_currentChannel) do { - case ("global"): { + _channel = ""; + _textColor = [1,1,1,1]; + switch (call EFUNC(common,currentChannel)) do { + case ("global"): { _channel = localize "str_channel_global"; _textColor = [(216/255),(216/255),(216/255),1]; - }; - case ("side"): { + }; + case ("side"): { _channel = localize "str_channel_side"; _textColor = [(70/255),(211/255),(252/255),1]; - }; - case ("group"): { + }; + case ("group"): { _channel = localize "str_channel_group"; _textColor = [(181/255),(248/255),(98/255),1]; - }; - case ("vehicle"): { + }; + case ("vehicle"): { _channel = localize "str_channel_vehicle"; _textColor = [(255/255),(208/255),(0/255),1]; - }; - case ("direct"): { + }; + case ("direct"): { _channel = localize "str_channel_direct"; _textColor = [(255/255),(255/255),(255/255),1]; - }; - case ("command"): { + }; + case ("command"): { _channel = localize "str_channel_command"; _textColor = [(255/255),(255/255),(70/255),1]; - }; }; - //If localization not found, then don't touch anything (default is RscButtonMenuOK's localized text) - if (_channel != "") then { - _buttonOK ctrlSetTextColor _textColor; - _buttonOK ctrlSetText format [localize "STR_AGM_Markers_PlaceIn", _channel]; - }; - false - }; + }; + + //If localization not found, then don't touch anything (default is RscButtonMenuOK's localized text) + if (_channel != "") then { + _buttonOK ctrlSetTextColor _textColor; + _buttonOK ctrlSetText format [localize "STR_ACE_Markers_PlaceIn", _channel]; }; //--- Background @@ -150,40 +144,15 @@ with uinamespace do { // init marker shape lb - _config = configfile >> "CfgMarkers"; - _index = 0; - - if (isNil "AGM_Markers_MarkersCache") then { - AGM_Markers_MarkersCache = []; - - for "_a" from 0 to (count _config - 1) do { - _marker = _config select _a; - - _scope = getNumber (_marker >> "scope"); - _name = getText (_marker >> "name"); - _icon = getText (_marker >> "icon"); - - if (_scope == 2) then { - _shape lbAdd _name; - _shape lbSetValue [_index, _a]; - _shape lbSetPicture [_index, _icon]; - - AGM_Markers_MarkersCache pushBack [_name, _a, _icon]; - - _index = _index + 1; - }; - }; - } else { - { + { _shape lbAdd (_x select 0); _shape lbSetValue [_forEachIndex, _x select 1]; _shape lbSetPicture [_forEachIndex, _x select 2]; - } forEach AGM_Markers_MarkersCache; - }; + } forEach GVAR(MarkersCache); - _shape ctrlAddEventHandler ["LBSelChanged", {_this call AGM_Markers_fnc_onLBSelChangedShape}]; + _shape ctrlAddEventHandler ["LBSelChanged", {_this call FUNC(onLBSelChangedShape)}]; - _curSelShape = uiNamespace getVariable ["AGM_Markers_curSelMarkerShape", 0]; + _curSelShape = GETGVAR(curSelMarkerShape,0); _shape lbSetCurSel _curSelShape; _data = _shape lbValue _curSelShape; _config = (configfile >> "CfgMarkers") select _data; @@ -192,74 +161,39 @@ with uinamespace do { // init marker color lb - _config = configfile >> "CfgMarkerColors"; - _index = 0; - - if (isNil "AGM_Markers_MarkerColorsCache") then { - AGM_Markers_MarkerColorsCache = []; - - for "_a" from 0 to (count _config - 1) do { - _marker = _config select _a; - - _scope = getNumber (_marker >> "scope"); - _name = getText (_marker >> "name"); - - if (_scope == 2) then { - _color lbAdd _name; - _color lbSetValue [_index, _a]; - - _rgba = getArray (_marker >> "color"); - - { - if (typeName _x != "SCALAR") then { - _rgba set [_forEachIndex, call compile _x]; - }; - } forEach _rgba; - - _icon = format ["#(argb,8,8,3)color(%1,%2,%3,%4)", _rgba select 0, _rgba select 1, _rgba select 2, _rgba select 3]; - - _color lbSetPicture [_index, _icon]; - - AGM_Markers_MarkerColorsCache pushBack [_name, _a, _icon]; - - _index = _index + 1; - }; - }; - } else { - { + { _color lbAdd (_x select 0); _color lbSetValue [_forEachIndex, _x select 1]; _color lbSetPicture [_forEachIndex, _x select 2]; - } forEach AGM_Markers_MarkerColorsCache; - }; + } forEach GVAR(MarkerColorsCache); - _color ctrlAddEventHandler ["LBSelChanged", {_this call AGM_Markers_fnc_onLBSelChangedColor}]; + _color ctrlAddEventHandler ["LBSelChanged", {_this call FUNC(onLBSelChangedColor)}]; - _curSelColor = uiNamespace getVariable ["AGM_Markers_curSelMarkerColor", 0]; + _curSelColor = GETGVAR(curSelMarkerColor,0); _color lbSetCurSel _curSelColor; _data = _color lbValue _curSelColor; _config = (configfile >> "CfgMarkerColors") select _data; _rgba = getArray (_config >> "color"); { - if (typeName _x != "SCALAR") then { - _rgba set [_forEachIndex, call compile _x]; - }; + if (typeName _x != "SCALAR") then { + _rgba set [_forEachIndex, call compile _x]; + }; } forEach _rgba; _picture ctrlSetTextColor _rgba; // init marker angle slider _angle sliderSetRange [-180, 180]; - _angle ctrlAddEventHandler ["SliderPosChanged", {_this call AGM_Markers_fnc_onSliderPosChangedAngle}]; + _angle ctrlAddEventHandler ["SliderPosChanged", {_this call FUNC(onSliderPosChangedAngle)}]; - _curSelAngle = uiNamespace getVariable ["AGM_Markers_curSelMarkerAngle", 0]; + _curSelAngle = GETGVAR(curSelMarkerAngle,0); _angle sliderSetPosition _curSelAngle; _curSelAngle = round _curSelAngle; if (_curSelAngle < 0) then { - _curSelAngle = _curSelAngle + 360; + _curSelAngle = _curSelAngle + 360; }; - _angleText ctrlSetText format [localize "STR_AGM_Markers_MarkerDirection", _curSelAngle]; - }; -}; + _angleText ctrlSetText format [localize "STR_ACE_Markers_MarkerDirection", _curSelAngle]; + +}, _this] call EFUNC(common,execNextFrame); diff --git a/TO_MERGE/agm/Markers/functions/fn_onLBSelChangedColor.sqf b/addons/markers/functions/fnc_onLBSelChangedColor.sqf similarity index 57% rename from TO_MERGE/agm/Markers/functions/fn_onLBSelChangedColor.sqf rename to addons/markers/functions/fnc_onLBSelChangedColor.sqf index 28c788e260..0aa541f5a5 100644 --- a/TO_MERGE/agm/Markers/functions/fn_onLBSelChangedColor.sqf +++ b/addons/markers/functions/fnc_onLBSelChangedColor.sqf @@ -1,22 +1,23 @@ // by commy2 +#include "script_component.hpp" private ["_ctrl", "_data", "_config", "_color"]; _ctrl = _this select 0; _data = _ctrl lbValue (_this select 1); -uiNamespace setVariable ["AGM_Markers_curSelMarkerColor", _this select 1]; +GVAR(curSelMarkerColor) = _this select 1; _config = (configfile >> "CfgMarkerColors") select _data; _color = getArray (_config >> "color"); { - if (typeName _x != "SCALAR") then { - _color set [_forEachIndex, call compile _x]; - }; + if (typeName _x != "SCALAR") then { + _color set [_forEachIndex, call compile _x]; + }; } forEach _color; ((ctrlParent _ctrl) displayCtrl 102) ctrlSetTextColor _color; -uiNamespace setVariable ["AGM_Markers_currentMarkerColor", _data]; +GVAR(currentMarkerColor) = _data; diff --git a/TO_MERGE/agm/Markers/functions/fn_onLBSelChangedShape.sqf b/addons/markers/functions/fnc_onLBSelChangedShape.sqf similarity index 66% rename from TO_MERGE/agm/Markers/functions/fn_onLBSelChangedShape.sqf rename to addons/markers/functions/fnc_onLBSelChangedShape.sqf index c47cff385b..f77e1f8ff8 100644 --- a/TO_MERGE/agm/Markers/functions/fn_onLBSelChangedShape.sqf +++ b/addons/markers/functions/fnc_onLBSelChangedShape.sqf @@ -1,11 +1,12 @@ // by commy2 +#include "script_component.hpp" private ["_ctrl", "_data", "_config", "_icon"]; _ctrl = _this select 0; _data = _ctrl lbValue (_this select 1); -uiNamespace setVariable ["AGM_Markers_curSelMarkerShape", _this select 1]; +GVAR(curSelMarkerShape) = _this select 1; _config = (configfile >> "CfgMarkers") select _data; @@ -13,4 +14,4 @@ _icon = getText (_config >> "icon"); ((ctrlParent _ctrl) displayCtrl 102) ctrlSetText _icon; -uiNamespace setVariable ["AGM_Markers_currentMarkerShape", _data]; +GVAR(currentMarkerShape) = _data; diff --git a/TO_MERGE/agm/Markers/functions/fn_onSliderPosChangedAngle.sqf b/addons/markers/functions/fnc_onSliderPosChangedAngle.sqf similarity index 51% rename from TO_MERGE/agm/Markers/functions/fn_onSliderPosChangedAngle.sqf rename to addons/markers/functions/fnc_onSliderPosChangedAngle.sqf index 4dabc45b35..354fb909e1 100644 --- a/TO_MERGE/agm/Markers/functions/fn_onSliderPosChangedAngle.sqf +++ b/addons/markers/functions/fnc_onSliderPosChangedAngle.sqf @@ -1,17 +1,18 @@ // by commy2 +#include "script_component.hpp" private ["_ctrl", "_data", "_direction"]; _ctrl = _this select 0; _data = _this select 1; -uiNamespace setVariable ["AGM_Markers_curSelMarkerAngle", _data]; +GVAR(curSelMarkerAngle) = _data; _direction = round _data; if (_direction < 0) then { - _direction = _direction + 360; + _direction = _direction + 360; }; -((ctrlParent _ctrl) displayCtrl 1221) ctrlSetText format [localize "STR_AGM_Markers_MarkerDirection", _direction]; +((ctrlParent _ctrl) displayCtrl 1221) ctrlSetText format [localize "STR_ACE_Markers_MarkerDirection", _direction]; -uiNamespace setVariable ["AGM_Markers_currentMarkerAngle", _data]; +GVAR(currentMarkerAngle) = _data; diff --git a/addons/markers/functions/fnc_placeMarker.sqf b/addons/markers/functions/fnc_placeMarker.sqf new file mode 100644 index 0000000000..56fe16700a --- /dev/null +++ b/addons/markers/functions/fnc_placeMarker.sqf @@ -0,0 +1,46 @@ +// by commy2 +#include "script_component.hpp" + +if (_this select 1 == 1) then { + disableserialization; + _display = _this select 0; + + _pos = ctrlPosition (_display displayCtrl 102); + _pos = [ + (_pos select 0) + (_pos select 2) / 2, + (_pos select 1) + (_pos select 3) / 2 + ]; + + switch (true) do { + case (!isNull findDisplay 12): { + _pos = (findDisplay 12 displayCtrl 51) ctrlMapScreenToWorld _pos; + }; + case (!isNull findDisplay 37): { + _pos = (findDisplay 37 displayCtrl 51) ctrlMapScreenToWorld _pos; + }; + case (!isNull findDisplay 52): { + _pos = (findDisplay 52 displayCtrl 51) ctrlMapScreenToWorld _pos; + }; + case (!isNull findDisplay 53): { + _pos = (findDisplay 53 displayCtrl 51) ctrlMapScreenToWorld _pos; + }; + }; + + // set and send marker data the next frame. the actual marker isn't created yet + [ + { + + [QGVAR(setMarkerNetwork), [ + allMapMarkers select (count allMapMarkers - 1), [ + GETGVAR(currentMarkerShape,0), + GETGVAR(currentMarkerColor,0), + _this, + GETGVAR(currentMarkerAngle,0) + ] + ]] call EFUNC(common,globalEvent); + + }, + _pos + ] call EFUNC(common,execNextFrame); + +}; diff --git a/addons/markers/functions/fnc_sendMarkersJIP.sqf b/addons/markers/functions/fnc_sendMarkersJIP.sqf new file mode 100644 index 0000000000..9915820d72 --- /dev/null +++ b/addons/markers/functions/fnc_sendMarkersJIP.sqf @@ -0,0 +1,13 @@ +// by commy2 +#include "script_component.hpp" + +private "_logic"; + +_logic = _this; + +[QGVAR(setMarkerJIP), _logic, [ + GETGVAR(allMapMarkers,[]), + GETGVAR(allMapMarkersProperties,[]), + _logic + ] +] call EFUNC(common,targetEvent); diff --git a/addons/markers/functions/fnc_setMarkerJIP.sqf b/addons/markers/functions/fnc_setMarkerJIP.sqf new file mode 100644 index 0000000000..8466e35776 --- /dev/null +++ b/addons/markers/functions/fnc_setMarkerJIP.sqf @@ -0,0 +1,27 @@ +// by commy2 +#include "script_component.hpp" + +private ["_allMapMarkers", "_allMapMarkersProperties", "_index", "_data", "_config"]; + +_allMapMarkers = _this select 0; +_allMapMarkersProperties = _this select 1; +_logic = _this select 2; + +{ + _index = _allMapMarkers find _x; + + if (_index != -1) then { + _data = _allMapMarkersProperties select _index; + + _config = (configfile >> "CfgMarkers") select (_data select 0); + _x setMarkerTypeLocal configName _config; + + _config = (configfile >> "CfgMarkerColors") select (_data select 1); + _x setMarkerColorLocal configName _config; + + _x setMarkerPosLocal (_data select 2); + _x setMarkerDirLocal (_data select 3); + }; +} forEach allMapMarkers; + +deleteVehicle _logic; diff --git a/addons/markers/functions/fnc_setMarkerNetwork.sqf b/addons/markers/functions/fnc_setMarkerNetwork.sqf new file mode 100644 index 0000000000..2356574ae3 --- /dev/null +++ b/addons/markers/functions/fnc_setMarkerNetwork.sqf @@ -0,0 +1,37 @@ +// by commy2 +#include "script_component.hpp" + +private ["_marker", "_data", "_config"]; + +_marker = _this select 0; +_data = _this select 1; + +_config = (configfile >> "CfgMarkers") select (_data select 0); +_marker setMarkerTypeLocal configName _config; + +_config = (configfile >> "CfgMarkerColors") select (_data select 1); +_marker setMarkerColorLocal configName _config; + +_marker setMarkerPosLocal (_data select 2); +_marker setMarkerDirLocal (_data select 3); + +// save properties on server machine for JIP, marker editing ready +if (isMultiplayer && {isServer}) then { + private ["_allMapMarkers", "_allMapMarkersProperties", "_index"]; + + _allMapMarkers = GETMVAR(allMapMarkers,[]); + _allMapMarkersProperties = GETMVAR(allMapMarkersProperties,[]); + + _index = _allMapMarkers find _marker; + + if (_index == -1) then { + _allMapMarkers pushBack _marker; + _allMapMarkersProperties pushBack _data; + } else { + _allMapMarkers set [_index, _marker]; + _allMapMarkersProperties set [_index, _data]; + }; + + GVAR(allMapMarkers) = _allMapMarkers; + GVAR(allMapMarkersProperties) = _allMapMarkersProperties; +}; diff --git a/addons/markers/functions/script_component.hpp b/addons/markers/functions/script_component.hpp new file mode 100644 index 0000000000..26adba2431 --- /dev/null +++ b/addons/markers/functions/script_component.hpp @@ -0,0 +1 @@ +#include "\z\ace\addons\markers\script_component.hpp" diff --git a/addons/markers/script_component.hpp b/addons/markers/script_component.hpp new file mode 100644 index 0000000000..2b1cb586a7 --- /dev/null +++ b/addons/markers/script_component.hpp @@ -0,0 +1,12 @@ +#define COMPONENT markers +#include "\z\ace\addons\main\script_mod.hpp" + +#ifdef DEBUG_ENABLED_MARKERS + #define DEBUG_MODE_FULL +#endif + +#ifdef DEBUG_ENABLED_MARKERS + #define DEBUG_SETTINGS DEBUG_ENABLED_MARKERS +#endif + +#include "\z\ace\addons\main\script_macros.hpp" \ No newline at end of file diff --git a/TO_MERGE/agm/Markers/stringtable.xml b/addons/markers/stringtable.xml similarity index 84% rename from TO_MERGE/agm/Markers/stringtable.xml rename to addons/markers/stringtable.xml index e324341854..0d2619ae40 100644 --- a/TO_MERGE/agm/Markers/stringtable.xml +++ b/addons/markers/stringtable.xml @@ -1,8 +1,8 @@  - + - + Direction: %1° Drehung: %1° Direction: %1° @@ -11,7 +11,7 @@ Dirección: %1° Направление: %1 - + Place in: %1 Platz in: %1 Colocar en: %1 diff --git a/addons/vector/CfgVehicles.hpp b/addons/vector/CfgVehicles.hpp index 1305e73f88..e9fd8945de 100644 --- a/addons/vector/CfgVehicles.hpp +++ b/addons/vector/CfgVehicles.hpp @@ -1,7 +1,7 @@ #define MACRO_ADDWEAPON(WEAPON,COUNT) class _xx_##WEAPON { \ - weapon = #WEAPON; \ - count = COUNT; \ + weapon = #WEAPON; \ + count = COUNT; \ } class CfgVehicles { diff --git a/extras/blank/XEH_preInit.sqf b/extras/blank/XEH_preInit.sqf index 802b74fd63..69abb46fa9 100644 --- a/extras/blank/XEH_preInit.sqf +++ b/extras/blank/XEH_preInit.sqf @@ -1,3 +1,7 @@ #include "script_component.hpp" +ADDON = false; + PREP(empty); + +ADDON = true; diff --git a/tools/rename_fn.py b/tools/rename_fn.py old mode 100644 new mode 100755 diff --git a/tools/stringtableduplicates.py b/tools/stringtableduplicates.py old mode 100644 new mode 100755