2017-09-16 17:45:07 +00:00
|
|
|
/*
|
|
|
|
Author/s:
|
|
|
|
Aaron Clark - EpochMod.com
|
|
|
|
|
|
|
|
Description:
|
2017-09-17 15:06:29 +00:00
|
|
|
Spawns Bunker Dynamically.
|
2017-09-16 17:45:07 +00:00
|
|
|
|
|
|
|
Improvements and or bugfixes and other contributions are welcome via the github:
|
|
|
|
https://github.com/EpochModTeam/Epoch/tree/release/Sources/epoch_server_bunker_event/EpochEvents/BunkerSpawner.sqf
|
|
|
|
*/
|
|
|
|
//[[[cog import generate_private_arrays ]]]
|
2017-10-18 20:53:32 +00:00
|
|
|
private ["_allBunkers","_animationStates","_bunkerCounter","_bunkerLocations","_bunkerLocationsKey","_colCount","_debug","_debugLocation","_expiresBunker","_firstBunker","_instanceID","_list","_loc1","_location","_maxBunkerLimitPerRow","_maxBunkerLimitSlots","_maxColumns","_memoryPoints","_modelInfo","_newBunkerCounter","_object","_originalLocation","_pOffset","_response","_rng","_rngChance","_rowCount","_score","_scriptHiveKey","_seed","_selectedBunker","_size","_valuesAndWeights","_veh"];
|
2017-09-16 17:45:07 +00:00
|
|
|
//[[[end]]]
|
|
|
|
if (worldName == "VR") then {
|
|
|
|
|
|
|
|
_debug = false;
|
2017-09-17 15:06:29 +00:00
|
|
|
_expiresBunker = 14400; // four hours
|
2017-09-17 17:20:14 +00:00
|
|
|
_debugLocation = getMarkerPos "respawn_west";
|
2017-09-16 17:45:07 +00:00
|
|
|
_memoryPoints = ["one","two","three","four"];
|
|
|
|
_bunkerCounter = 0;
|
|
|
|
_newBunkerCounter = 0;
|
2017-09-17 15:06:29 +00:00
|
|
|
|
2017-09-16 17:45:07 +00:00
|
|
|
_instanceID = call EPOCH_fn_InstanceID;
|
|
|
|
|
2017-10-18 20:53:32 +00:00
|
|
|
_maxBunkerLimitSlots = 1000;
|
|
|
|
_maxBunkerLimitPerRow = 100;
|
2017-09-17 15:06:29 +00:00
|
|
|
|
2017-10-02 16:10:22 +00:00
|
|
|
_rngChance = 0; // Lower this to spawn more positions
|
2017-10-18 20:53:32 +00:00
|
|
|
_scriptHiveKey = "EPOCH:DynamicBunker001"; // change this to force a new seed to be generated.
|
2017-09-16 17:45:07 +00:00
|
|
|
|
|
|
|
_bunkerLocationsKey = format ["%1:%2", _instanceID, worldname];
|
|
|
|
_response = [_scriptHiveKey, _bunkerLocationsKey] call EPOCH_fnc_server_hiveGETRANGE;
|
|
|
|
_response params [["_status",0],["_data",[]] ];
|
|
|
|
|
2017-09-17 17:11:40 +00:00
|
|
|
_firstBunker = objNull;
|
2017-10-03 20:05:37 +00:00
|
|
|
_bunkerLocations = [];
|
2017-09-17 17:11:40 +00:00
|
|
|
|
2017-09-16 17:45:07 +00:00
|
|
|
// check for proper return and data type
|
|
|
|
if (_status == 1 && _data isEqualType [] && !(_data isEqualTo [])) then {
|
2017-10-03 20:05:37 +00:00
|
|
|
_bunkerLocations = _data;
|
2017-09-16 17:45:07 +00:00
|
|
|
} else {
|
|
|
|
|
|
|
|
// generate new bunker
|
|
|
|
_size = 13.081;
|
|
|
|
_maxColumns = _maxBunkerLimitSlots / _maxBunkerLimitPerRow;
|
|
|
|
_allBunkers = [];
|
|
|
|
_newBunkerCounter = 0;
|
|
|
|
// Generate Seed
|
|
|
|
_seed = random 999999;
|
|
|
|
diag_log format["Generating bunker with seed: %1",_seed];
|
2017-09-17 15:06:29 +00:00
|
|
|
_location = ATLToASL _debugLocation;
|
2017-09-16 17:45:07 +00:00
|
|
|
_originalLocation = +_location;
|
2017-10-18 20:53:32 +00:00
|
|
|
_valuesAndWeights = [
|
|
|
|
"bunker_epoch", 0.2, // empty bunker
|
|
|
|
"bunker_epoch_01", 0.1, // tall concrete maze 1
|
|
|
|
"bunker_epoch_02", 0.05, // Epoch Corp storage
|
|
|
|
// "bunker_epoch_03", 0.01, // save for xmas
|
|
|
|
"bunker_epoch_04", 0.05, // generator room
|
|
|
|
// "bunker_epoch_05", 0.01, // invisible walls
|
|
|
|
"bunker_epoch_06", 0.05, // jail
|
|
|
|
"bunker_epoch_07", 0.05, // clone chamber
|
|
|
|
"bunker_epoch_08", 0.01, // epoch celebration room
|
|
|
|
"bunker_epoch_09", 0.05, // tallest concrete walls
|
|
|
|
"bunker_epoch_10", 0.05, // knee high concrete walls
|
|
|
|
"bunker_epoch_11", 0.1, // sewer
|
|
|
|
"bunker_epoch_12", 0.05, // concrete mid wall
|
|
|
|
"bunker_epoch_13", 0.05, // tall concrete maze 2
|
|
|
|
"bunker_epoch_14", 0.08, // odd concrete walls
|
2017-10-18 21:39:59 +00:00
|
|
|
"bunker_epoch_15", 0.05 // concrete mid wall maze
|
2017-09-16 17:45:07 +00:00
|
|
|
];
|
|
|
|
_rowCount = 0;
|
|
|
|
_colCount = 0;
|
|
|
|
//spawn x number of connected bunkers.
|
|
|
|
while {true} do {
|
|
|
|
if (_colCount > _maxColumns) exitWith {};
|
|
|
|
_rng = _seed random [_location select 0,_location select 1];
|
|
|
|
if (_rng > _rngChance) then {
|
2017-10-18 20:53:32 +00:00
|
|
|
_selectedBunker = selectRandomWeighted _valuesAndWeights;
|
2017-09-16 17:45:07 +00:00
|
|
|
_object = createSimpleObject [_selectedBunker, _location];
|
|
|
|
_allBunkers pushBack _object;
|
|
|
|
_newBunkerCounter = _newBunkerCounter + 1;
|
|
|
|
};
|
|
|
|
_location set [0,(_location select 0) + _size];
|
|
|
|
_rowCount = _rowCount + 1;
|
|
|
|
if (_rowCount >= _maxBunkerLimitPerRow) then {
|
2017-10-02 16:10:22 +00:00
|
|
|
_rngChance = 0.3;
|
2017-09-16 17:45:07 +00:00
|
|
|
_colCount = _colCount + 1;
|
|
|
|
_rowCount = 0;
|
|
|
|
_location set [0,_originalLocation select 0];
|
|
|
|
_location set [1,(_location select 1) + _size];
|
|
|
|
};
|
|
|
|
};
|
|
|
|
_score = 0;
|
|
|
|
{
|
|
|
|
_veh = _x;
|
|
|
|
_animationStates = [];
|
|
|
|
{
|
|
|
|
_pOffset = _veh selectionPosition _x;
|
|
|
|
if !(_pOffset isEqualTo [0,0,0]) then {
|
|
|
|
_loc1 = _veh modelToWorldVisual _pOffset;
|
|
|
|
_list = nearestObjects[_loc1, [], 1];
|
|
|
|
if !(_list isEqualTo []) then {
|
|
|
|
_score = _score + 1;
|
|
|
|
_animationStates pushBack 0
|
|
|
|
} else {
|
|
|
|
_animationStates pushBack 1
|
|
|
|
};
|
|
|
|
};
|
|
|
|
} forEach _memoryPoints;
|
|
|
|
_modelInfo = getModelInfo _veh;
|
2017-10-03 20:05:37 +00:00
|
|
|
_bunkerLocations pushBack [_modelInfo select 1, getPosWorld _veh, _animationStates, _score];
|
2017-09-16 17:45:07 +00:00
|
|
|
} forEach _allBunkers;
|
2017-10-03 20:05:37 +00:00
|
|
|
// remove temp bunkers
|
|
|
|
_allBunkers apply {deleteVehicle _x};
|
2017-09-16 17:45:07 +00:00
|
|
|
// save to DB
|
2017-10-03 20:05:37 +00:00
|
|
|
[_scriptHiveKey, _bunkerLocationsKey, _expiresBunker, _bunkerLocations] call EPOCH_fnc_server_hiveSETEX;
|
2017-09-16 17:45:07 +00:00
|
|
|
};
|
|
|
|
|
2017-10-03 20:05:37 +00:00
|
|
|
// spawn final bunkers
|
|
|
|
{
|
|
|
|
if (_x isEqualType [] && !(_x isEqualTo [])) then {
|
|
|
|
_x params ["_selectedBunker", "_posWorld", ["_memoryPointsStatus",[]] ];
|
|
|
|
_object = createSimpleObject [_selectedBunker, _posWorld];
|
|
|
|
if (isNull _firstBunker) then {_firstBunker = _object;};
|
|
|
|
{
|
|
|
|
_object animate [_x,(_memoryPointsStatus param [_forEachIndex,1]),true];
|
|
|
|
} forEach _memoryPoints;
|
|
|
|
_bunkerCounter = _bunkerCounter + 1;
|
|
|
|
};
|
|
|
|
} forEach _bunkerLocations;
|
|
|
|
|
2017-09-17 17:11:40 +00:00
|
|
|
// move respawn point into first bunker.
|
2017-09-17 17:20:14 +00:00
|
|
|
if (!(isNull _firstBunker) && {_firstBunker distance _debugLocation > 1}) then {
|
2017-09-17 17:11:40 +00:00
|
|
|
deleteMarker "respawn_west";
|
|
|
|
createMarker ["respawn_west", getposATL _firstBunker];
|
|
|
|
};
|
|
|
|
|
2017-09-16 17:45:07 +00:00
|
|
|
if (_debug) then {
|
|
|
|
diag_log format["DEBUG: Spawned %1 Existing Bunker",_bunkerCounter];
|
|
|
|
if (_newBunkerCounter > 0) then {
|
|
|
|
diag_log format["DEBUG: Spawned %1 New Bunker.",_newBunkerCounter];
|
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|