diff --git a/modules/custom_death_messages.lua b/modules/custom_death_messages.lua index 93aa61f0..1b6ff530 100644 --- a/modules/custom_death_messages.lua +++ b/modules/custom_death_messages.lua @@ -48,7 +48,7 @@ local function on_player_died(event) return end - if cause.name == "tank" then + if cause.type == "car" then local driver = cause.get_driver() if driver.player then game.print(player.name .. tag .. " was killed by " .. driver.player.name .. " " .. player.tag .. ".", message_color) diff --git a/modules/towny/connected_building.lua b/modules/towny/connected_building.lua index fbc4c4af..9f33f7ee 100644 --- a/modules/towny/connected_building.lua +++ b/modules/towny/connected_building.lua @@ -1,6 +1,6 @@ local Public = {} -local connection_radius = 5 +local connection_radius = 7 local entity_type_whitelist = { ["accumulator"] = true, diff --git a/modules/towny/main.lua b/modules/towny/main.lua index fdd998bc..24a5cfe2 100644 --- a/modules/towny/main.lua +++ b/modules/towny/main.lua @@ -103,9 +103,28 @@ local function on_gui_click(event) Info.close(event) end +local function on_player_died(event) + local player = game.players[event.player_index] + if not player.character then return end + if not player.character.valid then return end + Team.reveal_entity_to_all(player.character) +end + +local minute_actions = { + [60 * 5] = Team.update_town_chart_tags, + [60 * 10] = Team.set_all_player_colors, +} + +local function on_nth_tick(event) + local tick = game.tick % 3600 + if not minute_actions[tick] then return end + minute_actions[tick]() +end + local function on_init() global.towny = {} global.towny.requests = {} + global.towny.request_cooldowns = {} global.towny.town_centers = {} global.towny.cooldowns = {} global.towny.size_of_town_centers = 0 @@ -126,6 +145,7 @@ end local Event = require 'utils.event' Event.on_init(on_init) +Event.on_nth_tick(60, on_nth_tick) Event.add(defines.events.on_gui_click, on_gui_click) Event.add(defines.events.on_console_command, on_console_command) Event.add(defines.events.on_player_joined_game, on_player_joined_game) @@ -138,4 +158,5 @@ Event.add(defines.events.on_player_repaired_entity, on_player_repaired_entity) Event.add(defines.events.on_player_dropped_item, on_player_dropped_item) Event.add(defines.events.on_player_used_capsule, on_player_used_capsule) Event.add(defines.events.on_market_item_purchased, on_market_item_purchased) -Event.add(defines.events.on_gui_opened, on_gui_opened) \ No newline at end of file +Event.add(defines.events.on_gui_opened, on_gui_opened) +Event.add(defines.events.on_player_died, on_player_died) \ No newline at end of file diff --git a/modules/towny/team.lua b/modules/towny/team.lua index 004ee43f..00bf2de0 100644 --- a/modules/towny/team.lua +++ b/modules/towny/team.lua @@ -35,6 +35,12 @@ function Public.set_town_color(event) end end +function Public.set_all_player_colors() + for _, p in pairs(game.connected_players) do + Public.set_player_color(p) + end +end + function Public.add_player_to_town(player, town_center) player.force = town_center.market.force game.permissions.get_group("Default").add_player(player) @@ -175,7 +181,52 @@ function Public.declare_war(player, item) requesting_force.set_friend(target_force, false) target_force.set_friend(requesting_force, false) - game.print(">> Town " .. requesting_force.name .. " has set " .. target_force.name .. " as their foe!", {255, 255, 0}) + + game.print(">> " .. player.name .. " has dropped the coal! Town " .. target_force.name .. " and " .. requesting_force.name .. " are now at war!", {255, 255, 0}) +end + +local radius = 48 +function Public.reveal_entity_to_all(entity) + local chart_area = {{entity.position.x - radius, entity.position.y - radius}, {entity.position.x + radius, entity.position.y + radius}} + local surface = entity.surface + for _, force in pairs(game.forces) do + force.chart(surface, chart_area) + end +end + +local function delete_chart_tag_for_all_forces(market) + local forces = game.forces + local position = market.position + local surface = market.surface + for _, force in pairs(forces) do + local tags = force.find_chart_tags(surface, {{position.x - 0.1, position.y - 0.1}, {position.x + 0.1, position.y + 0.1}}) + local tag = tags[1] + if tag then + if tag.icon.name == "stone-furnace" then + tag.destroy() + end + end + end +end + +local function add_chart_tag(force, market) + local position = market.position + local tags = force.find_chart_tags(market.surface, {{position.x - 0.1, position.y - 0.1}, {position.x + 0.1, position.y + 0.1}}) + if tags[1] then return end + force.add_chart_tag(market.surface, {icon = {type = 'item', name = 'stone-furnace'}, position = position, text = market.force.name .. "'s Town"}) +end + +function Public.update_town_chart_tags() + local town_centers = global.towny.town_centers + local forces = game.forces + for _, town_center in pairs(town_centers) do + local market = town_center.market + for _, force in pairs(forces) do + if force.is_chunk_visible(market.surface, town_center.chunk_position) then + add_chart_tag(force, market) + end + end + end end function Public.add_new_force(force_name) @@ -202,11 +253,15 @@ function Public.kill_force(force_name) end player.force = game.forces.player end - + for _, e in pairs(surface.find_entities_filtered({force = force_name})) do - if e.health then - if e.valid then - if e.health > 0 then e.active = false end + if e.valid then + if e.type == "wall" or e.type == "gate" then + e.die() + else + if e.health then + if e.health > 0 then e.active = false end + end end end end @@ -216,6 +271,9 @@ function Public.kill_force(force_name) global.towny.town_centers[force_name] = nil global.towny.size_of_town_centers = global.towny.size_of_town_centers - 1 + delete_chart_tag_for_all_forces(market) + Public.reveal_entity_to_all(market) + game.print(">> " .. force_name .. "'s town has fallen!", {255, 255, 0}) end diff --git a/modules/towny/town_center.lua b/modules/towny/town_center.lua index 75512ba1..0569499a 100644 --- a/modules/towny/town_center.lua +++ b/modules/towny/town_center.lua @@ -6,12 +6,12 @@ local table_insert = table.insert local min_distance_to_spawn = 96 local square_min_distance_to_spawn = min_distance_to_spawn ^ 2 -local town_radius = 30 +local town_radius = 28 local radius_between_towns = 160 local colors = {} local c1 = 250 -local c2 = 175 +local c2 = 200 local c3 = -25 for v = c1, c2, c3 do table.insert(colors, {0, 0, v}) @@ -149,7 +149,7 @@ local function draw_town_spawn(player_name) for _, vector in pairs(turret_vectors) do local p = {position.x + vector[1], position.y + vector[2]} - p = surface.find_non_colliding_position("gun-turret", p, 32, 1) + p = surface.find_non_colliding_position("gun-turret", p, 64, 1) if p then local turret = surface.create_entity({name = "gun-turret", position = p, force = player_name}) turret.insert({name = "firearm-magazine", count = 16}) @@ -162,7 +162,7 @@ local function draw_town_spawn(player_name) for i = 1, 4, 1 do for _, vector in pairs(resource_vectors[i]) do local p = {position.x + vector[1], position.y + vector[2]} - p = surface.find_non_colliding_position(ores[i], p, 32, 1) + p = surface.find_non_colliding_position(ores[i], p, 64, 1) if p then surface.create_entity({name = ores[i], position = p, amount = 1500}) end @@ -173,7 +173,7 @@ local function draw_town_spawn(player_name) local m1 = -8 + math_random(0, 16) local m2 = -8 + math_random(0, 16) local p = {position.x + m1, position.y + m2} - p = surface.find_non_colliding_position("wooden-chest", p, 32, 1) + p = surface.find_non_colliding_position("wooden-chest", p, 64, 1) if p then local e = surface.create_entity({name = "wooden-chest", position = p, force = player_name}) local inventory = e.get_inventory(defines.inventory.chest) @@ -188,7 +188,7 @@ local function draw_town_spawn(player_name) for _, vector in pairs(additional_resource_vectors[vector_indexes[1]]) do if math_random(1, 6) == 1 then local p = {position.x + vector[1], position.y + vector[2]} - p = surface.find_non_colliding_position(tree, p, 32, 1) + p = surface.find_non_colliding_position(tree, p, 64, 1) if p then surface.create_entity({name = tree, position = p}) end @@ -206,7 +206,7 @@ local function draw_town_spawn(player_name) end for _, vector in pairs(additional_resource_vectors[vector_indexes[3]]) do local p = {position.x + vector[1], position.y + vector[2]} - p = surface.find_non_colliding_position("uranium-ore", p, 32, 1) + p = surface.find_non_colliding_position("uranium-ore", p, 64, 1) if p then surface.create_entity({name = "uranium-ore", position = p, amount = 1500}) end @@ -215,7 +215,7 @@ local function draw_town_spawn(player_name) for _ = 1, 3, 1 do local vector = vectors[math_random(1, #vectors)] local p = {position.x + vector[1], position.y + vector[2]} - p = surface.find_non_colliding_position("crude-oil", p, 32, 1) + p = surface.find_non_colliding_position("crude-oil", p, 64, 1) if p then surface.create_entity({name = "crude-oil", position = p, amount = 500000}) end @@ -343,6 +343,7 @@ function Public.found(event) global.towny.town_centers[player_name] = {} local town_center = global.towny.town_centers[player_name] town_center.market = surface.create_entity({name = "market", position = entity.position, force = player_name}) + town_center.chunk_position = {math.floor(town_center.market.position.x / 32), math.floor(town_center.market.position.y / 32)} town_center.max_health = 1000 town_center.health = town_center.max_health town_center.color = colors[math_random(1, #colors)]