a3_exile_occupation/scripts/occupationStatic.sqf

175 lines
5.4 KiB
Plaintext
Raw Normal View History

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-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
_maxAIcount = SC_maxAIcount;
_minFPS = SC_minFPS;
2016-04-02 19:06:53 +00:00
_debug = SC_debug;
_useLaunchers = DMS_ai_use_launchers;
_scaleAI = SC_scaleAI;
2016-04-02 19:06:53 +00:00
_statics = SC_statics; // details for the static spawns
_static = [];
_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;
};
_aiActive = {alive _x && (side _x == EAST OR side _x == WEST)} 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;
};
for [{_i = 0},{_i < (count _statics)},{_i =_i + 1}] do
{
_currentStatic = _statics select _i;
_spawnPosition = _currentStatic select 0;
_aiCount = _currentStatic select 1;
_radius = _currentStatic select 2;
_staticSearch = _currentStatic select 3;
_logDetail = format ["[OCCUPATION Static]:: Checking static spawn @ %1",_spawnPosition,_aiCount];
2016-04-02 19:06:53 +00:00
[_logDetail] call SC_fnc_log;
_okToSpawn = true;
Sleep 0.1;
while{_okToSpawn} do
{
// Don't spawn additional AI if there are already AI in range
_aiNear = count(_spawnPosition nearEntities ["O_recon_F", 250]);
2016-04-02 19:06:53 +00:00
if(_aiNear > 0) exitwith
{
_okToSpawn = false;
if(_debug) then
{
_logDetail = format ["[OCCUPATION Static]:: %1 already has %2 active AI patrolling",_spawnPosition,_aiNear];
[_logDetail] call SC_fnc_log;
};
};
// Don't spawn additional AI if there are players in range
2016-04-02 19:06:53 +00:00
if([_spawnPosition, 400] call ExileClient_util_world_isAlivePlayerInRange) exitwith
{
_okToSpawn = false;
if(_debug) then
{
_logDetail = format ["[OCCUPATION Static]:: %1 has players too close",_spawnPosition];
[_logDetail] call SC_fnc_log;
};
};
if(_okToSpawn) then
{
//////////////////////////////////////////////////////////////////////////////////////////////////////////////////
// Get AI to patrol the area
//////////////////////////////////////////////////////////////////////////////////////////////////////////////////
_groupRadius = _radius;
_difficulty = "random";
_side = "bandit";
DMS_ai_use_launchers = false;
2016-04-10 14:42:45 +00:00
_group = [_spawnPosition, _aiCount, _difficulty, "assault", _side] call DMS_fnc_SpawnAIGroup;
{
_unit = _x;
[_unit] joinSilent grpNull;
[_unit] joinSilent _group;
}foreach units _group;
[ _group,_spawnPosition,_difficulty,"AWARE" ] call DMS_fnc_SetGroupBehavior;
DMS_ai_use_launchers = true;
// Get the AI to shut the fuck up :)
enableSentences false;
enableRadio false;
if(!_staticSearch) then
{
[_group, _spawnPosition, _groupRadius] call bis_fnc_taskPatrol;
_group setBehaviour "AWARE";
_group setCombatMode "RED";
}
else
{
_buildings = _spawnPosition nearObjects ["building", _groupRadius];
{
2016-04-10 14:42:45 +00:00
_isEnterable = [_x] call BIS_fnc_isBuildingEnterable;
if(_isEnterable) then
{
2016-04-10 14:42:45 +00:00
_buildingPositions = [_x, 10] call BIS_fnc_buildingPositions;
_y = _x;
// Find Highest Point
_highest = [0,0,0];
{
2016-04-10 14:42:45 +00:00
if(_x select 2 > _highest select 2) then
{
_highest = _x;
};
} foreach _buildingPositions;
2016-04-10 14:42:45 +00:00
_wpPosition = _highest;
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";
_wp setWaypointCombatMode "RED";
_wp setWaypointCompletionRadius 1;
2016-04-10 14:42:45 +00:00
_wp waypointAttachObject _y;
_wp setwaypointHousePosition _i;
2016-04-02 19:06:53 +00:00
_wp setWaypointType "SAD";
};
} foreach _buildings;
2016-04-10 14:42:45 +00:00
if(count _buildings > 0 && !isNil "_wp") then
{
_wp setWaypointType "CYCLE";
};
2016-04-10 14:42:45 +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;
if(SC_mapMarkers && !isNil "_foundBuilding") then
{
_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-02 19:06:53 +00:00
_logDetail = "[OCCUPATION Static]: Ended";
[_logDetail] call SC_fnc_log;