/* Status Bar for Epochmod Developed by: Darth_Rogue Changed By: [Ignatz] He-Man Date: 2017-04-06 */ [] spawn { if (!isclass (getmissionconfig 'Ignatz_config')) exitwith { systemchat "Error: Can not load Config for Statusbar"; }; _config = getmissionconfig 'Ignatz_config'; Ignatz_StatusbarSelected = getnumber (_config >> "Statusbar_OnStart"); Ignatz_UseStatusBarSwitchKey = switch (tolower (gettext (_config >> "Statusbar_UseKeybind"))) do {case "true": {true};default {false}}; Ignatz_StatusBarSwitchKey = getnumber (_config >> "Statusbar_Keybind"); _RestartTime = getnumber (_config >> "Restart_Intervall"); _Restart_offset = getnumber (_config >> "AutoKickBeforeRestart"); _RestartWarningTimes = getarray (_config >> "Restart_WarningTimes"); _playersTxt = "%1"; _energyTxt = "%2"; _StaminaTxt = "%3"; _KryptoTxt = "%4"; _DamageTxt = "%5%15"; _HungerTxt = "%6%15"; _ThirstTxt = "%7%15"; _TempTxt = " %8%16"; _ToxicTxt = "%9"; _BloodTxt = "%10"; _GPSTxt = " %11"; _FPSTxt = "FPS %12"; _RestartTxt = "%13:%14"; _blanks = " "; /* Blanks for adjust the distance between the Icons */ _StatusbarTxt1L = _DamageTxt + _blanks + _HungerTxt + _blanks + _ThirstTxt + _blanks + _TempTxt + _blanks + _ToxicTxt + _blanks + _BloodTxt; _StatusbarTxt1R = _playersTxt + _blanks + _blanks + _KryptoTxt + _blanks + _blanks + _GPSTxt + _blanks + _blanks + _FPSTxt + _blanks + _blanks + _RestartTxt; _StatusbarTxt2L = _DamageTxt + _blanks + _HungerTxt + _blanks + _ThirstTxt + _blanks + _TempTxt + _blanks + _ToxicTxt + _blanks + _BloodTxt + _blanks; _StatusbarTxt2R = _playersTxt + _blanks + _KryptoTxt + _blanks + _GPSTxt + _blanks + _RestartTxt; _StatusbarTxt3L = _DamageTxt + _blanks + _HungerTxt + _blanks + _ThirstTxt; _StatusbarTxt3R = _playersTxt + _blanks + _GPSTxt + _blanks + _RestartTxt; _StatusbarPosY = safezoneY+safezoneH-0.07; /* 10% from the bottom */ _StatusbarHeight = 0.07; _StatusbarWidth1L = 0.67; _StatusbarWidth1R = 0.67; _StatusbarWidth2L = 0.41; _StatusbarWidth2R = 0.41; _StatusbarWidth3L = 0.35; _StatusbarWidth3R = 0.35; _BackgrundColor = [0,0,0,0.4]; /* [RR,GG,BB,TRANSPARENCY] RGB in 0-1!!! */ /* 1 count allplayers, 2 _energyPercent, 3 _stamina, 4 _wallet, 5 _damage, 6 _hunger, 7 _thirst, 8 _temp, 9 _toxPercent, 10 _bloodpressure, 11 format['%1/%2',_xx,_yy], 12 round diag_fps, 13 _hours, 14 _minutes, 15 '%', 16 '°C', 17 _colourDefault, 18 _colourEnergy, 19 _colourStamina, 20 _colourDamage, 21 _colourHunger, 22 _colourThirst, 23 _colourTemp, 24 _colourToxicity, 25 _colourBloodP, */ /* End Config */ waituntil {!isnull (finddisplay 46) && alive player}; disableSerialization; _display = finddisplay 46; _Ignatz_StatusbarActive = 0; _tempblink = false; _damageblink = false; _hungerblink = false; _thirstblink = false; _toxicblink = false; _bloodpblink = false; _colourDefault = parseText '#ADADAD'; _colour100 = parseText '#336600'; _colour90 = parseText '#339900'; _colour80 = parseText '#33CC00'; _colour70 = parseText '#33FF00'; _colour60 = parseText '#66FF00'; _colour50 = parseText '#CCFF00'; _colour40 = parseText '#CCCC00'; _colour30 = parseText '#CC9900'; _colour20 = parseText '#CC6600'; _colour10 = parseText '#CC3300'; _colour0 = parseText '#CC0000'; _colourDead = parseText '#000000'; _colourTempLowest = parseText '#0000CC'; _colourTempLower = parseText '#9600CC'; _colourTempMid = parseText '#336600'; _colourTempHigher = parseText '#CC0055'; _colourTempHighest = parseText '#FF0000'; _StatusbarL = _display ctrlCreate ["RscStructuredText", 10000]; _StatusbarR = _display ctrlCreate ["RscStructuredText", 10001]; _StatusbarL ctrlsetbackgroundcolor _BackgrundColor; _StatusbarR ctrlsetbackgroundcolor _BackgrundColor; _StatusbarL ctrlSetPosition [ safezoneX + safezoneW / 2 - 0, _StatusbarPosY, 0, _StatusbarHeight ]; _StatusbarR ctrlSetPosition [ safezoneX + safezoneW / 2 - 0, _StatusbarPosY, 0, _StatusbarHeight ]; _StatusbarL ctrlCommit 0.5; _StatusbarR ctrlCommit 0.5; _minutes = -1; _restart = false; while {true} do { if (_Ignatz_StatusbarActive != Ignatz_StatusbarSelected) then { switch Ignatz_StatusbarSelected do { case 0:{ _Ignatz_StatusbarActive = 0; _StatusbarL ctrlSetPosition [ safezoneX + safezoneW / 4, _StatusbarPosY, 0, _StatusbarHeight ]; _StatusbarR ctrlSetPosition [ safezoneX + safezoneW / 4 * 3, _StatusbarPosY, 0, _StatusbarHeight ]; }; case 1:{ _Ignatz_StatusbarActive = 1; _StatusbarL ctrlShow true; _StatusbarR ctrlShow true; _StatusbarL ctrlSetPosition [ safezoneX + safezoneW / 5 - _StatusbarWidth1L/2, _StatusbarPosY, _StatusbarWidth1L, _StatusbarHeight ]; _StatusbarR ctrlSetPosition [ safezoneX + safezoneW / 5 * 4 - _StatusbarWidth1R/2, _StatusbarPosY, _StatusbarWidth1R, _StatusbarHeight ]; }; case 2:{ _Ignatz_StatusbarActive = 2; _StatusbarL ctrlShow true; _StatusbarR ctrlShow true; _StatusbarL ctrlSetPosition [ safezoneX + safezoneW / 5 - _StatusbarWidth2L/2, _StatusbarPosY, _StatusbarWidth2L, _StatusbarHeight ]; _StatusbarR ctrlSetPosition [ safezoneX + safezoneW / 5 * 4 - _StatusbarWidth2R/2, _StatusbarPosY, _StatusbarWidth2R, _StatusbarHeight ]; }; case 3:{ _Ignatz_StatusbarActive = 3; _StatusbarL ctrlShow true; _StatusbarR ctrlShow true; _StatusbarL ctrlSetPosition [ safezoneX + safezoneW / 5 - _StatusbarWidth3L/2, _StatusbarPosY, _StatusbarWidth3L, _StatusbarHeight ]; _StatusbarR ctrlSetPosition [ safezoneX + safezoneW / 5 * 4 - _StatusbarWidth3R/2, _StatusbarPosY, _StatusbarWidth3R, _StatusbarHeight ]; }; }; _StatusbarL ctrlCommit 0.5; _StatusbarR ctrlCommit 0.5; uisleep 0.5; if (_Ignatz_StatusbarActive == 0) then { _StatusbarL ctrlShow false; _StatusbarL ctrlSetText ''; _StatusbarR ctrlShow false; _StatusbarR ctrlSetText ''; }; } else { uisleep 1; }; _time = (round(_RestartTime*3600+_Restart_offset-serverTime)) max 0; if (!isnil 'Ignatz_RestartOverrideTime') then { _time = (Ignatz_RestartOverrideTime+_Restart_offset-serverTime) max 0; }; _hours = (floor(_time/3600)); _minutes = (floor ((_time - _hours*3600)/60)); if (_restart) exitwith { _txt = 'SERVER IS SHUTTING DOWN NOW - PLEASE LOGOUT!'; _fixwait = 35; _randomwait = (random 15) max 5; TitleText [_txt,'BLACK OUT',_fixwait]; _msg = format ["SERVER IS SHUTTING DOWN
PLEASE LOGOUT NOW!
"]; _Ignatz_dyn = [_msg,0,safezoneY + safezoneH/2,60,10]; _Ignatz_dyn spawn BIS_fnc_dynamicText; uisleep (_fixwait/2); player setunitloadout (getunitloadout player); EPOCH_forceUpdateNow = true; uisleep (_fixwait/2); [] spawn { _result = ["Server Restart! - You will be kicked in a few seconds ...","Restart"] call BIS_fnc_guiMessage; (finddisplay 46) closedisplay 0; }; uisleep _randomwait; if (!isnull (finddisplay 999)) then { (finddisplay 999) closedisplay 0; }; uisleep 0.5; (finddisplay 46) closedisplay 0; }; if ((_hours*60+_minutes) == 0) then { _restart = true; }; if ((_hours*60+_minutes) in _RestartWarningTimes)then { if ((_hours*60+_minutes) == 1) then { _msg = format ["RESTART IN %1 MINUTE
PLEASE LOGOUT NOW!
",_minutes]; _Ignatz_dyn = [_msg,0,safezoneY + safezoneH/2,5,0.5]; _Ignatz_dyn spawn BIS_fnc_dynamicText; } else { _msg = format ["RESTART IN %1 MINUTES",_minutes]; _Ignatz_dyn = [_msg,safezoneX+safezoneW/1.5,safezoneY+safezoneH/1.5,5,0.5]; _Ignatz_dyn spawn BIS_fnc_dynamicText; }; _RestartWarningTimes = _RestartWarningTimes - [_hours*60+_minutes]; }; if (_minutes < 10) then { _minutes = "0" + (str _minutes); }; if !(_Ignatz_StatusbarActive == 0) then { _temp = round((EPOCH_playerTemp-32)/1.8*10)/10; _highestDMG = 0; { _currentDMG = _x; if (_currentDMG > _highestDMG) then{ _highestDMG = _currentDMG; }; } forEach (((getAllHitPointsDamage player) param[2,[]]) + [damage player]); _damage = round ((1 - _highestDMG) * 100); _hunger = round((EPOCH_playerHunger/5000) * 100); _thirst = round((EPOCH_playerThirst/2500) * 100); _wallet = EPOCH_playerCrypto; _stamina = round(EPOCH_playerStamina); _toxPercent = round (EPOCH_playerToxicity); _bloodpressure = round (EPOCH_playerBloodP); _energy = round(EPOCH_playerEnergy); _energyPercent = floor(_energy); _grid = mapGridPosition player; _xx = (format[_grid]) select [0,3]; _yy = (format[_grid]) select [3,3]; _colourBloodP = _colourDefault; if (_bloodpressure > 140 && _bloodpblink) then { _bloodpblink = false; } else { switch true do { case (_bloodpressure < 110) : {_colourBloodP = _colour100;}; case ((_bloodpressure >= 110) && (_bloodpressure < 120)) : {_colourBloodP = _colour90;}; case ((_bloodpressure >= 120) && (_bloodpressure < 130)) : {_colourBloodP = _colour80;}; case ((_bloodpressure >= 130) && (_bloodpressure < 140)) : {_colourBloodP = _colour70;}; case ((_bloodpressure >= 140) && (_bloodpressure < 150)) : {_colourBloodP = _colour50;}; case ((_bloodpressure >= 150) && (_bloodpressure < 160)) : {_colourBloodP = _colour40;}; case ((_bloodpressure >= 160) && (_bloodpressure < 170)) : {_colourBloodP = _colour30;}; case ((_bloodpressure >= 170) && (_bloodpressure < 180)) : {_colourBloodP = _colour20;}; case ((_bloodpressure >= 180) && (_bloodpressure < 190)) : {_colourBloodP = _colour10;}; case (_bloodpressure >= 190) : {_colourBloodP = _colourDead;}; }; if (_bloodpressure > 150) then { _bloodpblink = true; } else { _bloodpblink = false; }; }; _colourTemp = _colourDefault; if ((_temp <= 35.5 || _temp > 38.5) && _tempblink) then { _tempblink = false; } else { switch true do { case (_temp < 35.5) : {_colourTemp = _colourTempLowest;}; case ((_temp >= 35.5) && (_temp < 36.5)) : {_colourTemp = _colourTempLower;}; case ((_temp >= 36.5) && (_temp < 37.5)) : {_colourTemp = _colourTempMid;}; case ((_temp >= 37.5) && (_temp < 38.5)) : {_colourTemp = _colourTempHigher;}; case (_temp > 38.5) : {_colourTemp = _colourTempHighest;}; }; if (_temp <= 35.5 || _temp > 38.5) then { _tempblink = true; } else { _tempblink = false; }; }; _colourDamage = _colourDefault; if (_damage < 30 && _damageblink) then { _damageblink = false; } else { switch true do { case(_damage >= 100) : {_colourDamage = _colour100;}; case((_damage >= 90) && (_damage < 100)) : {_colourDamage = _colour90;}; case((_damage >= 80) && (_damage < 90)) : {_colourDamage = _colour80;}; case((_damage >= 70) && (_damage < 80)) : {_colourDamage = _colour70;}; case((_damage >= 60) && (_damage < 70)) : {_colourDamage = _colour60;}; case((_damage >= 50) && (_damage < 60)) : {_colourDamage = _colour50;}; case((_damage >= 40) && (_damage < 50)) : {_colourDamage = _colour40;}; case((_damage >= 30) && (_damage < 40)) : {_colourDamage = _colour30;}; case((_damage >= 20) && (_damage < 30)) : {_colourDamage = _colour20;}; case((_damage >= 10) && (_damage < 20)) : {_colourDamage = _colour10;}; case((_damage >= 1) && (_damage < 10)) : {_colourDamage = _colour0;}; case(_damage < 1) : {_colourDamage = _colourDead;}; }; if (_damage < 30) then { _damageblink = true; } else { _damageblink = false; }; }; _colourHunger = _colourDefault; if (_hunger < 10 && _hungerblink) then { _hungerblink = false; } else { switch true do { case(_hunger >= 100) : {_colourHunger = _colour100;}; case((_hunger >= 90) && (_hunger < 100)) : {_colourHunger = _colour90;}; case((_hunger >= 80) && (_hunger < 90)) : {_colourHunger = _colour80;}; case((_hunger >= 70) && (_hunger < 80)) : {_colourHunger = _colour70;}; case((_hunger >= 60) && (_hunger < 70)) : {_colourHunger = _colour60;}; case((_hunger >= 50) && (_hunger < 60)) : {_colourHunger = _colour50;}; case((_hunger >= 40) && (_hunger < 50)) : {_colourHunger = _colour40;}; case((_hunger >= 30) && (_hunger < 40)) : {_colourHunger = _colour30;}; case((_hunger >= 20) && (_hunger < 30)) : {_colourHunger = _colour20;}; case((_hunger >= 10) && (_hunger < 20)) : {_colourHunger = _colour10;}; case((_hunger >= 1) && (_hunger < 10)) : {_colourHunger = _colour0;}; case(_hunger < 1) : {_colourHunger = _colourDead;}; }; if (_hunger < 10) then { _hungerblink = true; } else { _hungerblink = false; }; }; _colourThirst = _colourDefault; if (_thirst < 10 && _thirstblink) then { _thirstblink = false; } else { switch true do{ case(_thirst >= 100) : {_colourThirst = _colour100;}; case((_thirst >= 90) && (_thirst < 100)) : {_colourThirst = _colour90;}; case((_thirst >= 80) && (_thirst < 90)) : {_colourThirst = _colour80;}; case((_thirst >= 70) && (_thirst < 80)) : {_colourThirst = _colour70;}; case((_thirst >= 60) && (_thirst < 70)) : {_colourThirst = _colour60;}; case((_thirst >= 50) && (_thirst < 60)) : {_colourThirst = _colour50;}; case((_thirst >= 40) && (_thirst < 50)) : {_colourThirst = _colour40;}; case((_thirst >= 30) && (_thirst < 40)) : {_colourThirst = _colour30;}; case((_thirst >= 20) && (_thirst < 30)) : {_colourThirst = _colour20;}; case((_thirst >= 10) && (_thirst < 20)) : {_colourThirst = _colour10;}; case((_thirst >= 1) && (_thirst < 10)) : {_colourThirst = _colour0;}; case(_thirst < 1) : {_colourThirst = _colourDead;}; }; if (_thirst < 10) then { _thirstblink = true; } else { _thirstblink = false; }; }; _colourEnergy = _colourDefault; switch true do { case(_energyPercent >= 100) : {_colourEnergy = _colour100;}; case((_energyPercent >= 90) && (_energyPercent < 100)) : {_colourEnergy = _colour90;}; case((_energyPercent >= 80) && (_energyPercent < 90)) : {_colourEnergy = _colour80;}; case((_energyPercent >= 70) && (_energyPercent < 80)) : {_colourEnergy = _colour70;}; case((_energyPercent >= 60) && (_energyPercent < 70)) : {_colourEnergy = _colour60;}; case((_energyPercent >= 50) && (_energyPercent < 60)) : {_colourEnergy = _colour50;}; case((_energyPercent >= 40) && (_energyPercent < 50)) : {_colourEnergy = _colour40;}; case((_energyPercent >= 30) && (_energyPercent < 40)) : {_colourEnergy = _colour30;}; case((_energyPercent >= 20) && (_energyPercent < 30)) : {_colourEnergy = _colour20;}; case((_energyPercent >= 10) && (_energyPercent < 20)) : {_colourEnergy = _colour10;}; case((_energyPercent >= 1) && (_energyPercent < 10)) : {_colourEnergy = _colour0;}; case(_energyPercent < 1) : {_colourEnergy = _colour0;}; }; _colourToxicity = _colourDefault; if (_toxPercent > 80 && _toxicblink) then { _toxicblink = false; } else { switch true do { case(_toxPercent >= 100) : {_colourToxicity = _colourDead;}; case((_toxPercent >= 90) && (_toxPercent < 100)) : {_colourToxicity = _colour0;}; case((_toxPercent >= 80) && (_toxPercent < 90)) : {_colourToxicity = _colour10;}; case((_toxPercent >= 70) && (_toxPercent < 80)) : {_colourToxicity = _colour20;}; case((_toxPercent >= 60) && (_toxPercent < 70)) : {_colourToxicity = _colour30;}; case((_toxPercent >= 50) && (_toxPercent < 60)) : {_colourToxicity = _colour40;}; case((_toxPercent >= 40) && (_toxPercent < 50)) : {_colourToxicity = _colour50;}; case((_toxPercent >= 30) && (_toxPercent < 40)) : {_colourToxicity = _colour60;}; case((_toxPercent >= 20) && (_toxPercent < 30)) : {_colourToxicity = _colour70;}; case((_toxPercent >= 10) && (_toxPercent < 20)) : {_colourToxicity = _colour80;}; case((_toxPercent >= 1) && (_toxPercent < 10)) : {_colourToxicity = _colour90;}; case(_toxPercent < 1) : {_colourToxicity = _colour100;}; }; if (_toxPercent > 80) then { _toxicblink = true; } else { _toxicblink = false; }; }; _colourStamina = _colourDefault; _bartextL = switch _Ignatz_StatusbarActive do { case 0:{ ""; }; case 1:{ _StatusbarTxt1L; }; case 2:{ _StatusbarTxt2L; }; case 3:{ _StatusbarTxt3L; }; }; _bartextR = switch _Ignatz_StatusbarActive do { case 0:{ ""; }; case 1:{ _StatusbarTxt1R; }; case 2:{ _StatusbarTxt2R; }; case 3:{ _StatusbarTxt3R; }; }; _StatusbarL ctrlSetStructuredText parseText format ["" + _bartextL + "", (playersNumber west)+(playersNumber east)+(playersNumber civilian)+(playersNumber resistance), _energyPercent, _stamina, _wallet, _damage, _hunger, _thirst, _temp, _toxPercent, _bloodpressure, format['%1/%2',_xx,_yy], round diag_fps, _hours, _minutes, '%', '°C', _colourDefault, _colourEnergy, _colourStamina, _colourDamage, _colourHunger, _colourThirst, _colourTemp, _colourToxicity, _colourBloodP ]; _StatusbarR ctrlSetStructuredText parseText format ["" + _bartextR + "", (playersNumber west)+(playersNumber east)+(playersNumber civilian)+(playersNumber resistance), _energyPercent, _stamina, _wallet, _damage, _hunger, _thirst, _temp, _toxPercent, _bloodpressure, format['%1/%2',_xx,_yy], round diag_fps, _hours, _minutes, '%', '°C', _colourDefault, _colourEnergy, _colourStamina, _colourDamage, _colourHunger, _colourThirst, _colourTemp, _colourToxicity, _colourBloodP ]; }; }; };