2017-12-31 08:16:37 +00:00
/*
reconfiguring the properties of the grid (keep in mind the grid has default settings, but these you should overwrite where needed.
2017-10-26 01:36:31 +00:00
2017-12-31 08:16:37 +00:00
IMPORTANT: The grid squares are named like : SAR_area_0_0
2017-10-26 01:36:31 +00:00
2017-12-31 08:16:37 +00:00
where the first 0 is the x counter, and the second 0 the y counter.
2017-10-26 01:36:31 +00:00
2017-12-31 08:16:37 +00:00
So to adress the bottom left square in the grid, you use SAR_area_0_0.
The square above that one would be: SAR_area_0_1
the square one to the right of the bottom left square is SAR_area_1_0
2017-10-26 01:36:31 +00:00
2017-12-31 08:16:37 +00:00
You want to change the number arrays in the below lines:
2017-10-26 01:36:31 +00:00
2017-12-31 08:16:37 +00:00
The order for these numbers is always [BANDIT, SURVIVOR, SOLDIER]
2017-10-26 01:36:31 +00:00
2017-12-31 08:16:37 +00:00
Lets take an example for Chernarus
2017-10-26 01:36:31 +00:00
2017-12-31 08:16:37 +00:00
// Kamenka, 0 bandit groups, 1 soldier groups, 2 survivor groups - spawn probability ba,so,su - maximum group members ba,so,su
_check = [["max_grps","rnd_grps","max_p_grp"],[[0,1,2],[0,75,100],[0,4,3]],"SAR_area_0_0"] call SAR_AI_mon_upd;
2017-10-26 01:36:31 +00:00
2017-12-31 08:16:37 +00:00
[[0,1,2],[0,75,100],[0,4,3]]
2017-10-26 01:36:31 +00:00
2017-12-31 08:16:37 +00:00
the first set of numbers : 0,1,2
stands for
0 bandit groups
1 soldier group
2 surivors groups
thats the max that can spawn in this grid
2017-10-26 01:36:31 +00:00
2017-12-31 08:16:37 +00:00
the second set of numbers : 0,75,100
that means:
0% probability to spawn bandit groups
75% for soldiers
100% for survivors
2017-10-26 01:36:31 +00:00
2017-12-31 08:16:37 +00:00
the last set of numbers : 0,4,3
thats the maximum number of ppl in the group (including the leader)
0 bandits
max 4 soldiers
max 3 survivors
this number is randomized
*/
private ["_type"];
2017-10-26 01:36:31 +00:00
2017-12-31 08:16:37 +00:00
_type = _this select 0;
2017-10-26 01:36:31 +00:00
2017-12-31 08:16:37 +00:00
if (SAR_dynamic_spawning && (_type == "dynamic")) then {
2017-10-26 01:36:31 +00:00
2017-12-31 08:16:37 +00:00
diag_log format["SAR_AI: Dynamic spawning definition / adjustments started"];
2017-10-26 01:36:31 +00:00
2017-12-31 08:16:37 +00:00
2017-10-26 01:36:31 +00:00
2017-12-31 08:16:37 +00:00
diag_log format["SAR_AI: Dynamic spawning definition / adjustments finished"];
};
if (_type == "static") then {
// waitUntil {UPSMON_INIT == 1;};
diag_log format["Sarge's AI System: Static spawning area definition started"];
2017-10-26 01:36:31 +00:00
2017-12-31 08:16:37 +00:00
/*
Example Marker
_this = createMarker ["SAR_marker_EXAMPLE_LOCATION", [1234.56,1234.5]];
_this setMarkerShape "RECTANGLE";
_this setMarkeralpha 0;
_this setMarkerType "Flag";
_this setMarkerBrush "Solid";
_this setMarkerSize [10, 10];
SAR_marker_EXAMPLE_LOCATION = _this;
*/
2017-10-26 01:36:31 +00:00
2017-12-31 08:16:37 +00:00
diag_log format["SAR_AI: Static spawning area definition finished"];
2017-10-26 01:36:31 +00:00
2017-12-31 08:16:37 +00:00
diag_log format["Sarge AI: Static Spawning for Helicopter patrols started"];
2017-10-26 01:36:31 +00:00
//---------------------------------------------------------------------------------
// Static, predefined heli patrol areas with configurable units
//---------------------------------------------------------------------------------
//
2017-12-31 08:16:37 +00:00
// format: [areamarker,type_of_group,(respawn),(respawntime)] call SAR_AI;
2017-10-26 01:36:31 +00:00
//
// areamarker : Name of an area, as defined in your area definitions (MUST NOT BE similar to SAR_area_ ! THIS IS IMPORTANT!)
// type_of_group : 1 = military, 2 = survivors, 3 = bandits
//
// respawn : true or false (optional)
// respawntime : time in secs until group respawns (optional)
// air_vehicle_type : classnema of the air vehicle you want to use
//
//
// Note: The crew will be automatically seized to man any available gun in the airplane / heli.
//
// Examples:
//
// A) military air group patrolling, respawning, respawn time = default configured time, using default randomized vehicles
//
2017-12-31 08:16:37 +00:00
// [SAR_marker_DEBUG,1,true] call SAR_fnc_AI_heli;
2017-10-26 01:36:31 +00:00
//
// B) bandit air group patrolling, not respawning,
//
2017-12-31 08:16:37 +00:00
// [SAR_marker_DEBUG,3] call SAR_fnc_AI_heli;
2017-10-26 01:36:31 +00:00
//
// C) survivor air group patrolling, respawning, respawn time = 120 seconds
//
2017-12-31 08:16:37 +00:00
// [SAR_marker_DEBUG,true,120] call SAR_fnc_AI_heli;
2017-10-26 01:36:31 +00:00
2017-12-31 08:16:37 +00:00
/*
Example Helicopter Patrol
[SAR_marker_EXAMPLE_LOCATION,1,true] call SAR_fnc_AI_heli;
*/
2017-10-26 01:36:31 +00:00
2017-12-31 08:16:37 +00:00
diag_log format["Sarge AI: Static Spawning for Helicopter patrols finished"];
2017-10-26 01:36:31 +00:00
2017-12-31 08:16:37 +00:00
diag_log format["Sarge AI: Static Spawning for infantry patrols started"];
2017-10-26 01:36:31 +00:00
//---------------------------------------------------------------------------------
// Static, predefined infantry patrols in defined areas with configurable units
//---------------------------------------------------------------------------------
//
2017-12-31 08:16:37 +00:00
// format: [areamarker,type_of_group,number_of_snipers,number_of_riflemen,action_to_do,(respawn),(respawntime)] call SAR_fnc_AI_infantry;
2017-10-26 01:36:31 +00:00
//
// areamarker : Name of an area, as defined in your area definitions (MUST NOT BE similar to SAR_area_ ! THIS IS IMPORTANT!)
// type_of_group : 1 = military, 2 = survivors, 3 = bandits
// number_of_snipers : amount of snipers in the group
// number_of_riflemen : amount of riflemen in the group
//
// action_to_do : groupaction (optional, default is "patrol")
// possible values:
// "fortify" -> the group will search for nearby buildings and move in them. They will stay there until an enemy spotted, then they will chase him.
// "ambush" -> the group will look for a nearby road, and setup an ambush. They will not move until an enemy was spotted.
// "patrol" -> the group will patrol random waypoints in the area, and engage any enemy they see.
//
// respawn : true or false (optional)
// respawntime : time in secs until group respawns (optional)
//
// Examples:
//
// A) military group patrolling, with 1 leader and 1 rifleman, respawning, respawn time = default configured time
//
2017-12-31 08:16:37 +00:00
// [SAR_marker_DEBUG,1,0,1,"patrol",true] call SAR_fnc_AI_infantry;
2017-10-26 01:36:31 +00:00
//
// B) bandit group patrolling, with 1 leader, 2 snipers and 1 rifleman, respawning, respawn time = 30 seconds
//
2017-12-31 08:16:37 +00:00
// [SAR_marker_DEBUG,3,2,1,"patrol",true,30] call SAR_fnc_AI_infantry;
2017-10-26 01:36:31 +00:00
//
// C) survivor group fortifying, with 1 leader, 1 sniper and 3 riflemen, not respawning
//
2017-12-31 08:16:37 +00:00
// [SAR_marker_DEBUG,2,1,3,"fortify",false] call SAR_fnc_AI_infantry;
/*
Example Static Infantry
[SAR_marker_EXAMPLE_LOCATION,3,0,6,"fortify",true] call SAR_fnc_AI_infantry;
*/
diag_log format["Sarge AI: Static Spawning for infantry patrols finished"];
2017-10-26 01:36:31 +00:00
2017-12-31 08:16:37 +00:00
diag_log format["Sarge AI: Static Spawning for vehicle patrols started"];
2017-10-26 01:36:31 +00:00
// Static spawns for vehicle groups
//
2017-12-31 08:16:37 +00:00
// format: [areamarker,type_of_group,vehicle array,crew array,(respawn),(respawntime)] call SAR_AI_land;
2017-10-26 01:36:31 +00:00
//
//
// areamarker : Name of an area, as defined in your area definitions
// type_of_group : 1 = military, 2 = survivors, 3 = bandits
// vehicle array : e.g. ["car1"], MUST be enclosed by [], and MUST be valid vehicle classnames. multiple vehicles are possible, like this: ["car1","car1","car1"]
// crew array : e.g. [[1,2,3]] -> the first entry in the array element sets if the leader travels in that vehicle, the second is the number of snipers in the vehicle, the third is the number of riflemen.
// must match to the number of defined vehicles, so for the above example, you need: [[1,2,3],[0,1,2],[0,1,1]]
//
//
// respawn : true or false (optional)
// respawntime : time in secs until group respawns (optional)
2017-12-31 08:16:37 +00:00
/*
Example Static Vehicle
[
SAR_marker_EXAMPLE_LOCATION, // Name of the area that the vehicle patrol will spawn in
3, // type of group
["CUP_B_Ural_CDF"], // used vehicle
[[1,2,5]], // Vehicle initial crew
true, // if this group should respawn or not
(random 300) // waittime until this group will respawn
] call SAR_fnc_AI_vehicle;
*/
diag_log format["Sarge AI: Static Spawning for vehicle patrols finished"];
2017-10-26 01:36:31 +00:00
};