Added timer to delete empty AI Vehicles
This commit is contained in:
parent
66ec5aa01f
commit
b621c3fa3e
@ -12,7 +12,7 @@
|
|||||||
|
|
||||||
By Ghostrider [GRG]
|
By Ghostrider [GRG]
|
||||||
Copyright 2016
|
Copyright 2016
|
||||||
Last updated 12-19-17
|
Last updated 12-22-17
|
||||||
|
|
||||||
--------------------------
|
--------------------------
|
||||||
License
|
License
|
||||||
@ -30,14 +30,17 @@
|
|||||||
|
|
||||||
_fn_releaseVehicle = {
|
_fn_releaseVehicle = {
|
||||||
params["_veh"];
|
params["_veh"];
|
||||||
blck_monitoredVehicles = blck_monitoredVehicles - [_veh];
|
//blck_monitoredVehicles = blck_monitoredVehicles - [_veh];
|
||||||
_veh setVehicleLock "UNLOCKED" ;
|
_veh setVehicleLock "UNLOCKED" ;
|
||||||
//_v setVariable["releasedToPlayers",true];
|
//_v setVariable["releasedToPlayers",true];
|
||||||
//[_v] call blck_fnc_emptyObject;
|
//[_v] call blck_fnc_emptyObject;
|
||||||
{
|
{
|
||||||
_veh removealleventhandlers _x;
|
_veh removealleventhandlers _x;
|
||||||
} forEach ["GetIn","GetOut","fired","hit","hitpart","reloaded","dammaged","HandleDamage"];
|
} forEach ["GetIn","GetOut","fired","hit","hitpart","reloaded","dammaged","HandleDamage"];
|
||||||
//diag_log format["_fnc_vehicleMonitor:: case of patrol vehicle released to players where vehicle = %1",_veh];
|
|
||||||
|
_veh setVariable["blck_DeleteAt",diag_tickTime + blck_vehicleDeleteTimer,true];
|
||||||
|
if ((damage _veh) > 0.5) then {_veh setDamage 0.5};
|
||||||
|
//diag_log format["_fnc_vehicleMonitor:: case of patrol vehicle released to players where vehicle = %1 and blck_deleteAT = %2",_veh, _veh getVariable["blck_DeleteAt",0]];
|
||||||
#ifdef blck_debugMode
|
#ifdef blck_debugMode
|
||||||
if (blck_debugLevel > 3) then
|
if (blck_debugLevel > 3) then
|
||||||
{
|
{
|
||||||
@ -50,6 +53,7 @@ _fn_destroyVehicleAndCrew = {
|
|||||||
params["_veh"];
|
params["_veh"];
|
||||||
//private["_crew"];
|
//private["_crew"];
|
||||||
//_crew = crew _veh;
|
//_crew = crew _veh;
|
||||||
|
//diag_log format["_fn_destroyVehicleAndCrew: called for _veh = %1",_veh];
|
||||||
{[_x] call blck_fnc_deleteAI;} forEach (crew _veh);
|
{[_x] call blck_fnc_deleteAI;} forEach (crew _veh);
|
||||||
[_veh] call blck_fn_deleteAIvehicle;
|
[_veh] call blck_fn_deleteAIvehicle;
|
||||||
};
|
};
|
||||||
@ -84,6 +88,7 @@ _fn_reloadAmmo = {
|
|||||||
|
|
||||||
blck_fn_deleteAIvehicle = {
|
blck_fn_deleteAIvehicle = {
|
||||||
params["_veh"];
|
params["_veh"];
|
||||||
|
//diag_log format["blck_fn_deleteAIvehicle: _veh %1 deleted",_veh];
|
||||||
{
|
{
|
||||||
_veh removeAllEventHandlers _x;
|
_veh removeAllEventHandlers _x;
|
||||||
}forEach ["Hit","HitPart","GetIn","GetOut","Fired","FiredNear","HandleDamage","Reloaded"];
|
}forEach ["Hit","HitPart","GetIn","GetOut","Fired","FiredNear","HandleDamage","Reloaded"];
|
||||||
@ -107,12 +112,26 @@ if (blck_debugLevel > 3) then {diag_log format["_fnc_vehicleMonitor:: function c
|
|||||||
};
|
};
|
||||||
#endif
|
#endif
|
||||||
private _evaluate = true;
|
private _evaluate = true;
|
||||||
|
//diag_log format["_fnc_vehicleMonitor: owner of _veh %1 isEqualTo %2",_veh, owner _veh];
|
||||||
|
if (owner _veh > 2 && !(owner _veh in blck_connectedHCs)) then
|
||||||
|
{
|
||||||
|
// Vehicle is NOT local to server or an HC so a player so must have been entered.
|
||||||
|
_evaluate = false;
|
||||||
|
_veh setVariable["blck_DeleteAt",0];
|
||||||
|
blck_monitoredVehicles = blck_monitoredVehicles - [_veh];
|
||||||
|
diag_log format["_fnc_vehicleMonitor: vehicle %1 now owned by player %2",_veh, owner _veh];
|
||||||
|
};
|
||||||
|
//diag_log format["_fnc_vehicleMonitor: _veh = %1 getVariable[blck_DeleteAt] = %2",_veh, _veh getVariable["blck_DeleteAt",0]];
|
||||||
|
if (_evaluate) then
|
||||||
|
{
|
||||||
|
//diag_log format["_fnc_vehicleMonitor: deleting _veh %1 with diag_tickTime %2 and blck_deleteAT %3",_veh,diag_tickTime,_veh getVariable["blck_DeleteAt",0]];
|
||||||
// Case where vehicle has been marked for deletion after a certain time.
|
// Case where vehicle has been marked for deletion after a certain time.
|
||||||
if ( (_veh getVariable["blck_DeleteAt",0] > 0) && (diag_tickTime > (_veh getVariable "blck_DeleteAt"))) then
|
if ( (_veh getVariable["blck_DeleteAt",0] > 0) && (diag_tickTime > (_veh getVariable "blck_DeleteAt"))) then
|
||||||
{
|
{
|
||||||
[_veh] call _fn_destroyVehicleAndCrew;
|
[_veh] call _fn_destroyVehicleAndCrew;
|
||||||
_evaluate = false;
|
_evaluate = false;
|
||||||
};
|
};
|
||||||
|
};
|
||||||
|
|
||||||
// Case where is an emplaced / static wweapon and has no alive crew and such vehicles should be 'killed' or released to players
|
// Case where is an emplaced / static wweapon and has no alive crew and such vehicles should be 'killed' or released to players
|
||||||
if (_evaluate) then
|
if (_evaluate) then
|
||||||
@ -135,7 +154,10 @@ if (blck_debugLevel > 3) then {diag_log format["_fnc_vehicleMonitor:: function c
|
|||||||
_evaluate = false;
|
_evaluate = false;
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
if ( (_veh getVariable["blck_DeleteAt",0]) > 0) then
|
||||||
|
{
|
||||||
|
_evaluate = false;
|
||||||
|
};
|
||||||
// Case where a vehicle is NOT an emplaced / static weapon and has no alive crew and such vehicles should be 'killed' or released to players
|
// Case where a vehicle is NOT an emplaced / static weapon and has no alive crew and such vehicles should be 'killed' or released to players
|
||||||
if (_evaluate) then
|
if (_evaluate) then
|
||||||
{
|
{
|
||||||
@ -159,10 +181,9 @@ if (blck_debugLevel > 3) then {diag_log format["_fnc_vehicleMonitor:: function c
|
|||||||
if ( _veh getVariable["missionCompleted",0] > 0 && ({alive _x} count crew _veh > 0)) then
|
if ( _veh getVariable["missionCompleted",0] > 0 && ({alive _x} count crew _veh > 0)) then
|
||||||
{
|
{
|
||||||
//diag_log format["_fnc_vehicleMonitor:: case of mission vehicle with AI alive at mission end: schedule destruction with _veh = %1 and typeOf _veh = %2",_veh, typeOf _veh];
|
//diag_log format["_fnc_vehicleMonitor:: case of mission vehicle with AI alive at mission end: schedule destruction with _veh = %1 and typeOf _veh = %2",_veh, typeOf _veh];
|
||||||
private["_cleanupTimer"];
|
private _cleanupTimer = _veh getVariable["blck_DeleteAt",0]; // The time delete to deleting any alive AI units
|
||||||
_cleanupTimer = _veh getVariable["cleanupTimer",0]; // The time delat to deleting any alive AI units
|
if (_cleanupTimer == 0) then {_veh setVariable["blck_DeleteAt",diag_tickTime + blck_vehicleDeleteTimer]};
|
||||||
// "missionCompleted" = the time at which the mission was completed or aborted
|
if (diag_tickTime > _veh getVariable["blck_DeleteAt",0]) then
|
||||||
if (diag_tickTime > ((blck_AliveAICleanUpTimer - 70) + (_veh getVariable["missionCompleted",0])) ) then
|
|
||||||
{
|
{
|
||||||
[_veh] call _fn_destroyVehicleAndCrew;
|
[_veh] call _fn_destroyVehicleAndCrew;
|
||||||
_evaluate = false;
|
_evaluate = false;
|
||||||
|
@ -12,7 +12,7 @@
|
|||||||
*/
|
*/
|
||||||
#include"\q\addons\custom_server\Configs\blck_defines.hpp";
|
#include"\q\addons\custom_server\Configs\blck_defines.hpp";
|
||||||
|
|
||||||
blck_debugON = true;
|
blck_debugON = false;
|
||||||
blck_debugLevel = 0; // Sets level of detail for debugging info - WIP.
|
blck_debugLevel = 0; // Sets level of detail for debugging info - WIP.
|
||||||
blck_minFPS = 8;
|
blck_minFPS = 8;
|
||||||
|
|
||||||
|
@ -130,6 +130,8 @@ _sm_Vehicles = +blck_sm_Vehicles;
|
|||||||
// params["_coords","_noVehiclePatrols","_aiDifficultyLevel","_uniforms","_headGear","_missionPatrolVehicles",["_useRelativePos",true],["weapons",[]],["_vests",blck_vests],["_isScubaGroup",false]];
|
// params["_coords","_noVehiclePatrols","_aiDifficultyLevel","_uniforms","_headGear","_missionPatrolVehicles",["_useRelativePos",true],["weapons",[]],["_vests",blck_vests],["_isScubaGroup",false]];
|
||||||
//diag_log format["[blckeagls static vehiclePatrol spawner] _weapType = %1 and _difficulty = %2",_weapType,_difficulty];
|
//diag_log format["[blckeagls static vehiclePatrol spawner] _weapType = %1 and _difficulty = %2",_weapType,_difficulty];
|
||||||
_return = [_pos,1,_difficulty,blck_SkinList,blck_headgear,[_groupParameters],false] call blck_fnc_spawnMissionVehiclePatrols;
|
_return = [_pos,1,_difficulty,blck_SkinList,blck_headgear,[_groupParameters],false] call blck_fnc_spawnMissionVehiclePatrols;
|
||||||
|
// _return = [_vehicles, _missionAI, _abort];
|
||||||
|
_group = group (_return select 1 select 0);
|
||||||
[blck_sm_Vehicles,_x,_group,-1] call _fnc_updateGroupSpawnTimerFields;
|
[blck_sm_Vehicles,_x,_group,-1] call _fnc_updateGroupSpawnTimerFields;
|
||||||
//diag_log format["_sm_monitorStaticUnits | spawn emplaced step :: blck_sm_Vehicles updated to %1",blck_sm_Vehicles];
|
//diag_log format["_sm_monitorStaticUnits | spawn emplaced step :: blck_sm_Vehicles updated to %1",blck_sm_Vehicles];
|
||||||
};
|
};
|
||||||
|
@ -15,8 +15,8 @@ private ["_staticMissions"];
|
|||||||
|
|
||||||
_staticMissions = [
|
_staticMissions = [
|
||||||
// [mod (Epoch, Exile), map (Altis, Tanoa etc), mission center, eg [10445,2014,0], filename.sqf (name of static mission template for that mission)];
|
// [mod (Epoch, Exile), map (Altis, Tanoa etc), mission center, eg [10445,2014,0], filename.sqf (name of static mission template for that mission)];
|
||||||
["Epoch","Altis","staticMissionExample2.sqf"],
|
//["Epoch","Altis","staticMissionExample2_Epoch.sqf"],
|
||||||
["Exile","Altis","staticMissionExample2.sqf"]
|
//["Exile","Altis","staticMissionExample2_Exile.sqf"]
|
||||||
];
|
];
|
||||||
|
|
||||||
diag_log "[blckeagls] GMS_StaticMissions_Lists.sqf <Loaded>";
|
diag_log "[blckeagls] GMS_StaticMissions_Lists.sqf <Loaded>";
|
||||||
|
@ -0,0 +1,25 @@
|
|||||||
|
/*
|
||||||
|
by Ghostrider [GRG]
|
||||||
|
for ghostridergaming
|
||||||
|
12/5/17
|
||||||
|
--------------------------
|
||||||
|
License
|
||||||
|
--------------------------
|
||||||
|
All the code and information provided here is provided under an Attribution Non-Commercial ShareAlike 4.0 Commons License.
|
||||||
|
|
||||||
|
http://creativecommons.org/licenses/by-nc-sa/4.0/
|
||||||
|
*/
|
||||||
|
#include "\q\addons\custom_server\Configs\blck_defines.hpp";
|
||||||
|
|
||||||
|
private ["_staticMissions"];
|
||||||
|
|
||||||
|
_staticMissions = [
|
||||||
|
// [mod (Epoch, Exile), map (Altis, Tanoa etc), mission center, eg [10445,2014,0], filename.sqf (name of static mission template for that mission)];
|
||||||
|
["Epoch","Altis","staticMissionExample2_Epoch.sqf"],
|
||||||
|
["Exile","Altis","staticMissionExample2_Exile.sqf"]
|
||||||
|
];
|
||||||
|
|
||||||
|
diag_log "[blckeagls] GMS_StaticMissions_Lists_Epoch.sqf <Loaded>";
|
||||||
|
|
||||||
|
_staticMissions
|
||||||
|
|
@ -0,0 +1,23 @@
|
|||||||
|
/*
|
||||||
|
by Ghostrider [GRG]
|
||||||
|
for ghostridergaming
|
||||||
|
12/5/17
|
||||||
|
--------------------------
|
||||||
|
License
|
||||||
|
--------------------------
|
||||||
|
All the code and information provided here is provided under an Attribution Non-Commercial ShareAlike 4.0 Commons License.
|
||||||
|
|
||||||
|
http://creativecommons.org/licenses/by-nc-sa/4.0/
|
||||||
|
*/
|
||||||
|
#include "\q\addons\custom_server\Configs\blck_defines.hpp";
|
||||||
|
|
||||||
|
private ["_staticMissions"];
|
||||||
|
|
||||||
|
_staticMissions = [
|
||||||
|
// [mod (Epoch, Exile), map (Altis, Tanoa etc), mission center, eg [10445,2014,0], filename.sqf (name of static mission template for that mission)];
|
||||||
|
["Exile","Altis","staticMissionExample2.sqf"]
|
||||||
|
];
|
||||||
|
|
||||||
|
diag_log "[blckeagls] GMS_StaticMissions_Lists_Exile.sqf <Loaded>";
|
||||||
|
|
||||||
|
_staticMissions
|
@ -14,27 +14,34 @@ diag_log "[blckeagls] GMS_StaticMissions_init.sqf <Initializing Static Mission S
|
|||||||
|
|
||||||
//static mission descriptor for code: [position,level, numAI or [min,maxAI],patrolRadius, respawn, group[groupNull],spawnedAt[0],respawn[0]]
|
//static mission descriptor for code: [position,level, numAI or [min,maxAI],patrolRadius, respawn, group[groupNull],spawnedAt[0],respawn[0]]
|
||||||
#include "\q\addons\custom_server\Configs\blck_defines.hpp";
|
#include "\q\addons\custom_server\Configs\blck_defines.hpp";
|
||||||
#include "\q\addons\custom_server\Missions\Static\GMS_StaticMissions_Lists.sqf";
|
|
||||||
#include "\q\addons\custom_server\Missions\Static\Code\GMS_fnc_sm_init_functions.sqf";
|
#include "\q\addons\custom_server\Missions\Static\Code\GMS_fnc_sm_init_functions.sqf";
|
||||||
|
#include "\q\addons\custom_server\Missions\Static\GMS_StaticMissions_Lists.sqf";
|
||||||
|
|
||||||
private["_mod","_map","_missionMod","_missionMap","_missionLocation","_missionDataFile"];
|
private["_mod","_map","_missionMod","_missionMap","_missionLocation","_missionDataFile"];
|
||||||
//diag_log "[blckeagls] GMS_StaticMissions_init.sqf <Getting Mod Type>";
|
//diag_log "[blckeagls] GMS_StaticMissions_init.sqf <Getting Mod Type>";
|
||||||
_mod = call blck_fnc_getModType;
|
_mod = toLower(call blck_fnc_getModType);
|
||||||
//diag_log format["[blckeagls] GMS_StaticMissions_init.sqf <mod type = %1>",_mod];
|
//diag_log format["[blckeagls] GMS_StaticMissions_init.sqf <mod type = %1>",_mod];
|
||||||
|
|
||||||
|
//diag_log format["[blckeagls] GMS_StaticMissions_init <_staticMissions> = %1",_staticMissions];
|
||||||
//diag_log "[blckeagls] GMS_StaticMissions_init.sqf <Getting map name>";
|
//diag_log "[blckeagls] GMS_StaticMissions_init.sqf <Getting map name>";
|
||||||
_map = toLower worldName;
|
_map = toLower worldName;
|
||||||
diag_log format["[blckeagls] GMS_StaticMissions_init.sqf <map name = %1>",_map];
|
//diag_log format["[blckeagls] GMS_StaticMissions_init.sqf <map name = %1>",_map];
|
||||||
blck_staticMissions = [];
|
|
||||||
//diag_log format["[blckeagls] GMS_StaticMissions_init.sqf <_staticMissions = %1>",_staticMissions];
|
//diag_log format["[blckeagls] GMS_StaticMissions_init.sqf <_staticMissions = %1>",_staticMissions];
|
||||||
{
|
{
|
||||||
//diag_log format["[blckeagls] GMS_StaticMissions_init.sqf <Spawning Mission = %1>",_x];
|
//diag_log format["[blckeagls] GMS_StaticMissions_init.sqf <Evaluating Mission = %1>",_x];
|
||||||
if ((_mod isEqualTo "Epoch")&& _x select 0 isEqualTo "Epoch") then
|
//diag_log format["[blckeagls] GMS_StaticMissions_init.sqf <worldName = %1 | _mod = %2>",_map,_mod];
|
||||||
|
if ((_map) isEqualTo toLower(_x select 1)) then
|
||||||
|
{
|
||||||
|
if ((_mod isEqualTo "epoch") && (toLower(_x select 0) isEqualTo "epoch")) then
|
||||||
|
{
|
||||||
|
|
||||||
|
call compilefinal preprocessFileLineNumbers format["\q\addons\custom_server\Missions\Static\missions\%1",(_x select 2)];
|
||||||
|
};
|
||||||
|
|
||||||
|
if ((_mod isEqualTo "exile") && (toLower(_x select 0) isEqualTo "exile")) then
|
||||||
{
|
{
|
||||||
call compilefinal preprocessFileLineNumbers format["\q\addons\custom_server\Missions\Static\missions\%1",(_x select 2)];
|
call compilefinal preprocessFileLineNumbers format["\q\addons\custom_server\Missions\Static\missions\%1",(_x select 2)];
|
||||||
};
|
};
|
||||||
if ((_mod isEqualTo "Exile")&& _x select 0 isEqualTo "Exile") then
|
|
||||||
{
|
|
||||||
call compilefinal preprocessFileLineNumbers format["\q\addons\custom_server\Missions\Static\missions\%1",(_x select 2)];
|
|
||||||
};
|
};
|
||||||
uiSleep 1;
|
uiSleep 1;
|
||||||
}forEach _staticMissions;
|
}forEach _staticMissions;
|
||||||
|
@ -65,18 +65,18 @@ _missionLootBoxes = [ // Paste appropriate lines from M3EDEN editor output her
|
|||||||
// [["box_classname1",_customLootArray1,[px,py,pz],...,_customLootArray1],["box_classname2",,[px2,py2,pz2],...,_customLootArray2]
|
// [["box_classname1",_customLootArray1,[px,py,pz],...,_customLootArray1],["box_classname2",,[px2,py2,pz2],...,_customLootArray2]
|
||||||
// where _customLootArray follows the same format as blck_BoxLoot_Red and the other pre-defined arrays and
|
// where _customLootArray follows the same format as blck_BoxLoot_Red and the other pre-defined arrays and
|
||||||
// where _customlootcountsarray1 also follows the same format as the predefined arrays like blck_lootCountsRed
|
// where _customlootcountsarray1 also follows the same format as the predefined arrays like blck_lootCountsRed
|
||||||
["Box_NATO_Ammo_F",[22917.4,16763,6.30803],[[0,1,0],[0,0,1]],[true,false], _crateLoot, [[1,2],[4,6],[2,6],[5,8],6,1] ],
|
[selectRandom blck_crateTypes,[22917.4,16763,6.30803],[[0,1,0],[0,0,1]],[true,false], _crateLoot, [[1,2],[4,6],[2,6],[5,8],6,1] ],
|
||||||
["Box_NATO_Ammo_F",[22893,16766.8,6.31652],[[0,1,0],[0,0,1]],[true,false], _crateLoot, _lootCounts],
|
[selectRandom blck_crateTypes,[22893,16766.8,6.31652],[[0,1,0],[0,0,1]],[true,false], _crateLoot, _lootCounts],
|
||||||
// 0 1 2 3 4 5
|
// 0 1 2 3 4 5
|
||||||
["Box_NATO_Ammo_F",[22904.8,16742.5,6.30195],[[0,1,0],[0,0,1]],[true,false], _crateLoot, _lootCounts]
|
[selectRandom blck_crateTypes,[22904.8,16742.5,6.30195],[[0,1,0],[0,0,1]],[true,false], _crateLoot, _lootCounts]
|
||||||
]; // If this array is empty a single loot chest will be added at the center. If you add items loot chest(s) will be spawned in specific positions.
|
]; // If this array is empty a single loot chest will be added at the center. If you add items loot chest(s) will be spawned in specific positions.
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
_missionLootVehicles = [ // Paste appropriate lines from the output of M3EDEN Editor here and add the loot crate type and loot counts at the end of each entry as shown in the example below.
|
_missionLootVehicles = [ // Paste appropriate lines from the output of M3EDEN Editor here and add the loot crate type and loot counts at the end of each entry as shown in the example below.
|
||||||
// Many vehicles have less inventory capacity than crates so you may have to modify _lootcounts to avoid having stuff spawned all over the ground.
|
// Many vehicles have less inventory capacity than crates so you may have to modify _lootcounts to avoid having stuff spawned all over the ground.
|
||||||
["Exile_Car_Van_Box_Guerilla02",[22896.8,16790.1,3.18987],[[0,1,0],[0,0,1]],[true,false], _crateLoot, [[1,2],[4,6],[2,6],[5,8],6,1]],
|
//["Exile_Car_Van_Box_Guerilla02",[22896.8,16790.1,3.18987],[[0,1,0],[0,0,1]],[true,false], _crateLoot, [[1,2],[4,6],[2,6],[5,8],6,1]],
|
||||||
["Exile_Car_Van_Fuel_Guerilla02",[22919,16782.7,3.18132],[[0,1,0],[0.00129187,0,0.999999]],[true,false],_crateLoot, _lootCounts]
|
//["Exile_Car_Van_Fuel_Guerilla02",[22919,16782.7,3.18132],[[0,1,0],[0.00129187,0,0.999999]],[true,false],_crateLoot, _lootCounts]
|
||||||
]; // [ ["vehicleClassName", [px, py, pz] /* possition at which to spawn*/, _loot /* pointer to array of loot (see below)];
|
]; // [ ["vehicleClassName", [px, py, pz] /* possition at which to spawn*/, _loot /* pointer to array of loot (see below)];
|
||||||
// When blank nothing is spawned.
|
// When blank nothing is spawned.
|
||||||
// You can use the same format used for _missionLootBoxes to add vehicles with/without loot.
|
// You can use the same format used for _missionLootBoxes to add vehicles with/without loot.
|
||||||
@ -99,20 +99,20 @@ _noAIGroups = blck_AIGrps_Red; // Modify as needed; note that these values are
|
|||||||
_aiGroupParameters = [
|
_aiGroupParameters = [
|
||||||
// [ [px, py, pz] /* position*/, "difficulty", 4 /*Number to Spawn*/, 150 /*radius of patrol*/]
|
// [ [px, py, pz] /* position*/, "difficulty", 4 /*Number to Spawn*/, 150 /*radius of patrol*/]
|
||||||
//[[22920.4,16887.3,3.19144],"red",[1,2], 75,120],
|
//[[22920.4,16887.3,3.19144],"red",[1,2], 75,120],
|
||||||
//[[22993.3,16830.8,5.6292],"red",4, 75,0],
|
[[22993.3,16830.8,5.6292],"red",4, 75,9000],
|
||||||
//[[22947.8,16717,6.80305],"red",4, 75,0],
|
[[22947.8,16717,6.80305],"red",4, 75,900],
|
||||||
//[[22849,16720.4,7.33123],"red",4, 75,0],
|
[[22849,16720.4,7.33123],"red",4, 75,9000],
|
||||||
//[[22832.9,16805.6,4.59315],"red",4, 75,0],
|
[[22832.9,16805.6,4.59315],"red",4, 75,900],
|
||||||
//[[22909.8,16778.6,3.19144],"red",4, 75,0],
|
[[22909.8,16778.6,3.19144],"red",4, 75,900],
|
||||||
[[22819.4,16929.5,5.33892],"red",4, 75,0],
|
[[22819.4,16929.5,5.33892],"red",4, 75,900],
|
||||||
[[22819.4,16929.5,5.33892],"red",4, 75,60]
|
[[22819.4,16929.5,5.33892],"red",4, 75,900]
|
||||||
];
|
];
|
||||||
|
|
||||||
_noVehiclePatrols = blck_SpawnVeh_Red; // Modified as needed; can be a numberic value (e.g. 3) or range presented as [2,4];
|
_noVehiclePatrols = blck_SpawnVeh_Red; // Modified as needed; can be a numberic value (e.g. 3) or range presented as [2,4];
|
||||||
// Note that this value is ignored if you define vehicle patrols in the array below.
|
// Note that this value is ignored if you define vehicle patrols in the array below.
|
||||||
_vehiclePatrolParameters = [
|
_vehiclePatrolParameters = [
|
||||||
["B_G_Offroad_01_armed_F",[22819.4,16929.5,3.17413],"red", 600,60],
|
["B_G_Offroad_01_armed_F",[22819.4,16929.5,3.17413],"red", 600,900],
|
||||||
["B_G_Offroad_01_repair_F",[22809.5,16699.2,8.78706],"green", 600,60]
|
["B_G_Offroad_01_repair_F",[22809.5,16699.2,8.78706],"green", 600,900]
|
||||||
]; //[ ["vehicleClassName",[px,py,pz] /* center of patrol area */, difficulty /* blue, red etc*/, patrol radius] ]
|
]; //[ ["vehicleClassName",[px,py,pz] /* center of patrol area */, difficulty /* blue, red etc*/, patrol radius] ]
|
||||||
// When this array is empty, vehicle patrols will be scattered randomely around the mission.
|
// When this array is empty, vehicle patrols will be scattered randomely around the mission.
|
||||||
// Allows you to define the location of the center of the patrol, vehicle type spawned, radius to patrol, and AI difficulty (blue, red, green etc).
|
// Allows you to define the location of the center of the patrol, vehicle type spawned, radius to patrol, and AI difficulty (blue, red, green etc).
|
||||||
@ -121,8 +121,8 @@ _aircraftTypes = blck_patrolHelisRed; // You can use one of the pre-defined li
|
|||||||
_noAirPatrols = blck_noPatrolHelisRed; // You can use one of the pre-defined values or a custom one. acceptable values are integers (1,2,3) or a range such as [2,4];
|
_noAirPatrols = blck_noPatrolHelisRed; // You can use one of the pre-defined values or a custom one. acceptable values are integers (1,2,3) or a range such as [2,4];
|
||||||
// Note: this value is ignored if you specify air patrols in the array below.
|
// Note: this value is ignored if you specify air patrols in the array below.
|
||||||
_airPatrols = [
|
_airPatrols = [
|
||||||
//["Exile_Chopper_Huey_Armed_Green",[22923.4,16953,3.19],"red",1000,0],
|
["Exile_Chopper_Huey_Armed_Green",[22923.4,16953,3.19],"red",1000,900]//,
|
||||||
[selectRandom _aircraftTypes,[22830.2,16618.1,11.4549],"green",1000,60]
|
//[selectRandom _aircraftTypes,[22830.2,16618.1,11.4549],"green",1000,0]
|
||||||
];
|
];
|
||||||
// Change _useMines to true/false below to enable mission-specific settings.
|
// Change _useMines to true/false below to enable mission-specific settings.
|
||||||
_useMines = blck_useMines; // Set to false if you have vehicles patrolling nearby.
|
_useMines = blck_useMines; // Set to false if you have vehicles patrolling nearby.
|
||||||
|
@ -0,0 +1,135 @@
|
|||||||
|
/*
|
||||||
|
This is a simple mission using precisely placed loot crates and infantry, static weapons and vehicle patrols.
|
||||||
|
See the accompanying example mission in the exampleMission folder to get an idea how I laid this out.
|
||||||
|
Note that I exported the mission using the exportAll function of M3EDEN editor.
|
||||||
|
*/
|
||||||
|
private ["_markerLabel","_endMsg","_startMsg","_lootCounts","_crateLoot","_markerMissionName","_missionLandscapeMode","_missionLandscape",
|
||||||
|
"_missionLootBoxes","_missionLootVehicles","_missionEmplacedWeapons","_minNoAI","_maxNoAI","_noAIGroups","_noVehiclePatrols","_noEmplacedWeapons",
|
||||||
|
"_uniforms","_headgear","_chanceReinforcements","_noPara","_helipatrol","_endCondition","_markerColor","_markerType","_useMines"];
|
||||||
|
|
||||||
|
_mission = "static mission example #2"; // Included for additional documentation. Not intended to be spawned as a mission per se.
|
||||||
|
_missionCenter = [22907,16789,0]; // I pulled this from the position of the marker.
|
||||||
|
_difficulty = "red"; // Skill level of AI (blue, red, green etc)
|
||||||
|
diag_log format["[blckeagls static missions] STARTED initializing middions %1 position at %2 difficulty %3",_mission,_missionCenter,_difficulty];
|
||||||
|
_crateLoot = blck_BoxLoot_Orange; // You can use a customized _crateLoot configuration by defining an array here. It must follow the following format shown for a hypothetical loot array called _customLootArray
|
||||||
|
/*
|
||||||
|
_customLootArray =
|
||||||
|
// Loot is grouped as [weapons],[magazines],[items] in order to be able to use the correct function to load the item into the crate later on.
|
||||||
|
// Each item consist of the following information ["ItemName",minNum, maxNum] where min is the smallest number added and min+max is the largest number added.
|
||||||
|
|
||||||
|
[
|
||||||
|
[// Weapons
|
||||||
|
|
||||||
|
["srifle_DMR_06_olive_F","20Rnd_762x51_Mag"]
|
||||||
|
],
|
||||||
|
[//Magazines
|
||||||
|
["10Rnd_93x64_DMR_05_Mag" ,1,5]
|
||||||
|
],
|
||||||
|
[ // Optics
|
||||||
|
["optic_KHS_tan",1,3]
|
||||||
|
],
|
||||||
|
[// Materials and supplies
|
||||||
|
["Exile_Item_MetalScrews",3,10]
|
||||||
|
//
|
||||||
|
],
|
||||||
|
[//Items
|
||||||
|
["Exile_Item_MountainDupe",1,3]
|
||||||
|
],
|
||||||
|
[ // Backpacks
|
||||||
|
["B_OutdoorPack_tan",1,2]
|
||||||
|
]
|
||||||
|
];
|
||||||
|
*/
|
||||||
|
|
||||||
|
_lootCounts = blck_lootCountsRed; // You can use a customized set of loot counts or one that is predefined but it must follow the following format:
|
||||||
|
// values are: number of things from the weapons, magazines, optics, materials(cinder etc), items (food etc) and backpacks arrays to add, respectively.
|
||||||
|
// blck_lootCountsOrange = [[6,8],[24,32],[5,10],[25,35],16,1]; // Orange
|
||||||
|
|
||||||
|
_markerLabel = "";
|
||||||
|
//_markerType = ["ELIPSE",[200,200],"GRID"];
|
||||||
|
// An alternative would be:
|
||||||
|
_markerType = ["mil_triangle",[0,0]]; // You can replace mil_triangle with any other valid Arma 3 marker type https://community.bistudio.com/wiki/cfgMarkers
|
||||||
|
_markerColor = "ColorRed"; // This can be any valid Arma Marker Color
|
||||||
|
_markerMissionName = "Bad People Live Here";
|
||||||
|
_missionLandscapeMode = "precise"; // acceptable values are "random","precise"
|
||||||
|
// In precise mode objects will be spawned at the relative positions specified.
|
||||||
|
// In the random mode, objects will be randomly spawned within the mission area.
|
||||||
|
_missionLandscape = [ // Paste appropriate lines from M3EDEN output here.
|
||||||
|
["Land_Cargo_HQ_V2_F",[22894.7,16766,3.19],[[0,1,0],[0,0,1]],[true,false]],
|
||||||
|
["Land_Cargo_HQ_V1_F",[22918.1,16761.9,3.18151],[[0,1,0],[0,0,1]],[true,false]],
|
||||||
|
["Land_Cargo_HQ_V3_F",[22907.6,16740.3,3.17544],[[0,1,0],[0,0,1]],[true,false]],
|
||||||
|
["Land_Dome_Small_F",[22908.2,16808.8,3.19],[[0,1,0],[0,0,1]],[true,false]]
|
||||||
|
]; // list of objects to spawn as landscape using output from M3EDEN editor.
|
||||||
|
|
||||||
|
_missionLootBoxes = [ // Paste appropriate lines from M3EDEN editor output here, then add the appropriate lootArray
|
||||||
|
// [["box_classname1",_customLootArray1,[px,py,pz],...,_customLootArray1],["box_classname2",,[px2,py2,pz2],...,_customLootArray2]
|
||||||
|
// where _customLootArray follows the same format as blck_BoxLoot_Red and the other pre-defined arrays and
|
||||||
|
// where _customlootcountsarray1 also follows the same format as the predefined arrays like blck_lootCountsRed
|
||||||
|
[selectRandom blck_crateTypes,[22917.4,16763,6.30803],[[0,1,0],[0,0,1]],[true,false], _crateLoot, [[1,2],[4,6],[2,6],[5,8],6,1] ],
|
||||||
|
[selectRandom blck_crateTypes,[22893,16766.8,6.31652],[[0,1,0],[0,0,1]],[true,false], _crateLoot, _lootCounts],
|
||||||
|
// 0 1 2 3 4 5
|
||||||
|
[selectRandom blck_crateTypes,[22904.8,16742.5,6.30195],[[0,1,0],[0,0,1]],[true,false], _crateLoot, _lootCounts]
|
||||||
|
]; // If this array is empty a single loot chest will be added at the center. If you add items loot chest(s) will be spawned in specific positions.
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
_missionLootVehicles = [ // Paste appropriate lines from the output of M3EDEN Editor here and add the loot crate type and loot counts at the end of each entry as shown in the example below.
|
||||||
|
// Many vehicles have less inventory capacity than crates so you may have to modify _lootcounts to avoid having stuff spawned all over the ground.
|
||||||
|
//["Exile_Car_Van_Box_Guerilla02",[22896.8,16790.1,3.18987],[[0,1,0],[0,0,1]],[true,false], _crateLoot, [[1,2],[4,6],[2,6],[5,8],6,1]],
|
||||||
|
//["Exile_Car_Van_Fuel_Guerilla02",[22919,16782.7,3.18132],[[0,1,0],[0.00129187,0,0.999999]],[true,false],_crateLoot, _lootCounts]
|
||||||
|
]; // [ ["vehicleClassName", [px, py, pz] /* possition at which to spawn*/, _loot /* pointer to array of loot (see below)];
|
||||||
|
// When blank nothing is spawned.
|
||||||
|
// You can use the same format used for _missionLootBoxes to add vehicles with/without loot.
|
||||||
|
|
||||||
|
_noEmplacedWeapons = blck_SpawnEmplaced_Red; // Modified as needed; can be a numberic value (e.g. 3) or range presented as [2,4]
|
||||||
|
//format: _noEmplacedWeapons = [2,3]; // a range of values
|
||||||
|
// or _noEmplacedWeapons = 3; // a constant number of emplaced weps per misison
|
||||||
|
// Note that this value is ignored if you define static weapon positions and types in the array below.
|
||||||
|
_missionEmplacedWeapons = [
|
||||||
|
//["B_G_Mortar_01_F",[22867.3,16809.1,3.17968],"red",0,0],
|
||||||
|
//["B_HMG_01_high_F",[22944.3,16820.5,3.14243],"green",0,0]
|
||||||
|
]; // example [ ["emplacedClassName",[px, py, pz] /* position to spawn weapon */, difficulty /* difficulty of AI manning weapon (blue, red etc)] ];
|
||||||
|
// can be used to define the precise placement of static weapons [[1,2,3] /*loc 1*/, [2,3,4] /*loc 2*/]; if blank random locations will be used
|
||||||
|
// If the number of possible locations exceeds the number of emplaced weapons specified above then only some of the locations in the array will have emplaced weapons spawned.
|
||||||
|
// If you leave this array blank then emplaced weapons will be spawned at random locations around the mission using the default list of emplace weapons.
|
||||||
|
|
||||||
|
_minNoAI = blck_MinAI_Red; // Modify as needed
|
||||||
|
_maxNoAI = blck_MaxAI_Red; // Modify as needed.
|
||||||
|
_noAIGroups = blck_AIGrps_Red; // Modify as needed; note that these values are ignored of you specify AI patrols in the array below.
|
||||||
|
_aiGroupParameters = [
|
||||||
|
// [ [px, py, pz] /* position*/, "difficulty", 4 /*Number to Spawn*/, 150 /*radius of patrol*/]
|
||||||
|
//[[22920.4,16887.3,3.19144],"red",[1,2], 75,120],
|
||||||
|
//[[22993.3,16830.8,5.6292],"red",4, 75,9000],
|
||||||
|
//[[22947.8,16717,6.80305],"red",4, 75,900],
|
||||||
|
//[[22849,16720.4,7.33123],"red",4, 75,9000],
|
||||||
|
//[[22832.9,16805.6,4.59315],"red",4, 75,900],
|
||||||
|
//[[22909.8,16778.6,3.19144],"red",4, 75,900],
|
||||||
|
//[[22819.4,16929.5,5.33892],"red",4, 75,900],
|
||||||
|
[[22819.4,16929.5,5.33892],"red",4, 75,900]
|
||||||
|
];
|
||||||
|
|
||||||
|
_noVehiclePatrols = blck_SpawnVeh_Red; // Modified as needed; can be a numberic value (e.g. 3) or range presented as [2,4];
|
||||||
|
// Note that this value is ignored if you define vehicle patrols in the array below.
|
||||||
|
_vehiclePatrolParameters = [
|
||||||
|
//["B_G_Offroad_01_armed_F",[22819.4,16929.5,3.17413],"red", 600,900],
|
||||||
|
["B_G_Offroad_01_repair_F",[22809.5,16699.2,8.78706],"green", 600,90]
|
||||||
|
]; //[ ["vehicleClassName",[px,py,pz] /* center of patrol area */, difficulty /* blue, red etc*/, patrol radius] ]
|
||||||
|
// When this array is empty, vehicle patrols will be scattered randomely around the mission.
|
||||||
|
// Allows you to define the location of the center of the patrol, vehicle type spawned, radius to patrol, and AI difficulty (blue, red, green etc).
|
||||||
|
|
||||||
|
_aircraftTypes = blck_patrolHelisRed; // You can use one of the pre-defined lists in blck_configs or your own custom array.
|
||||||
|
_noAirPatrols = blck_noPatrolHelisRed; // You can use one of the pre-defined values or a custom one. acceptable values are integers (1,2,3) or a range such as [2,4];
|
||||||
|
// Note: this value is ignored if you specify air patrols in the array below.
|
||||||
|
_airPatrols = [
|
||||||
|
["Exile_Chopper_Huey_Armed_Green",[22923.4,16953,3.19],"red",1000,900]//,
|
||||||
|
//[selectRandom _aircraftTypes,[22830.2,16618.1,11.4549],"green",1000,0]
|
||||||
|
];
|
||||||
|
// Change _useMines to true/false below to enable mission-specific settings.
|
||||||
|
_useMines = blck_useMines; // Set to false if you have vehicles patrolling nearby.
|
||||||
|
_uniforms = blck_SkinList; // You can replace this list with a custom list of uniforms if you like.
|
||||||
|
_headgear = blck_headgear; // You can replace this list with a custom list of headgear.
|
||||||
|
_weapons = blck_WeaponList_Orange; // You can replace this list with a customized list of weapons, or another predifined list from blck_configs_epoch or blck_configs_exile as appropriate.
|
||||||
|
|
||||||
|
#include "\q\addons\custom_server\Missions\Static\Code\GMS_fnc_sm_initializeMission.sqf";
|
||||||
|
|
||||||
|
diag_log format["[blckeagls static missions] COMPLETED initializing middions %1 position at %2 difficulty %3",_mission,_missionCenter,_difficulty];
|
@ -0,0 +1,135 @@
|
|||||||
|
/*
|
||||||
|
This is a simple mission using precisely placed loot crates and infantry, static weapons and vehicle patrols.
|
||||||
|
See the accompanying example mission in the exampleMission folder to get an idea how I laid this out.
|
||||||
|
Note that I exported the mission using the exportAll function of M3EDEN editor.
|
||||||
|
*/
|
||||||
|
private ["_markerLabel","_endMsg","_startMsg","_lootCounts","_crateLoot","_markerMissionName","_missionLandscapeMode","_missionLandscape",
|
||||||
|
"_missionLootBoxes","_missionLootVehicles","_missionEmplacedWeapons","_minNoAI","_maxNoAI","_noAIGroups","_noVehiclePatrols","_noEmplacedWeapons",
|
||||||
|
"_uniforms","_headgear","_chanceReinforcements","_noPara","_helipatrol","_endCondition","_markerColor","_markerType","_useMines"];
|
||||||
|
|
||||||
|
_mission = "static mission example #2"; // Included for additional documentation. Not intended to be spawned as a mission per se.
|
||||||
|
_missionCenter = [22907,16789,0]; // I pulled this from the position of the marker.
|
||||||
|
_difficulty = "red"; // Skill level of AI (blue, red, green etc)
|
||||||
|
diag_log format["[blckeagls static missions] STARTED initializing middions %1 position at %2 difficulty %3",_mission,_missionCenter,_difficulty];
|
||||||
|
_crateLoot = blck_BoxLoot_Orange; // You can use a customized _crateLoot configuration by defining an array here. It must follow the following format shown for a hypothetical loot array called _customLootArray
|
||||||
|
/*
|
||||||
|
_customLootArray =
|
||||||
|
// Loot is grouped as [weapons],[magazines],[items] in order to be able to use the correct function to load the item into the crate later on.
|
||||||
|
// Each item consist of the following information ["ItemName",minNum, maxNum] where min is the smallest number added and min+max is the largest number added.
|
||||||
|
|
||||||
|
[
|
||||||
|
[// Weapons
|
||||||
|
|
||||||
|
["srifle_DMR_06_olive_F","20Rnd_762x51_Mag"]
|
||||||
|
],
|
||||||
|
[//Magazines
|
||||||
|
["10Rnd_93x64_DMR_05_Mag" ,1,5]
|
||||||
|
],
|
||||||
|
[ // Optics
|
||||||
|
["optic_KHS_tan",1,3]
|
||||||
|
],
|
||||||
|
[// Materials and supplies
|
||||||
|
["Exile_Item_MetalScrews",3,10]
|
||||||
|
//
|
||||||
|
],
|
||||||
|
[//Items
|
||||||
|
["Exile_Item_MountainDupe",1,3]
|
||||||
|
],
|
||||||
|
[ // Backpacks
|
||||||
|
["B_OutdoorPack_tan",1,2]
|
||||||
|
]
|
||||||
|
];
|
||||||
|
*/
|
||||||
|
|
||||||
|
_lootCounts = blck_lootCountsRed; // You can use a customized set of loot counts or one that is predefined but it must follow the following format:
|
||||||
|
// values are: number of things from the weapons, magazines, optics, materials(cinder etc), items (food etc) and backpacks arrays to add, respectively.
|
||||||
|
// blck_lootCountsOrange = [[6,8],[24,32],[5,10],[25,35],16,1]; // Orange
|
||||||
|
|
||||||
|
_markerLabel = "";
|
||||||
|
//_markerType = ["ELIPSE",[200,200],"GRID"];
|
||||||
|
// An alternative would be:
|
||||||
|
_markerType = ["mil_triangle",[0,0]]; // You can replace mil_triangle with any other valid Arma 3 marker type https://community.bistudio.com/wiki/cfgMarkers
|
||||||
|
_markerColor = "ColorRed"; // This can be any valid Arma Marker Color
|
||||||
|
_markerMissionName = "Bad People Live Here";
|
||||||
|
_missionLandscapeMode = "precise"; // acceptable values are "random","precise"
|
||||||
|
// In precise mode objects will be spawned at the relative positions specified.
|
||||||
|
// In the random mode, objects will be randomly spawned within the mission area.
|
||||||
|
_missionLandscape = [ // Paste appropriate lines from M3EDEN output here.
|
||||||
|
["Land_Cargo_HQ_V2_F",[22894.7,16766,3.19],[[0,1,0],[0,0,1]],[true,false]],
|
||||||
|
["Land_Cargo_HQ_V1_F",[22918.1,16761.9,3.18151],[[0,1,0],[0,0,1]],[true,false]],
|
||||||
|
["Land_Cargo_HQ_V3_F",[22907.6,16740.3,3.17544],[[0,1,0],[0,0,1]],[true,false]],
|
||||||
|
["Land_Dome_Small_F",[22908.2,16808.8,3.19],[[0,1,0],[0,0,1]],[true,false]]
|
||||||
|
]; // list of objects to spawn as landscape using output from M3EDEN editor.
|
||||||
|
|
||||||
|
_missionLootBoxes = [ // Paste appropriate lines from M3EDEN editor output here, then add the appropriate lootArray
|
||||||
|
// [["box_classname1",_customLootArray1,[px,py,pz],...,_customLootArray1],["box_classname2",,[px2,py2,pz2],...,_customLootArray2]
|
||||||
|
// where _customLootArray follows the same format as blck_BoxLoot_Red and the other pre-defined arrays and
|
||||||
|
// where _customlootcountsarray1 also follows the same format as the predefined arrays like blck_lootCountsRed
|
||||||
|
[selectRandom blck_crateTypes,[22917.4,16763,6.30803],[[0,1,0],[0,0,1]],[true,false], _crateLoot, [[1,2],[4,6],[2,6],[5,8],6,1] ],
|
||||||
|
[selectRandom blck_crateTypes,[22893,16766.8,6.31652],[[0,1,0],[0,0,1]],[true,false], _crateLoot, _lootCounts],
|
||||||
|
// 0 1 2 3 4 5
|
||||||
|
[selectRandom blck_crateTypes,[22904.8,16742.5,6.30195],[[0,1,0],[0,0,1]],[true,false], _crateLoot, _lootCounts]
|
||||||
|
]; // If this array is empty a single loot chest will be added at the center. If you add items loot chest(s) will be spawned in specific positions.
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
_missionLootVehicles = [ // Paste appropriate lines from the output of M3EDEN Editor here and add the loot crate type and loot counts at the end of each entry as shown in the example below.
|
||||||
|
// Many vehicles have less inventory capacity than crates so you may have to modify _lootcounts to avoid having stuff spawned all over the ground.
|
||||||
|
//["Exile_Car_Van_Box_Guerilla02",[22896.8,16790.1,3.18987],[[0,1,0],[0,0,1]],[true,false], _crateLoot, [[1,2],[4,6],[2,6],[5,8],6,1]],
|
||||||
|
//["Exile_Car_Van_Fuel_Guerilla02",[22919,16782.7,3.18132],[[0,1,0],[0.00129187,0,0.999999]],[true,false],_crateLoot, _lootCounts]
|
||||||
|
]; // [ ["vehicleClassName", [px, py, pz] /* possition at which to spawn*/, _loot /* pointer to array of loot (see below)];
|
||||||
|
// When blank nothing is spawned.
|
||||||
|
// You can use the same format used for _missionLootBoxes to add vehicles with/without loot.
|
||||||
|
|
||||||
|
_noEmplacedWeapons = blck_SpawnEmplaced_Red; // Modified as needed; can be a numberic value (e.g. 3) or range presented as [2,4]
|
||||||
|
//format: _noEmplacedWeapons = [2,3]; // a range of values
|
||||||
|
// or _noEmplacedWeapons = 3; // a constant number of emplaced weps per misison
|
||||||
|
// Note that this value is ignored if you define static weapon positions and types in the array below.
|
||||||
|
_missionEmplacedWeapons = [
|
||||||
|
//["B_G_Mortar_01_F",[22867.3,16809.1,3.17968],"red",0,0],
|
||||||
|
//["B_HMG_01_high_F",[22944.3,16820.5,3.14243],"green",0,0]
|
||||||
|
]; // example [ ["emplacedClassName",[px, py, pz] /* position to spawn weapon */, difficulty /* difficulty of AI manning weapon (blue, red etc)] ];
|
||||||
|
// can be used to define the precise placement of static weapons [[1,2,3] /*loc 1*/, [2,3,4] /*loc 2*/]; if blank random locations will be used
|
||||||
|
// If the number of possible locations exceeds the number of emplaced weapons specified above then only some of the locations in the array will have emplaced weapons spawned.
|
||||||
|
// If you leave this array blank then emplaced weapons will be spawned at random locations around the mission using the default list of emplace weapons.
|
||||||
|
|
||||||
|
_minNoAI = blck_MinAI_Red; // Modify as needed
|
||||||
|
_maxNoAI = blck_MaxAI_Red; // Modify as needed.
|
||||||
|
_noAIGroups = blck_AIGrps_Red; // Modify as needed; note that these values are ignored of you specify AI patrols in the array below.
|
||||||
|
_aiGroupParameters = [
|
||||||
|
// [ [px, py, pz] /* position*/, "difficulty", 4 /*Number to Spawn*/, 150 /*radius of patrol*/]
|
||||||
|
//[[22920.4,16887.3,3.19144],"red",[1,2], 75,120],
|
||||||
|
//[[22993.3,16830.8,5.6292],"red",4, 75,9000],
|
||||||
|
//[[22947.8,16717,6.80305],"red",4, 75,900],
|
||||||
|
//[[22849,16720.4,7.33123],"red",4, 75,9000],
|
||||||
|
//[[22832.9,16805.6,4.59315],"red",4, 75,900],
|
||||||
|
//[[22909.8,16778.6,3.19144],"red",4, 75,900],
|
||||||
|
//[[22819.4,16929.5,5.33892],"red",4, 75,900],
|
||||||
|
[[22819.4,16929.5,5.33892],"red",4, 75,900]
|
||||||
|
];
|
||||||
|
|
||||||
|
_noVehiclePatrols = blck_SpawnVeh_Red; // Modified as needed; can be a numberic value (e.g. 3) or range presented as [2,4];
|
||||||
|
// Note that this value is ignored if you define vehicle patrols in the array below.
|
||||||
|
_vehiclePatrolParameters = [
|
||||||
|
["Exile_Car_Offroad_Armed_Guerilla01",[22819.4,16929.5,3.17413],"red", 600,900],
|
||||||
|
["Exile_Car_Offroad_Armed_Guerilla02",[22809.5,16699.2,8.78706],"green", 600,90]
|
||||||
|
]; //[ ["vehicleClassName",[px,py,pz] /* center of patrol area */, difficulty /* blue, red etc*/, patrol radius] ]
|
||||||
|
// When this array is empty, vehicle patrols will be scattered randomely around the mission.
|
||||||
|
// Allows you to define the location of the center of the patrol, vehicle type spawned, radius to patrol, and AI difficulty (blue, red, green etc).
|
||||||
|
|
||||||
|
_aircraftTypes = blck_patrolHelisRed; // You can use one of the pre-defined lists in blck_configs or your own custom array.
|
||||||
|
_noAirPatrols = blck_noPatrolHelisRed; // You can use one of the pre-defined values or a custom one. acceptable values are integers (1,2,3) or a range such as [2,4];
|
||||||
|
// Note: this value is ignored if you specify air patrols in the array below.
|
||||||
|
_airPatrols = [
|
||||||
|
["Exile_Chopper_Huey_Armed_Green",[22923.4,16953,3.19],"red",1000,900]//,
|
||||||
|
//[selectRandom _aircraftTypes,[22830.2,16618.1,11.4549],"green",1000,0]
|
||||||
|
];
|
||||||
|
// Change _useMines to true/false below to enable mission-specific settings.
|
||||||
|
_useMines = blck_useMines; // Set to false if you have vehicles patrolling nearby.
|
||||||
|
_uniforms = blck_SkinList; // You can replace this list with a custom list of uniforms if you like.
|
||||||
|
_headgear = blck_headgear; // You can replace this list with a custom list of headgear.
|
||||||
|
_weapons = blck_WeaponList_Orange; // You can replace this list with a customized list of weapons, or another predifined list from blck_configs_epoch or blck_configs_exile as appropriate.
|
||||||
|
|
||||||
|
#include "\q\addons\custom_server\Missions\Static\Code\GMS_fnc_sm_initializeMission.sqf";
|
||||||
|
|
||||||
|
diag_log format["[blckeagls static missions] COMPLETED initializing missions %1 position at %2 difficulty %3",_mission,_missionCenter,_difficulty];
|
@ -17,8 +17,8 @@ private ["_staticMissions"];
|
|||||||
|
|
||||||
_staticMissions = [
|
_staticMissions = [
|
||||||
// [mod (Epoch, Exile), map (Altis, Tanoa etc), mission center, eg [10445,2014,0], filename.sqf (name of static mission template for that mission)];
|
// [mod (Epoch, Exile), map (Altis, Tanoa etc), mission center, eg [10445,2014,0], filename.sqf (name of static mission template for that mission)];
|
||||||
["Epoch","Altis","\q\addons\custom_server\Missions\Static\staticMissionExample2.sqf"],
|
["Epoch","Altis","staticMissionExample2_Epoch.sqf"],
|
||||||
["Exile","Altis","\q\addons\custom_server\Missions\UMS\staticMissions\staticMissionExample2.sqf"]
|
["Exile","Altis","staticMissionExample2_Exile.sqf"]
|
||||||
];
|
];
|
||||||
|
|
||||||
diag_log "[blckeagls] GMS_UMS_StaticMissions_Lists.sqf <Loaded>";
|
diag_log "[blckeagls] GMS_UMS_StaticMissions_Lists.sqf <Loaded>";
|
||||||
|
@ -22,18 +22,29 @@ if (!isServer) exitWith{};
|
|||||||
uiSleep 3;
|
uiSleep 3;
|
||||||
private["_mod","_map","_missionMod","_missionMap","_missionLocation","_missionDataFile"];
|
private["_mod","_map","_missionMod","_missionMap","_missionLocation","_missionDataFile"];
|
||||||
//diag_log "[blckeagls] GMS__UMS_StaticMissions_init.sqf <Getting Mod Type>";
|
//diag_log "[blckeagls] GMS__UMS_StaticMissions_init.sqf <Getting Mod Type>";
|
||||||
_mod = call blck_fnc_getModType;
|
_mod = toLower(call blck_fnc_getModType);
|
||||||
//diag_log format["[blckeagls] GMS__UMS_StaticMissions_init.sqf <mod type = %1>",_mod];
|
//diag_log format["[blckeagls] GMS__UMS_StaticMissions_init.sqf <mod type = %1>",_mod];
|
||||||
|
//diag_log format["[blckeagls] GMS__UMS_StaticMissions_init <_staticMissions> = %1",_staticMissions];
|
||||||
//diag_log "[blckeagls] GMS__UMS_StaticMissions_init.sqf <Getting map name>";
|
//diag_log "[blckeagls] GMS__UMS_StaticMissions_init.sqf <Getting map name>";
|
||||||
_map = toLower worldName;
|
_map = toLower worldName;
|
||||||
//diag_log format["[blckeagls] GMS__UMS_StaticMissions_init.sqf <map name = %1>",_map];
|
//diag_log format["[blckeagls] GMS__UMS_StaticMissions_init.sqf <map name = %1>",_map];
|
||||||
blck_staticMissions = [];
|
|
||||||
//diag_log format["[blckeagls] GMS__UMS_StaticMissions_init.sqf <_staticMissions = %1>",_staticMissions];
|
|
||||||
{
|
{
|
||||||
diag_log format["[blckeagls] GMS__UMS_StaticMissions_init.sqf <Spawning Mission = %1>",_x];
|
//diag_log format["[blckeagls] GMS__UMS_StaticMissions_init.sqf <Evaluating Mission = %1>",_x];
|
||||||
//[] execVM format["%1",(_x select 2)];
|
//diag_log format["[blckeagls] GMS__UMS_StaticMissions_init.sqf <worldName = %1 | _mod = %2>",_map,_mod];
|
||||||
[] call compileFinal preprocessFileLineNumbers format["%1",(_x select 2)];
|
if ((_map) isEqualTo toLower(_x select 1)) then
|
||||||
uiSleep 15;
|
{
|
||||||
|
if ((_mod isEqualTo "epoch") && (toLower(_x select 0) isEqualTo "epoch")) then
|
||||||
|
{
|
||||||
|
|
||||||
|
call compilefinal preprocessFileLineNumbers format["\q\addons\custom_server\Missions\UMS\staticMissions\%1",(_x select 2)];
|
||||||
|
};
|
||||||
|
|
||||||
|
if ((_mod isEqualTo "exile") && (toLower(_x select 0) isEqualTo "exile")) then
|
||||||
|
{
|
||||||
|
call compilefinal preprocessFileLineNumbers format["\q\addons\custom_server\Missions\UMS\staticMissions\%1",(_x select 2)];
|
||||||
|
};
|
||||||
|
};
|
||||||
|
uiSleep 1;
|
||||||
}forEach _staticMissions;
|
}forEach _staticMissions;
|
||||||
|
|
||||||
diag_log "[blckeagls] GMS__UMS_StaticMissions_init.sqf <Loaded>";
|
diag_log "[blckeagls] GMS__UMS_StaticMissions_init.sqf <Loaded>";
|
||||||
|
@ -0,0 +1,133 @@
|
|||||||
|
/*
|
||||||
|
This is a simple mission using precisely placed loot crates and infantry, static weapons and vehicle patrols.
|
||||||
|
See the accompanying example mission in the exampleMission folder to get an idea how I laid this out.
|
||||||
|
Note that I laid out the mission in EDEN editor, exported the mission using the exportAll function of M3EDEN editor. then copied, pasted and apporpriately edidet the specific categories of items to be spawned.
|
||||||
|
*/
|
||||||
|
private ["_markerLabel","_endMsg","_startMsg","_lootCounts","_crateLoot","_markerMissionName","_missionLandscapeMode","_missionLandscape",
|
||||||
|
"_missionLootBoxes","_missionLootVehicles","_missionEmplacedWeapons","_minNoAI","_maxNoAI","_noAIGroups","_noVehiclePatrols","_noEmplacedWeapons",
|
||||||
|
"_uniforms","_headgear","_chanceReinforcements","_noPara","_helipatrol","_endCondition","_markerColor","_markerType","_useMines","_difficulty","_mission","_missionCenter"];
|
||||||
|
|
||||||
|
_mission = "UMS mission example #2"; // Included for additional documentation. Not intended to be spawned as a mission per se.
|
||||||
|
_missionCenter = [22584.9,15304.8,0]; // I pulled this from the position of the marker.
|
||||||
|
_difficulty = "red"; // Skill level of AI (blue, red, green etc)
|
||||||
|
diag_log format["[blckeagls UMS missions] STARTED initializing mission %1 position at %2 difficulty %3",_mission,_missionCenter,_difficulty];
|
||||||
|
_crateLoot = blck_BoxLoot_Orange; // You can use a customized _crateLoot configuration by defining an array here. It must follow the following format shown for a hypothetical loot array called _customLootArray
|
||||||
|
/*
|
||||||
|
_customLootArray =
|
||||||
|
// Loot is grouped as [weapons],[magazines],[items] in order to be able to use the correct function to load the item into the crate later on.
|
||||||
|
// Each item consist of the following information ["ItemName",minNum, maxNum] where min is the smallest number added and min+max is the largest number added.
|
||||||
|
|
||||||
|
[
|
||||||
|
[// Weapons
|
||||||
|
|
||||||
|
["srifle_DMR_06_olive_F","20Rnd_762x51_Mag"]
|
||||||
|
],
|
||||||
|
[//Magazines
|
||||||
|
["10Rnd_93x64_DMR_05_Mag" ,1,5]
|
||||||
|
],
|
||||||
|
[ // Optics
|
||||||
|
["optic_KHS_tan",1,3]
|
||||||
|
],
|
||||||
|
[// Materials and supplies
|
||||||
|
["Exile_Item_MetalScrews",3,10]
|
||||||
|
//
|
||||||
|
],
|
||||||
|
[//Items
|
||||||
|
["Exile_Item_MountainDupe",1,3]
|
||||||
|
],
|
||||||
|
[ // Backpacks
|
||||||
|
["B_OutdoorPack_tan",1,2]
|
||||||
|
]
|
||||||
|
];
|
||||||
|
*/
|
||||||
|
|
||||||
|
_lootCounts = blck_lootCountsRed; // You can use a customized set of loot counts or one that is predefined but it must follow the following format:
|
||||||
|
// values are: number of things from the weapons, magazines, optics, materials(cinder etc), items (food etc) and backpacks arrays to add, respectively.
|
||||||
|
// blck_lootCountsOrange = [[6,8],[24,32],[5,10],[25,35],16,1]; // Orange
|
||||||
|
|
||||||
|
_markerLabel = "";
|
||||||
|
//_markerType = ["ELIPSE",[200,200],"GRID"];
|
||||||
|
// An alternative would be:
|
||||||
|
_markerType = ["mil_triangle",[0,0]]; // You can replace mil_triangle with any other valid Arma 3 marker type https://community.bistudio.com/wiki/cfgMarkers
|
||||||
|
_markerColor = "ColorRed"; // This can be any valid Arma Marker Color
|
||||||
|
_markerMissionName = "Bad Fishermen Live Here";
|
||||||
|
_missionLandscapeMode = "precise"; // acceptable values are "random","precise"
|
||||||
|
// In precise mode objects will be spawned at the relative positions specified.
|
||||||
|
// In the random mode, objects will be randomly spawned within the mission area.
|
||||||
|
_missionLandscape = [ // Paste appropriate lines from M3EDEN output here.
|
||||||
|
// ["Land_Cargo_HQ_V2_F",[22894.7,16766,3.19],[[0,1,0],[0,0,1]],[true,false]],
|
||||||
|
["Land_Boat_05_wreck_F",[22571.5,15278.9,0],[[0,1,0],[0,0,1]],[true,false]]
|
||||||
|
]; // list of objects to spawn as landscape using output from M3EDEN editor.
|
||||||
|
|
||||||
|
_missionLootBoxes = [ // Paste appropriate lines from M3EDEN editor output here, then add the appropriate lootArray
|
||||||
|
// [["box_classname1",_customLootArray1,[px,py,pz],...,_customLootArray1],["box_classname2",,[px2,py2,pz2],...,_customLootArray2]
|
||||||
|
// where _customLootArray follows the same format as blck_BoxLoot_Red and the other pre-defined arrays and
|
||||||
|
// where _customlootcountsarray1 also follows the same format as the predefined arrays like blck_lootCountsRed
|
||||||
|
// ["Box_NATO_Ammo_F",[22893,16766.8,6.31652],[[0,1,0],[0,0,1]],[true,false], _crateLoot, _lootCounts],
|
||||||
|
[selectRandom blck_UMS_crates,[22584.9,15282.2,-1],[[0,1,0],[0,0,1]],[true,false], _crateLoot, _lootCounts]
|
||||||
|
]; // If this array is empty a single loot chest will be added at the center. If you add items loot chest(s) will be spawned in specific positions.
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
_missionLootVehicles = [ // Paste appropriate lines from the output of M3EDEN Editor here and add the loot crate type and loot counts at the end of each entry as shown in the example below.
|
||||||
|
// Many vehicles have less inventory capacity than crates so you may have to modify _lootcounts to avoid having stuff spawned all over the ground.
|
||||||
|
//["Exile_Car_Van_Box_Guerilla02",[22896.8,16790.1,3.18987],[[0,1,0],[0,0,1]],[true,false], _crateLoot, [[1,2],[4,6],[2,6],[5,8],6,1]],
|
||||||
|
["B_T_Boat_Transport_01_F",[22570.1,15235.3,-4.49949],[[0,1,0],[0,0,1]],[true,false],_crateLoot, _lootCounts]
|
||||||
|
]; // [ ["vehicleClassName", [px, py, pz] /* possition at which to spawn*/, _loot /* pointer to array of loot (see below)];
|
||||||
|
// When blank nothing is spawned.
|
||||||
|
// You can use the same format used for _missionLootBoxes to add vehicles with/without loot.
|
||||||
|
|
||||||
|
_noEmplacedWeapons = blck_SpawnEmplaced_Red; // Modified as needed; can be a numberic value (e.g. 3) or range presented as [2,4]
|
||||||
|
//format: _noEmplacedWeapons = [2,3]; // a range of values
|
||||||
|
// or _noEmplacedWeapons = 3; // a constant number of emplaced weps per misison
|
||||||
|
// Note that this value is ignored if you define static weapon positions and types in the array below.
|
||||||
|
_missionEmplacedWeapons = [
|
||||||
|
//["B_G_Mortar_01_F",[22867.3,16809.1,3.17968],"red",0,0],
|
||||||
|
//["B_HMG_01_high_F",[22944.3,16820.5,3.14243],"green",0,0]
|
||||||
|
];
|
||||||
|
// example [ ["emplacedClassName",[px, py, pz] /* position to spawn weapon */, difficulty /* difficulty of AI manning weapon (blue, red etc)] ];
|
||||||
|
// can be used to define the precise placement of static weapons [[1,2,3] /*loc 1*/, [2,3,4] /*loc 2*/]; if blank random locations will be used
|
||||||
|
// If the number of possible locations exceeds the number of emplaced weapons specified above then only some of the locations in the array will have emplaced weapons spawned.
|
||||||
|
// If you leave this array blank then emplaced weapons will be spawned at random locations around the mission using the default list of emplace weapons.
|
||||||
|
|
||||||
|
_minNoAI = blck_MinAI_Red; // Modify as needed
|
||||||
|
_maxNoAI = blck_MaxAI_Red; // Modify as needed.
|
||||||
|
_noAIGroups = blck_AIGrps_Red; // Modify as needed; note that these values are ignored of you specify AI patrols in the array below.
|
||||||
|
_aiGroupParameters = [
|
||||||
|
// [ [px, py, pz] /* position*/, "difficulty", 4 /*Number to Spawn*/, 150 /*radius of patrol*/]
|
||||||
|
|
||||||
|
];
|
||||||
|
_aiScubaGroupParameters = [
|
||||||
|
// [ [px, py, pz] /* position*/, "difficulty", 4 /*Number to Spawn*/, 150 /*radius of patrol*/]
|
||||||
|
//[[22584.9,15304.8,-4.27578],"red",4, 75,0],
|
||||||
|
[[22613.5,15269.1,-4.28332],"red",3, 75,900],
|
||||||
|
[[22549,15288.9,0],"red",3, 75,900]
|
||||||
|
];
|
||||||
|
_noVehiclePatrols = blck_SpawnVeh_Red; // Modified as needed; can be a numberic value (e.g. 3) or range presented as [2,4];
|
||||||
|
// Note that this value is ignored if you define vehicle patrols in the array below.
|
||||||
|
_vehiclePatrolParameters = [
|
||||||
|
//["B_T_Boat_Transport_01_F",[22570.1,15235.3,-4.49949],"red",4, 75,60],
|
||||||
|
//["B_T_Boat_Armed_01_minigun_F",[22578.6,15273.3,-0.0354593],"red",3, 75,0]
|
||||||
|
]; //[ ["vehicleClassName",[px,py,pz] /* center of patrol area */, difficulty /* blue, red etc*/, patrol radius] ]
|
||||||
|
// When this array is empty, vehicle patrols will be scattered randomely around the mission.
|
||||||
|
// Allows you to define the location of the center of the patrol, vehicle type spawned, radius to patrol, and AI difficulty (blue, red, green etc).
|
||||||
|
|
||||||
|
_submarinePatrolParameters = [
|
||||||
|
//["B_SDV_01_F",[22584.9,15304.8,-1],"red",4, 75,0],
|
||||||
|
//["B_SDV_01_F",[22609.9,15299.8,-1],"red",3, 75,0]
|
||||||
|
];
|
||||||
|
|
||||||
|
_aircraftTypes = blck_patrolHelisRed; // You can use one of the pre-defined lists in blck_configs or your own custom array.
|
||||||
|
_noAirPatrols = blck_noPatrolHelisRed; // You can use one of the pre-defined values or a custom one. acceptable values are integers (1,2,3) or a range such as [2,4];
|
||||||
|
// Note: this value is ignored if you specify air patrols in the array below.
|
||||||
|
_airPatrols = [
|
||||||
|
//["Exile_Chopper_Huey_Armed_Green",[22923.4,16953,3.19],"red",1000,0],
|
||||||
|
//[selectRandom _aircraftTypes,_missionCenter,"green",1000,0]
|
||||||
|
];
|
||||||
|
|
||||||
|
// Change _useMines to true/false below to enable mission-specific settings.
|
||||||
|
_useMines = false; // Set to false if you have vehicles patrolling nearby.
|
||||||
|
|
||||||
|
#include "\q\addons\custom_server\Missions\UMS\code\GMS_fnc_sm_initializeUMSStaticMission.sqf";
|
||||||
|
|
||||||
|
diag_log format["[blckeagls static missions] COMPLETED initializing middions %1 position at %2 difficulty %3",_mission,_missionCenter,_difficulty];
|
@ -0,0 +1,133 @@
|
|||||||
|
/*
|
||||||
|
This is a simple mission using precisely placed loot crates and infantry, static weapons and vehicle patrols.
|
||||||
|
See the accompanying example mission in the exampleMission folder to get an idea how I laid this out.
|
||||||
|
Note that I laid out the mission in EDEN editor, exported the mission using the exportAll function of M3EDEN editor. then copied, pasted and apporpriately edidet the specific categories of items to be spawned.
|
||||||
|
*/
|
||||||
|
private ["_markerLabel","_endMsg","_startMsg","_lootCounts","_crateLoot","_markerMissionName","_missionLandscapeMode","_missionLandscape",
|
||||||
|
"_missionLootBoxes","_missionLootVehicles","_missionEmplacedWeapons","_minNoAI","_maxNoAI","_noAIGroups","_noVehiclePatrols","_noEmplacedWeapons",
|
||||||
|
"_uniforms","_headgear","_chanceReinforcements","_noPara","_helipatrol","_endCondition","_markerColor","_markerType","_useMines","_difficulty","_mission","_missionCenter"];
|
||||||
|
|
||||||
|
_mission = "UMS mission example #2"; // Included for additional documentation. Not intended to be spawned as a mission per se.
|
||||||
|
_missionCenter = [22584.9,15304.8,0]; // I pulled this from the position of the marker.
|
||||||
|
_difficulty = "red"; // Skill level of AI (blue, red, green etc)
|
||||||
|
diag_log format["[blckeagls UMS missions] STARTED initializing mission %1 position at %2 difficulty %3",_mission,_missionCenter,_difficulty];
|
||||||
|
_crateLoot = blck_BoxLoot_Orange; // You can use a customized _crateLoot configuration by defining an array here. It must follow the following format shown for a hypothetical loot array called _customLootArray
|
||||||
|
/*
|
||||||
|
_customLootArray =
|
||||||
|
// Loot is grouped as [weapons],[magazines],[items] in order to be able to use the correct function to load the item into the crate later on.
|
||||||
|
// Each item consist of the following information ["ItemName",minNum, maxNum] where min is the smallest number added and min+max is the largest number added.
|
||||||
|
|
||||||
|
[
|
||||||
|
[// Weapons
|
||||||
|
|
||||||
|
["srifle_DMR_06_olive_F","20Rnd_762x51_Mag"]
|
||||||
|
],
|
||||||
|
[//Magazines
|
||||||
|
["10Rnd_93x64_DMR_05_Mag" ,1,5]
|
||||||
|
],
|
||||||
|
[ // Optics
|
||||||
|
["optic_KHS_tan",1,3]
|
||||||
|
],
|
||||||
|
[// Materials and supplies
|
||||||
|
["Exile_Item_MetalScrews",3,10]
|
||||||
|
//
|
||||||
|
],
|
||||||
|
[//Items
|
||||||
|
["Exile_Item_MountainDupe",1,3]
|
||||||
|
],
|
||||||
|
[ // Backpacks
|
||||||
|
["B_OutdoorPack_tan",1,2]
|
||||||
|
]
|
||||||
|
];
|
||||||
|
*/
|
||||||
|
|
||||||
|
_lootCounts = blck_lootCountsRed; // You can use a customized set of loot counts or one that is predefined but it must follow the following format:
|
||||||
|
// values are: number of things from the weapons, magazines, optics, materials(cinder etc), items (food etc) and backpacks arrays to add, respectively.
|
||||||
|
// blck_lootCountsOrange = [[6,8],[24,32],[5,10],[25,35],16,1]; // Orange
|
||||||
|
|
||||||
|
_markerLabel = "";
|
||||||
|
//_markerType = ["ELIPSE",[200,200],"GRID"];
|
||||||
|
// An alternative would be:
|
||||||
|
_markerType = ["mil_triangle",[0,0]]; // You can replace mil_triangle with any other valid Arma 3 marker type https://community.bistudio.com/wiki/cfgMarkers
|
||||||
|
_markerColor = "ColorRed"; // This can be any valid Arma Marker Color
|
||||||
|
_markerMissionName = "Bad Fishermen Live Here";
|
||||||
|
_missionLandscapeMode = "precise"; // acceptable values are "random","precise"
|
||||||
|
// In precise mode objects will be spawned at the relative positions specified.
|
||||||
|
// In the random mode, objects will be randomly spawned within the mission area.
|
||||||
|
_missionLandscape = [ // Paste appropriate lines from M3EDEN output here.
|
||||||
|
// ["Land_Cargo_HQ_V2_F",[22894.7,16766,3.19],[[0,1,0],[0,0,1]],[true,false]],
|
||||||
|
["Land_Boat_05_wreck_F",[22571.5,15278.9,0],[[0,1,0],[0,0,1]],[true,false]]
|
||||||
|
]; // list of objects to spawn as landscape using output from M3EDEN editor.
|
||||||
|
|
||||||
|
_missionLootBoxes = [ // Paste appropriate lines from M3EDEN editor output here, then add the appropriate lootArray
|
||||||
|
// [["box_classname1",_customLootArray1,[px,py,pz],...,_customLootArray1],["box_classname2",,[px2,py2,pz2],...,_customLootArray2]
|
||||||
|
// where _customLootArray follows the same format as blck_BoxLoot_Red and the other pre-defined arrays and
|
||||||
|
// where _customlootcountsarray1 also follows the same format as the predefined arrays like blck_lootCountsRed
|
||||||
|
// ["Box_NATO_Ammo_F",[22893,16766.8,6.31652],[[0,1,0],[0,0,1]],[true,false], _crateLoot, _lootCounts],
|
||||||
|
[selectRandom blck_UMS_crates,[22584.9,15282.2,-1],[[0,1,0],[0,0,1]],[true,false], _crateLoot, _lootCounts]
|
||||||
|
]; // If this array is empty a single loot chest will be added at the center. If you add items loot chest(s) will be spawned in specific positions.
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
_missionLootVehicles = [ // Paste appropriate lines from the output of M3EDEN Editor here and add the loot crate type and loot counts at the end of each entry as shown in the example below.
|
||||||
|
// Many vehicles have less inventory capacity than crates so you may have to modify _lootcounts to avoid having stuff spawned all over the ground.
|
||||||
|
//["Exile_Car_Van_Box_Guerilla02",[22896.8,16790.1,3.18987],[[0,1,0],[0,0,1]],[true,false], _crateLoot, [[1,2],[4,6],[2,6],[5,8],6,1]],
|
||||||
|
["B_T_Boat_Transport_01_F",[22570.1,15235.3,-4.49949],[[0,1,0],[0,0,1]],[true,false],_crateLoot, _lootCounts]
|
||||||
|
]; // [ ["vehicleClassName", [px, py, pz] /* possition at which to spawn*/, _loot /* pointer to array of loot (see below)];
|
||||||
|
// When blank nothing is spawned.
|
||||||
|
// You can use the same format used for _missionLootBoxes to add vehicles with/without loot.
|
||||||
|
|
||||||
|
_noEmplacedWeapons = blck_SpawnEmplaced_Red; // Modified as needed; can be a numberic value (e.g. 3) or range presented as [2,4]
|
||||||
|
//format: _noEmplacedWeapons = [2,3]; // a range of values
|
||||||
|
// or _noEmplacedWeapons = 3; // a constant number of emplaced weps per misison
|
||||||
|
// Note that this value is ignored if you define static weapon positions and types in the array below.
|
||||||
|
_missionEmplacedWeapons = [
|
||||||
|
//["B_G_Mortar_01_F",[22867.3,16809.1,3.17968],"red",0,0],
|
||||||
|
//["B_HMG_01_high_F",[22944.3,16820.5,3.14243],"green",0,0]
|
||||||
|
];
|
||||||
|
// example [ ["emplacedClassName",[px, py, pz] /* position to spawn weapon */, difficulty /* difficulty of AI manning weapon (blue, red etc)] ];
|
||||||
|
// can be used to define the precise placement of static weapons [[1,2,3] /*loc 1*/, [2,3,4] /*loc 2*/]; if blank random locations will be used
|
||||||
|
// If the number of possible locations exceeds the number of emplaced weapons specified above then only some of the locations in the array will have emplaced weapons spawned.
|
||||||
|
// If you leave this array blank then emplaced weapons will be spawned at random locations around the mission using the default list of emplace weapons.
|
||||||
|
|
||||||
|
_minNoAI = blck_MinAI_Red; // Modify as needed
|
||||||
|
_maxNoAI = blck_MaxAI_Red; // Modify as needed.
|
||||||
|
_noAIGroups = blck_AIGrps_Red; // Modify as needed; note that these values are ignored of you specify AI patrols in the array below.
|
||||||
|
_aiGroupParameters = [
|
||||||
|
// [ [px, py, pz] /* position*/, "difficulty", 4 /*Number to Spawn*/, 150 /*radius of patrol*/]
|
||||||
|
|
||||||
|
];
|
||||||
|
_aiScubaGroupParameters = [
|
||||||
|
// [ [px, py, pz] /* position*/, "difficulty", 4 /*Number to Spawn*/, 150 /*radius of patrol*/]
|
||||||
|
//[[22584.9,15304.8,-4.27578],"red",4, 75,0],
|
||||||
|
[[22613.5,15269.1,-4.28332],"red",3, 75,900],
|
||||||
|
[[22549,15288.9,0],"red",3, 75,900]
|
||||||
|
];
|
||||||
|
_noVehiclePatrols = blck_SpawnVeh_Red; // Modified as needed; can be a numberic value (e.g. 3) or range presented as [2,4];
|
||||||
|
// Note that this value is ignored if you define vehicle patrols in the array below.
|
||||||
|
_vehiclePatrolParameters = [
|
||||||
|
//["B_T_Boat_Transport_01_F",[22570.1,15235.3,-4.49949],"red",4, 75,60],
|
||||||
|
//["B_T_Boat_Armed_01_minigun_F",[22578.6,15273.3,-0.0354593],"red",3, 75,0]
|
||||||
|
]; //[ ["vehicleClassName",[px,py,pz] /* center of patrol area */, difficulty /* blue, red etc*/, patrol radius] ]
|
||||||
|
// When this array is empty, vehicle patrols will be scattered randomely around the mission.
|
||||||
|
// Allows you to define the location of the center of the patrol, vehicle type spawned, radius to patrol, and AI difficulty (blue, red, green etc).
|
||||||
|
|
||||||
|
_submarinePatrolParameters = [
|
||||||
|
//["B_SDV_01_F",[22584.9,15304.8,-1],"red",4, 75,0],
|
||||||
|
//["B_SDV_01_F",[22609.9,15299.8,-1],"red",3, 75,0]
|
||||||
|
];
|
||||||
|
|
||||||
|
_aircraftTypes = blck_patrolHelisRed; // You can use one of the pre-defined lists in blck_configs or your own custom array.
|
||||||
|
_noAirPatrols = blck_noPatrolHelisRed; // You can use one of the pre-defined values or a custom one. acceptable values are integers (1,2,3) or a range such as [2,4];
|
||||||
|
// Note: this value is ignored if you specify air patrols in the array below.
|
||||||
|
_airPatrols = [
|
||||||
|
//["Exile_Chopper_Huey_Armed_Green",[22923.4,16953,3.19],"red",1000,0],
|
||||||
|
//[selectRandom _aircraftTypes,_missionCenter,"green",1000,0]
|
||||||
|
];
|
||||||
|
|
||||||
|
// Change _useMines to true/false below to enable mission-specific settings.
|
||||||
|
_useMines = false; // Set to false if you have vehicles patrolling nearby.
|
||||||
|
|
||||||
|
#include "\q\addons\custom_server\Missions\UMS\code\GMS_fnc_sm_initializeUMSStaticMission.sqf";
|
||||||
|
|
||||||
|
diag_log format["[blckeagls static missions] COMPLETED initializing middions %1 position at %2 difficulty %3",_mission,_missionCenter,_difficulty];
|
@ -1,6 +1,6 @@
|
|||||||
private ["_version","_versionDate"];
|
private ["_version","_versionDate"];
|
||||||
blck_version = "6.74 Build 100";
|
blck_version = "6.76 Build 102";
|
||||||
_blck_version = blck_version;
|
_blck_version = blck_version;
|
||||||
_blck_versionDate = "12-18-17 7:00 PM";
|
_blck_versionDate = "12-22-17 7:00 PM";
|
||||||
blck_pvs_version = _blck_version;
|
blck_pvs_version = _blck_version;
|
||||||
publicVariable blck_pvs_version;
|
publicVariable blck_pvs_version;
|
||||||
|
Loading…
Reference in New Issue
Block a user