2016-07-24 08:09:11 +00:00
//null = [(playersArray select _playerno), [positionA, positionB, positionC...], previousLocation] execVM "createObj.sqf";
2016-07-24 12:38:12 +00:00
diag_log format["createObj called, _this: %1", _this];
2016-07-24 07:57:58 +00:00
waitUntil {!(isNil "missionInitComplete")};
2016-07-24 08:09:11 +00:00
_target = _this select 0;
_lzLocs = _this select 1;
_prevLZ = _this select 2;
_playerno = _this select 3;
_player = playersArray select _playerno;
2016-07-24 07:57:58 +00:00
2016-07-24 12:38:12 +00:00
if (!!(taskIdsArray select _playerno)) exitWith { diag_log format["createObj: Task %1 already exists for %2", (taskIdsArray select _playerno), _playerno] };
2016-07-24 07:57:58 +00:00
2016-07-24 12:38:12 +00:00
_lzLoc = (_lzLocs - [_prevLZ]) call BIS_fnc_SelectRandom;
2016-07-24 07:57:58 +00:00
2016-07-24 08:09:11 +00:00
_taskid = format["p%1_lz%2", _playerno, _lzLoc];
2016-07-24 13:29:32 +00:00
[[_player, west],[_taskid],[format["Player %2: Fly to and land within %1m of the LZ", lzSize, _playerno], format["p%1 LZ", _playerno], "LZ"],(getPos _lzLoc),"AUTOASSIGNED",1,true, "move", true] call BIS_fnc_taskCreate;
2016-07-24 09:11:48 +00:00
taskIdsArray set [_playerno, _taskid];
2016-07-24 08:09:11 +00:00
2016-07-24 13:29:32 +00:00
_trg = createTrigger["EmptyDetector",getPos _lzLoc, true];
2016-07-24 08:09:11 +00:00
_trg setTriggerArea[lzSize,lzSize,0,false];
_trg setTriggerActivation["WEST","PRESENT",false];
_trg setTriggerTimeout [2.5, 2.5, 2.5, true];
_trgaction = format["null = [thisTrigger, '%2', (playersArray select %1), %3, %4, %1] execVM 'landingComplete.sqf'", _playerno, _taskid, _lzLoc, _lzLocs];
2016-07-24 13:29:32 +00:00
_trgcond = "[thisList] call lzlanded";
2016-07-24 08:09:11 +00:00
diag_log format["LZ trigger condition: %1", _trgcond];
diag_log format["LZ trigger action: %1", _trgaction];
2016-07-24 13:29:32 +00:00
_trg setTriggerStatements[_trgcond, _trgaction, ""];
2016-07-24 08:09:11 +00:00
2016-07-24 13:29:32 +00:00
// TODO: delete the trigger when deleting the task on player death or similar
2016-07-24 08:09:11 +00:00
null = [(getPos _lzLoc), (playersArray select _playerno), _playerno] execVM 'createSquad.sqf';
2016-07-24 07:57:58 +00:00
//Make the LZ hot if the roll demands it
if ((random 1) < hotLZChance) then
{
2016-07-24 08:09:11 +00:00
null = [(getPos _lzLoc), _playerno] execVM 'enemySquad.sqf';
hintSilent "LZ is hot";
2016-07-24 07:57:58 +00:00
};
if ((random 1) < AAChance) then
{
2016-07-24 08:09:11 +00:00
null = [(getPos _lzLoc), _playerno] execVM 'AASquad.sqf';
hint "LZ has AA!";
2016-07-24 07:57:58 +00:00
};
2016-07-24 08:09:11 +00:00
landingCompleteArray set [_playerno, false];
publicVariable "landingCompleteArray";
2016-07-24 07:57:58 +00:00
if (bSmoke) then
{
2016-07-24 08:09:11 +00:00
null = [(getPos _lzLoc), _playerno] execVM 'spawnSmoke.sqf';
};