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;
|
|
|
|
_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 13:43:08 +00:00
|
|
|
_lzLoc = (lzList - [_prevLZ]) call BIS_fnc_SelectRandom;
|
2016-07-24 07:57:58 +00:00
|
|
|
|
|
|
|
|
2016-07-24 14:05:22 +00:00
|
|
|
|
2016-07-24 14:39:27 +00:00
|
|
|
_handle = [(getPos _lzLoc), (playersArray select _playerno), _playerno] execVM 'createSquad.sqf';
|
|
|
|
waitUntil {isNull _handle};
|
|
|
|
_squadArray = squadMDArray select _playerno;
|
|
|
|
_squad = _squadArray select (count _squadArray - 1);
|
2016-07-24 08:09:11 +00:00
|
|
|
|
2016-07-24 14:39:27 +00:00
|
|
|
_lzhot = false;
|
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';
|
2016-07-24 14:39:27 +00:00
|
|
|
_lzhot = true;
|
2016-07-24 07:57:58 +00:00
|
|
|
};
|
2016-07-24 14:39:27 +00:00
|
|
|
_lzAA = false;
|
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';
|
2016-07-24 14:39:27 +00:00
|
|
|
_lzAA = true;
|
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';
|
|
|
|
};
|
2016-07-24 14:39:27 +00:00
|
|
|
|
|
|
|
_shortestDesc = format["LZ %1", lzCounter];
|
|
|
|
_shortdesc = _shortestDesc;
|
|
|
|
_longdesc = _shortdesc;
|
|
|
|
if (!!(ferryingArray select _playerno)) then
|
|
|
|
{
|
|
|
|
diag_log format["creating ferry task for %1 (player %2)", _squad, _playerno];
|
|
|
|
_longdesc = format["%1 wants to fly to this location", _squad];
|
|
|
|
_shortdesc = format["Drop off %1", _squad];
|
2016-07-24 15:09:51 +00:00
|
|
|
if (_lzAA and _lzhot) then
|
|
|
|
{
|
|
|
|
_longdesc = _longdesc + "<br/><strong>Be advised:</strong> Intel reports heavy enemy activity with AA assets at the location";
|
|
|
|
};
|
|
|
|
if (!_lzAA and _lzhot) then
|
|
|
|
{
|
|
|
|
_longdesc = _longdesc + "<br/><strong>Be advised:</strong> Intel reports enemy activity at the location";
|
|
|
|
};
|
2016-07-24 14:39:27 +00:00
|
|
|
} else {
|
|
|
|
diag_log format["creating pickup task for %1 (player %2)", _squad, _playerno];
|
|
|
|
_longdesc = format["%1 is requesting airlift from this location", _squad];
|
|
|
|
_shortdesc = format["Pick up %1", _squad];
|
2016-07-24 15:09:51 +00:00
|
|
|
if (_lzAA and _lzhot) then
|
|
|
|
{
|
|
|
|
_longdesc = _longdesc + "<br/><strong>Be advised:</strong> LZ is hot and enemy AA assets have been observed";
|
|
|
|
};
|
|
|
|
if (!_lzAA and _lzhot) then
|
|
|
|
{
|
|
|
|
_longdesc = _longdesc + "<br/><strong>Be advised:</strong> LZ is hot";
|
|
|
|
};
|
2016-07-24 14:39:27 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
_taskid = format["p%1_lz%2", _playerno, _lzLoc];
|
|
|
|
[[_player, west],[_taskid],[_longdesc, _shortdesc, _shortestDesc],(getPos _lzLoc),"AUTOASSIGNED",1,true, "move", true] call BIS_fnc_taskCreate;
|
|
|
|
taskIdsArray set [_playerno, _taskid];
|
|
|
|
|
|
|
|
lzCounter = lzCounter + 1;
|
|
|
|
publicVariable "lzCounter";
|
|
|
|
|
|
|
|
|
|
|
|
_trg = createTrigger["EmptyDetector",getPos _lzLoc, true];
|
|
|
|
_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, %1] execVM 'landingComplete.sqf'", _playerno, _taskid, _lzLoc];
|
|
|
|
_trgcond = "[thisList] call lzlanded";
|
|
|
|
diag_log format["LZ trigger condition: %1", _trgcond];
|
|
|
|
diag_log format["LZ trigger action: %1", _trgaction];
|
|
|
|
_trg setTriggerStatements[_trgcond, _trgaction, ""];
|
|
|
|
trigIdsArray set [_playerno, _trg];
|