Advertisement
LadyVal

A3XAI

Mar 25th, 2019
135
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
text 41.84 KB | None | 0 0
  1. class CfgPatches {
  2. class A3XAI_config {
  3. units[] = {};
  4. weapons[] = {};
  5. requiredVersion = 0.1;
  6. A3XAIVersion = "0.2.1";
  7. requiredAddons[] = {};
  8. };
  9. };
  10.  
  11. class CfgA3XAISettings {
  12.  
  13. /* A3XAI Settings
  14. --------------------------------------------------------------------------------------------------------------------*/
  15.  
  16. //Enable or disable event logging to the server RPT file (named arma3server_[date]_[time].rpt). Debug level setting. 0: No debug output, 1: Basic Debug output, 2: Detailed Debug output. (Default: 0)
  17. //Debug output may help finding additional information about A3XAI's background behavior. This output is helpful when asking for help regarding bugs or unexpected behaviors.
  18. debugLevel = 1;
  19.  
  20. //Frequency of server monitor update to RPT log in seconds. The monitor periodically reports number of max/current AI units and dynamically spawned triggers into RPT log. (Default: 300, 0 = Disable reporting)
  21. monitorReportRate = 300;
  22.  
  23. //Enable or disable verification and error-correction of classname tables used by A3XAI. If invalid entries are found, they are removed and logged into the RPT log.
  24. //If disabled, any invalid classnames will not be removed and clients may crash if AI bodies with invalid items are looted. Only disable if a previous scan shows no invalid classnames (Default: 1).
  25. verifyClassnames = 1;
  26.  
  27. //Enables checking of all A3XAI config settings. (Default: 1)
  28. verifySettings = 1;
  29.  
  30. //Minimum seconds to pass until each dead AI body or destroyed vehicle can be cleaned up by A3XAI's task scheduler. A3XAI will not clean up a body/vehicle if there is a player close by (Default: 900).
  31. cleanupDelay = 900;
  32.  
  33. //Enabled: A3XAI will load custom spawn/blacklist definitions file on startup (A3XAI_config.pbo >> custom_defs.sqf) (Default: 0)
  34. loadCustomFile = 0;
  35.  
  36.  
  37. /* A3XAI HC Settings
  38. --------------------------------------------------------------------------------------------------------------------*/
  39.  
  40. //Enables A3XAI headless client support. (Default: 0)
  41. enableHC = 0;
  42.  
  43. //If HC support enabled, A3XAI will pause during post-initialization until HC has successfully connected. (Default: 0)
  44. //IMPORTANT: It is highly recommended to ensure that the HC is properly setup before enabling this option, otherwise A3XAI may be stuck waiting for HC to to connect.
  45. waitForHC = 0;
  46.  
  47.  
  48. /* Dynamic Classname Settings
  49.  
  50. If a setting is disabled, A3XAI will use the corresponding classname table further below. See "AI clothing, weapon, loot, and equipment settings" section.
  51. --------------------------------------------------------------------------------------------------------------------*/
  52.  
  53. //Purchase price limit for items generated by dynamic classname system as defined in CfgExileArsenal. Lowering this value may reduce variety of items carried by AI. (Default: 2000)
  54. itemPriceLimit = 7000;
  55.  
  56. //1: Generate AI weapons from Exile trader tables (Default)
  57. //0: Weapons defined by pistolList, rifleList, machinegunList, sniperList
  58. //dynamicWeaponBlacklist: Classnames of weapons to ignore from Exile trader tables
  59. generateDynamicWeapons = 1;
  60. dynamicWeaponBlacklist[] = {};
  61.  
  62. //1: Use Exile loot table data as whitelist for AI-usable weapon scopes (Default)
  63. //0: Scopes defined by weaponOpticsList
  64. //dynamicOpticsBlacklist: List of optics classnames to ignore from Exile trader tables.
  65. generateDynamicOptics = 1;
  66. dynamicOpticsBlacklist[] = {};
  67.  
  68. //1: Generate AI uniform types from Exile trader tables (Default)
  69. //0: Uniforms defined by uniformTypes0, uniformTypes1, uniformTypes2, uniformTypes3
  70. //dynamicUniformBlacklist: List of uniform classnames to ignore from Exile trader tables.
  71. generateDynamicUniforms = 1;
  72. dynamicUniformBlacklist[] = {};
  73.  
  74. //1: Generate AI backpack types from Exile trader tables (Default)
  75. //0: Backpacks defined by backpackTypes0, backpackTypes1, backpackTypes2, backpackTypes3
  76. //dynamicBackpackBlacklist: List of backpack classnames to ignore from Exile trader tables.
  77. generateDynamicBackpacks = 1;
  78. dynamicBackpackBlacklist[] = {};
  79.  
  80. //1: Generate AI backpack types from Exile trader tables (Default)
  81. //0: Vests defined by vestTypes0, vestTypes1, vestTypes2, vestTypes3
  82. //dynamicVestBlacklist: List of vest classnames to ignore from Exile trader tables.
  83. generateDynamicVests = 1;
  84. dynamicVestBlacklist[] = {};
  85.  
  86. //1: Generate AI headgear types from Exile trader tables (Default)
  87. //0: Headgear defined by headgearTypes0, headgearTypes1, headgearTypes2, headgearTypes3
  88. //dynamicHeadgearBlacklist: List of headgear classnames to ignore from Exile trader tables.
  89. generateDynamicHeadgear = 1;
  90. dynamicHeadgearBlacklist[] = {};
  91.  
  92. //1: Generate AI food types from Exile trader tables (Default)
  93. //0: Food defined by foodLoot
  94. //dynamicFoodBlacklist: List of food classnames to ignore from Exile trader tables.
  95. generateDynamicFood = 1;
  96. dynamicFoodBlacklist[] = {};
  97.  
  98. //1: Generate AI generic loot types from Exile trader tables. Includes "Hardware", "Smoke", "Flare" -class items. (Default)
  99. //0: Loot defined by MiscLoot
  100. //dynamicLootBlacklist: List of loot classnames to ignore from Exile trader tables.
  101. generateDynamicLoot = 1;
  102. dynamicLootBlacklist[] = {};
  103.  
  104.  
  105. //Enable or disable radio message receiving. Players with radios or part of a group with at least one radio will be able to intercept some AI communications. (Default: 0)
  106. enableRadioMessages = 1;
  107.  
  108.  
  109. /* Shared AI Unit Settings. These settings affect all AI spawned unless noted otherwise.
  110. --------------------------------------------------------------------------------------------------------------------*/
  111.  
  112. //Sets side/faction for AI spawned by A3XAI. If A3XAI units are hostile with AI spawned from other install addons, consider changing this setting. Acceptable sides: east or west (Default: east)
  113. side = EAST;
  114.  
  115. //Number of online players required for maximum (or minimum) AI spawn chance. Affects Static, Dynamic, Random AI spawns. (Default: 10)
  116. playerCountThreshold = 1;
  117.  
  118. //1: Spawn chance multiplier scales upwards from value defined by chanceScalingThreshold to 1.00. 0: Spawn chance multiplier scales downwards from 1.00 to chanceScalingThreshold.
  119. upwardsChanceScaling = 0;
  120.  
  121. //If upwardsChanceScaling is 1: Initial spawn chance multiplier. If upwardsChanceScaling is 0: Final spawn chance multiplier. (Default: 0.50)
  122. chanceScalingThreshold = 0.25;
  123.  
  124. //(Static/Dynamic/Random Spawns) minAI: Minimum number of units. addAI: maximum number of additional units. unitLevel: Unit level (0-3)
  125. minAI_village = 1;
  126. addAI_village = 1;
  127. unitLevel_village = 0;
  128. spawnChance_village = 0.40;
  129.  
  130. //(Static/Dynamic/Random Spawns) minAI: Minimum number of units. addAI: maximum number of additional units. unitLevel: Unit level (0-3)
  131. minAI_city = 1;
  132. addAI_city = 2;
  133. unitLevel_city = 1;
  134. spawnChance_city = 0.60;
  135.  
  136. //(Static/Dynamic/Random Spawns) minAI: Minimum number of units. addAI: maximum number of additional units. unitLevel: Unit level (0-3)
  137. minAI_capitalCity = 2;
  138. addAI_capitalCity = 1;
  139. unitLevel_capitalCity = 1;
  140. spawnChance_capitalCity = 0.70;
  141.  
  142. //(Static/Dynamic/Random Spawns) minAI: Minimum number of units. addAI: maximum number of additional units. unitLevel: Unit level (0-3)
  143. minAI_remoteArea = 1;
  144. addAI_remoteArea = 2;
  145. unitLevel_remoteArea = 2;
  146. spawnChance_remoteArea = 0.80;
  147.  
  148. //(Static/Dynamic/Random Spawns) minAI: Minimum number of units. addAI: maximum number of additional units. unitLevel: Unit level (0-3)
  149. minAI_wilderness = 1;
  150. addAI_wilderness = 2;
  151. unitLevel_wilderness = 1;
  152. spawnChance_wilderness = 0.50;
  153.  
  154. //(For dynamic and random spawns only) Defines amount of time to wait in seconds until cleaning up temporary blacklist area after dynamic/random spawn is deactivated (Default: 1200)
  155. tempBlacklistTime = 1200;
  156.  
  157. //Enable or disable AI death messages. Messages will be visible to all group members of player responsible for killing the AI unit. (Default: 1)
  158. enableDeathMessages = 1;
  159.  
  160. //If enabled, AI group will attempt to track down player responsible for killing a group member. (Default: 1)
  161. enableFindKiller = 1;
  162.  
  163. //If normal probability check for spawning NVGs fails, then give AI temporary NVGs during night hours. Temporary NVGs are unlootable and will be removed at death (Default: 0).
  164. enableTempNVGs = 0;
  165.  
  166. //Minimum AI unit level requirement to use underslung grenade launchers. Set to -1 to disable completely. (Default: 1)
  167. levelRequiredGL = 1;
  168.  
  169. //Minimum AI unit level requirement to use launcher weapons. Set to -1 to disable completely. Launchers are unlootable and will be removed at death (Default: -1)
  170. levelRequiredLauncher = 1;
  171.  
  172. //List of launcher-type weapons that AI can use.
  173. launcherTypes[] = {"launch_RPG32_F","launch_B_Titan_short_F","launch_I_Titan_short_F","launch_O_Titan_short_F"};
  174.  
  175. //Maximum number of launcher weapons allowed per group (Default: 1)
  176. launchersPerGroup = 1;
  177.  
  178. //Enable or disable AI self-healing. Level 0 AI cannot self-heal. Affects: All AI infantry units (Default: 1).
  179. enableHealing = 1;
  180.  
  181. //If enabled, A3XAI will remove all explosive ammo (missiles, rockets, bombs - but not HE rounds) from spawned AI air vehicles. (Default: 1)
  182. //Affects: All AI air vehicle types (patrols/custom/reinforcement). Does not affect UAV/UGVs.
  183. removeExplosiveAmmo = 0;
  184.  
  185. //if enabled, AI units suffer no damage from vehicle collisions. (Default: 1)
  186. noCollisionDamage = 0;
  187.  
  188. //If enabled, AI killed by vehicle collisions will have their gear removed (Default: 1)
  189. roadKillPenalty = 0;
  190.  
  191. //Array of positions defining trader locations. AI will be non-hostile and damage immune around this area.
  192. //Use this if your server is not using the standard Exile trader markers or sensors in mission.sqm
  193. //For performance reasons, do not add locations other than actual trader positions to this array.
  194. //Example: traderAreaLocations[] = {{2998.06,18175.5,0},{14600,16797.2,0},{23334.6,24188.9,0}};
  195. traderAreaLocations[] = {};
  196.  
  197.  
  198. /* Static Infantry AI Spawning Settings
  199.  
  200. A3XAI will spawn an AI group at various named locations on the map if players are nearby.
  201. --------------------------------------------------------------------------------------------------------------------*/
  202.  
  203. //Enable or disable static AI spawns. If enabled, AI spawn points will be generated in cities, towns, and other named areas.
  204. //Enabled: A3XAI automatically generates static spawns at named locations on map. Disabled: No static spawns will be generated. (Default: 1)
  205. enableStaticSpawns = 0;
  206.  
  207. //Set minimum and maximum wait time (seconds) to respawn an AI group after all units have been killed. Applies to both static AI and custom spawned AI (Default: Min 300, Max 600).
  208. respawnTimeMin = 300;
  209. respawnTimeMax = 600;
  210.  
  211. //Time to allow spawned AI units to exist in seconds before being despawned when no players are present in a trigger area. Applies to both static AI and custom spawned AI (Default: 120)
  212. despawnWait = 300;
  213.  
  214. //Respawn Limits. Set to -1 for unlimited respawns. (Default: -1 for each).
  215. respawnLimit_village = -1;
  216. respawnLimit_city = -1;
  217. respawnLimit_capitalCity = -1;
  218. respawnLimit_remoteArea = -1;
  219.  
  220.  
  221. /* Dynamic Infantry AI Spawning Settings. Probabilities should add up to 1.00
  222.  
  223. A3XAI will create ambient threat in the area for each player by periodically spawning AI to create unexpected ambush encounters. These AI may occasionally seek out and hunt a player.
  224. --------------------------------------------------------------------------------------------------------------------*/
  225.  
  226. //Upper limit of dynamic spawns on map at once. Set to 0 to disable dynamic spawns (Default: 15)
  227. maxDynamicSpawns = 0;
  228.  
  229. //Minimum time (in seconds) that must pass between dynamic spawns for each player (Default: 900)
  230. timePerDynamicSpawn = 900;
  231.  
  232. //Players offline for this amount of time (seconds) will have their last spawn timestamp reset (Default: 3600)
  233. purgeLastDynamicSpawnTime = 3600;
  234.  
  235. //Probability for dynamic AI to actively hunt a targeted player. If probability check fails, dynamic AI will patrol the area instead of hunting (Default: 0.60)
  236. spawnHunterChance = 0.60;
  237.  
  238. //Time to wait (seconds) before despawning all AI units in dynamic spawn area when no players are present. (Default: 120)
  239. despawnDynamicSpawnTime = 120;
  240.  
  241.  
  242. /* Random Infantry AI Spawning Settings
  243.  
  244. A3XAI will create spawns that are randomly placed around the map and are periodically relocated. These spawns are preferentially created in named locations, but may be also created anywhere in the world.
  245. --------------------------------------------------------------------------------------------------------------------*/
  246.  
  247. //Maximum number of placed random spawns on map. Set to -1 for A3XAI to automatically adjust spawn limit according to map size. Set to 0 to disable random spawns. (Default: -1)
  248. maxRandomSpawns = 0;
  249.  
  250. //Time to wait (seconds) before despawning all AI units in random spawn area when no players are present. (Default: 120)
  251. despawnRandomSpawnTime = 120;
  252.  
  253. //Minimum distance between a random spawn location and other random spawns. (Default: 0)
  254. distanceBetweenRandomSpawns = 0;
  255.  
  256.  
  257. /* Shared AI Vehicle Settings
  258.  
  259. These settings affect the following AI vehicle patrol types: Air, Land, UAV, UGV
  260. --------------------------------------------------------------------------------------------------------------------*/
  261.  
  262. //Time to wait (seconds) before despawning disabled/destroyed AI vehicles. If vehiclesAllowedForPlayers is enabled, this timer is cleared once a player enters the vehicle. (Default: 600)
  263. vehicleDespawnTime = 900;
  264.  
  265. //Enable player use of AI vehicles. Players must either disable the vehicle or kill all units of the group in order to access the vehicle. (Default: 0)
  266. vehiclesAllowedForPlayers = 0;
  267.  
  268. //Add name of location as displayed on map prevent AI vehicle patrols from travelling to these locations. Location names are case-sensitive. Note: Vehicles may still pass through these areas
  269. //Example: waypointBlacklistAir[] = {"Aggelochori","Panochori","Zaros"};
  270. waypointBlacklistAir[] = {}; //Affects Air vehicles (including UAVs)
  271. waypointBlacklistLand[] = {}; //Affects Land vehicles (including UGVs)
  272.  
  273.  
  274. /* AI Air Vehicle patrol settings.
  275.  
  276. IMPORTANT: UAVs (Unmanned aerial vehicles) are not supported by this function. UAV spawns can be configured in the "UAV Patrol Settings" section further below.
  277.  
  278. A3XAI will create AI vehicle patrols that will randomly travel between different cities and towns, and engage any players encountered.
  279. Helicopters with available cargo space may also occasionally deploy an AI group by parachute.
  280. --------------------------------------------------------------------------------------------------------------------*/
  281.  
  282. //Global maximum number of active AI air vehicle patrols. Set at 0 to disable (Default: 0).
  283. maxAirPatrols = 0;
  284.  
  285. //Probability of spawning Level 0/1/2/3 AI air vehicle patrol spawns. Probabilities should add up to 1.00
  286. levelChancesAir[] = {0.25,0.25,0.25,0.25};
  287.  
  288. //Set minimum and maximum wait time in seconds to respawn an AI vehicle patrol after vehicle is destroyed or disabled. (Default: Min 600, Max 900).
  289. respawnAirMinTime = 600;
  290. respawnAirMaxTime = 900;
  291.  
  292. //Classnames of air vehicle types to use, with the maximum amount of each type to spawn.
  293. airVehicleList[] = {
  294. //{"B_Heli_Light_01_armed_F",5},
  295. {"B_Heli_Transport_01_F",1},
  296. {"B_Heli_Transport_03_F",1}
  297. };
  298.  
  299. //Maximum number of gunner units per air vehicle. Limited by actual number of available gunner positions. (Default: 2)
  300. //Affects: All AI air vehicle patrols, including custom and reinforcement.
  301. airGunnerUnits = 5;
  302.  
  303. //Probability of AI helicopter sucessfully detecting player if there is line-of-sight. AI helicopters will conduct a visual sweep upon arriving at each waypoint and some distance after leaving. (Default: 0.80)
  304. //Affects: All AI air vehicle patrols, including custom and reinforcement.
  305. airDetectChance = 0.50;
  306.  
  307. //Probability of AI to deploy infantry units by parachute if players are nearby when helicopter is investigating a waypoint. (Default: 0.50)
  308. //Affects: Air vehicle patrols.
  309. paradropChance = 0.90;
  310.  
  311. //Cooldown time for AI paradrop deployment in seconds. (Default: 1800).
  312. //Affects: Air vehicle patrols.
  313. paradropCooldown = 1800;
  314.  
  315. //Number of infantry AI to paradrop if players are nearby when helicopter is investigating a waypoint, or if helicopter is reinforcing a dynamic AI spawn. Limited by number of cargo seats available in the vehicle. (Default: 3)
  316. //Affects: Air vehicle patrols, air reinforcements.
  317. paradropAmount = 4;
  318.  
  319.  
  320. /* AI Land Vehicle patrol settings. These AI vehicles will randomly travel between different cities and towns.
  321.  
  322. IMPORTANT: UGVs (Unmanned ground vehicles) are not supported by this function. UGV spawns can be configured in the "UGV Patrol Settings" section further below.
  323.  
  324. A3XAI will create AI vehicle patrols that will randomly travel between different cities and towns, and engage any players encountered.
  325. --------------------------------------------------------------------------------------------------------------------*/
  326.  
  327. //Global maximum number of active AI land vehicle patrols. Set at 0 to disable (Default: 0).
  328. maxLandPatrols = 20;
  329.  
  330. //Probability of spawning Level 0/1/2/3 AI land vehicle spawns. Probabilities should add up to 1.00
  331. levelChancesLand[] = {0.25,0.25,0.25,0.25};
  332.  
  333. //Set minimum and maximum wait time in seconds to respawn an AI vehicle patrol after vehicle is destroyed or disabled. (Default: Min 600, Max 900).
  334. respawnLandMinTime = 600;
  335. respawnLandMaxTime = 900;
  336.  
  337. //Classnames of land vehicle types to use, with the maximum amount of each type to spawn.
  338. landVehicleList[] =
  339. {
  340. //Fox Cars
  341. {"Fox_Pickup_6S",2},
  342. {"Fox_Pickup_Tow",2},
  343. {"Fox_Pickup_Apocalypse",2},
  344. {"Fox_Charger_Apocalypse",2},
  345. {"Fox_Tahoe_Apocalypse",2},
  346. {"Fox_F40",2},
  347. {"Fox_Viper",2},
  348. {"Fox_GNX",2},
  349. //{"Fox_Outsider",5},
  350. {"Fox_Landrover",2},
  351. {"Fox_Landrover2",2},
  352. {"Fox_Interceptor",2},
  353. {"Fox_DaytonaStratos",2},
  354. {"Fox_DaytonaGeneral",2},
  355. {"Fox_Daytona",2},
  356. {"Fox_ChallengerBR",2},
  357. {"Fox_ChallengerDev",2},
  358. {"Fox_ChallengerDev2",2},
  359. {"Fox_ChallengerYB",2},
  360. {"Fox_ChallengerO",2},
  361. {"Fox_ChallengerW",2},
  362. {"Fox_LandCruiserFox",2},
  363. {"Fox_LandCruiser3",2},
  364. {"Fox_LandCruiser2",2},
  365. {"Fox_LandCruiser",2},
  366. {"Fox_Patrol",2},
  367. {"Fox_Patrol2",2},
  368. {"Fox_Patrol3",2},
  369. {"Fox_BUS",2},
  370. //Trucks and transports
  371. {"O_Truck_03_fuel_F",2},
  372. {"O_Truck_03_ammo_F",2},
  373. {"O_Truck_03_repair_F",2},
  374. {"O_Truck_03_medical_F",5},
  375. {"O_Truck_03_transport_F",5},
  376. {"O_T_Truck_03_repair_ghex_F",2},
  377. {"O_T_Truck_03_ammo_ghex_F",2},
  378. {"O_T_Truck_03_fuel_ghex_F",2},
  379. {"O_T_Truck_03_medical_ghex_F",5},
  380. {"O_G_Van_02_transport_F",5},
  381. {"O_G_Van_02_vehicle_F",5},
  382. {"B_Truck_01_transport_F",5},
  383. {"B_Truck_01_covered_F",5},
  384. {"B_Truck_01_box_F",2},
  385. {"B_Truck_01_Repair_F",2},
  386. {"B_Truck_01_ammo_F",2},
  387. {"B_Truck_01_fuel_F",2},
  388. {"B_Truck_01_medical_F",5},
  389. {"B_T_Truck_01_transport_F",5},
  390. {"B_T_Truck_01_covered_F",5},
  391. {"B_T_Truck_01_box_F",2},
  392. {"B_T_Truck_01_Repair_F",2},
  393. {"B_T_Truck_01_ammo_F",2},
  394. {"B_T_Truck_01_medical_F",5},
  395. //Armed APCs
  396. {"I_MRAP_03_hmg_F",3},
  397. {"I_APC_Wheeled_03_cannon_F",3},
  398. {"B_APC_Wheeled_01_cannon_F",3},
  399. {"B_APC_Wheeled_03_cannon_F",3},
  400. {"B_T_LSV_01_armed_F",3},
  401. {"B_T_LSV_01_AT_F",3},
  402. {"B_T_MRAP_01_hmg_F",3},
  403. {"O_APC_Wheeled_02_rcws_v2_F",3},
  404. {"O_T_APC_Wheeled_02_rcws_v2_ghex_F",3},
  405. {"O_LSV_02_armed_F",3}
  406.  
  407. };
  408.  
  409. //Maximum number of gunner units per land vehicle. Limited by actual number of available gunner positions. (Default: 2)
  410. landGunnerUnits = 6;
  411.  
  412. //Maximum number of cargo units per land vehicle. Limited by actual number of available cargo positions. (Default: 3)
  413. landCargoUnits = 15;
  414.  
  415.  
  416. /* AI Air Reinforcement Settings
  417.  
  418. Allowed types of AI groups (defined by airReinforcementAllowedTypes) may call for temporary air reinforcements if a player kills one of their units.
  419. Probability to summon reinforcements determined by airReinforcementSpawnChance<AI level>, where <AI level> is the level of the calling group.
  420. Once summoned, armed reinforcement vehicles will remain in the area for a duration determined by airReinforcementDuration<AI level> and engage nearby players.
  421. Unarmed reinforcement vehicles will deploy a paradrop group and exit the area.
  422.  
  423. --------------------------------------------------------------------------------------------------------------------*/
  424.  
  425. //Maximum allowed number of simultaneous active reinforcements (Default: 5)
  426. maxAirReinforcements = 1;
  427.  
  428. //Air vehicles to use as reinforcement vehicles. Default: {"B_Heli_Transport_01_F","B_Heli_Light_01_armed_F"}
  429. //Armed air vehicles will detect and engage players within reinforcement area. Unarmed air vehicles will deploy an AI paradrop group.
  430. airReinforcementVehicles[] = {
  431. "B_Heli_Transport_01_F"
  432. //"B_Heli_Light_01_armed_F"
  433. };
  434.  
  435. //Probability to spawn reinforcements for each AI level.
  436. airReinforcementSpawnChance0 = 0.00;
  437. airReinforcementSpawnChance1 = 0.10;
  438. airReinforcementSpawnChance2 = 0.20;
  439. airReinforcementSpawnChance3 = 0.30;
  440.  
  441. //AI types permitted to summon reinforcements. Default: airReinforcementAllowedFor[] = {"static","dynamic","random"};
  442. //Usable AI types: "static", "dynamic", "random", "air", "land", "staticcustom", "aircustom", "landcustom", "vehiclecrew"
  443. airReinforcementAllowedFor[] = {"dynamic","random"};
  444.  
  445. //Maximum time for reinforcement for armed air vehicles in seconds. AI air vehicle will leave the area after this time if not destroyed.
  446. airReinforcementDuration0 = 120;
  447. airReinforcementDuration1 = 180;
  448. airReinforcementDuration2 = 240;
  449. airReinforcementDuration3 = 300;
  450.  
  451.  
  452. /* UAV Patrol Settings
  453.  
  454. IMPORTANT: UAV patrols are a feature in testing, and may undergo significant changes or possible removal in future versions.
  455.  
  456. A3XAI can spawn UAVs that patrol between named locations, and deploy air reinforcements if players are found.
  457. In order for air reinforcements to be deployed, maxAirReinforcements must be greater than zero and the current limit of air reinforcements has not been exceeded.
  458. --------------------------------------------------------------------------------------------------------------------*/
  459.  
  460. //Global maximum number of active UAV patrols. Set at 0 to disable (Default: 0).
  461. maxUAVPatrols = 0;
  462.  
  463. //Classnames of UAV types to use, with the maximum amount of each type to spawn.
  464. UAVList[] = {
  465. {"I_UAV_02_CAS_F",5},
  466. {"I_UAV_02_F",5},
  467. {"B_UAV_02_CAS_F",5},
  468. {"B_UAV_02_F",5},
  469. {"O_UAV_02_CAS_F",5},
  470. {"O_UAV_02_F",5}
  471. };
  472.  
  473. //Probability of spawning Level 0/1/2/3 UAV spawns. Probabilities should add up to 1.00
  474. levelChancesUAV[] = {0.35,0.50,0.15,0.00};
  475.  
  476. //Set minimum and maximum wait time in seconds to respawn a UAV after vehicle is destroyed or disabled. (Default: Min 600, Max 900).
  477. respawnUAVMinTime = 600;
  478. respawnUAVMaxTime = 900;
  479.  
  480. //Set to '1' to set detection-only behavior (UAV will not directly engage enemies). (Default: 0)
  481. detectOnlyUAVs = 0;
  482.  
  483. //Cooldown required in between air reinforcement summons when detecting players. Value in seconds. (Default: 1800)
  484. UAVCallReinforceCooldown = 1800;
  485.  
  486. //Probability to successfully detect player if there is line-of-sight. If at least one player is detected, air reinforcements will be summoned to the area. (Default: 0.50)
  487. UAVDetectChance = 0.80;
  488.  
  489.  
  490. /* UGV Patrol Settings
  491.  
  492. IMPORTANT: UGV patrols are a feature in testing, and may undergo significant changes or possible removal in future versions.
  493.  
  494. A3XAI can spawn UGVs that patrol between named locations, and deploy air reinforcements if players are found. Damaged UGVs repair themselves over time if not engaging enemes.
  495. In order for air reinforcements to be deployed, maxAirReinforcements must be greater than zero and the current limit of air reinforcements has not been exceeded.
  496. --------------------------------------------------------------------------------------------------------------------*/
  497.  
  498. //Global maximum number of active UGV patrols. Set at 0 to disable (Default: 0).
  499. maxUGVPatrols = 0;
  500.  
  501. //Classnames of UGV types to use, with the maximum amount of each type to spawn.
  502. UGVList[] = {
  503. {"I_UGV_01_rcws_F",5},
  504. {"B_UGV_01_rcws_F",5},
  505. {"O_UGV_01_rcws_F",5}
  506. };
  507.  
  508. //Probability of spawning Level 0/1/2/3 AI UGV spawns. Probabilities should add up to 1.00
  509. levelChancesUGV[] = {0.35,0.50,0.15,0.00};
  510.  
  511. //Set minimum and maximum wait time in seconds to respawn a UGV patrol after vehicle is destroyed or disabled. (Default: Min 600, Max 900).
  512. respawnUGVMinTime = 600;
  513. respawnUGVMaxTime = 900;
  514.  
  515. //Set to '1' to set detection-only behavior (UGV will not directly engage enemies). (Default: 0)
  516. detectOnlyUGVs = 0;
  517.  
  518. //Cooldown required in between air reinforcement summons when detecting players. Value in seconds. (Default: 1800)
  519. UGVCallReinforceCooldown = 1800;
  520.  
  521. //Probability to successfully detect player if there is line-of-sight. If at least one player is detected, air reinforcements will be summoned to the area. (Default: 0.50)
  522. UGVDetectChance = 0.80;
  523.  
  524.  
  525. /*
  526. AI skill settings.
  527.  
  528. These settings affect all AI units spawned by A3XAI.
  529.  
  530. Skill Level: Description
  531. 0: Low-level AI found in villages
  532. 1: Medium-level AI found in cities and capital cities
  533. 2: High-level AI found in remote areas such as factories and military bases
  534. 3: Expert-level AI.
  535.  
  536. Valid skill range: 0.00 - 1.00.
  537. Hint: For all skill types, higher number = better skill. For skill sub-type explanation, see: https://community.bistudio.com/wiki/AI_Sub-skills
  538. */
  539.  
  540. //AI skill settings level 0 (Skill, Minimum skill, Maximum skill). Defaults: Accuracy 0.05-0.10, Others 0.30-0.50
  541. skill0[] = {
  542. {"aimingAccuracy",0.05,0.10},
  543. {"aimingShake",0.30,0.50},
  544. {"aimingSpeed",0.30,0.50},
  545. {"spotDistance",0.30,0.50},
  546. {"spotTime",0.30,0.50},
  547. {"courage",0.30,0.50},
  548. {"reloadSpeed",0.30,0.50},
  549. {"commanding",0.30,0.50},
  550. {"general",0.30,0.50}
  551. };
  552.  
  553. //AI skill settings level 1 (Skill, Minimum skill, Maximum skill). Defaults: Accuracy 0.10-0.15, Others 0.40-0.60
  554. skill1[] = {
  555. {"aimingAccuracy",0.10,0.15},
  556. {"aimingShake",0.40,0.60},
  557. {"aimingSpeed",0.40,0.60},
  558. {"spotDistance",0.40,0.60},
  559. {"spotTime",0.40,0.60},
  560. {"courage",0.40,0.60},
  561. {"reloadSpeed",0.40,0.60},
  562. {"commanding",0.40,0.60},
  563. {"general",0.40,0.60}
  564. };
  565.  
  566. //AI skill settings level 2 (Skill, Minimum skill, Maximum skill). Defaults: Accuracy 0.15-0.20, Others 0.50-0.70
  567. skill2[] = {
  568. {"aimingAccuracy",0.15,0.20},
  569. {"aimingShake",0.50,0.70},
  570. {"aimingSpeed",0.50,0.70},
  571. {"spotDistance",0.50,0.70},
  572. {"spotTime",0.50,0.70},
  573. {"courage",0.50,0.70},
  574. {"reloadSpeed",0.50,0.70},
  575. {"commanding",0.50,0.70},
  576. {"general",0.50,0.70}
  577. };
  578.  
  579. //AI skill settings level 3 (Skill, Minimum skill, Maximum skill). Defaults: Accuracy 0.20-0.25, Others 0.60-0.80
  580. skill3[] = {
  581. {"aimingAccuracy",0.20,0.25},
  582. {"aimingShake",0.60,0.80},
  583. {"aimingSpeed",0.60,0.80},
  584. {"spotDistance",0.60,0.80},
  585. {"spotTime",0.60,0.80},
  586. {"courage",0.60,0.80},
  587. {"reloadSpeed",0.60,0.80},
  588. {"commanding",0.60,0.80},
  589. {"general",0.60,0.80}
  590. };
  591.  
  592.  
  593. /* AI loadout probability settings.
  594. --------------------------------------------------------------------------------------------------------------------*/
  595.  
  596. //Probabilities to equip backpack, according to AI level.
  597. addBackpackChance0 = 0.60;
  598. addBackpackChance1 = 0.70;
  599. addBackpackChance2 = 0.80;
  600. addBackpackChance3 = 0.90;
  601.  
  602. //Probabilities to equip vest, according to AI level.
  603. addVestChance0 = 0.60;
  604. addVestChance1 = 0.70;
  605. addVestChance2 = 0.80;
  606. addVestChance3 = 0.90;
  607.  
  608. //Probabilities to equip headgear, according to AI level.
  609. addHeadgearChance0 = 0.60;
  610. addHeadgearChance1 = 0.70;
  611. addHeadgearChance2 = 0.80;
  612. addHeadgearChance3 = 0.90;
  613.  
  614. //Probabilities to equip level 0-3 AI with each weapon type. Order: {pistols, rifles, machineguns, sniper rifles}. Probabilities must add up to 1.00.
  615. useWeaponChance0[] = {0.20,0.80,0.00,0.00};
  616. useWeaponChance1[] = {0.00,0.90,0.05,0.05};
  617. useWeaponChance2[] = {0.00,0.80,0.10,0.10};
  618. useWeaponChance3[] = {0.00,0.70,0.15,0.15};
  619.  
  620. //Probability to select a random optics attachment (ie: scopes) for level 0-3 AI
  621. opticsChance0 = 0.00;
  622. opticsChance1 = 0.30;
  623. opticsChance2 = 0.60;
  624. opticsChance3 = 0.90;
  625.  
  626. //Probability to select a random pointer attachment (ie: flashlights) for level 0-3 AI
  627. pointerChance0 = 0.00;
  628. pointerChance1 = 0.30;
  629. pointerChance2 = 0.60;
  630. pointerChance3 = 0.90;
  631.  
  632. //Probability to select a random muzzle attachment (ie: suppressors) for level 0-3 AI
  633. muzzleChance0 = 0.00;
  634. muzzleChance1 = 0.30;
  635. muzzleChance2 = 0.60;
  636. muzzleChance3 = 0.90;
  637.  
  638. //Probability to select a random underbarrel attachment (ie: bipods) for level 0-3 AI
  639. underbarrelChance0 = 0.00;
  640. underbarrelChance1 = 0.30;
  641. underbarrelChance2 = 0.60;
  642. underbarrelChance3 = 0.90;
  643.  
  644.  
  645. /* AI loot quantity settings
  646. --------------------------------------------------------------------------------------------------------------------*/
  647.  
  648. //Maximum number of food loot items found on AI. (Default: 2)
  649. foodLootCount = 2;
  650.  
  651. //Maximum number of items to select from MiscLoot (generic loot) table. (Default: 2)
  652. miscLootCount = 2;
  653.  
  654.  
  655. /* AI loot probability settings. AI loot is pre-generated into a pool for each unit and randomly pulled to units as time passes.
  656. --------------------------------------------------------------------------------------------------------------------*/
  657.  
  658. //Chance to add a single InstaDoc to group loot pool per unit (Default: 0.25)
  659. firstAidKitChance = 0.25;
  660.  
  661. //Probability to successfully pull a random item from loot pool for level 0-3 AI. Influences the rate at which loot items are added to units.
  662. lootPullChance0 = 0.20;
  663. lootPullChance1 = 0.40;
  664. lootPullChance2 = 0.60;
  665. lootPullChance3 = 0.80;
  666.  
  667.  
  668. /* Respect rewards for AI kills. Note: This section only has effects if enableRespectRewards is enabled.
  669. --------------------------------------------------------------------------------------------------------------------*/
  670.  
  671. //Enable Exile-style handling (ie: Respect rewards, kill-count tracking) for AI kills (Default: 1)
  672. enableRespectRewards = 1;
  673.  
  674. //Respect bonus for kills with Axe
  675. respectHumiliation = 300;
  676.  
  677. //Respect bonus for standard kills
  678. respectFragged = 100;
  679.  
  680. //Respect bonus for collision kills with parachute
  681. respectChute = 600;
  682.  
  683. //Respect bonus for collision kills with air vehicle
  684. respectBigBird = 600;
  685.  
  686. //Respect bonus for collision kills by vehicle driver
  687. respectRoadkill = 500;
  688.  
  689. //Respect bonus for kills with vehicle weapons
  690. respectLetItRain = 150;
  691.  
  692. //Respect bonus per kill streak
  693. respectKillstreak = 50;
  694.  
  695. //Respect bonus per 100m distance from target
  696. respectPer100m = 50;
  697.  
  698.  
  699. /*
  700. AI skin, weapon, loot, and equipment settings
  701.  
  702. Note: Some of the below tables may not be used by A3XAI if a dynamic classname setting is enabled. Check each section below for details.
  703. */
  704.  
  705. //AI uniform classnames. Note: uniformTypes0-3 will not be read if generateDynamicUniforms is enabled.
  706. //------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
  707. uniformTypes0[] = {"U_C_Journalist","U_C_Poloshirt_blue","U_C_Poloshirt_burgundy","U_C_Poloshirt_salmon","U_C_Poloshirt_stripped","U_C_Poloshirt_tricolour","U_C_Poor_1","U_C_Poor_2","U_C_Poor_shorts_1","U_C_Scientist"};
  708. uniformTypes1[] = {"U_B_CombatUniform_mcam_worn","U_B_CTRG_1","U_B_CTRG_2","U_B_CTRG_3","U_I_CombatUniform","U_I_CombatUniform_shortsleeve","U_I_CombatUniform_tshirt","U_I_OfficerUniform","U_O_CombatUniform_ocamo","U_O_CombatUniform_oucamo","U_C_HunterBody_grn","U_IG_Guerilla1_1","U_IG_Guerilla2_1","U_IG_Guerilla2_2","U_IG_Guerilla2_3","U_IG_Guerilla3_1","U_BG_Guerilla2_1","U_IG_Guerilla3_2","U_BG_Guerrilla_6_1","U_BG_Guerilla1_1","U_BG_Guerilla2_2","U_BG_Guerilla2_3","U_BG_Guerilla3_1","U_BG_leader","U_IG_leader","U_B_GhillieSuit","U_I_GhillieSuit","U_O_GhillieSuit","U_B_HeliPilotCoveralls","U_I_HeliPilotCoveralls","U_B_PilotCoveralls","U_I_pilotCoveralls"};
  709. uniformTypes2[] = {"U_OrestesBody","U_NikosAgedBody","U_NikosBody","U_B_CombatUniform_mcam","U_B_CTRG_1","U_B_CTRG_2","U_B_CTRG_3","U_O_OfficerUniform_ocamo","U_B_SpecopsUniform_sgg","U_O_SpecopsUniform_blk","U_O_SpecopsUniform_ocamo","U_I_G_Story_Protagonist_F","U_IG_Guerilla2_1","U_BG_Guerrilla_6_1","U_I_G_resistanceLeader_F","U_B_FullGhillie_ard","U_B_FullGhillie_lsh","U_B_FullGhillie_sard","U_B_GhillieSuit","U_I_FullGhillie_ard","U_I_FullGhillie_lsh","U_I_FullGhillie_sard","U_I_GhillieSuit","U_O_FullGhillie_ard","U_O_FullGhillie_lsh","U_O_FullGhillie_sard","U_O_GhillieSuit","U_I_Wetsuit","U_O_Wetsuit","U_B_Wetsuit","U_B_survival_uniform"};
  710. uniformTypes3[] = {"U_OrestesBody","U_NikosAgedBody","U_NikosBody","U_O_OfficerUniform_ocamo","U_B_SpecopsUniform_sgg","U_O_SpecopsUniform_blk","U_O_SpecopsUniform_ocamo","U_I_G_Story_Protagonist_F","U_I_G_resistanceLeader_F","U_B_FullGhillie_ard","U_B_FullGhillie_lsh","U_B_FullGhillie_sard","U_I_FullGhillie_ard","U_I_FullGhillie_lsh","U_I_FullGhillie_sard","U_O_FullGhillie_ard","U_O_FullGhillie_lsh","U_O_FullGhillie_sard","U_I_Wetsuit","U_O_Wetsuit","U_B_Wetsuit","U_B_survival_uniform"};
  711.  
  712. //AI weapon classnames. Note: pistolList, rifleList, machinegunList, sniperList will not be read if generateDynamicWeapons is enabled.
  713. //------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
  714. pistolList[] = {"hgun_ACPC2_F","hgun_P07_F","hgun_Pistol_heavy_01_F","hgun_Pistol_heavy_02_F","hgun_Rook40_F"};
  715. rifleList[] = {"arifle_Katiba_C_F","arifle_Katiba_F","arifle_Katiba_GL_F","arifle_Mk20_F","arifle_Mk20_GL_F","arifle_Mk20_GL_plain_F","arifle_Mk20_plain_F","arifle_Mk20C_F","arifle_Mk20C_plain_F","arifle_MX_Black_F","arifle_MX_F","arifle_MX_GL_Black_F","arifle_MX_GL_F","arifle_MXC_Black_F","arifle_MXC_F","arifle_SDAR_F","arifle_TRG20_F","arifle_TRG21_F","arifle_TRG21_GL_F"};
  716. machinegunList[] = {"arifle_MX_SW_Black_F","arifle_MX_SW_F","LMG_Mk200_F","LMG_Zafir_F","MMG_01_hex_F","MMG_01_tan_F","MMG_02_black_F","MMG_02_camo_F","MMG_02_sand_F"};
  717. sniperList[] = {"arifle_MXM_Black_F","arifle_MXM_F","srifle_DMR_01_F","srifle_DMR_02_camo_F","srifle_DMR_02_F","srifle_DMR_02_sniper_F","srifle_DMR_03_F","srifle_DMR_03_khaki_F","srifle_DMR_03_multicam_F","srifle_DMR_03_tan_F","srifle_DMR_03_woodland_F","srifle_DMR_04_F","srifle_DMR_04_Tan_F","srifle_DMR_05_blk_F","srifle_DMR_05_hex_F","srifle_DMR_05_tan_f","srifle_DMR_06_camo_F","srifle_DMR_06_olive_F","srifle_EBR_F","srifle_GM6_camo_F","srifle_GM6_F","srifle_LRR_camo_F","srifle_LRR_F"};
  718.  
  719. //AI weapon scope attachment settings. Note: weaponOpticsList will not be read if generateDynamicOptics is enabled.
  720. weaponOpticsList[] = {"optic_NVS","optic_SOS","optic_LRPS","optic_AMS","optic_AMS_khk","optic_AMS_snd","optic_KHS_blk","optic_KHS_hex","optic_KHS_old","optic_KHS_tan","optic_DMS","optic_Arco","optic_Hamr","Elcan_Exile","Elcan_reflex_Exile","optic_MRCO","optic_Holosight","optic_Holosight_smg","optic_Aco","optic_ACO_grn","optic_Aco_smg","optic_ACO_grn_smg","optic_Yorris","optic_MRD"};
  721.  
  722. //AI backpack types (for AI levels 0-3). Note: backpackTypes0-3 will not be read if generateDynamicBackpacks is enabled.
  723. //------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
  724. backpackTypes0[] = {"B_AssaultPack_blk","B_AssaultPack_cbr","B_AssaultPack_dgtl","B_AssaultPack_khk","B_AssaultPack_mcamo","B_AssaultPack_rgr","B_AssaultPack_sgg","B_OutdoorPack_blk","B_OutdoorPack_blu","B_OutdoorPack_tan"};
  725. backpackTypes1[] = {"B_Bergen_blk","B_Bergen_mcamo","B_Bergen_rgr","B_Bergen_sgg","B_FieldPack_blk","B_FieldPack_cbr","B_FieldPack_ocamo","B_FieldPack_oucamo","B_OutdoorPack_blk","B_OutdoorPack_blu","B_OutdoorPack_tan","B_TacticalPack_blk","B_TacticalPack_mcamo","B_TacticalPack_ocamo","B_TacticalPack_oli","B_TacticalPack_rgr"};
  726. backpackTypes2[] = {"B_Bergen_blk","B_Bergen_mcamo","B_Bergen_rgr","B_Bergen_sgg","B_Carryall_cbr","B_Carryall_khk","B_Carryall_mcamo","B_Carryall_ocamo","B_Carryall_oli","B_Carryall_oucamo","B_FieldPack_blk","B_FieldPack_cbr","B_FieldPack_ocamo","B_FieldPack_oucamo","B_HuntingBackpack","B_Kitbag_cbr","B_Kitbag_mcamo","B_Kitbag_sgg"};
  727. backpackTypes3[] = {"B_Carryall_cbr","B_Carryall_khk","B_Carryall_mcamo","B_Carryall_ocamo","B_Carryall_oli","B_Carryall_oucamo","B_HuntingBackpack","B_Kitbag_cbr","B_Kitbag_mcamo","B_Kitbag_sgg"};
  728.  
  729. //AI vest types (for AI levels 0-3). Note: vestTypes0-3 will not be read if generateDynamicVests is enabled.
  730. //------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
  731. vestTypes0[] = {"V_Press_F","V_Rangemaster_belt","V_BandollierB_blk","V_BandollierB_cbr","V_BandollierB_khk","V_BandollierB_oli","V_BandollierB_rgr","V_Chestrig_blk","V_Chestrig_khk","V_Chestrig_oli","V_Chestrig_rgr"};
  732. vestTypes1[] = {"V_Chestrig_blk","V_Chestrig_khk","V_Chestrig_oli","V_Chestrig_rgr","V_HarnessO_brn","V_HarnessO_gry","V_HarnessOGL_brn","V_HarnessOGL_gry","V_HarnessOSpec_brn","V_HarnessOSpec_gry","V_PlateCarrier1_blk","V_PlateCarrier1_rgr","V_PlateCarrier2_rgr","V_PlateCarrier3_rgr","V_PlateCarrierH_CTRG","V_PlateCarrierIA1_dgtl","V_PlateCarrierIA2_dgtl","V_PlateCarrierL_CTRG"};
  733. vestTypes2[] = {"V_TacVest_blk","V_TacVest_blk_POLICE","V_TacVest_brn","V_TacVest_camo","V_TacVest_khk","V_TacVest_oli","V_TacVestCamo_khk","V_TacVestIR_blk","V_I_G_resistanceLeader_F","V_PlateCarrier2_rgr","V_PlateCarrier3_rgr","V_PlateCarrierGL_blk","V_PlateCarrierGL_mtp","V_PlateCarrierGL_rgr","V_PlateCarrierH_CTRG","V_PlateCarrierIA1_dgtl","V_PlateCarrierIA2_dgtl","V_PlateCarrierIAGL_dgtl","V_PlateCarrierIAGL_oli","V_PlateCarrierL_CTRG","V_PlateCarrierSpec_blk","V_PlateCarrierSpec_mtp","V_PlateCarrierSpec_rgr"};
  734. vestTypes3[] = {"V_TacVest_blk_POLICE","V_PlateCarrierGL_blk","V_PlateCarrierGL_mtp","V_PlateCarrierGL_rgr","V_PlateCarrierIAGL_dgtl","V_PlateCarrierIAGL_oli","V_PlateCarrierSpec_blk","V_PlateCarrierSpec_mtp","V_PlateCarrierSpec_rgr"};
  735.  
  736. //AI head gear types. Note: headgearTypes0-3 will not be read if generateDynamicHeadgear is enabled.
  737. headgearTypes0[] = {"H_Cap_blk","H_Cap_blk_Raven","H_Cap_blu","H_Cap_brn_SPECOPS","H_Cap_grn","H_Cap_headphones","H_Cap_khaki_specops_UK","H_Cap_oli","H_Cap_press","H_Cap_red","H_Cap_tan","H_Cap_tan_specops_US","H_Watchcap_blk","H_Watchcap_camo"};
  738. headgearTypes1[] = {"H_Beret_02","H_Beret_blk","H_Beret_blk_POLICE","H_Beret_brn_SF","H_Beret_grn","H_Beret_grn_SF","H_Beret_ocamo","H_Beret_red","H_Shemag_khk","H_Shemag_olive","H_Shemag_olive_hs","H_Shemag_tan"};
  739. headgearTypes2[] = {"H_Beret_Colonel","H_HelmetB","H_HelmetB_black","H_HelmetB_camo","H_HelmetB_desert","H_HelmetB_grass","H_HelmetB_paint","H_HelmetB_plain_blk","H_HelmetB_sand","H_HelmetB_snakeskin","H_HelmetLeaderO_ocamo","H_HelmetLeaderO_oucamo","H_HelmetO_ocamo","H_HelmetO_oucamo","H_HelmetSpecB","H_HelmetSpecB_blk","H_HelmetSpecB_paint1","H_HelmetSpecB_paint2","H_HelmetSpecO_blk","H_HelmetSpecO_ocamo","H_CrewHelmetHeli_B","H_CrewHelmetHeli_I","H_CrewHelmetHeli_O","H_PilotHelmetHeli_B","H_PilotHelmetHeli_I","H_PilotHelmetHeli_O"};
  740. headgearTypes3[] = {"H_Beret_Colonel","H_HelmetB_camo","H_HelmetLeaderO_ocamo","H_HelmetLeaderO_oucamo","H_HelmetO_ocamo","H_HelmetO_oucamo","H_HelmetSpecO_blk","H_HelmetSpecO_ocamo","H_PilotHelmetHeli_B","H_PilotHelmetHeli_I","H_PilotHelmetHeli_O"};
  741.  
  742.  
  743. //AI Food/Loot item types.
  744. // Note: foodLoot will not be read if generateDynamicFood is enabled.
  745. // Note: miscLoot will not be read if generateDynamicLoot is enabled.
  746. //------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
  747. foodLoot[] = {"Exile_Item_GloriousKnakworst","Exile_Item_SausageGravy","Exile_Item_ChristmasTinner","Exile_Item_BBQSandwich","Exile_Item_Surstromming","Exile_Item_Catfood","Exile_Item_PlasticBottleFreshWater","Exile_Item_Beer","Exile_Item_Energydrink"};
  748. miscLoot[] = {"Exile_Item_Rope","Exile_Item_DuctTape","Exile_Item_ExtensionCord","Exile_Item_FuelCanisterEmpty","Exile_Item_JunkMetal","Exile_Item_LightBulb","Exile_Item_MetalBoard","Exile_Item_MetalPole","Exile_Item_CamoTentKit"};
  749.  
  750.  
  751. //AI toolbelt item types. Toolbelt items are added to AI inventory upon death. Format: [item classname, item probability]
  752. //------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
  753. toolsList0[] = {
  754. {"Exile_Item_XM8",0.90},{"ItemCompass",0.30},{"ItemMap",0.30},{"ItemGPS",0.00},{"ItemRadio",0.00}
  755. };
  756. toolsList1[] = {
  757. {"Exile_Item_XM8",0.90},{"ItemCompass",0.50},{"ItemMap",0.50},{"ItemGPS",0.10},{"ItemRadio",0.10}
  758. };
  759. toolsList2[] = {
  760. {"Exile_Item_XM8",0.90},{"ItemCompass",0.70},{"ItemMap",0.70},{"ItemGPS",0.20},{"ItemRadio",0.20}
  761. };
  762. toolsList3[] = {
  763. {"Exile_Item_XM8",0.90},{"ItemCompass",0.90},{"ItemMap",0.90},{"ItemGPS",0.30},{"ItemRadio",0.30}
  764. };
  765.  
  766.  
  767. //AI-useable toolbelt item types. These items are added to AI inventory at unit creation and may be used by AI. Format: {item classname, item probability}
  768. //------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
  769. gadgetsList0[] = {
  770. {"binocular",0.30},{"NVGoggles",0.00}
  771. };
  772. gadgetsList1[] = {
  773. {"binocular",0.50},{"NVGoggles",0.10}
  774. };
  775. gadgetsList2[] = {
  776. {"binocular",0.70},{"NVGoggles",0.20}
  777. };
  778. gadgetsList3[] = {
  779. {"binocular",0.90},{"NVGoggles",0.30}
  780. };
  781. };
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement