mirror of
https://github.com/ComfyFactory/ComfyFactorio.git
synced 2025-01-16 02:47:48 +02:00
WD - fix weird spawn position
This commit is contained in:
parent
eaf07a1572
commit
c177f17d80
@ -322,7 +322,9 @@ local function on_tick()
|
||||
progress()
|
||||
end
|
||||
|
||||
Event.on_init(on_init)
|
||||
Event.add(defines.events.on_tick, on_tick)
|
||||
if not Public.read_tables_only then
|
||||
Event.on_init(on_init)
|
||||
Event.add(defines.events.on_tick, on_tick)
|
||||
end
|
||||
|
||||
return Public
|
||||
|
@ -4,6 +4,8 @@ local BiterHealthBooster = require 'modules.biter_health_booster_v2'
|
||||
local Difficulty = require 'modules.difficulty_vote_by_amount'
|
||||
local Alert = require 'utils.alert'
|
||||
local Server = require 'utils.server'
|
||||
local Collapse = require 'modules.collapse'
|
||||
Collapse.read_tables_only = true
|
||||
|
||||
local random = math.random
|
||||
local floor = math.floor
|
||||
@ -11,22 +13,6 @@ local sqrt = math.sqrt
|
||||
local round = math.round
|
||||
local raise = Event.raise
|
||||
|
||||
local function debug_print(msg)
|
||||
local debug = Public.get('debug')
|
||||
if not debug then
|
||||
return
|
||||
end
|
||||
print('WaveDefense: ' .. msg)
|
||||
end
|
||||
|
||||
local function debug_print_health(msg)
|
||||
local debug = Public.get('debug_health')
|
||||
if not debug then
|
||||
return
|
||||
end
|
||||
print('[HEALTHBOOSTER]: ' .. msg)
|
||||
end
|
||||
|
||||
local function valid(userdata)
|
||||
if not (userdata and userdata.valid) then
|
||||
return false
|
||||
@ -168,14 +154,14 @@ local function fill_tiles(entity, size)
|
||||
surface.set_tiles({{name = 'sand-1', position = tile.position}}, true)
|
||||
end
|
||||
end
|
||||
debug_print('fill_tiles - filled tiles cause we found non-placable tiles.')
|
||||
Public.debug_print('fill_tiles - filled tiles cause we found non-placable tiles.')
|
||||
end
|
||||
|
||||
local function get_spawn_pos()
|
||||
local surface_index = Public.get('surface_index')
|
||||
local surface = game.surfaces[surface_index]
|
||||
if not surface then
|
||||
return debug_print('get_spawn_pos - surface was not valid?')
|
||||
return Public.debug_print('get_spawn_pos - surface was not valid?')
|
||||
end
|
||||
|
||||
local c = 0
|
||||
@ -183,11 +169,14 @@ local function get_spawn_pos()
|
||||
::retry::
|
||||
|
||||
local initial_position = Public.get('spawn_position')
|
||||
local target = Public.get('target')
|
||||
|
||||
if random(1, 2) == 1 then
|
||||
initial_position = {x = initial_position.x, y = initial_position.y - 30}
|
||||
else
|
||||
initial_position = {x = initial_position.x, y = initial_position.y - 20}
|
||||
if initial_position.y - target.position.y > 10 then
|
||||
if random(1, 2) == 1 then
|
||||
initial_position = {x = initial_position.x, y = initial_position.y - 30}
|
||||
else
|
||||
initial_position = {x = initial_position.x, y = initial_position.y - 20}
|
||||
end
|
||||
end
|
||||
|
||||
local located_position = find_initial_spot(surface, initial_position)
|
||||
@ -206,21 +195,21 @@ local function get_spawn_pos()
|
||||
if remove_entities then
|
||||
c = c + 1
|
||||
valid_position = Public.get('spawn_position')
|
||||
debug_print(serpent.block('valid_position - x:' .. valid_position.x .. ' y:' .. valid_position.y))
|
||||
Public.debug_print(serpent.block('valid_position - x:' .. valid_position.x .. ' y:' .. valid_position.y))
|
||||
remove_trees({surface = surface, position = valid_position, valid = true})
|
||||
remove_rocks({surface = surface, position = valid_position, valid = true})
|
||||
fill_tiles({surface = surface, position = valid_position, valid = true})
|
||||
Public.set('spot', 'nil')
|
||||
if c == 5 then
|
||||
return debug_print('get_spawn_pos - we could not find a spawning pos?')
|
||||
return Public.debug_print('get_spawn_pos - we could not find a spawning pos?')
|
||||
end
|
||||
goto retry
|
||||
else
|
||||
return debug_print('get_spawn_pos - we could not find a spawning pos?')
|
||||
return Public.debug_print('get_spawn_pos - we could not find a spawning pos?')
|
||||
end
|
||||
end
|
||||
|
||||
debug_print(serpent.block('valid_position - x:' .. valid_position.x .. ' y:' .. valid_position.y))
|
||||
Public.debug_print(serpent.block('valid_position - x:' .. valid_position.x .. ' y:' .. valid_position.y))
|
||||
|
||||
return valid_position
|
||||
end
|
||||
@ -228,15 +217,15 @@ end
|
||||
local function is_unit_valid(biter)
|
||||
local max_biter_age = Public.get('max_biter_age')
|
||||
if not biter.entity then
|
||||
debug_print('is_unit_valid - unit destroyed - does no longer exist')
|
||||
Public.debug_print('is_unit_valid - unit destroyed - does no longer exist')
|
||||
return false
|
||||
end
|
||||
if not biter.entity.valid then
|
||||
debug_print('is_unit_valid - unit destroyed - invalid')
|
||||
Public.debug_print('is_unit_valid - unit destroyed - invalid')
|
||||
return false
|
||||
end
|
||||
if biter.spawn_tick + max_biter_age < game.tick then
|
||||
debug_print('is_unit_valid - unit destroyed - timed out')
|
||||
Public.debug_print('is_unit_valid - unit destroyed - timed out')
|
||||
return false
|
||||
end
|
||||
return true
|
||||
@ -245,7 +234,7 @@ end
|
||||
local function refresh_active_unit_threat()
|
||||
local active_biter_threat = Public.get('active_biter_threat')
|
||||
local generated_units = Public.get('generated_units')
|
||||
debug_print('refresh_active_unit_threat - current value ' .. active_biter_threat)
|
||||
Public.debug_print('refresh_active_unit_threat - current value ' .. active_biter_threat)
|
||||
local biter_threat = 0
|
||||
for k, biter in pairs(generated_units.active_biters) do
|
||||
if valid(biter.entity) then
|
||||
@ -256,7 +245,7 @@ local function refresh_active_unit_threat()
|
||||
end
|
||||
local biter_health_boost = BiterHealthBooster.get('biter_health_boost')
|
||||
Public.set('active_biter_threat', round(biter_threat * biter_health_boost, 2))
|
||||
debug_print('refresh_active_unit_threat - new value ' .. active_biter_threat)
|
||||
Public.debug_print('refresh_active_unit_threat - new value ' .. active_biter_threat)
|
||||
if generated_units.unit_group_pos.index > 500 then
|
||||
generated_units.unit_group_pos.positions = {}
|
||||
generated_units.unit_group_pos.index = 0
|
||||
@ -285,7 +274,7 @@ local function time_out_biters()
|
||||
entity.destroy()
|
||||
end
|
||||
end
|
||||
debug_print('time_out_biters: ' .. k .. ' got deleted.')
|
||||
Public.debug_print('time_out_biters: ' .. k .. ' got deleted.')
|
||||
generated_units.active_biters[k] = nil
|
||||
end
|
||||
end
|
||||
@ -316,7 +305,7 @@ local function get_random_close_spawner()
|
||||
if not spawner or (center.x - spawner_2.position.x) ^ 2 + (center.y - spawner_2.position.y) ^ 2 < (center.x - spawner.position.x) ^ 2 + (center.y - spawner.position.y) ^ 2 then
|
||||
spawner = spawner_2
|
||||
if spawner and spawner.position then
|
||||
debug_print('get_random_close_spawner - Found at x' .. spawner.position.x .. ' y' .. spawner.position.y)
|
||||
Public.debug_print('get_random_close_spawner - Found at x' .. spawner.position.x .. ' y' .. spawner.position.y)
|
||||
end
|
||||
end
|
||||
end
|
||||
@ -368,7 +357,7 @@ local function set_main_target()
|
||||
|
||||
Public.set('target', sec_target)
|
||||
raise(Public.events.on_target_aquired, {target = target})
|
||||
debug_print('set_main_target -- New main target ' .. sec_target.name .. ' at position x' .. sec_target.position.x .. ' y' .. sec_target.position.y .. ' selected.')
|
||||
Public.debug_print('set_main_target -- New main target ' .. sec_target.name .. ' at position x' .. sec_target.position.x .. ' y' .. sec_target.position.y .. ' selected.')
|
||||
end
|
||||
|
||||
local function set_group_spawn_position(surface)
|
||||
@ -383,7 +372,7 @@ local function set_group_spawn_position(surface)
|
||||
Public.set('spawn_position', {x = position.x, y = position.y})
|
||||
local spawn_position = get_spawn_pos()
|
||||
if spawn_position then
|
||||
debug_print('set_group_spawn_position -- Changed position to x' .. spawn_position.x .. ' y' .. spawn_position.y .. '.')
|
||||
Public.debug_print('set_group_spawn_position -- Changed position to x' .. spawn_position.x .. ' y' .. spawn_position.y .. '.')
|
||||
end
|
||||
end
|
||||
|
||||
@ -423,7 +412,7 @@ local function can_units_spawn()
|
||||
local threat = Public.get('threat')
|
||||
|
||||
if threat <= 0 then
|
||||
debug_print('can_units_spawn - threat too low')
|
||||
Public.debug_print('can_units_spawn - threat too low')
|
||||
time_out_biters()
|
||||
return false
|
||||
end
|
||||
@ -431,14 +420,14 @@ local function can_units_spawn()
|
||||
local active_biter_count = Public.get('active_biter_count')
|
||||
local max_active_biters = Public.get('max_active_biters')
|
||||
if active_biter_count >= max_active_biters then
|
||||
debug_print('can_units_spawn - active biter count too high')
|
||||
Public.debug_print('can_units_spawn - active biter count too high')
|
||||
time_out_biters()
|
||||
return false
|
||||
end
|
||||
|
||||
local active_biter_threat = Public.get('active_biter_threat')
|
||||
if active_biter_threat >= threat then
|
||||
debug_print('can_units_spawn - active biter threat too high (' .. active_biter_threat .. ')')
|
||||
Public.debug_print('can_units_spawn - active biter threat too high (' .. active_biter_threat .. ')')
|
||||
time_out_biters()
|
||||
return false
|
||||
end
|
||||
@ -469,7 +458,7 @@ local function get_active_unit_groups_count()
|
||||
end
|
||||
end
|
||||
end
|
||||
debug_print('Active unit group count: ' .. count)
|
||||
Public.debug_print('Active unit group count: ' .. count)
|
||||
return count
|
||||
end
|
||||
|
||||
@ -531,7 +520,7 @@ local function spawn_biter(surface, position, forceSpawn, is_boss_biter, unit_se
|
||||
if final_health < 1 then
|
||||
final_health = 1
|
||||
end
|
||||
debug_print_health('final_health - unit: ' .. biter.name .. ' with h-m: ' .. final_health)
|
||||
Public.debug_print_health('final_health - unit: ' .. biter.name .. ' with h-m: ' .. final_health)
|
||||
BiterHealthBooster.add_unit(biter, final_health)
|
||||
end
|
||||
|
||||
@ -574,8 +563,8 @@ local function increase_biter_damage()
|
||||
local e_old_melee = e.get_ammo_damage_modifier('melee')
|
||||
local e_old_biological = e.get_ammo_damage_modifier('biological')
|
||||
|
||||
debug_print('Melee: ' .. melee + e_old_melee)
|
||||
debug_print('Biological: ' .. bio + e_old_biological)
|
||||
Public.debug_print('Melee: ' .. melee + e_old_melee)
|
||||
Public.debug_print('Biological: ' .. bio + e_old_biological)
|
||||
|
||||
e.set_ammo_damage_modifier('melee', melee + e_old_melee)
|
||||
e.set_ammo_damage_modifier('biological', bio + e_old_biological)
|
||||
@ -592,7 +581,7 @@ local function increase_biters_health()
|
||||
if modified_unit_health.current_value > modified_unit_health.limit_value then
|
||||
modified_unit_health.current_value = modified_unit_health.limit_value
|
||||
end
|
||||
debug_print_health('modified_unit_health.current_value: ' .. modified_unit_health.current_value)
|
||||
Public.debug_print_health('modified_unit_health.current_value: ' .. modified_unit_health.current_value)
|
||||
Public.set('modified_unit_health').current_value = modified_unit_health.current_value + modified_unit_health.health_increase_per_boss_wave
|
||||
|
||||
-- this sets boss units health
|
||||
@ -600,7 +589,7 @@ local function increase_biters_health()
|
||||
if modified_boss_unit_health.current_value > modified_boss_unit_health.limit_value then
|
||||
modified_boss_unit_health.current_value = modified_boss_unit_health.limit_value
|
||||
end
|
||||
debug_print_health('modified_boss_unit_health.current_value: ' .. modified_boss_unit_health.current_value)
|
||||
Public.debug_print_health('modified_boss_unit_health.current_value: ' .. modified_boss_unit_health.current_value)
|
||||
Public.set('modified_boss_unit_health').current_value = modified_boss_unit_health.current_value + modified_boss_unit_health.health_increase_per_boss_wave
|
||||
end
|
||||
|
||||
@ -622,7 +611,7 @@ local function increase_unit_group_size()
|
||||
end
|
||||
|
||||
Public.set('average_unit_group_size', new_average_unit_group_size)
|
||||
debug_print_health('average_unit_group_size - ' .. new_average_unit_group_size)
|
||||
Public.debug_print_health('average_unit_group_size - ' .. new_average_unit_group_size)
|
||||
end
|
||||
end
|
||||
|
||||
@ -644,7 +633,7 @@ local function increase_max_active_unit_groups()
|
||||
end
|
||||
|
||||
Public.set('max_active_unit_groups', new_max_active_unit_groups)
|
||||
debug_print_health('max_active_unit_groups - ' .. new_max_active_unit_groups)
|
||||
Public.debug_print_health('max_active_unit_groups - ' .. new_max_active_unit_groups)
|
||||
end
|
||||
end
|
||||
|
||||
@ -727,14 +716,14 @@ local function reform_group(group)
|
||||
for _, biter in pairs(group.members) do
|
||||
new_group.add_member(biter)
|
||||
end
|
||||
debug_print('Creating new unit group, because old one was stuck.')
|
||||
Public.debug_print('Creating new unit group, because old one was stuck.')
|
||||
generated_units.unit_groups[new_group.group_number] = new_group
|
||||
local unit_groups_size = Public.get('unit_groups_size')
|
||||
Public.set('unit_groups_size', unit_groups_size + 1)
|
||||
|
||||
return new_group
|
||||
else
|
||||
debug_print('Destroying stuck group.')
|
||||
Public.debug_print('Destroying stuck group.')
|
||||
if generated_units.unit_groups[group.group_number] then
|
||||
if generated_units.unit_group_last_command[group.group_number] then
|
||||
generated_units.unit_group_last_command[group.group_number] = nil
|
||||
@ -810,7 +799,7 @@ local function get_main_command(group)
|
||||
return
|
||||
end
|
||||
|
||||
debug_print('get_main_command - starting')
|
||||
Public.debug_print('get_main_command - starting')
|
||||
|
||||
local target_position = target.position
|
||||
local distance_to_target = floor(sqrt((target_position.x - group_position.x) ^ 2 + (target_position.y - group_position.y) ^ 2))
|
||||
@ -820,9 +809,9 @@ local function get_main_command(group)
|
||||
round((target_position.y - group_position.y) / steps, 3)
|
||||
}
|
||||
|
||||
debug_print('get_commmands - to main target x' .. target_position.x .. ' y' .. target_position.y)
|
||||
debug_print('get_commmands - distance_to_target:' .. distance_to_target .. ' steps:' .. steps)
|
||||
debug_print('get_commmands - vector ' .. vector[1] .. '_' .. vector[2])
|
||||
Public.debug_print('get_commmands - to main target x' .. target_position.x .. ' y' .. target_position.y)
|
||||
Public.debug_print('get_commmands - distance_to_target:' .. distance_to_target .. ' steps:' .. steps)
|
||||
Public.debug_print('get_commmands - vector ' .. vector[1] .. '_' .. vector[2])
|
||||
|
||||
for _ = 1, steps, 1 do
|
||||
local old_position = group_position
|
||||
@ -907,7 +896,7 @@ local function command_to_main_target(group, bypass)
|
||||
|
||||
local commands = get_main_command(group)
|
||||
|
||||
debug_print('get_main_command - got commands')
|
||||
Public.debug_print('get_main_command - got commands')
|
||||
|
||||
local surface_index = Public.get('surface_index')
|
||||
|
||||
@ -922,7 +911,7 @@ local function command_to_main_target(group, bypass)
|
||||
commands = commands
|
||||
}
|
||||
)
|
||||
debug_print('get_main_command - sent commands')
|
||||
Public.debug_print('get_main_command - sent commands')
|
||||
if valid(group) then
|
||||
generated_units.unit_group_last_command[group.group_number] = game.tick
|
||||
end
|
||||
@ -1007,25 +996,25 @@ end
|
||||
|
||||
local function spawn_unit_group(fs, only_bosses)
|
||||
if fs then
|
||||
debug_print('spawn_unit_group - forcing new biters')
|
||||
Public.debug_print('spawn_unit_group - forcing new biters')
|
||||
else
|
||||
if not can_units_spawn() then
|
||||
debug_print('spawn_unit_group - Cant spawn units?')
|
||||
Public.debug_print('spawn_unit_group - Cant spawn units?')
|
||||
return
|
||||
end
|
||||
end
|
||||
local target = Public.get('target')
|
||||
if not valid(target) then
|
||||
debug_print('spawn_unit_group - Target was not valid?')
|
||||
Public.debug_print('spawn_unit_group - Target was not valid?')
|
||||
return
|
||||
end
|
||||
|
||||
local max_active_unit_groups = Public.get('max_active_unit_groups')
|
||||
if fs then
|
||||
debug_print('spawn_unit_group - forcing new biters')
|
||||
Public.debug_print('spawn_unit_group - forcing new biters')
|
||||
else
|
||||
if get_active_unit_groups_count() >= max_active_unit_groups then
|
||||
debug_print('spawn_unit_group - unit_groups at max')
|
||||
Public.debug_print('spawn_unit_group - unit_groups at max')
|
||||
return
|
||||
end
|
||||
end
|
||||
@ -1047,7 +1036,7 @@ local function spawn_unit_group(fs, only_bosses)
|
||||
}
|
||||
for _, v in pairs(surface.find_entities_filtered {area = area, name = 'land-mine'}) do
|
||||
if v and v.valid then
|
||||
debug_print('spawn_unit_group - found land-mines')
|
||||
Public.debug_print('spawn_unit_group - found land-mines')
|
||||
v.die()
|
||||
end
|
||||
end
|
||||
@ -1061,7 +1050,7 @@ local function spawn_unit_group(fs, only_bosses)
|
||||
local wave_number = Public.get('wave_number')
|
||||
Public.wave_defense_set_unit_raffle(wave_number)
|
||||
|
||||
debug_print('Spawning unit group at x' .. spawn_position.x .. ' y' .. spawn_position.y)
|
||||
Public.debug_print('Spawning unit group at x' .. spawn_position.x .. ' y' .. spawn_position.y)
|
||||
|
||||
local event_data = {}
|
||||
|
||||
@ -1093,7 +1082,7 @@ local function spawn_unit_group(fs, only_bosses)
|
||||
for _ = 1, group_size, 1 do
|
||||
local biter = spawn_biter(surface, spawn_position, fs, false, unit_settings)
|
||||
if not biter then
|
||||
debug_print('spawn_unit_group - No biters were found?')
|
||||
Public.debug_print('spawn_unit_group - No biters were found?')
|
||||
break
|
||||
end
|
||||
unit_group.add_member(biter)
|
||||
@ -1116,7 +1105,7 @@ local function spawn_unit_group(fs, only_bosses)
|
||||
for _ = 1, count, 1 do
|
||||
local biter = spawn_biter(surface, spawn_position, fs, true, unit_settings)
|
||||
if not biter then
|
||||
debug_print('spawn_unit_group - No biter was found?')
|
||||
Public.debug_print('spawn_unit_group - No biter was found?')
|
||||
break
|
||||
end
|
||||
unit_group.add_member(biter)
|
||||
@ -1191,14 +1180,19 @@ local function log_threat()
|
||||
end
|
||||
end
|
||||
|
||||
local function normalize_spawn_position()
|
||||
local collapse_spawn_position = Collapse.get_position()
|
||||
Public.set_spawn_position({x = collapse_spawn_position.x, y = collapse_spawn_position.y - 25})
|
||||
end
|
||||
|
||||
local tick_tasks = {
|
||||
[30] = set_main_target,
|
||||
[60] = set_enemy_evolution,
|
||||
[90] = check_group_positions,
|
||||
[120] = give_main_command_to_group,
|
||||
[150] = log_threat,
|
||||
[180] = Public.build_nest,
|
||||
[210] = Public.build_worm
|
||||
[180] = Public.build_worm,
|
||||
[210] = Public.build_nest
|
||||
}
|
||||
|
||||
local tick_tasks_t2 = {
|
||||
@ -1283,5 +1277,6 @@ Event.on_nth_tick(
|
||||
)
|
||||
|
||||
Public.set_next_wave = set_next_wave
|
||||
Public.normalize_spawn_position = normalize_spawn_position
|
||||
|
||||
return Public
|
||||
|
@ -128,6 +128,7 @@ local function pause_waves_state(state)
|
||||
else
|
||||
local message = ({'wave_defense.start_waves'})
|
||||
Alert.alert_all_players(30, message, nil, 'achievement/tech-maniac', 0.75)
|
||||
Public.normalize_spawn_position()
|
||||
Public.set('paused', false)
|
||||
Public.set('paused_waves_for', nil)
|
||||
Public.set('last_pause', nil)
|
||||
|
@ -57,8 +57,9 @@ function Public.reset_wave_defense()
|
||||
this.active_biter_threat = 0
|
||||
this.average_unit_group_size = 24
|
||||
this.biter_raffle = {}
|
||||
this.debug = false
|
||||
this.debug = true
|
||||
this.debug_health = false
|
||||
this.disable_spawn_near_target = true
|
||||
this.log_wave_to_discord = true
|
||||
this.paused = false
|
||||
this.pause_without_votes = true
|
||||
@ -168,6 +169,20 @@ function Public.reset_wave_defense()
|
||||
}
|
||||
end
|
||||
|
||||
function Public.debug_print(msg)
|
||||
if not this.debug then
|
||||
return
|
||||
end
|
||||
log('WaveDefense: ' .. msg)
|
||||
end
|
||||
|
||||
function Public.debug_print_health(msg)
|
||||
if not this.debug then
|
||||
return
|
||||
end
|
||||
log('[HEALTHBOOSTER]: ' .. msg)
|
||||
end
|
||||
|
||||
--- This gets values from our table
|
||||
-- @param key <string>
|
||||
function Public.get(key)
|
||||
|
@ -1,10 +1,13 @@
|
||||
local Public = require 'modules.wave_defense.table'
|
||||
local Event = require 'utils.event'
|
||||
local BiterHealthBooster = require 'modules.biter_health_booster_v2'
|
||||
local math_random = math.random
|
||||
local round = math.round
|
||||
local Token = require 'utils.token'
|
||||
local Task = require 'utils.task'
|
||||
local Alert = require 'utils.alert'
|
||||
|
||||
local round = math.round
|
||||
local random = math.random
|
||||
local place_nest_near_unit_group
|
||||
|
||||
local immunity_spawner =
|
||||
Token.register(
|
||||
@ -61,73 +64,158 @@ local function remove_unit(entity)
|
||||
end
|
||||
end
|
||||
|
||||
local function place_nest_near_unit_group()
|
||||
local random_group = Public.get('random_group')
|
||||
if not (random_group and random_group.valid) then
|
||||
return
|
||||
end
|
||||
if is_loaded_bool('maps.mountain_fortress_v3.table') then
|
||||
local Core = require 'maps.mountain_fortress_v3.core'
|
||||
|
||||
local generated_units = Public.get('generated_units')
|
||||
local group = generated_units.unit_groups[random_group.group_number]
|
||||
if not group then
|
||||
return
|
||||
end
|
||||
if not group.valid then
|
||||
return
|
||||
end
|
||||
if not group.members then
|
||||
return
|
||||
end
|
||||
if not group.members[1] then
|
||||
return
|
||||
end
|
||||
local unit = group.members[math_random(1, #group.members)]
|
||||
if not unit.valid then
|
||||
return
|
||||
end
|
||||
local name = 'biter-spawner'
|
||||
if math_random(1, 3) == 1 then
|
||||
name = 'spitter-spawner'
|
||||
end
|
||||
local position = unit.surface.find_non_colliding_position(name, unit.position, 12, 1)
|
||||
if not position then
|
||||
return
|
||||
end
|
||||
local r = Public.get('nest_building_density')
|
||||
if
|
||||
unit.surface.count_entities_filtered(
|
||||
{
|
||||
type = 'unit-spawner',
|
||||
force = unit.force,
|
||||
area = {{position.x - r, position.y - r}, {position.x + r, position.y + r}}
|
||||
}
|
||||
) > 0
|
||||
then
|
||||
return
|
||||
end
|
||||
place_nest_near_unit_group = function()
|
||||
local random_group = Public.get('random_group')
|
||||
if not (random_group and random_group.valid) then
|
||||
return
|
||||
end
|
||||
|
||||
local boss = is_boss(unit)
|
||||
local disable_spawn_near_target = Public.get('spawn_near_target')
|
||||
|
||||
local modified_unit_health = Public.get('modified_unit_health')
|
||||
local modified_boss_unit_health = Public.get('modified_boss_unit_health')
|
||||
local generated_units = Public.get('generated_units')
|
||||
local group = generated_units.unit_groups[random_group.group_number]
|
||||
if not group then
|
||||
return
|
||||
end
|
||||
if not group.valid then
|
||||
return
|
||||
end
|
||||
if not group.members then
|
||||
return
|
||||
end
|
||||
if not group.members[1] then
|
||||
return
|
||||
end
|
||||
local unit = group.members[random(1, #group.members)]
|
||||
if not unit.valid then
|
||||
return
|
||||
end
|
||||
|
||||
local spawner = unit.surface.create_entity({name = name, position = position, force = unit.force})
|
||||
spawner.destructible = false
|
||||
Task.set_timeout_in_ticks(200, immunity_spawner, {entity = spawner})
|
||||
if Core.is_around_train(unit) and disable_spawn_near_target then
|
||||
Public.debug_print('place_nest_near_unit_group - cannot spawn inside locomotive aura')
|
||||
return
|
||||
end
|
||||
|
||||
if boss then
|
||||
BiterHealthBooster.add_boss_unit(spawner, modified_boss_unit_health.current_value, 0.5)
|
||||
else
|
||||
BiterHealthBooster.add_unit(spawner, modified_unit_health.current_value)
|
||||
local name = 'biter-spawner'
|
||||
if random(1, 3) == 1 then
|
||||
name = 'spitter-spawner'
|
||||
end
|
||||
|
||||
local position = unit.surface.find_non_colliding_position(name, unit.position, 12, 1)
|
||||
if not position then
|
||||
return
|
||||
end
|
||||
local r = Public.get('nest_building_density')
|
||||
if
|
||||
unit.surface.count_entities_filtered(
|
||||
{
|
||||
type = 'unit-spawner',
|
||||
force = unit.force,
|
||||
area = {{position.x - r, position.y - r}, {position.x + r, position.y + r}}
|
||||
}
|
||||
) > 0
|
||||
then
|
||||
return
|
||||
end
|
||||
|
||||
local boss = is_boss(unit)
|
||||
|
||||
local modified_unit_health = Public.get('modified_unit_health')
|
||||
local modified_boss_unit_health = Public.get('modified_boss_unit_health')
|
||||
|
||||
local spawner = unit.surface.create_entity({name = name, position = position, force = unit.force})
|
||||
spawner.destructible = false
|
||||
local immunity_delay = random(100, 200)
|
||||
Task.set_timeout_in_ticks(immunity_delay, immunity_spawner, {entity = spawner})
|
||||
|
||||
if boss then
|
||||
BiterHealthBooster.add_boss_unit(spawner, modified_boss_unit_health.current_value, 0.5)
|
||||
else
|
||||
BiterHealthBooster.add_unit(spawner, modified_unit_health.current_value)
|
||||
end
|
||||
generated_units.nests[#generated_units.nests + 1] = spawner
|
||||
unit.surface.create_entity({name = 'blood-explosion-huge', position = position})
|
||||
unit.surface.create_entity({name = 'blood-explosion-huge', position = unit.position})
|
||||
local msg = 'A spawner was spawned!'
|
||||
Alert.alert_all_players_location(spawner.position, msg, {r = 0.8, g = 0.1, b = 0.1})
|
||||
remove_unit(unit)
|
||||
unit.destroy()
|
||||
local threat = Public.get('threat')
|
||||
Public.set('threat', threat - Public.threat_values[name])
|
||||
return true
|
||||
end
|
||||
else
|
||||
place_nest_near_unit_group = function()
|
||||
local random_group = Public.get('random_group')
|
||||
if not (random_group and random_group.valid) then
|
||||
return
|
||||
end
|
||||
|
||||
local generated_units = Public.get('generated_units')
|
||||
local group = generated_units.unit_groups[random_group.group_number]
|
||||
if not group then
|
||||
return
|
||||
end
|
||||
if not group.valid then
|
||||
return
|
||||
end
|
||||
if not group.members then
|
||||
return
|
||||
end
|
||||
if not group.members[1] then
|
||||
return
|
||||
end
|
||||
local unit = group.members[random(1, #group.members)]
|
||||
if not unit.valid then
|
||||
return
|
||||
end
|
||||
local name = 'biter-spawner'
|
||||
if random(1, 3) == 1 then
|
||||
name = 'spitter-spawner'
|
||||
end
|
||||
local position = unit.surface.find_non_colliding_position(name, unit.position, 12, 1)
|
||||
if not position then
|
||||
return
|
||||
end
|
||||
local r = Public.get('nest_building_density')
|
||||
if
|
||||
unit.surface.count_entities_filtered(
|
||||
{
|
||||
type = 'unit-spawner',
|
||||
force = unit.force,
|
||||
area = {{position.x - r, position.y - r}, {position.x + r, position.y + r}}
|
||||
}
|
||||
) > 0
|
||||
then
|
||||
return
|
||||
end
|
||||
|
||||
local boss = is_boss(unit)
|
||||
|
||||
local modified_unit_health = Public.get('modified_unit_health')
|
||||
local modified_boss_unit_health = Public.get('modified_boss_unit_health')
|
||||
|
||||
local spawner = unit.surface.create_entity({name = name, position = position, force = unit.force})
|
||||
spawner.destructible = false
|
||||
Task.set_timeout_in_ticks(100, immunity_spawner, {entity = spawner})
|
||||
|
||||
if boss then
|
||||
BiterHealthBooster.add_boss_unit(spawner, modified_boss_unit_health.current_value, 0.5)
|
||||
else
|
||||
BiterHealthBooster.add_unit(spawner, modified_unit_health.current_value)
|
||||
end
|
||||
generated_units.nests[#generated_units.nests + 1] = spawner
|
||||
unit.surface.create_entity({name = 'blood-explosion-huge', position = position})
|
||||
unit.surface.create_entity({name = 'blood-explosion-huge', position = unit.position})
|
||||
remove_unit(unit)
|
||||
unit.destroy()
|
||||
local threat = Public.get('threat')
|
||||
Public.set('threat', threat - Public.threat_values[name])
|
||||
return true
|
||||
end
|
||||
generated_units.nests[#generated_units.nests + 1] = spawner
|
||||
unit.surface.create_entity({name = 'blood-explosion-huge', position = position})
|
||||
unit.surface.create_entity({name = 'blood-explosion-huge', position = unit.position})
|
||||
remove_unit(unit)
|
||||
unit.destroy()
|
||||
local threat = Public.get('threat')
|
||||
Public.set('threat', threat - Public.threat_values[name])
|
||||
return true
|
||||
end
|
||||
|
||||
function Public.build_nest()
|
||||
@ -153,7 +241,7 @@ function Public.build_worm()
|
||||
end
|
||||
local worm_building_chance = Public.get('worm_building_chance') --[[@as integer]]
|
||||
|
||||
if math_random(1, worm_building_chance) ~= 1 then
|
||||
if random(1, worm_building_chance) ~= 1 then
|
||||
return
|
||||
end
|
||||
|
||||
@ -180,7 +268,7 @@ function Public.build_worm()
|
||||
if not group.members[1] then
|
||||
return
|
||||
end
|
||||
local unit = group.members[math_random(1, #group.members)]
|
||||
local unit = group.members[random(1, #group.members)]
|
||||
if not unit.valid then
|
||||
return
|
||||
end
|
||||
@ -232,14 +320,17 @@ end
|
||||
|
||||
local function shred_simple_entities(entity)
|
||||
local threat = Public.get('threat')
|
||||
if threat < 25000 then
|
||||
if threat < 5000 then
|
||||
return
|
||||
end
|
||||
local simple_entities =
|
||||
entity.surface.find_entities_filtered(
|
||||
{
|
||||
type = 'simple-entity',
|
||||
area = {{entity.position.x - 3, entity.position.y - 3}, {entity.position.x + 3, entity.position.y + 3}}
|
||||
area = {
|
||||
{entity.position.x - 3, entity.position.y - 3},
|
||||
{entity.position.x + 3, entity.position.y + 3}
|
||||
}
|
||||
}
|
||||
)
|
||||
if #simple_entities == 0 then
|
||||
@ -290,9 +381,21 @@ local function spawn_unit_spawner_inhabitants(entity)
|
||||
for _ = 1, count, 1 do
|
||||
local position = {entity.position.x + (-4 + math.random(0, 8)), entity.position.y + (-4 + math.random(0, 8))}
|
||||
if math.random(1, 4) == 1 then
|
||||
entity.surface.create_entity({name = Public.wave_defense_roll_spitter_name(), position = position, force = 'enemy'})
|
||||
entity.surface.create_entity(
|
||||
{
|
||||
name = Public.wave_defense_roll_spitter_name(),
|
||||
position = position,
|
||||
force = 'enemy'
|
||||
}
|
||||
)
|
||||
else
|
||||
entity.surface.create_entity({name = Public.wave_defense_roll_biter_name(), position = position, force = 'enemy'})
|
||||
entity.surface.create_entity(
|
||||
{
|
||||
name = Public.wave_defense_roll_biter_name(),
|
||||
position = position,
|
||||
force = 'enemy'
|
||||
}
|
||||
)
|
||||
end
|
||||
end
|
||||
end
|
||||
@ -306,14 +409,14 @@ local function on_entity_died(event)
|
||||
local disable_threat_below_zero = Public.get('disable_threat_below_zero')
|
||||
local valid_enemy_forces = Public.get('valid_enemy_forces')
|
||||
if not valid_enemy_forces then
|
||||
return
|
||||
goto continue
|
||||
end
|
||||
|
||||
local biter_health_boost = BiterHealthBooster.get('biter_health_boost')
|
||||
|
||||
if entity.type == 'unit' then
|
||||
if not Public.threat_values[entity.name] then
|
||||
return
|
||||
goto continue
|
||||
end
|
||||
if disable_threat_below_zero then
|
||||
local threat = Public.get('threat')
|
||||
@ -322,7 +425,7 @@ local function on_entity_died(event)
|
||||
if sub <= 0 or threat <= 0 then
|
||||
Public.set('threat', 0)
|
||||
remove_unit(entity)
|
||||
return
|
||||
goto continue
|
||||
end
|
||||
Public.set('threat', math.round(threat - Public.threat_values[entity.name] * biter_health_boost, 2))
|
||||
remove_unit(entity)
|
||||
@ -343,6 +446,8 @@ local function on_entity_died(event)
|
||||
end
|
||||
end
|
||||
|
||||
::continue::
|
||||
|
||||
if entity.force.index == 3 then
|
||||
if event.cause then
|
||||
if event.cause.valid then
|
||||
|
Loading…
Reference in New Issue
Block a user