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

504 lines
17 KiB
Lua
Raw Normal View History

local Event = require 'utils.event'
local Public = require 'maps.mountain_fortress_v3.table'
2020-05-23 21:18:18 +02:00
local Collapse = require 'modules.collapse'
2021-05-25 22:19:20 +02:00
local RPG = require 'modules.rpg.main'
local WD = require 'modules.wave_defense.table'
2020-06-07 13:33:24 +02:00
local Alert = require 'utils.alert'
local Task = require 'utils.task_token'
local Color = require 'utils.color_presets'
2023-11-05 16:34:23 +01:00
local ICF = require 'maps.mountain_fortress_v3.ic.functions'
local Session = require 'utils.datastore.session_data'
2020-05-23 21:18:18 +02:00
local floor = math.floor
2020-12-05 18:09:09 +01:00
local abs = math.abs
2020-08-14 17:16:04 +02:00
local random = math.random
local sub = string.sub
2020-05-23 21:18:18 +02:00
local sqrt = math.sqrt
local zone_settings = Public.zone_settings
2020-11-17 12:45:27 +01:00
2024-07-02 19:01:41 +02:00
local clear_breach_text_and_render = function ()
local beam1 = Public.get('zone1_beam1')
2021-11-23 20:28:23 +01:00
if beam1 and beam1.valid then
beam1.destroy()
end
local beam2 = Public.get('zone1_beam2')
2021-11-23 20:28:23 +01:00
if beam2 and beam2.valid then
beam2.destroy()
end
local beam3 = Public.get('zone1_beam3')
if beam3 and beam3.valid then
beam3.destroy()
end
local zone1_text1 = Public.get('zone1_text1')
2021-11-23 20:28:23 +01:00
if zone1_text1 then
rendering.set_text(zone1_text1, 'Collapse has begun!')
2021-11-23 20:28:23 +01:00
end
local zone1_text2 = Public.get('zone1_text2')
2021-11-23 20:28:23 +01:00
if zone1_text2 then
rendering.set_text(zone1_text2, 'Collapse has begun!')
2021-11-23 20:28:23 +01:00
end
local zone1_text3 = Public.get('zone1_text3')
2021-11-23 20:28:23 +01:00
if zone1_text3 then
rendering.set_text(zone1_text3, 'Collapse has begun!')
2021-11-23 20:28:23 +01:00
end
end
2020-06-05 23:53:58 +02:00
local collapse_message =
Task.register(
2024-07-02 19:01:41 +02:00
function (data)
local pos = data.position
local message = ({ 'breached_wall.collapse_start' })
local collapse_position = {
position = pos
}
Alert.alert_all_players_location(collapse_position, message)
end
)
2020-06-05 23:53:58 +02:00
2023-11-06 09:03:19 +01:00
local driving_state_changed_token =
Task.register(
2024-07-02 19:01:41 +02:00
function (event)
local player_index = event.player_index
local player = game.get_player(player_index)
if not player or not player.valid then
return
end
2023-11-06 09:03:19 +01:00
2024-07-02 19:01:41 +02:00
local entity = event.entity
if not (entity and entity.valid) then
return
end
2023-11-06 09:03:19 +01:00
2024-07-02 19:01:41 +02:00
local s = Public.get('validate_spider')
if entity.name == 'spidertron' then
if player.driving then
if not s[player.index] then
s[player.index] = entity
end
else
if s[player.index] then
s[player.index] = nil
end
2023-11-06 09:03:19 +01:00
end
end
end
2024-07-02 19:01:41 +02:00
)
2023-11-06 09:03:19 +01:00
2020-08-14 17:16:04 +02:00
local spidertron_unlocked =
Task.register(
2024-07-02 19:01:41 +02:00
function (event)
if event then
local message = ({ 'breached_wall.spidertron_unlocked' })
if event.bw then
message = ({ 'breached_wall.spidertron_unlocked_bw' })
end
Alert.alert_all_players(30, message, nil, 'achievement/tech-maniac', 0.1)
2022-11-24 15:00:59 +01:00
end
end
2024-07-02 19:01:41 +02:00
)
2021-05-15 16:01:07 +02:00
2020-06-05 23:53:58 +02:00
local first_player_to_zone =
Task.register(
2024-07-02 19:01:41 +02:00
function (data)
local player = data.player
if not player or not player.valid then
return
end
local breached_wall = data.breached_wall
local message = ({ 'breached_wall.first_to_reach', player.name, breached_wall })
Alert.alert_all_players(10, message)
Public.shuffle_prices()
2020-09-17 09:14:07 +02:00
end
2024-07-02 19:01:41 +02:00
)
2020-06-05 23:53:58 +02:00
local artillery_warning =
Task.register(
2024-07-02 19:01:41 +02:00
function ()
local message = ({ 'breached_wall.artillery_warning' })
Alert.alert_all_players(10, message)
end
)
2020-06-03 20:09:00 +02:00
2024-07-02 19:01:41 +02:00
local breach_wall_warning_teleport = function (player, check_trusted)
if not player or not player.valid then
return
end
local wave_number = WD.get('wave_number')
if wave_number >= 200 then
return false
end
if not check_trusted then
2024-07-02 19:01:41 +02:00
local message = ({ 'breached_wall.warning_teleport', player.name })
Alert.alert_all_players(40, message)
else
2024-07-02 19:01:41 +02:00
local message = ({ 'breached_wall.warning_not_trusted_teleport', player.name })
Alert.alert_all_players(40, message)
end
local pos = player.surface.find_non_colliding_position('character', player.force.get_spawn_position(player.surface), 3, 0)
if pos then
player.teleport(pos, player.surface)
else
pos = game.forces.player.get_spawn_position(player.surface)
player.teleport(pos, player.surface)
end
return true
end
2020-11-17 15:03:05 +01:00
local spidertron_too_far =
Task.register(
2024-07-02 19:01:41 +02:00
function (data)
local player = data.player
local message = ({ 'breached_wall.cheating_through', player.name })
Alert.alert_all_players(30, message)
end
)
2020-11-17 15:03:05 +01:00
2024-07-02 19:01:41 +02:00
local check_distance_between_player_and_locomotive = function (player)
local surface = player.surface
local position = player.position
local locomotive = Public.get('locomotive')
if not locomotive or not locomotive.valid then
return
end
2024-05-13 10:51:59 +02:00
-- local collapse_position = Collapse.get_position()
2024-03-22 17:30:19 +01:00
local adjusted_zones = Public.get('adjusted_zones')
local gap_between_locomotive = Public.get('gap_between_locomotive')
gap_between_locomotive.highest_pos = locomotive.position
gap_between_locomotive = Public.get('gap_between_locomotive')
2024-04-22 22:53:48 +02:00
local p_y = abs(position.y)
if p_y < 300 then
return
2024-03-22 17:30:19 +01:00
end
2024-04-22 22:53:48 +02:00
local t_y = abs(gap_between_locomotive.highest_pos.y)
2024-05-13 10:51:59 +02:00
-- local c_y = abs(collapse_position.y)
2024-04-22 22:53:48 +02:00
local locomotive_distance_too_far = p_y - t_y > gap_between_locomotive.neg_gap
2024-05-13 10:51:59 +02:00
-- local collapse_distance_too_far = p_y - c_y > gap_between_locomotive.neg_gap_collapse
2024-04-22 22:53:48 +02:00
if locomotive_distance_too_far then
if adjusted_zones.reversed then
2024-07-02 19:01:41 +02:00
player.teleport({ position.x, t_y + gap_between_locomotive.neg_gap - 4 }, surface)
2024-04-22 22:53:48 +02:00
else
2024-07-02 19:01:41 +02:00
player.teleport({ position.x, (t_y + gap_between_locomotive.neg_gap - 4) * -1 }, surface)
2024-04-22 22:53:48 +02:00
end
2024-03-22 17:30:19 +01:00
2024-07-02 19:01:41 +02:00
player.print(({ 'breached_wall.hinder' }), Color.warning)
2023-05-05 00:41:22 +02:00
if player.driving then
player.driving = false
end
if player.character then
player.character.health = player.character.health - 5
2024-07-02 19:01:41 +02:00
player.character.surface.create_entity({ name = 'water-splash', position = position })
if player.character.health <= 0 then
player.character.die('enemy')
end
end
2024-07-02 19:01:41 +02:00
-- elseif collapse_distance_too_far then
-- if adjusted_zones.reversed then
-- player.teleport({position.x, t_y + gap_between_locomotive.neg_gap_collapse - 4}, surface)
-- else
-- player.teleport({position.x, (t_y + gap_between_locomotive.neg_gap_collapse - 4) * -1}, surface)
-- end
-- player.print(({'breached_wall.hinder_collapse'}), Color.warning)
-- if player.driving then
-- player.driving = false
-- end
-- if player.character then
-- player.character.health = player.character.health - 5
-- player.character.surface.create_entity({name = 'water-splash', position = position})
-- if player.character.health <= 0 then
-- player.character.die('enemy')
-- end
-- end
end
end
2024-07-02 19:01:41 +02:00
local compare_player_pos = function (player)
2020-11-23 22:10:45 +01:00
local p = player.position
local index = player.index
local adjusted_zones = Public.get('adjusted_zones')
2022-04-07 16:11:18 +02:00
if not adjusted_zones.size then
return
end
local zone = floor((abs(p.y / zone_settings.zone_depth)) % adjusted_zones.size) + 1
local rpg_t = RPG.get_value_from_player(index)
2022-04-07 00:17:41 +02:00
if adjusted_zones.scrap[zone] then
if rpg_t and not rpg_t.scrap_zone then
rpg_t.scrap_zone = true
end
2020-12-05 18:09:09 +01:00
else
if rpg_t and rpg_t.scrap_zone then
rpg_t.scrap_zone = false
2020-11-23 22:10:45 +01:00
end
2020-12-05 18:09:09 +01:00
end
2022-04-07 00:17:41 +02:00
if adjusted_zones.forest[zone] then
if rpg_t and not rpg_t.forest_zone then
rpg_t.forest_zone = true
end
else
if rpg_t and rpg_t.forest_zone then
rpg_t.forest_zone = false
end
end
2020-11-23 22:10:45 +01:00
end
2024-07-02 19:01:41 +02:00
local compare_player_and_train = function (player, entity)
2020-12-04 01:09:52 +01:00
if not player.driving then
return
end
if not (entity and entity.valid) then
return
end
2023-11-05 16:34:23 +01:00
local car = ICF.get_car(entity.unit_number)
2020-11-17 15:03:05 +01:00
local position = player.position
local locomotive = Public.get('locomotive')
2020-11-17 15:03:05 +01:00
if not locomotive or not locomotive.valid then
return
end
local gap_between_zones = Public.get('gap_between_zones')
2020-11-18 15:24:22 +01:00
gap_between_zones.highest_pos = locomotive.position
gap_between_zones = Public.get('gap_between_zones')
2020-11-18 15:24:22 +01:00
2024-04-22 22:53:48 +02:00
local c_y = abs(position.y)
local t_y = abs(gap_between_zones.highest_pos.y)
2022-01-16 20:37:27 +01:00
2024-04-22 22:53:48 +02:00
local spidertron_warning_position = gap_between_zones.neg_gap + 50
local locomotive_distance_too_far = c_y - t_y > spidertron_warning_position
2024-07-02 19:01:41 +02:00
local spidertron_warning_position_pre_warning = spidertron_warning_position - 100
local locomotive_distance_too_far_pre_warning = c_y - t_y > spidertron_warning_position_pre_warning
local surface = player.surface
2024-03-22 17:30:19 +01:00
2024-07-02 19:01:41 +02:00
local color = Color.yellow
if locomotive_distance_too_far_pre_warning and not locomotive_distance_too_far then
local msg = 'Warning! You are getting too far away from the train!'
surface.create_entity(
{
name = 'flying-text',
position = position,
text = msg,
color = color
}
)
player.print(msg, color)
elseif locomotive_distance_too_far then
local msg = 'Warning! You are too far away from the train! TURN BACK!'
2022-01-16 20:37:27 +01:00
surface.create_entity(
2022-04-05 19:27:46 +02:00
{
name = 'flying-text',
position = position,
2024-07-02 19:01:41 +02:00
text = msg,
color = color
2022-04-05 19:27:46 +02:00
}
)
2024-07-02 19:01:41 +02:00
player.print(msg, color)
2020-11-17 15:03:05 +01:00
if entity.health then
2023-11-05 16:34:23 +01:00
if car and car.health_pool and car.health_pool.health then
car.health_pool.health = car.health_pool.health - 500
end
2020-11-17 15:03:05 +01:00
entity.health = entity.health - 500
if entity.health <= 0 then
entity.die('enemy')
2024-07-02 19:01:41 +02:00
Task.set_timeout_in_ticks(30, spidertron_too_far, { player = player })
2020-11-17 15:03:05 +01:00
return
end
end
end
end
2020-05-23 21:18:18 +02:00
local function distance(player)
2020-11-17 12:45:27 +01:00
local index = player.index
2021-05-25 22:19:20 +02:00
local bonus = RPG.get_value_from_player(index, 'bonus')
local rpg_extra = RPG.get('rpg_extra')
local breached_wall = Public.get('breached_wall')
local bonus_xp_on_join = Public.get('bonus_xp_on_join')
local enable_arties = Public.get('enable_arties')
2020-06-03 20:09:00 +02:00
2020-11-23 22:10:45 +01:00
local p = player.position
local validate_spider = Public.get('validate_spider')
if validate_spider[index] then
local e = validate_spider[index]
2020-11-17 15:03:05 +01:00
if not (e and e.valid) then
validate_spider[index] = nil
2020-11-17 15:03:05 +01:00
end
compare_player_and_train(player, validate_spider[index])
2020-11-17 15:03:05 +01:00
end
2020-11-23 22:10:45 +01:00
compare_player_pos(player)
2022-04-07 00:17:41 +02:00
local distance_to_center = floor(sqrt(p.y ^ 2))
2024-03-22 17:30:19 +01:00
local adjusted_zones = Public.get('adjusted_zones')
if adjusted_zones.reversed then
if distance_to_center < zone_settings.zone_depth * bonus + 32 then
2024-03-22 17:30:19 +01:00
return
end
else
if distance_to_center < zone_settings.zone_depth * bonus - 10 then
2024-03-22 17:30:19 +01:00
return
end
2020-05-23 21:18:18 +02:00
end
2020-06-03 20:09:00 +02:00
local breach_wall_warning = Public.get('breach_wall_warning')
2024-05-13 10:51:59 +02:00
local collapse_started = Public.get('collapse_started')
2024-04-21 18:51:33 +02:00
local block_non_trusted_trigger_collapse = Public.get('block_non_trusted_trigger_collapse')
2022-04-07 00:17:41 +02:00
local max = zone_settings.zone_depth * bonus
local breach_max = zone_settings.zone_depth * breached_wall
local breach_max_times = distance_to_center >= breach_max
local max_times = distance_to_center >= max
2020-06-03 20:09:00 +02:00
if max_times then
2024-05-13 10:51:59 +02:00
if block_non_trusted_trigger_collapse and not Session.get_trusted_player(player) and not collapse_started then
if breach_wall_warning_teleport(player, true) then
return
end
end
if not breach_wall_warning then
Public.set('breach_wall_warning', true)
breach_wall_warning_teleport(player)
return
end
2020-06-03 20:09:00 +02:00
if breach_max_times then
local placed_trains_in_zone = Public.get('placed_trains_in_zone')
local biters = Public.get('biters')
2020-05-23 21:18:18 +02:00
rpg_extra.breached_walls = rpg_extra.breached_walls + 1
2020-07-06 15:45:09 +02:00
rpg_extra.reward_new_players = bonus_xp_on_join * rpg_extra.breached_walls
Public.set('breached_wall', breached_wall + 1)
biters.amount = 0
2023-11-21 00:35:47 +01:00
-- local random_seed = Public.get('random_seed')
-- Public.set('random_seed', random_seed + (breached_wall + 1 * 2))
placed_trains_in_zone.randomized = false
Public.enemy_weapon_damage()
2022-11-24 15:00:59 +01:00
local spidertron_unlocked_enabled = Public.get('spidertron_unlocked_enabled')
if Public.get('breached_wall') >= Public.get('spidertron_unlocked_at_zone') and not spidertron_unlocked_enabled then
Public.set('spidertron_unlocked_enabled', true)
local main_market_items = Public.get('main_market_items')
2020-08-14 17:16:04 +02:00
if not main_market_items['spidertron'] then
2022-11-24 15:00:59 +01:00
local bw = Public.get('bw')
local spider_tooltip = 'BiterStunner 9000'
local rng
if bw then
rng = random(30000, 80000)
spider_tooltip = spider_tooltip .. ' (Exclusive sale!)'
else
rng = random(70000, 120000)
end
2020-08-14 17:16:04 +02:00
main_market_items['spidertron'] = {
stack = 1,
value = 'coin',
price = rng,
2022-11-24 15:00:59 +01:00
tooltip = spider_tooltip,
2020-08-14 17:16:04 +02:00
upgrade = false,
static = true
}
2024-07-02 19:01:41 +02:00
Task.set_timeout_in_ticks(150, spidertron_unlocked, { bw = bw })
2020-08-14 17:16:04 +02:00
end
end
2020-06-05 23:53:58 +02:00
local data = {
player = player,
breached_wall = breached_wall
}
Task.set_timeout_in_ticks(360, first_player_to_zone, data)
2020-06-03 20:09:00 +02:00
if breached_wall == 5 then
2020-07-28 11:24:16 +02:00
if enable_arties == 6 then
Task.set_timeout_in_ticks(360, artillery_warning)
end
2020-06-03 20:09:00 +02:00
end
end
2020-11-17 15:03:05 +01:00
2024-05-28 10:43:10 +02:00
if not Collapse.has_collapse_started() then
2021-11-23 20:28:23 +01:00
clear_breach_text_and_render()
2024-05-13 10:51:59 +02:00
Public.set('collapse_started', true)
2020-06-03 20:09:00 +02:00
Collapse.start_now(true)
2020-06-05 23:53:58 +02:00
local data = {
position = Collapse.get_position()
}
Task.set_timeout_in_ticks(550, collapse_message, data)
2020-05-23 21:18:18 +02:00
end
2020-11-17 15:03:05 +01:00
2024-05-28 10:43:10 +02:00
if Collapse.has_collapse_started() then
clear_breach_text_and_render()
end
2021-05-25 22:19:20 +02:00
RPG.set_value_to_player(index, 'bonus', bonus + 1)
2020-11-17 12:45:27 +01:00
2021-05-25 22:19:20 +02:00
RPG.gain_xp(player, bonus_xp_on_join * bonus)
2020-05-23 21:18:18 +02:00
return
end
end
local function on_player_changed_position(event)
2023-09-05 00:03:55 +02:00
local final_battle = Public.get('final_battle')
if final_battle then
return
end
2020-09-17 09:14:07 +02:00
local player = game.get_player(event.player_index)
2022-09-03 21:26:20 +02:00
if not player or not player.valid then
return
end
if player.controller_type == defines.controllers.spectator then
return
end
local surface_name = player.surface.name
local map_name = 'mtn_v3'
if sub(surface_name, 0, #map_name) ~= map_name then
return
end
2020-05-23 21:18:18 +02:00
2024-03-23 09:10:54 +01:00
if player.position.y > -100 and player.position.y < -100 then
return
end
if player.position.y > 100 and player.position.y < 100 then
2024-03-22 17:30:19 +01:00
return
end
check_distance_between_player_and_locomotive(player)
if random(1, 3) ~= 1 then
2020-05-23 21:18:18 +02:00
return
end
distance(player)
end
2020-11-17 15:03:05 +01:00
local function on_player_driving_changed_state(event)
2023-09-05 00:03:55 +02:00
local final_battle = Public.get('final_battle')
if final_battle then
return
end
2023-11-06 09:03:19 +01:00
local player = game.get_player(event.player_index)
2020-11-17 15:03:05 +01:00
if not (player and player.valid) then
return
end
2023-11-05 16:34:23 +01:00
2020-11-17 15:03:05 +01:00
local entity = event.entity
if not (entity and entity.valid) then
return
end
2023-11-05 16:34:23 +01:00
2024-07-02 19:01:41 +02:00
Task.set_timeout_in_ticks(15, driving_state_changed_token, { player_index = player.index, entity = entity })
2020-11-17 15:03:05 +01:00
end
2020-05-23 21:18:18 +02:00
Event.add(defines.events.on_player_changed_position, on_player_changed_position)
2020-11-17 15:03:05 +01:00
Event.add(defines.events.on_player_driving_changed_state, on_player_driving_changed_state)
return Public