mirror of
https://github.com/EpochModTeam/DayZ-Epoch.git
synced 2025-12-14 04:02:37 +03:00
Fixed crash spawner & supply drop loot positioning
This commit is contained in:
@@ -1,98 +1,101 @@
|
|||||||
private ["_guaranteedLoot","_randomizedLoot","_spawnChance","_spawnMarker","_spawnRadius","_spawnFire","_fadeFire","_crashModel","_lootTable","_crashName","_spawnRoll","_position","_crash","_config","_hasAdjustment","_newHeight","_adjustedPos","_num","_itemTypes","_index","_weights","_cntWeights","_nearby","_itemType","_needsrelocated","_istoomany"];
|
private ["_guaranteedLoot","_randomizedLoot","_spawnChance","_spawnMarker","_spawnRadius","_spawnFire","_fadeFire","_crashModel","_lootTable","_crashName","_spawnRoll","_position","_crash","_config","_hasAdjustment","_newHeight","_adjustedPos","_num","_itemTypes","_index","_weights","_cntWeights","_nearby","_itemType","_needsrelocated","_istoomany","_pos","_lootPos"];
|
||||||
|
|
||||||
_guaranteedLoot = 3;
|
_guaranteedLoot = 3;
|
||||||
_randomizedLoot = 4;
|
_randomizedLoot = 4;
|
||||||
_spawnChance = 0.50;
|
_spawnChance = 0.50;
|
||||||
_spawnMarker = 'center';
|
_spawnMarker = 'center';
|
||||||
// _spawnRadius = 5000;
|
// _spawnRadius = 5000;
|
||||||
_spawnRadius = HeliCrashArea;
|
_spawnRadius = HeliCrashArea;
|
||||||
_spawnFire = true;
|
_spawnFire = true;
|
||||||
_fadeFire = false;
|
_fadeFire = false;
|
||||||
|
_minLootRadius = 4;
|
||||||
|
_maxLootRadius = 4;
|
||||||
_spawnRoll = random 1;
|
_spawnRoll = random 1;
|
||||||
if (_spawnRoll <= _spawnChance) then {
|
if (_spawnRoll <= _spawnChance) then {
|
||||||
|
|
||||||
_crashModel = ["UH60Wreck_DZ","UH1Wreck_DZ","UH60_NAVY_Wreck_DZ","UH60_ARMY_Wreck_DZ","UH60_NAVY_Wreck_burned_DZ","UH60_ARMY_Wreck_burned_DZ","Mass_grave_DZ"] call BIS_fnc_selectRandom;
|
_crashModel = ["UH60Wreck_DZ","UH1Wreck_DZ","UH60_NAVY_Wreck_DZ","UH60_ARMY_Wreck_DZ","UH60_NAVY_Wreck_burned_DZ","UH60_ARMY_Wreck_burned_DZ","Mass_grave_DZ"] call BIS_fnc_selectRandom;
|
||||||
|
|
||||||
if(_crashModel == "Mass_grave_DZ") then {
|
if(_crashModel == "Mass_grave_DZ") then {
|
||||||
_lootTable = "MassGrave";
|
_lootTable = "MassGrave";
|
||||||
} else {
|
} else {
|
||||||
_lootTable = "HeliCrash";
|
_lootTable = "HeliCrash";
|
||||||
};
|
};
|
||||||
|
_maxLootRadius = _maxLootRadius - _minLootRadius;
|
||||||
|
_crashName = getText (configFile >> "CfgVehicles" >> _crashModel >> "displayName");
|
||||||
|
|
||||||
_crashName = getText (configFile >> "CfgVehicles" >> _crashModel >> "displayName");
|
// Loop for a new location without any vehicles
|
||||||
|
_needsrelocated = true;
|
||||||
|
while {_needsrelocated} do {
|
||||||
|
_position = [getMarkerPos _spawnMarker,0,_spawnRadius,10,0,2000,0] call BIS_fnc_findSafePos;
|
||||||
|
_istoomany = _position nearObjects ["AllVehicles",10];
|
||||||
|
if((count _istoomany) == 0) then { _needsrelocated = false; };
|
||||||
|
};
|
||||||
|
|
||||||
// Loop for a new location without any vehicles
|
//diag_log(format["CRASHSPAWNER: Spawning '%1' with loot table '%2' NOW! (%3) at: %4", _crashName, _lootTable, time, str(_position)]);
|
||||||
_needsrelocated = true;
|
|
||||||
while {_needsrelocated} do {
|
|
||||||
_position = [getMarkerPos _spawnMarker,0,_spawnRadius,10,0,2000,0] call BIS_fnc_findSafePos;
|
|
||||||
_istoomany = _position nearObjects ["AllVehicles",10];
|
|
||||||
if((count _istoomany) == 0) then { _needsrelocated = false; };
|
|
||||||
};
|
|
||||||
|
|
||||||
//diag_log(format["CRASHSPAWNER: Spawning '%1' with loot table '%2' NOW! (%3) at: %4", _crashName, _lootTable, time, str(_position)]);
|
_crash = createVehicle [_crashModel,_position, [], 0, "CAN_COLLIDE"];
|
||||||
|
// Randomize the direction the wreck is facing
|
||||||
|
_crash setDir round(random 360);
|
||||||
|
|
||||||
_crash = createVehicle [_crashModel,_position, [], 0, "CAN_COLLIDE"];
|
// Using "custom" wrecks (using the destruction model of a vehicle vs. a prepared wreck model) will result
|
||||||
// Randomize the direction the wreck is facing
|
// in the model spawning halfway in the ground. To combat this, an OPTIONAL configuration can be tied to
|
||||||
_crash setDir round(random 360);
|
// the CfgVehicles class you've created for the custom wreck to define how high above the ground it should
|
||||||
|
// spawn. This is optional.
|
||||||
|
_config = configFile >> "CfgVehicles" >> _crashModel >> "heightAdjustment";
|
||||||
|
_hasAdjustment = isNumber(_config);
|
||||||
|
_newHeight = 0;
|
||||||
|
if (_hasAdjustment) then {
|
||||||
|
_newHeight = getNumber(_config);
|
||||||
|
};
|
||||||
|
|
||||||
// Using "custom" wrecks (using the destruction model of a vehicle vs. a prepared wreck model) will result
|
// Must setPos after a setDir otherwise the wreck won't level itself with the terrain
|
||||||
// in the model spawning halfway in the ground. To combat this, an OPTIONAL configuration can be tied to
|
_adjustedPos = [(_position select 0), (_position select 1), _newHeight];
|
||||||
// the CfgVehicles class you've created for the custom wreck to define how high above the ground it should
|
//diag_log(format["DIAG: Designated Position: %1", str(_adjustedPos)]);
|
||||||
// spawn. This is optional.
|
_crash setPos _adjustedPos;
|
||||||
_config = configFile >> "CfgVehicles" >> _crashModel >> "heightAdjustment";
|
|
||||||
_hasAdjustment = isNumber(_config);
|
|
||||||
_newHeight = 0;
|
|
||||||
if (_hasAdjustment) then {
|
|
||||||
_newHeight = getNumber(_config);
|
|
||||||
};
|
|
||||||
|
|
||||||
// Must setPos after a setDir otherwise the wreck won't level itself with the terrain
|
// I don't think this is needed (you can't get "in" a crash), but it was in the original DayZ Crash logic
|
||||||
_adjustedPos = [(_position select 0), (_position select 1), _newHeight];
|
PVDZE_serverObjectMonitor set [count PVDZE_serverObjectMonitor,_crash];
|
||||||
//diag_log(format["DIAG: Designated Position: %1", str(_adjustedPos)]);
|
|
||||||
_crash setPos _adjustedPos;
|
|
||||||
|
|
||||||
// I don't think this is needed (you can't get "in" a crash), but it was in the original DayZ Crash logic
|
_crash setVariable ["ObjectID","1",true];
|
||||||
PVDZE_serverObjectMonitor set [count PVDZE_serverObjectMonitor,_crash];
|
_pos = getPos _crash;
|
||||||
|
// Disable simulation server side
|
||||||
|
_crash enableSimulation false;
|
||||||
|
|
||||||
_crash setVariable ["ObjectID","1",true];
|
_num = round(random _randomizedLoot) + _guaranteedLoot;
|
||||||
|
|
||||||
// Disable simulation server side
|
if(_crashModel == "Mass_grave_DZ") then {
|
||||||
_crash enableSimulation false;
|
_spawnFire = false;
|
||||||
|
_num = _num * 2;
|
||||||
|
};
|
||||||
|
|
||||||
_num = round(random _randomizedLoot) + _guaranteedLoot;
|
if (_spawnFire) then {
|
||||||
|
//["PVDZE_obj_Fire",[_crash,2,time,false,_fadeFire]] call broadcastRpcCallAll;
|
||||||
|
PVDZE_obj_Fire = [_crash,2,time,false,_fadeFire];
|
||||||
|
publicVariable "PVDZE_obj_Fire";
|
||||||
|
_crash setvariable ["fadeFire",_fadeFire,true];
|
||||||
|
};
|
||||||
|
|
||||||
if(_crashModel == "Mass_grave_DZ") then {
|
if (DZE_MissionLootTable) then {
|
||||||
_spawnFire = false;
|
_itemTypes = [] + getArray (missionConfigFile >> "CfgBuildingLoot" >> _lootTable >> "lootType");
|
||||||
_num = _num * 2;
|
} else {
|
||||||
};
|
_itemTypes = [] + getArray (configFile >> "CfgBuildingLoot" >> _lootTable >> "lootType");
|
||||||
|
};
|
||||||
|
_CBLBase = dayz_CBLBase find (toLower(_lootTable));
|
||||||
|
_weights = dayz_CBLChances select _CBLBase;
|
||||||
|
_cntWeights = count _weights;
|
||||||
|
|
||||||
if (_spawnFire) then {
|
for "_x" from 1 to _num do {
|
||||||
//["PVDZE_obj_Fire",[_crash,2,time,false,_fadeFire]] call broadcastRpcCallAll;
|
//create loot
|
||||||
PVDZE_obj_Fire = [_crash,2,time,false,_fadeFire];
|
_maxLootRadius = (random _maxLootRadius) + _minLootRadius;
|
||||||
publicVariable "PVDZE_obj_Fire";
|
_lootPos = [_pos, _maxLootRadius, random 360] call BIS_fnc_relPos;
|
||||||
_crash setvariable ["fadeFire",_fadeFire,true];
|
_index1 = floor(random _cntWeights);
|
||||||
};
|
_index2 = _weights select _index1;
|
||||||
|
_itemType = _itemTypes select _index2;
|
||||||
if (DZE_MissionLootTable) then {
|
[_itemType select 0, _itemType select 1, _lootPos, 5] call spawn_loot;
|
||||||
_itemTypes = [] + getArray (missionConfigFile >> "CfgBuildingLoot" >> _lootTable >> "lootType");
|
};
|
||||||
} else {
|
// ReammoBox is preferred parent class here, as WeaponHolder wouldn't match MedBox0 && other such items.
|
||||||
_itemTypes = [] + getArray (configFile >> "CfgBuildingLoot" >> _lootTable >> "lootType");
|
_nearby = _pos nearObjects ["ReammoBox", sizeOf(_crashModel)];
|
||||||
};
|
{
|
||||||
_CBLBase = dayz_CBLBase find (toLower(_lootTable));
|
_x setVariable ["permaLoot",true];
|
||||||
_weights = dayz_CBLChances select _CBLBase;
|
} count _nearBy;
|
||||||
_cntWeights = count _weights;
|
|
||||||
|
|
||||||
for "_x" from 1 to _num do {
|
|
||||||
//create loot
|
|
||||||
_index1 = floor(random _cntWeights);
|
|
||||||
_index2 = _weights select _index1;
|
|
||||||
_itemType = _itemTypes select _index2;
|
|
||||||
[_itemType select 0, _itemType select 1, _position, 5] call spawn_loot;
|
|
||||||
};
|
|
||||||
// ReammoBox is preferred parent class here, as WeaponHolder wouldn't match MedBox0 && other such items.
|
|
||||||
_nearby = _position nearObjects ["ReammoBox", sizeOf(_crashModel)];
|
|
||||||
{
|
|
||||||
_x setVariable ["permaLoot",true];
|
|
||||||
} count _nearBy;
|
|
||||||
};
|
};
|
||||||
@@ -1,65 +1,68 @@
|
|||||||
private ["_guaranteedLoot","_randomizedLoot","_spawnChance","_spawnMarker","_spawnRadius","_crashModel","_lootTable","_spawnRoll","_position","_crash","_config","_num","_itemTypes","_index","_weights","_cntWeights","_nearby","_itemType","_needsrelocated","_istoomany"];
|
private ["_guaranteedLoot","_randomizedLoot","_spawnChance","_spawnMarker","_spawnRadius","_crashModel","_lootTable","_spawnRoll","_position","_crash","_config","_num","_itemTypes","_index","_weights","_cntWeights","_nearby","_itemType","_needsrelocated","_istoomany","_pos","_lootPos"];
|
||||||
|
|
||||||
_guaranteedLoot = 4;
|
_guaranteedLoot = 4;
|
||||||
_randomizedLoot = 8;
|
_randomizedLoot = 8;
|
||||||
_spawnChance = 0.50;
|
_spawnChance = 0.50;
|
||||||
_spawnMarker = 'center';
|
_spawnMarker = 'center';
|
||||||
_spawnRadius = (HeliCrashArea/2);
|
_spawnRadius = (HeliCrashArea/2);
|
||||||
|
_minLootRadius = 4;
|
||||||
|
_maxLootRadius = 4;
|
||||||
_spawnRoll = random 1;
|
_spawnRoll = random 1;
|
||||||
if (_spawnRoll <= _spawnChance) then {
|
if (_spawnRoll <= _spawnChance) then {
|
||||||
|
|
||||||
_crashModel = "Supply_Crate_DZE";
|
|
||||||
|
|
||||||
_lootTable = "SupplyDrop";
|
_crashModel = "Supply_Crate_DZE";
|
||||||
|
|
||||||
// Loop for a new location without any vehicles
|
|
||||||
_needsrelocated = true;
|
|
||||||
while {_needsrelocated} do {
|
|
||||||
_position = [getMarkerPos _spawnMarker,0,_spawnRadius,10,0,2000,0] call BIS_fnc_findSafePos;
|
|
||||||
_istoomany = _position nearObjects ["AllVehicles",10];
|
|
||||||
if((count _istoomany) == 0) then { _needsrelocated = false; };
|
|
||||||
};
|
|
||||||
|
|
||||||
//diag_log(format["CRASHSPAWNER: Spawning '%1' with loot table '%2' NOW! (%3) at: %4", _crashName, _lootTable, time, str(_position)]);
|
_lootTable = "SupplyDrop";
|
||||||
|
|
||||||
_crash = createVehicle [_crashModel,_position, [], 0, "CAN_COLLIDE"];
|
// Loop for a new location without any vehicles
|
||||||
|
_needsrelocated = true;
|
||||||
// Randomize the direction the wreck is facing
|
while {_needsrelocated} do {
|
||||||
_crash setDir round(random 360);
|
_position = [getMarkerPos _spawnMarker,0,_spawnRadius,10,0,2000,0] call BIS_fnc_findSafePos;
|
||||||
|
_istoomany = _position nearObjects ["AllVehicles",10];
|
||||||
|
if((count _istoomany) == 0) then { _needsrelocated = false; };
|
||||||
|
};
|
||||||
|
|
||||||
_crash setPos _position;
|
//diag_log(format["CRASHSPAWNER: Spawning '%1' with loot table '%2' NOW! (%3) at: %4", _crashName, _lootTable, time, str(_position)]);
|
||||||
|
|
||||||
// I don't think this is needed (you can't get "in" a crash), but it was in the original DayZ Crash logic
|
_crash = createVehicle [_crashModel,_position, [], 0, "CAN_COLLIDE"];
|
||||||
//PVDZE_serverObjectMonitor set [count PVDZE_serverObjectMonitor,_crash];
|
|
||||||
|
|
||||||
//_crash setVariable ["ObjectID","1",true];
|
// Randomize the direction the wreck is facing
|
||||||
|
_crash setDir round(random 360);
|
||||||
|
|
||||||
// Disable simulation server side
|
_crash setPos _position;
|
||||||
_crash enableSimulation false;
|
|
||||||
|
// I don't think this is needed (you can't get "in" a crash), but it was in the original DayZ Crash logic
|
||||||
|
//PVDZE_serverObjectMonitor set [count PVDZE_serverObjectMonitor,_crash];
|
||||||
|
|
||||||
|
//_crash setVariable ["ObjectID","1",true];
|
||||||
|
_pos = getPos _crash;
|
||||||
|
// Disable simulation server side
|
||||||
|
_crash enableSimulation false;
|
||||||
|
|
||||||
_num = (round(random _randomizedLoot)) + _guaranteedLoot;
|
_num = (round(random _randomizedLoot)) + _guaranteedLoot;
|
||||||
|
|
||||||
if (DZE_MissionLootTable) then {
|
|
||||||
_itemTypes = [] + getArray (missionConfigFile >> "CfgBuildingLoot" >> _lootTable >> "lootType");
|
|
||||||
} else {
|
|
||||||
_itemTypes = [] + getArray (configFile >> "CfgBuildingLoot" >> _lootTable >> "lootType");
|
|
||||||
};
|
|
||||||
_CBLBase = dayz_CBLBase find (toLower(_lootTable));
|
|
||||||
_weights = dayz_CBLChances select _CBLBase;
|
|
||||||
_cntWeights = count _weights;
|
|
||||||
|
|
||||||
for "_x" from 1 to _num do {
|
if (DZE_MissionLootTable) then {
|
||||||
//create loot
|
_itemTypes = [] + getArray (missionConfigFile >> "CfgBuildingLoot" >> _lootTable >> "lootType");
|
||||||
_index1 = floor(random _cntWeights);
|
} else {
|
||||||
_index2 = _weights select _index1;
|
_itemTypes = [] + getArray (configFile >> "CfgBuildingLoot" >> _lootTable >> "lootType");
|
||||||
_itemType = _itemTypes select _index2;
|
};
|
||||||
[_itemType select 0, _itemType select 1, _position, 5] call spawn_loot;
|
_CBLBase = dayz_CBLBase find (toLower(_lootTable));
|
||||||
};
|
_weights = dayz_CBLChances select _CBLBase;
|
||||||
|
_cntWeights = count _weights;
|
||||||
// ReammoBox is preferred parent class here, as WeaponHolder wouldn't match MedBox0 && other such items.
|
|
||||||
_nearby = _position nearObjects ["ReammoBox", sizeOf(_crashModel)];
|
for "_x" from 1 to _num do {
|
||||||
{
|
//create loot
|
||||||
_x setVariable ["permaLoot",true];
|
_maxLootRadius = (random _maxLootRadius) + _minLootRadius;
|
||||||
} count _nearBy;
|
_lootPos = [_pos, _maxLootRadius, random 360] call BIS_fnc_relPos;
|
||||||
|
_index1 = floor(random _cntWeights);
|
||||||
|
_index2 = _weights select _index1;
|
||||||
|
_itemType = _itemTypes select _index2;
|
||||||
|
[_itemType select 0, _itemType select 1, _lootPos, 5] call spawn_loot;
|
||||||
|
};
|
||||||
|
|
||||||
|
// ReammoBox is preferred parent class here, as WeaponHolder wouldn't match MedBox0 && other such items.
|
||||||
|
_nearby = _position nearObjects ["ReammoBox", sizeOf(_crashModel)];
|
||||||
|
{
|
||||||
|
_x setVariable ["permaLoot",true];
|
||||||
|
} count _nearBy;
|
||||||
};
|
};
|
||||||
Reference in New Issue
Block a user