1
0
mirror of https://github.com/ComfyFactory/ComfyFactorio.git synced 2025-01-24 03:47:58 +02:00

515 lines
18 KiB
Lua
Raw Normal View History

2019-04-28 19:38:44 +02:00
local event = require 'utils.event'
2019-03-13 20:22:21 +01:00
local math_random = math.random
local simplex_noise = require 'utils.simplex_noise'.d2
2019-03-14 18:06:39 +01:00
local create_tile_chain = require "functions.create_tile_chain"
2019-09-08 03:54:02 +02:00
local spawn_circle_size = bb_config.border_river_width
2019-03-15 01:39:49 +01:00
local ores = {"copper-ore", "iron-ore", "stone", "coal"}
2019-07-14 21:37:12 +02:00
2019-03-16 20:25:21 +01:00
local function shuffle(tbl)
local size = #tbl
for i = size, 1, -1 do
local rand = math_random(size)
tbl[i], tbl[rand] = tbl[rand], tbl[i]
end
return tbl
end
2019-03-24 05:21:55 +01:00
local function get_noise(name, pos)
2019-03-13 20:22:21 +01:00
local seed = game.surfaces[1].map_gen_settings.seed
local noise_seed_add = 25000
if name == 1 then
local noise = {}
2019-03-18 23:53:27 +01:00
noise[1] = simplex_noise(pos.x * 0.0042, pos.y * 0.0042, seed)
2019-03-13 20:22:21 +01:00
seed = seed + noise_seed_add
2019-03-18 23:53:27 +01:00
noise[2] = simplex_noise(pos.x * 0.031, pos.y * 0.031, seed)
2019-07-23 17:15:32 +02:00
seed = seed + noise_seed_add
noise[3] = simplex_noise(pos.x * 0.1, pos.y * 0.1, seed)
local noise = noise[1] + noise[2] * 0.08 + noise[3] * 0.015
2019-03-13 20:22:21 +01:00
return noise
2019-03-17 21:39:05 +01:00
end
if name == 2 then
local noise = {}
2019-03-18 04:47:27 +01:00
noise[1] = simplex_noise(pos.x * 0.011, pos.y * 0.011, seed)
2019-03-17 21:39:05 +01:00
seed = seed + noise_seed_add
2019-03-18 14:23:12 +01:00
noise[2] = simplex_noise(pos.x * 0.08, pos.y * 0.08, seed)
2019-03-18 04:47:27 +01:00
local noise = noise[1] + noise[2] * 0.2
2019-03-17 21:39:05 +01:00
return noise
end
2019-03-18 14:23:12 +01:00
if name == 3 then
local noise = {}
noise[1] = simplex_noise(pos.x * 0.02, pos.y * 0.02, seed)
seed = seed + noise_seed_add
noise[2] = simplex_noise(pos.x * 0.08, pos.y * 0.08, seed)
local noise = noise[1] + noise[2] * 0.1
return noise
end
2019-03-13 20:22:21 +01:00
end
2019-09-14 03:00:43 +02:00
local function get_replacement_tile(surface, position)
for i = 1, 128, 1 do
local vectors = {{0, i}, {0, i * -1}, {i, 0}, {i * -1, 0}}
table.shuffle_table(vectors)
for k, v in pairs(vectors) do
local tile = surface.get_tile(position.x + v[1], position.y + v[2])
if not tile.collides_with("resource-layer") then
if tile.name ~= "stone-path" then
return tile.name
end
end
end
end
return "grass-1"
end
local function get_chunk_position(position)
local chunk_position = {}
position.x = math.floor(position.x, 0)
position.y = math.floor(position.y, 0)
for x = 0, 31, 1 do
if (position.x - x) % 32 == 0 then chunk_position.x = (position.x - x) / 32 end
end
for y = 0, 31, 1 do
if (position.y - y) % 32 == 0 then chunk_position.y = (position.y - y) / 32 end
end
return chunk_position
end
local function regenerate_decoratives(surface, position)
local chunk = get_chunk_position(position)
if not chunk then return end
surface.destroy_decoratives({area = {{chunk.x * 32, chunk.y * 32}, {chunk.x * 32 + 32, chunk.y * 32 + 32}}})
local decorative_names = {}
for k,v in pairs(game.decorative_prototypes) do
if v.autoplace_specification then
decorative_names[#decorative_names+1] = k
end
end
surface.regenerate_decorative(decorative_names, {chunk})
end
2019-03-21 10:06:12 +01:00
local function draw_noise_ore_patch(position, name, surface, radius, richness)
2019-03-16 20:25:21 +01:00
if not position then return end
if not name then return end
if not surface then return end
if not radius then return end
if not richness then return end
local math_random = math.random
local noise_seed_add = 25000
local richness_part = richness / radius
2019-03-21 10:06:12 +01:00
for y = radius * -3, radius * 3, 1 do
for x = radius * -3, radius * 3, 1 do
2019-03-16 20:25:21 +01:00
local pos = {x = x + position.x, y = y + position.y}
local seed = game.surfaces[1].map_gen_settings.seed
2019-03-21 10:06:12 +01:00
local noise_1 = simplex_noise(pos.x * 0.0125, pos.y * 0.0125, seed)
2019-03-16 20:25:21 +01:00
seed = seed + noise_seed_add
2019-03-21 10:06:12 +01:00
local noise_2 = simplex_noise(pos.x * 0.1, pos.y * 0.1, seed)
local noise = noise_1 + noise_2 * 0.12
2019-03-16 20:25:21 +01:00
local distance_to_center = math.sqrt(x^2 + y^2)
local a = richness - richness_part * distance_to_center
2019-03-21 10:06:12 +01:00
if distance_to_center < radius - math.abs(noise * radius * 0.85) and a > 1 then
2019-03-16 20:25:21 +01:00
if surface.can_place_entity({name = name, position = pos, amount = a}) then
2019-03-21 10:06:12 +01:00
surface.create_entity{name = name, position = pos, amount = a}
local mirror_pos = {x = pos.x * -1, y = pos.y * -1}
surface.create_entity{name = name, position = mirror_pos, amount = a}
2019-03-16 20:25:21 +01:00
end
end
end
end
end
2019-09-08 03:54:02 +02:00
function is_within_spawn_circle(pos)
if math.abs(pos.x) > spawn_circle_size then return false end
if math.abs(pos.y) > spawn_circle_size then return false end
if math.sqrt(pos.x ^ 2 + pos.y ^ 2) > spawn_circle_size then return false end
return true
end
function is_horizontal_border_river(pos)
2019-03-19 04:05:32 +01:00
if pos.y > -5 and pos.x > -5 and pos.x < 5 then return false end
if math.floor(bb_config.border_river_width * -0.5) < pos.y + (get_noise(1, pos) * 5) then return true end
2019-03-14 01:00:20 +01:00
return false
2019-03-13 21:39:46 +01:00
end
2019-03-14 18:06:39 +01:00
local function generate_circle_spawn(event)
2019-09-14 03:00:43 +02:00
if global.bb_circle_spawn_generated then return end
2019-07-13 15:21:12 +02:00
2019-09-14 03:00:43 +02:00
local surface = event.surface
if surface.is_chunk_generated({6, 6}) then global.bb_circle_spawn_generated = true end
2019-03-14 18:06:39 +01:00
local left_top_x = event.area.left_top.x
local left_top_y = event.area.left_top.y
2019-09-14 03:00:43 +02:00
local r = 101
2019-03-14 18:06:39 +01:00
for x = 0, 31, 1 do
for y = 0, 31, 1 do
local pos = {x = left_top_x + x, y = left_top_y + y}
local distance_to_center = math.sqrt(pos.x ^ 2 + pos.y ^ 2)
2019-07-26 21:47:59 +02:00
local noise = get_noise(2, pos) * 15
2019-03-14 18:06:39 +01:00
local tile = false
2019-03-15 03:59:43 +01:00
if distance_to_center < spawn_circle_size then
tile = "deepwater"
if math_random(1, 48) == 1 then surface.create_entity({name = "fish", position = pos}) end
end
2019-03-17 18:19:40 +01:00
if distance_to_center < 9.5 then tile = "refined-concrete" end
2019-07-26 21:47:59 +02:00
if distance_to_center < 7 then tile = "sand-1" end
2019-09-14 03:00:43 +02:00
if distance_to_center + noise < r - 10 and distance_to_center > spawn_circle_size and not is_horizontal_border_river(pos) then
2019-07-26 21:47:59 +02:00
local tile_name = surface.get_tile(pos).name
if tile_name == "water" or tile_name == "deepwater" then
2019-09-14 03:00:43 +02:00
surface.set_tiles({{name = get_replacement_tile(surface, pos), position = pos}}, true)
--surface.set_tiles({{name = "stone-path", position = pos}}, true)
2019-07-26 21:47:59 +02:00
--if math_random(1,256) == 1 then
-- local wrecks = {"big-ship-wreck-1", "big-ship-wreck-2", "big-ship-wreck-3"}
-- surface.create_entity({name = wrecks[math_random(1, #wrecks)], position = pos, force = "north"})
--end
2019-09-14 03:00:43 +02:00
--if bb_config.random_scrap and math_random(1,64) == 1 then
-- surface.create_entity({name = "mineable-wreckage", position = pos})
--end
2019-07-26 21:47:59 +02:00
end
end
2019-09-09 22:41:25 +02:00
2019-03-14 18:06:39 +01:00
if tile then surface.set_tiles({{name = tile, position = pos}}, true) end
2019-03-17 21:39:05 +01:00
2019-07-26 21:47:59 +02:00
if surface.can_place_entity({name = "coal", position = pos}) then
2019-07-23 17:15:32 +02:00
2019-03-19 04:05:32 +01:00
if distance_to_center + noise < r and distance_to_center + noise > r - 1.75 then
2019-03-17 21:39:05 +01:00
surface.create_entity({name = "stone-wall", position = pos, force = "north"})
end
2019-07-23 17:15:32 +02:00
2019-03-17 21:39:05 +01:00
if distance_to_center + noise < r - 4 and distance_to_center + noise > r - 6 then
2019-09-14 03:00:43 +02:00
if math_random(1,56) == 1 then
2019-03-17 21:39:05 +01:00
if surface.can_place_entity({name = "gun-turret", position = pos}) then
2019-03-19 04:05:32 +01:00
local t = surface.create_entity({name = "gun-turret", position = pos, force = "north"})
2019-07-14 21:37:12 +02:00
t.insert({name = "firearm-magazine", count = math_random(6,12)})
2019-03-17 21:39:05 +01:00
end
end
end
2019-07-23 17:15:32 +02:00
2019-09-14 03:00:43 +02:00
--if distance_to_center + noise < r - 3 and distance_to_center + noise > r - 7 then
--if math_random(1,3) ~= 1 then
--surface.set_tiles({{name = "stone-path", position = pos}}, true)
--end
--end
2019-07-23 17:15:32 +02:00
2019-09-14 03:00:43 +02:00
--if distance_to_center + noise < r - 3 and distance_to_center + noise > r - 20 then
--if math_random(1, 256) == 1 then
--if surface.can_place_entity({name = "mineable-wreckage", position = pos}) then
--surface.create_entity({name = "mineable-wreckage", position = pos, force = "neutral"})
--end
--end
--end
2019-07-23 17:15:32 +02:00
end
2019-03-14 18:06:39 +01:00
end
end
2019-09-14 03:00:43 +02:00
regenerate_decoratives(surface, event.area.left_top)
2019-03-14 01:00:20 +01:00
end
2019-03-14 18:06:39 +01:00
local function generate_silos(event)
2019-09-14 03:00:43 +02:00
if global.bb_silos_generated then return end
if event.area.left_top.x ~= -128 then return end
if event.area.left_top.y ~= -128 then return end
global.bb_silos_generated = true
2019-03-21 10:06:12 +01:00
2019-09-14 03:00:43 +02:00
local surface = event.surface
local pos = surface.find_non_colliding_position("rocket-silo", {x = -16 + math.random(0, 24), y = -64 + math.random(0, 16)}, 20, 1)
if not pos then pos = {0,-64} end
2019-03-21 10:06:12 +01:00
global.rocket_silo["north"] = surface.create_entity({
name = "rocket-silo",
position = pos,
force = "north"
})
global.rocket_silo["north"].minable = false
for i = 1, 32, 1 do
create_tile_chain(surface, {name = "stone-path", position = global.rocket_silo["north"].position}, 32, 10)
2019-03-19 04:05:32 +01:00
end
2019-03-13 21:39:46 +01:00
end
2019-03-14 22:50:09 +01:00
local function generate_river(event)
2019-09-14 03:00:43 +02:00
if event.area.left_top.y < -32 then return end
2019-03-13 20:22:21 +01:00
local surface = event.surface
local left_top_x = event.area.left_top.x
local left_top_y = event.area.left_top.y
2019-03-13 21:39:46 +01:00
for x = 0, 31, 1 do
for y = 0, 31, 1 do
2019-03-13 20:22:21 +01:00
local pos = {x = left_top_x + x, y = left_top_y + y}
local distance_to_center = math.sqrt(pos.x ^ 2 + pos.y ^ 2)
2019-09-08 03:54:02 +02:00
if is_horizontal_border_river(pos) then
2019-03-15 03:59:43 +01:00
surface.set_tiles({{name = "deepwater", position = pos}})
2019-03-17 02:35:58 +01:00
if math_random(1, 64) == 1 then surface.create_entity({name = "fish", position = pos}) end
2019-03-15 03:59:43 +01:00
end
2019-03-13 20:22:21 +01:00
end
end
2019-03-14 22:50:09 +01:00
end
2019-03-17 02:35:58 +01:00
local function rainbow_ore_and_ponds(event)
2019-03-15 01:39:49 +01:00
local surface = event.surface
local left_top_x = event.area.left_top.x
local left_top_y = event.area.left_top.y
for x = 0, 31, 1 do
for y = 0, 31, 1 do
local pos = {x = left_top_x + x, y = left_top_y + y}
if surface.can_place_entity({name = "iron-ore", position = pos}) then
local noise = get_noise(1, pos)
2019-07-23 17:15:32 +02:00
if noise > 0.85 then
2019-07-18 15:58:37 +02:00
local amount = math_random(750, 1500) + math.sqrt(pos.x ^ 2 + pos.y ^ 2) * 1.1
2019-03-27 03:58:22 +01:00
local m = (noise - 0.82) * 40
2019-03-24 05:21:55 +01:00
amount = amount * m
2019-07-23 17:15:32 +02:00
local i = math.ceil(math.abs(noise * 75)) % 4
2019-03-15 01:39:49 +01:00
if i == 0 then i = 4 end
2019-03-24 05:21:55 +01:00
surface.create_entity({name = ores[i], position = pos, amount = amount})
2019-03-15 01:39:49 +01:00
end
2019-09-09 22:41:25 +02:00
--if noise < -0.79 then
-- if noise < -0.85 then
-- surface.set_tiles({{name = "deepwater", position = pos}})
-- else
-- surface.set_tiles({{name = "water", position = pos}})
-- end
-- if math_random(1, 48) == 1 then surface.create_entity({name = "fish", position = pos}) end
--end
2019-03-15 01:39:49 +01:00
end
end
end
end
2019-09-14 03:00:43 +02:00
local function generate_potential_spawn_ore(surface)
2019-03-21 10:06:12 +01:00
local r = 130
local area = {{r * -1, r * -1}, {r, 0}}
local ores = {}
ores["iron-ore"] = surface.count_entities_filtered({name = "iron-ore", area = area})
ores["copper-ore"] = surface.count_entities_filtered({name = "copper-ore", area = area})
ores["coal"] = surface.count_entities_filtered({name = "coal", area = area})
ores["stone"] = surface.count_entities_filtered({name = "stone", area = area})
for ore, ore_count in pairs(ores) do
2019-03-22 19:42:59 +01:00
if ore_count < 750 or ore_count == nil then
2019-03-21 10:06:12 +01:00
local pos = {}
for a = 1, 32, 1 do
pos = {x = -96 + math_random(0, 192), y = -20 - math_random(0, 96)}
if surface.can_place_entity({name = "coal", position = pos, amount = 1}) then
break
end
end
2019-09-14 03:00:43 +02:00
draw_noise_ore_patch(pos, ore, surface, math_random(18, 28), math_random(1000, 2000))
2019-03-16 20:25:21 +01:00
end
end
end
2019-07-14 21:37:12 +02:00
local worm_turrets = {
[1] = "small-worm-turret",
[2] = "medium-worm-turret",
[3] = "big-worm-turret",
[4] = "behemoth-worm-turret"
}
local worm_tile_coords = {}
for x = 0, 31, 1 do
for y = 0, 31, 1 do
worm_tile_coords[#worm_tile_coords + 1] = {x, y}
end
end
local function generate_extra_worm_turrets(event)
local surface = event.surface
local left_top = event.area.left_top
local chunk_distance_to_center = math.sqrt(left_top.x ^ 2 + left_top.y ^ 2)
2019-07-23 17:15:32 +02:00
if bb_config.bitera_area_distance > chunk_distance_to_center then return end
2019-07-14 21:37:12 +02:00
2019-07-23 17:15:32 +02:00
local highest_worm_tier = math.floor((chunk_distance_to_center - bb_config.bitera_area_distance) * 0.002) + 1
2019-07-14 21:37:12 +02:00
if highest_worm_tier > 4 then highest_worm_tier = 4 end
2019-07-23 17:15:32 +02:00
local average_worm_amount_per_chunk = 0.65
2019-07-14 21:37:12 +02:00
local worm_amount = math_random(math.floor(average_worm_amount_per_chunk * 0.5), math.ceil(average_worm_amount_per_chunk * 1.5))
for a = 1, worm_amount, 1 do
local coord_modifier = worm_tile_coords[math_random(1, #worm_tile_coords)]
local pos = {left_top.x + coord_modifier[1], left_top.y + coord_modifier[2]}
local name = worm_turrets[math_random(1, highest_worm_tier)]
local position = surface.find_non_colliding_position("big-worm-turret", pos, 8, 1)
if position then
surface.create_entity({name = name, position = position, force = "north_biters"})
end
end
end
local scrap_vectors = {}
for x = -5, 5, 1 do
for y = -5, 5, 1 do
if math.sqrt(x^2 + y^2) <= 5 then
scrap_vectors[#scrap_vectors + 1] = {x, y}
end
end
end
local function generate_scrap(event)
local distance_to_center = math.sqrt(event.area.left_top.x ^ 2 + event.area.left_top.y ^ 2)
local worms = event.surface.find_entities_filtered({area = event.area, type = "turret"})
if #worms == 0 then return end
for _, e in pairs(worms) do
if math_random(1,2) == 1 then
2019-07-14 21:37:12 +02:00
for c = 1, math_random(2,12), 1 do
local vector = scrap_vectors[math_random(1, #scrap_vectors)]
local position = {e.position.x + vector[1], e.position.y + vector[2]}
if e.surface.can_place_entity({name = "mineable-wreckage", position = position, force = "neutral"}) then
e.surface.create_entity({name = "mineable-wreckage", position = position, force = "neutral"})
end
end
2019-07-18 15:41:17 +02:00
end
end
end
2019-07-23 17:15:32 +02:00
local function is_biter_area(position)
--if position.x + position.y > -352 + (get_noise(3, position) * 16) then return false end
if position.y + (get_noise(3, position) * 16) > (bb_config.bitera_area_distance * -1) - (math.abs(position.x) * 0.33) then return false end
return true
end
2019-07-18 15:41:17 +02:00
local function builders_area_process_entity(e)
2019-07-23 17:15:32 +02:00
if is_biter_area(e.position) then
2019-07-18 15:41:17 +02:00
if e.type == "resource" then
e.destroy()
return
end
if e.type == "turret" then
e.destroy()
return
end
if e.type == "cliff" then
e.destroy()
return
end
if e.type == "tree" then
2019-07-23 17:15:32 +02:00
if math_random(1, 32) == 1 then e.surface.create_entity({name = "rock-big", position = e.position, force = "neutral"}) end
2019-07-18 15:41:17 +02:00
e.destroy()
return
end
2019-07-23 17:15:32 +02:00
else
if e.type == "turret" or e.type == "unit-spawner" then
e.destroy()
return
end
end
end
2019-07-18 15:41:17 +02:00
local function builders_area_process_tile(t, surface)
2019-09-08 03:54:02 +02:00
if is_horizontal_border_river(t.position) then return end
2019-07-23 17:15:32 +02:00
if not is_biter_area(t.position) then return end
2019-07-18 15:41:17 +02:00
local noise_index = math.floor(math.abs(get_noise(3, t.position)) * 7) + 1
if noise_index > 7 then noise_index = 7 end
surface.set_tiles({{name = "dirt-" .. noise_index, position = t.position}})
2019-07-23 17:15:32 +02:00
2019-07-29 15:24:02 +02:00
if math_random(1, 160) == 1 then
2019-07-23 17:15:32 +02:00
if t.position.x ^ 2 + t.position.y ^ 2 < 129600 then return end
2019-07-18 15:58:37 +02:00
local spawner_position = surface.find_non_colliding_position("biter-spawner", t.position, 8, 1)
if spawner_position then
if math_random(1, 4) == 1 then
surface.create_entity({name = "spitter-spawner", position = spawner_position, force = "north_biters"})
else
surface.create_entity({name = "biter-spawner", position = spawner_position, force = "north_biters"})
end
end
end
2019-07-18 15:41:17 +02:00
end
2019-03-14 22:50:09 +01:00
local function on_chunk_generated(event)
if event.area.left_top.y >= 0 then return end
local surface = event.surface
if surface.name ~= "biter_battles" then return end
2019-07-13 19:12:18 +02:00
for _, e in pairs(surface.find_entities_filtered({area = event.area, force = "enemy"})) do
surface.create_entity({name = e.name, position = e.position, force = "north_biters", direction = e.direction})
2019-03-14 22:50:09 +01:00
e.destroy()
end
2019-03-13 20:22:21 +01:00
2019-03-17 02:35:58 +01:00
rainbow_ore_and_ponds(event)
2019-03-14 22:50:09 +01:00
generate_river(event)
2019-03-17 02:35:58 +01:00
generate_circle_spawn(event)
generate_silos(event)
2019-03-14 18:06:39 +01:00
2019-07-18 15:41:17 +02:00
if bb_config.builders_area then
for _, t in pairs(surface.find_tiles_filtered({area = event.area, name = {"water", "deepwater"}})) do
builders_area_process_tile(t, surface)
2019-07-13 15:21:12 +02:00
end
2019-07-18 15:41:17 +02:00
for _, e in pairs(surface.find_entities_filtered({area = event.area})) do
builders_area_process_entity(e)
end
2019-07-13 15:21:12 +02:00
end
2019-07-14 21:37:12 +02:00
generate_extra_worm_turrets(event)
2019-07-13 19:12:18 +02:00
if bb_config.random_scrap then
generate_scrap(event)
2019-07-13 19:12:18 +02:00
end
2019-03-21 10:06:12 +01:00
if event.area.left_top.y == -320 and event.area.left_top.x == -320 then
2019-09-14 03:00:43 +02:00
generate_potential_spawn_ore(surface)
2019-03-15 21:50:49 +01:00
local area = {{-10,-10},{10,10}}
for _, e in pairs(surface.find_entities_filtered({area = area})) do
if e.name ~= "character" then e.destroy() end
2019-03-14 22:50:09 +01:00
end
2019-03-15 21:50:49 +01:00
surface.destroy_decoratives({area = area})
2019-03-21 10:06:12 +01:00
for _, silo in pairs(global.rocket_silo) do
for _, entity in pairs(surface.find_entities({{silo.position.x - 4, silo.position.y - 4}, {silo.position.x + 4, silo.position.y + 4}})) do
if entity.type == "simple-entity" or entity.type == "tree" or entity.type == "resource" then
entity.destroy()
end
end
end
2019-03-14 01:00:20 +01:00
end
end
--Landfill Restriction
local function restrict_landfill(surface, inventory, tiles)
for _, t in pairs(tiles) do
2019-03-14 01:00:20 +01:00
local distance_to_center = math.sqrt(t.position.x ^ 2 + t.position.y ^ 2)
local check_position = t.position
if check_position.y > 0 then check_position = {x = check_position.x * -1, y = (check_position.y * -1) - 1} end
2019-09-08 03:54:02 +02:00
if is_horizontal_border_river(check_position) or distance_to_center < spawn_circle_size then
surface.set_tiles({{name = t.old_tile.name, position = t.position}}, true)
inventory.insert({name = "landfill", count = 1})
2019-03-14 01:00:20 +01:00
end
end
end
local function on_player_built_tile(event)
local player = game.players[event.player_index]
restrict_landfill(player.surface, player, event.tiles)
2019-03-14 01:00:20 +01:00
end
local function on_robot_built_tile(event)
restrict_landfill(event.robot.surface, event.robot.get_inventory(defines.inventory.robot_cargo), event.tiles)
2019-03-13 20:22:21 +01:00
end
--Construction Robot Restriction
local robot_build_restriction = {
["north"] = function(y)
if y >= -10 then return true end
end,
["south"] = function(y)
if y <= 10 then return true end
end
}
local function on_robot_built_entity(event)
if not robot_build_restriction[event.robot.force.name] then return end
if not robot_build_restriction[event.robot.force.name](event.created_entity.position.y) then return end
local inventory = event.robot.get_inventory(defines.inventory.robot_cargo)
inventory.insert({name = event.created_entity.name, count = 1})
event.robot.surface.create_entity({name = "explosion", position = event.created_entity.position})
game.print("Team " .. event.robot.force.name .. "'s construction drone had an accident.", {r = 200, g = 50, b = 100})
event.created_entity.destroy()
end
local function on_marked_for_deconstruction(event)
2019-03-19 22:48:29 +01:00
if not event.entity.valid then return end
if event.entity.name == "fish" then event.entity.cancel_deconstruction(game.players[event.player_index].force.name) end
end
event.add(defines.events.on_marked_for_deconstruction, on_marked_for_deconstruction)
2019-03-14 18:06:39 +01:00
event.add(defines.events.on_entity_damaged, on_entity_damaged)
event.add(defines.events.on_robot_built_entity, on_robot_built_entity)
2019-03-14 01:00:20 +01:00
event.add(defines.events.on_robot_built_tile, on_robot_built_tile)
event.add(defines.events.on_player_built_tile, on_player_built_tile)
event.add(defines.events.on_chunk_generated, on_chunk_generated)