2016-03-23 11:05:19 +00:00
|
|
|
if (!isServer) exitWith {};
|
2016-04-12 10:14:07 +00:00
|
|
|
|
2016-04-02 19:06:53 +00:00
|
|
|
_logDetail = format ["[OCCUPATION Static]:: Starting Monitor"];
|
|
|
|
[_logDetail] call SC_fnc_log;
|
2016-03-23 11:05:19 +00:00
|
|
|
|
2016-04-12 10:14:07 +00:00
|
|
|
private["_wp","_wp2","_wp3"];
|
|
|
|
|
2016-04-02 19:06:53 +00:00
|
|
|
_middle = worldSize/2;
|
|
|
|
_spawnCenter = [_middle,_middle,0]; // Centre point for the map
|
|
|
|
_maxDistance = _middle; // Max radius for the map
|
2016-03-23 11:05:19 +00:00
|
|
|
|
|
|
|
_maxAIcount = SC_maxAIcount;
|
|
|
|
_minFPS = SC_minFPS;
|
2016-04-02 19:06:53 +00:00
|
|
|
_debug = SC_debug;
|
|
|
|
_useLaunchers = DMS_ai_use_launchers;
|
2016-03-23 11:05:19 +00:00
|
|
|
_scaleAI = SC_scaleAI;
|
|
|
|
|
2016-04-02 19:06:53 +00:00
|
|
|
_statics = SC_statics; // details for the static spawns
|
|
|
|
_static = [];
|
2016-03-23 11:05:19 +00:00
|
|
|
|
|
|
|
_currentPlayerCount = count playableUnits;
|
|
|
|
if(_currentPlayerCount > _scaleAI) then
|
|
|
|
{
|
|
|
|
_maxAIcount = _maxAIcount - (_currentPlayerCount - _scaleAI) ;
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
// Don't spawn additional AI if the server fps is below 8
|
2016-04-02 19:06:53 +00:00
|
|
|
if(diag_fps < _minFPS) exitWith
|
|
|
|
{
|
|
|
|
_logDetail = format ["[OCCUPATION Static]:: Held off spawning more AI as the server FPS is only %1",diag_fps];
|
|
|
|
[_logDetail] call SC_fnc_log;
|
|
|
|
};
|
2016-03-23 11:05:19 +00:00
|
|
|
|
2016-04-15 00:49:24 +00:00
|
|
|
_aiActive = {alive _x && (side _x == SC_BanditSide OR side _x == SC_SurvivorSide)} count allUnits;
|
2016-04-02 19:06:53 +00:00
|
|
|
if(_aiActive > _maxAIcount) exitWith
|
|
|
|
{
|
|
|
|
_logDetail = format ["[OCCUPATION Static]:: %1 active AI, so not spawning AI this time",_aiActive];
|
|
|
|
[_logDetail] call SC_fnc_log;
|
|
|
|
};
|
2016-03-23 11:05:19 +00:00
|
|
|
|
2016-04-14 10:29:30 +00:00
|
|
|
|
2016-03-23 11:05:19 +00:00
|
|
|
{
|
2016-04-14 10:29:30 +00:00
|
|
|
_currentStatic = _x;
|
2016-03-23 11:05:19 +00:00
|
|
|
_spawnPosition = _currentStatic select 0;
|
|
|
|
_aiCount = _currentStatic select 1;
|
|
|
|
_radius = _currentStatic select 2;
|
|
|
|
_staticSearch = _currentStatic select 3;
|
|
|
|
|
2016-04-06 10:29:59 +00:00
|
|
|
_logDetail = format ["[OCCUPATION Static]:: Checking static spawn @ %1",_spawnPosition,_aiCount];
|
2016-04-02 19:06:53 +00:00
|
|
|
[_logDetail] call SC_fnc_log;
|
2016-03-23 11:05:19 +00:00
|
|
|
|
|
|
|
_okToSpawn = true;
|
|
|
|
Sleep 0.1;
|
|
|
|
|
|
|
|
while{_okToSpawn} do
|
|
|
|
{
|
|
|
|
|
|
|
|
// Don't spawn additional AI if there are already AI in range
|
2016-04-15 00:49:24 +00:00
|
|
|
_nearBanditAI = { side _x == SC_BanditSide AND _x distance _spawnPosition < 250 } count allUnits;
|
|
|
|
if(_nearBanditAI > 0) exitwith
|
2016-04-02 19:06:53 +00:00
|
|
|
{
|
|
|
|
_okToSpawn = false;
|
|
|
|
if(_debug) then
|
|
|
|
{
|
2016-04-15 00:49:24 +00:00
|
|
|
_logDetail = format ["[OCCUPATION Static]:: %1 already has %2 active AI patrolling",_spawnPosition,_nearBanditAI];
|
2016-04-02 19:06:53 +00:00
|
|
|
[_logDetail] call SC_fnc_log;
|
|
|
|
};
|
|
|
|
};
|
2016-03-23 11:05:19 +00:00
|
|
|
|
|
|
|
// Don't spawn additional AI if there are players in range
|
2016-04-14 10:29:30 +00:00
|
|
|
if([_spawnPosition, 250] call ExileClient_util_world_isAlivePlayerInRange) exitwith
|
2016-04-02 19:06:53 +00:00
|
|
|
{
|
|
|
|
_okToSpawn = false;
|
|
|
|
if(_debug) then
|
|
|
|
{
|
|
|
|
_logDetail = format ["[OCCUPATION Static]:: %1 has players too close",_spawnPosition];
|
|
|
|
[_logDetail] call SC_fnc_log;
|
|
|
|
};
|
|
|
|
};
|
2016-03-23 11:05:19 +00:00
|
|
|
|
|
|
|
if(_okToSpawn) then
|
|
|
|
{
|
|
|
|
//////////////////////////////////////////////////////////////////////////////////////////////////////////////////
|
|
|
|
// Get AI to patrol the area
|
|
|
|
//////////////////////////////////////////////////////////////////////////////////////////////////////////////////
|
|
|
|
_groupRadius = _radius;
|
|
|
|
_difficulty = "random";
|
|
|
|
_side = "bandit";
|
|
|
|
|
|
|
|
DMS_ai_use_launchers = false;
|
2016-04-14 10:29:30 +00:00
|
|
|
_initialGroup = [_spawnPosition, _aiCount, _difficulty, "assault", _side] call DMS_fnc_SpawnAIGroup;
|
|
|
|
DMS_ai_use_launchers = _useLaunchers;
|
|
|
|
_initialGroup setCombatMode "BLUE";
|
|
|
|
_initialGroup setBehaviour "SAFE";
|
|
|
|
|
2016-04-15 00:49:24 +00:00
|
|
|
_group = createGroup SC_BanditSide;
|
2016-04-14 10:29:30 +00:00
|
|
|
_group setVariable ["DMS_LockLocality",nil];
|
|
|
|
_group setVariable ["DMS_SpawnedGroup",true];
|
|
|
|
_group setVariable ["DMS_Group_Side", _side];
|
2016-04-11 12:59:33 +00:00
|
|
|
|
|
|
|
{
|
2016-04-14 10:29:30 +00:00
|
|
|
_unit = _x;
|
2016-04-11 12:59:33 +00:00
|
|
|
[_unit] joinSilent grpNull;
|
|
|
|
[_unit] joinSilent _group;
|
2016-04-14 10:29:30 +00:00
|
|
|
if(SC_debug) then
|
|
|
|
{
|
|
|
|
_tag = createVehicle ["Sign_Arrow_F", position _unit, [], 0, "CAN_COLLIDE"];
|
|
|
|
_tag attachTo [_unit,[0,0,0.6],"Head"];
|
|
|
|
};
|
|
|
|
}foreach units _initialGroup;
|
|
|
|
|
2016-03-23 11:05:19 +00:00
|
|
|
|
|
|
|
// Get the AI to shut the fuck up :)
|
|
|
|
enableSentences false;
|
|
|
|
enableRadio false;
|
2016-04-14 10:29:30 +00:00
|
|
|
|
2016-03-23 11:05:19 +00:00
|
|
|
if(!_staticSearch) then
|
|
|
|
{
|
|
|
|
[_group, _spawnPosition, _groupRadius] call bis_fnc_taskPatrol;
|
|
|
|
_group setBehaviour "AWARE";
|
|
|
|
_group setCombatMode "RED";
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2016-03-30 08:33:25 +00:00
|
|
|
_buildings = _spawnPosition nearObjects ["building", _groupRadius];
|
2016-03-23 11:05:19 +00:00
|
|
|
{
|
2016-04-10 14:42:45 +00:00
|
|
|
_isEnterable = [_x] call BIS_fnc_isBuildingEnterable;
|
|
|
|
|
|
|
|
if(_isEnterable) then
|
2016-03-23 11:05:19 +00:00
|
|
|
{
|
2016-04-10 14:42:45 +00:00
|
|
|
_buildingPositions = [_x, 10] call BIS_fnc_buildingPositions;
|
|
|
|
_y = _x;
|
2016-03-23 11:05:19 +00:00
|
|
|
// Find Highest Point
|
|
|
|
_highest = [0,0,0];
|
|
|
|
{
|
2016-04-10 14:42:45 +00:00
|
|
|
if(_x select 2 > _highest select 2) then
|
2016-03-23 11:05:19 +00:00
|
|
|
{
|
|
|
|
_highest = _x;
|
|
|
|
};
|
|
|
|
|
|
|
|
} foreach _buildingPositions;
|
2016-04-10 14:42:45 +00:00
|
|
|
_wpPosition = _highest;
|
2016-04-11 12:59:33 +00:00
|
|
|
diag_log format ["Static Patrol %3 waypoint added - building: %1 position: %2",_y,_highest,_group];
|
2016-04-10 14:42:45 +00:00
|
|
|
_i = _buildingPositions find _wpPosition;
|
|
|
|
_wp = _group addWaypoint [_wpPosition, 0] ;
|
|
|
|
_wp setWaypointBehaviour "AWARE";
|
2016-03-23 11:05:19 +00:00
|
|
|
_wp setWaypointCombatMode "RED";
|
|
|
|
_wp setWaypointCompletionRadius 1;
|
2016-04-10 14:42:45 +00:00
|
|
|
_wp waypointAttachObject _y;
|
2016-03-23 11:05:19 +00:00
|
|
|
_wp setwaypointHousePosition _i;
|
2016-04-02 19:06:53 +00:00
|
|
|
_wp setWaypointType "SAD";
|
2016-03-23 11:05:19 +00:00
|
|
|
|
|
|
|
};
|
|
|
|
} foreach _buildings;
|
2016-04-10 14:42:45 +00:00
|
|
|
if(count _buildings > 0 && !isNil "_wp") then
|
2016-03-23 11:05:19 +00:00
|
|
|
{
|
|
|
|
_wp setWaypointType "CYCLE";
|
|
|
|
};
|
2016-04-10 14:42:45 +00:00
|
|
|
};
|
|
|
|
|
2016-03-23 11:05:19 +00:00
|
|
|
//////////////////////////////////////////////////////////////////////////////////////////////////////////////////
|
2016-04-02 19:06:53 +00:00
|
|
|
_logDetail = format ["[OCCUPATION Static]:: Spawning %1 AI in at %2 to patrol",_aiCount,_spawnPosition];
|
|
|
|
[_logDetail] call SC_fnc_log;
|
2016-03-23 11:05:19 +00:00
|
|
|
|
2016-04-06 10:29:59 +00:00
|
|
|
if(SC_mapMarkers && !isNil "_foundBuilding") then
|
2016-03-23 11:05:19 +00:00
|
|
|
{
|
|
|
|
_marker = createMarker [format ["%1", _foundBuilding],_spawnPosition];
|
|
|
|
_marker setMarkerShape "Icon";
|
|
|
|
_marker setMarkerSize [3,3];
|
|
|
|
_marker setMarkerType "mil_dot";
|
|
|
|
_marker setMarkerBrush "Solid";
|
|
|
|
_marker setMarkerAlpha 0.5;
|
|
|
|
_marker setMarkerColor "ColorRed";
|
|
|
|
_marker setMarkerText "Occupied Area (static)";
|
|
|
|
};
|
|
|
|
|
|
|
|
_okToSpawn = false;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2016-04-14 10:29:30 +00:00
|
|
|
}forEach _statics;
|
|
|
|
|
2016-04-02 19:06:53 +00:00
|
|
|
_logDetail = "[OCCUPATION Static]: Ended";
|
|
|
|
[_logDetail] call SC_fnc_log;
|