1
0
mirror of https://github.com/ComfyFactory/ComfyFactorio.git synced 2025-01-10 00:43:27 +02:00
ComfyFactorio/maps/mountain_fortress_v3/buried_enemies.lua

249 lines
6.4 KiB
Lua
Raw Normal View History

2020-11-17 13:45:27 +02:00
local Event = require 'utils.event'
local Global = require 'utils.global'
2021-02-10 22:21:19 +02:00
local BiterHealthBooster = require 'modules.biter_health_booster_v2'
2020-11-17 13:45:27 +02:00
local WD = require 'modules.wave_defense.table'
local WPT = require 'maps.mountain_fortress_v3.table'
local this = {}
2020-11-17 13:45:27 +02:00
Global.register(
this,
2020-11-17 13:45:27 +02:00
function(t)
this = t
2020-11-17 13:45:27 +02:00
end
)
local Public = {}
2022-06-10 22:06:35 +02:00
local round = math.round
2020-11-17 13:45:27 +02:00
local floor = math.floor
local random = math.random
local abs = math.abs
local sqrt = math.sqrt
local spawn_amount_rolls = {}
for a = 48, 1, -1 do
spawn_amount_rolls[#spawn_amount_rolls + 1] = floor(a ^ 5)
end
local random_particles = {
'dirt-2-stone-particle-medium',
'dirt-4-dust-particle',
'coal-particle'
}
local s_random_particles = #random_particles
local function create_particles(data)
local surface = data.surface
local position = data.position
local amount = data.amount
if not surface or not surface.valid then
return
end
2022-04-18 01:17:26 +02:00
for _ = 1, amount, 1 do
2020-11-17 13:45:27 +02:00
local m = random(6, 12)
local m2 = m * 0.005
surface.create_particle(
{
name = random_particles[random(1, s_random_particles)],
position = position,
frame_speed = 0.1,
vertical_speed = 0.1,
height = 0.1,
movement = {m2 - (random(0, m) * 0.01), m2 - (random(0, m) * 0.01)}
}
)
end
end
local function spawn_biters(data)
local surface = data.surface
2020-11-23 23:10:45 +02:00
if not (surface and surface.valid) then
return false
2020-11-23 23:10:45 +02:00
end
2020-11-17 13:45:27 +02:00
local position = data.position
local h = floor(abs(position.y))
2020-11-17 13:45:27 +02:00
local max_biters = WPT.get('biters')
if max_biters.amount >= max_biters.limit then
return false
2020-11-17 13:45:27 +02:00
end
if not position then
position = surface.find_non_colliding_position('small-biter', position, 10, 1)
if not position then
return false
2020-11-17 13:45:27 +02:00
end
end
local unit_to_create
2022-06-10 22:06:35 +02:00
WD.wave_defense_set_unit_raffle(h * 0.20)
2020-11-17 13:45:27 +02:00
if random(1, 3) == 1 then
unit_to_create = WD.wave_defense_roll_spitter_name()
2020-11-17 13:45:27 +02:00
else
unit_to_create = WD.wave_defense_roll_biter_name()
2020-11-17 13:45:27 +02:00
end
2022-06-10 22:06:35 +02:00
if not unit_to_create then
print('buried_enemies - unit_to_create was nil?')
return
end
local modified_unit_health = WD.get('modified_unit_health')
local modified_boss_unit_health = WD.get('modified_boss_unit_health')
2022-06-10 22:06:35 +02:00
local unit_settings = WD.get('unit_settings')
local unit = surface.create_entity({name = unit_to_create, position = position})
max_biters.amount = max_biters.amount + 1
if random(1, 30) == 1 then
BiterHealthBooster.add_boss_unit(unit, modified_boss_unit_health.current_value, 0.38)
else
2022-06-10 22:06:35 +02:00
local final_health = round(modified_unit_health.current_value * unit_settings.scale_units_by_health[unit.name], 3)
if final_health < 1 then
final_health = 1
end
BiterHealthBooster.add_unit(unit, final_health)
2020-11-17 13:45:27 +02:00
end
return true
2020-11-17 13:45:27 +02:00
end
local function spawn_worms(data)
local modified_unit_health = WD.get('modified_unit_health')
local modified_boss_unit_health = WD.get('modified_boss_unit_health')
2020-11-17 13:45:27 +02:00
local max_biters = WPT.get('biters')
if max_biters.amount >= max_biters.limit then
return
end
local unit_to_create = WD.wave_defense_roll_worm_name()
2020-11-17 13:45:27 +02:00
local surface = data.surface
2020-11-23 23:10:45 +02:00
if not (surface and surface.valid) then
return
end
2020-11-17 13:45:27 +02:00
local position = data.position
WD.wave_defense_set_worm_raffle(sqrt(position.x ^ 2 + position.y ^ 2) * 0.20)
local unit = surface.create_entity({name = unit_to_create, position = position})
2020-11-17 13:45:27 +02:00
max_biters.amount = max_biters.amount + 1
2022-06-10 22:06:35 +02:00
local worm_unit_settings = WD.get('worm_unit_settings')
if random(1, 30) == 1 then
BiterHealthBooster.add_boss_unit(unit, modified_boss_unit_health.current_value, 0.38)
else
2022-06-10 22:06:35 +02:00
local final_health = round(modified_unit_health.current_value * worm_unit_settings.scale_units_by_health[unit.name], 3)
if final_health < 1 then
final_health = 1
end
BiterHealthBooster.add_unit(unit, final_health)
end
2020-11-17 13:45:27 +02:00
end
2021-05-16 13:48:50 +02:00
function Public.buried_biter(surface, position)
2020-11-23 23:10:45 +02:00
if not (surface and surface.valid) then
2020-11-17 13:45:27 +02:00
return
end
if not position then
return
end
if not position.x then
return
end
if not position.y then
return
end
2021-05-16 13:48:50 +02:00
for t = 1, 60, 1 do
if not this[game.tick + t] then
this[game.tick + t] = {}
2020-11-17 13:45:27 +02:00
end
this[game.tick + t][#this[game.tick + t] + 1] = {
2020-11-17 13:45:27 +02:00
callback = 'create_particles',
2021-05-16 13:48:50 +02:00
data = {surface = surface, position = {x = position.x, y = position.y}, amount = math.ceil(t * 0.05)}
2020-11-17 13:45:27 +02:00
}
2021-05-16 13:48:50 +02:00
if t == 60 then
this[game.tick + t][#this[game.tick + t] + 1] = {
2021-05-16 13:48:50 +02:00
callback = 'spawn_biters',
data = {surface = surface, position = {x = position.x, y = position.y}}
}
2020-11-17 13:45:27 +02:00
end
end
end
function Public.buried_worm(surface, position)
2020-11-23 23:10:45 +02:00
if not (surface and surface.valid) then
2020-11-17 13:45:27 +02:00
return
end
if not position then
return
end
if not position.x then
return
end
if not position.y then
return
end
2021-05-16 13:48:50 +02:00
for t = 1, 60, 1 do
if not this[game.tick + t] then
this[game.tick + t] = {}
2020-11-17 13:45:27 +02:00
end
this[game.tick + t][#this[game.tick + t] + 1] = {
2020-11-17 13:45:27 +02:00
callback = 'create_particles',
2021-05-16 13:48:50 +02:00
data = {surface = surface, position = {x = position.x, y = position.y}, amount = math.ceil(t * 0.05)}
2020-11-17 13:45:27 +02:00
}
2021-05-16 13:48:50 +02:00
if t == 60 then
this[game.tick + t][#this[game.tick + t] + 1] = {
2020-11-17 13:45:27 +02:00
callback = 'spawn_worms',
data = {surface = surface, position = {x = position.x, y = position.y}}
}
end
end
end
local callbacks = {
['create_particles'] = create_particles,
['spawn_biters'] = spawn_biters,
['spawn_worms'] = spawn_worms
}
local function on_tick()
local t = game.tick
if not this[t] then
2020-11-17 13:45:27 +02:00
return
end
for _, token in pairs(this[t]) do
2020-11-17 13:45:27 +02:00
local callback = token.callback
local data = token.data
local cbl = callbacks[callback]
if callbacks[callback] then
cbl(data)
end
end
this[t] = nil
2020-11-17 13:45:27 +02:00
end
2020-11-23 23:10:45 +02:00
function Public.reset()
for k, _ in pairs(this) do
this[k] = nil
2020-11-23 23:10:45 +02:00
end
end
2020-11-17 13:45:27 +02:00
Event.add(defines.events.on_tick, on_tick)
return Public