// make sure we wait for Display #46 waitUntil {!(isNull (findDisplay 46))}; // force update within 15 seconds EPOCH_forceUpdate = false; _forceUpdate = false; // force update within 1 second EPOCH_forceUpdateNow = false; // init local player stat vars _playerRadiation = EPOCH_playerRadiation; _playerAliveTime = EPOCH_playerAliveTime; // start alive timer _clientAliveTimer = diag_tickTime; // init player stat vars _customVarsInit = ["CfgEpochClient", "customVarsDefaults", EPOCH_customVarsDefaults] call EPOCH_fnc_returnConfigEntryV2; _customVarNames = _customVarsInit apply {_x param [0,""]}; _defaultVarValues = _customVarsInit apply {_x param [1,0]}; _customVarLimits = _customVarsInit apply {_x param [2,[]]}; // inline function to sync player stats to server _fnc_forceUpdate = { private _customVars = []; { // use local var from inside master loop switch (_x) do { case ("Radiation"): { _customVars pushBack _playerRadiation; }; case ("AliveTime"):{ _customVars pushBack _playerAliveTime; }; default { private _customVarIndex = _customVarNames find _x; if (_customVarIndex != -1) then { _customVars pushBack (missionNamespace getVariable [format["EPOCH_player%1",_x],_defaultVarValues select _customVarIndex]); }; }; }; } forEach _customVarNames; [player,_customVars,Epoch_personalToken] remoteExec ["EPOCH_fnc_savePlayer",2]; }; // disable fuel sources client side. {_x setFuelCargo 0;} foreach (missionNamespace getVariable ["EPOCH_staticFuelSources", []]); // setup display EH's if (isNil "EPOCH_display_setup_complete") then { EPOCH_display_setup_complete = true; { (findDisplay 46) displayAddEventHandler [_x,(["CfgEpochClient", _x, ""] call EPOCH_fnc_returnConfigEntryV2)]; } forEach (["CfgEpochClient", "displayAddEventHandler", []] call EPOCH_fnc_returnConfigEntryV2); // reset anim state player switchMove ""; // setup Epoch Hud call epoch_dynamicHUD_start; }; // Background radiation _backgroundRadiation = ["CfgEpochClient", "backgroundRadiation", 10] call EPOCH_fnc_returnConfigEntryV2; _radsLevel = 0; _prevEquippedItem = []; _damagePlayer = damage player; _isOnFoot = isNull objectParent player; _panic = false; _prevEnergy = EPOCH_playerEnergy; // init config data _antagonistRndChance = ["CfgEpochClient", "antagonistRngChance", 100] call EPOCH_fnc_returnConfigEntryV2; _baseHungerLoss = ["CfgEpochClient", "baseHungerLoss", 2] call EPOCH_fnc_returnConfigEntryV2; _baseThirstLoss = ["CfgEpochClient", "baseThirstLoss", 2] call EPOCH_fnc_returnConfigEntryV2; _energyCostNV = ["CfgEpochClient", "energyCostNV", 3] call EPOCH_fnc_returnConfigEntryV2; _energyRegenMax = ["CfgEpochClient", "energyRegenMax", 5] call EPOCH_fnc_returnConfigEntryV2; _energyRange = ["CfgEpochClient", "energyRange", 75] call EPOCH_fnc_returnConfigEntryV2; _hudConfigs = ["CfgEpochClient", "hudConfigs", []] call EPOCH_fnc_returnConfigEntryV2; EPOCH_chargeRate = 0; EPOCH_playerIsSwimming = false; _antagonistChanceDefaults = [ "Epoch_Cloak_F",0.07, "Epoch_Sapper_F",0.25, "Epoch_SapperG_F",0.12, "Epoch_SapperB_F",0.06, "I_UAV_01_F",0.2, "PHANTOM",0.01, "EPOCH_RyanZombie_1",0.25 ]; _antagonistChances = ["CfgEpochClient", "antagonistChances", _antagonistChanceDefaults] call EPOCH_fnc_returnConfigEntryV2; // Init antagonist spawn limits _spawnIndex = []; _spawnLimits = []; _antagonistSpawnDefaults = [ ["Epoch_Cloak_F", 1], ["GreatWhite_F", 2], ["Epoch_Sapper_F",2], ["Epoch_SapperG_F",1], ["Epoch_SapperB_F",1], ["I_UAV_01_F",2], ["PHANTOM",1], ["B_Heli_Transport_01_F",1], ["EPOCH_RyanZombie_1",12] ]; _antagonistSpawnLimits = ["CfgEpochClient", "antagonistSpawnIndex", _antagonistSpawnDefaults] call EPOCH_fnc_returnConfigEntryV2; { _x params ["_spawnName","_spawnLimit"]; if (_spawnName isEqualTo "EPOCH_RyanZombie_1") then { if (EPOCH_mod_Ryanzombies_Enabled) then { _spawnIndex pushBack _spawnName; _spawnLimits pushBack _spawnLimit; }; } else { _spawnIndex pushBack _spawnName; _spawnLimits pushBack _spawnLimit; }; } forEach _antagonistSpawnLimits; EPOCH_spawnIndex = _spawnIndex; EPOCH_spawnLimits = _spawnLimits; // default data if mismatch if !(EPOCH_playerSpawnArray isEqualTypeParams _spawnIndex) then{ EPOCH_playerSpawnArray = []; { EPOCH_playerSpawnArray pushBack 0 } forEach _spawnIndex; }; // find radio { if (configName(inheritsFrom(configFile >> "CfgWeapons" >> _x)) == "ItemRadio") exitWith{ EPOCH_equippedItem_PVS = [_x, true, player]; }; } forEach assignedItems player; // lootBubble Init _buildingJammerRange = ["CfgEpochClient", "buildingJammerRange", 75] call EPOCH_fnc_returnConfigEntryV2; _masterConfig = 'CfgBuildingLootPos' call EPOCH_returnConfig; _lootClasses = []; _lootClassesIgnore = ['Default']; '_cN = configName _x;if !(_cN in _lootClassesIgnore)then{_lootClasses pushBackUnique _cN}; true' configClasses _masterConfig; _lastPlayerPos = getPosATL player; _lootBubble = { private["_jammer", "_others", "_objects", "_nearObjects", "_building", "_lootDist", "_lootLoc", "_playerPos", "_distanceTraveled"]; _playerPos = getPosATL vehicle player; _distanceTraveled = _lastPlayerPos distance _playerPos; if (_distanceTraveled > 10 && _distanceTraveled < 200) then { _lootDist = 30 + _distanceTraveled; _lootLoc = player getRelPos [_lootDist, (random [-180,0,180])]; _objects = nearestObjects[_lootLoc, _lootClasses, 30]; _jammer = nearestObjects [_lootLoc, ["PlotPole_EPOCH","ProtectionZone_Invisible_F"], _buildingJammerRange]; if (!(_objects isEqualTo[]) && (_jammer isEqualTo[])) then { _building = selectRandom _objects; if !(_building in EPOCH_LootedBlds) then { _others = _building nearEntities[["Epoch_Male_F", "Epoch_Female_F"], 15]; if (_others isEqualTo[]) then { _nearObjects = nearestObjects[_building, ["WH_Loot", "Animated_Loot"], sizeOf (typeOf _building)]; //diag_log format["DEBUG: sizeof %1 %2",sizeOf (typeOf _building), typeOf _building]; if (_nearObjects isEqualTo[]) then { [_building] call EPOCH_spawnLoot; }; }; }; }; }; _lastPlayerPos = _playerPos; }; // init weather temperature var if not already set if (isNil "EPOCH_CURRENT_WEATHER") then { EPOCH_CURRENT_WEATHER = 75; }; _cursorTarget = objNull; // init cfgBaseBuilding config var _cfgBaseBuilding = 'CfgBaseBuilding' call EPOCH_returnConfig; _cfgObjectInteractions = 'CfgObjectInteractions' call EPOCH_returnConfig; _EPOCH_BuildTraderMisson = { params ['_inGameTasksconfig','_taskName',['_unit',objnull],['_taskItem',objnull]]; _taskTitle = getText ( _inGameTasksconfig >> _taskName >> "title"); _taskSQF = getText ( _inGameTasksconfig >> _taskName >> "initsqf"); if !(_taskSQF isequalto '') then { call compile format ["[_taskName,player,_unit,_taskItem] execVM ""%1""",_taskSQF]; }; _taskCall = getText ( _inGameTasksconfig >> _taskName >> "initcall"); if !(_taskCall isequalto '') then { call compile _taskCall; }; _taskDelay = diag_ticktime + (getNumber ( _inGameTasksconfig >> _taskName >> "triggerDelay")); _triggerintervall = getNumber ( _inGameTasksconfig >> _taskName >> "triggerintervall"); _taskItems = getArray ( _inGameTasksconfig >> _taskName >> "items"); if !(_taskItems isequalto []) then { [player,Epoch_personalToken,_taskItems,[],objNull,false] remoteExec ["EPOCH_Server_createObject",2]; }; _taskMarkerType = getnumber (_inGameTasksconfig >> _taskName >> 'markerType'); if (_taskMarkerType > 0) then { _taskMarkerVis = getNumber ( _inGameTasksconfig >> _taskName >> "markerVisible"); _markerPos = [0,0,0]; if (isNil "EPOCH_taskMarkerPos") then { if !(isNull _trgt) then { _markerPos = getPos _trgt; }; if !(isNull _unit) then{ _markerPos = getPos _unit; }; if !(isNull _taskItem) then { _markerPos = getPos _taskItem; }; } else { _markerPos = EPOCH_taskMarkerPos; }; _mkrName = format ["EPOCHTaskMark%1%2",_taskName,diag_tickTime]; EPOCH_taskMarker = [_mkrName,_taskMarkerVis]; _taskMarkerText = getText ( _inGameTasksconfig >> _taskName >> "markerText"); _taskMarkerRad = getNumber ( _inGameTasksconfig >> _taskName >> "markerRadius"); if(_taskMarkerType == 2)then{ _markerPos set [0, (_markerPos select 0) + (floor (random _taskMarkerRad) - (_taskMarkerRad / 2))]; _markerPos set [1, (_markerPos select 1) + (floor (random _taskMarkerRad) - (_taskMarkerRad / 2))]; }; [[_taskMarkerVis,player],_markerPos,"ELLIPSE","mil_dot",_taskMarkerText,"ColorYellow",[_taskMarkerRad,_taskMarkerRad], "SolidBorder", 42, 0.6,_mkrName] remoteExec ["EPOCH_server_makeMarker",2]; }; _taskDialogues = []; { _x params [["_condition",""],["_dialogue",""]]; if !(_condition isequalto "" || _dialogue isequalto "") then { _taskDialogues pushback [compile _condition,_dialogue]; }; } foreach (getarray (_inGameTasksconfig >> _taskName >> 'dialogues')); _taskEvents = []; { _x params [["_condition",""],["_taskEventCALL",""],["_taskEventTasks",[]]]; if !(_condition isequalto "") then { _taskEvents pushback [compile _condition,compile _taskEventCALL,_taskEventTasks]; }; } foreach (getarray (_inGameTasksconfig >> _taskName >> 'callevents')); _taskFailedCond = compile getText ( _inGameTasksconfig >> _taskName >> "failedCondition"); _taskFailTime = (getNumber ( _inGameTasksconfig >> _taskName >> "abandonTime")); if (_taskFailTime < 1) then {_taskFailTime=999999} else {_taskFailTime = _taskFailTime + diag_ticktime}; _taskFailedDiags = getArray ( _inGameTasksconfig >> _taskName >> "faileddialogues"); _taskFailedSQF = getText ( _inGameTasksconfig >> _taskName >> "failedSQF"); _taskFailedCall = compile getText ( _inGameTasksconfig >> _taskName >> "failedCall"); _nextTask = getArray ( _inGameTasksconfig >> _taskName >> "failedTask"); _taskCompleteCond = compile getText ( _inGameTasksconfig >> _taskName >> "completeCondition"); _taskReward = getArray ( _inGameTasksconfig >> _taskName >> "reward"); _taskCompleteDiags = getArray ( _inGameTasksconfig >> _taskName >> "completedialogues"); _taskCompleteCall = compile getText ( _inGameTasksconfig >> _taskName >> "completedCALL"); _taskNextTrigger = getArray ( _inGameTasksconfig >> _taskName >> "nextTask"); _missionCleanUpCall = compile getText ( _inGameTasksconfig >> _taskName >> "cleanUpCall"); _taskCleanup = getNumber ( _inGameTasksconfig >> _taskName >> "cleanUp"); _return = [ [_inGameTasksconfig,_taskName,_unit,_taskItem,_taskTitle,_missionCleanUpCall,_taskCleanup], _taskDelay, _triggerintervall, _taskDialogues, _taskEvents, [_taskFailedCond,_taskFailTime,_taskFailedDiags,_taskFailedSQF,_taskFailedCall,_nextTask], [_taskCompleteCond,_taskReward,_taskCompleteDiags,_taskCompleteCall,_taskNextTrigger] ]; EPOCH_task_startTime = diag_ticktime; _return }; _epoch_tradermissionarray = []; EPOCH_ActiveTraderMission = []; _LastMissionTrigger = 0;