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

442 lines
14 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'
2020-06-05 23:53:58 +02:00
local Task = require 'utils.task'
local Token = require 'utils.token'
local Color = require 'utils.color_presets'
2023-11-05 16:34:23 +01:00
local ICF = require 'maps.mountain_fortress_v3.ic.functions'
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
2021-11-23 20:28:23 +01: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 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 =
Token.register(
function(data)
local pos = data.position
2020-09-04 22:04:28 +02:00
local message = ({'breached_wall.collapse_start'})
2020-06-05 23:53:58 +02:00
local collapse_position = {
position = pos
}
Alert.alert_all_players_location(collapse_position, message)
end
)
2023-11-06 09:03:19 +01:00
local driving_state_changed_token =
Token.register(
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
local entity = event.entity
if not (entity and entity.valid) then
return
end
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
end
end
end
)
2020-08-14 17:16:04 +02:00
local spidertron_unlocked =
Token.register(
2022-11-24 15:00:59 +01: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)
end
2020-08-14 17:16:04 +02:00
end
)
2021-05-15 16:01:07 +02:00
2020-06-05 23:53:58 +02:00
local first_player_to_zone =
Token.register(
function(data)
local player = data.player
2020-09-17 09:14:07 +02:00
if not player or not player.valid then
return
end
2020-06-05 23:53:58 +02:00
local breached_wall = data.breached_wall
2020-10-30 22:05:05 +01:00
local message = ({'breached_wall.first_to_reach', player.name, breached_wall})
2020-06-05 23:53:58 +02:00
Alert.alert_all_players(10, message)
Public.shuffle_prices()
2020-06-05 23:53:58 +02:00
end
)
local artillery_warning =
Token.register(
function()
2020-09-04 22:04:28 +02:00
local message = ({'breached_wall.artillery_warning'})
2020-06-05 23:53:58 +02:00
Alert.alert_all_players(10, message)
end
)
2020-06-03 20:09:00 +02:00
local breach_wall_warning_teleport = function(player)
if not player or not player.valid then
return
end
local wave_number = WD.get('wave_number')
if wave_number >= 200 then
return
end
local message = ({'breached_wall.warning_teleport', player.name})
Alert.alert_all_players(40, message)
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
end
2020-11-17 15:03:05 +01:00
local spidertron_too_far =
Token.register(
function(data)
local player = data.player
local message = ({'breached_wall.cheating_through', player.name})
Alert.alert_all_players(30, message)
end
)
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
local collapse_position = Collapse.get_position()
local gap_between_locomotive = Public.get('gap_between_locomotive')
gap_between_locomotive.highest_pos = locomotive.position
gap_between_locomotive = Public.get('gap_between_locomotive')
local p_y = position.y
local t_y = gap_between_locomotive.highest_pos.y
local c_y = collapse_position.y
if p_y - t_y <= gap_between_locomotive.neg_gap then
2022-05-08 23:06:15 +02:00
player.teleport({position.x, locomotive.position.y + gap_between_locomotive.neg_gap + 2}, surface)
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
player.character.surface.create_entity({name = 'water-splash', position = position})
if player.character.health <= 0 then
player.character.die('enemy')
end
end
end
if p_y - c_y <= gap_between_locomotive.neg_gap_collapse then
player.teleport({position.x, c_y + gap_between_locomotive.neg_gap_collapse + 2}, surface)
player.print(({'breached_wall.hinder_collapse'}), Color.warning)
if player.driving then
2023-05-05 00:41:22 +02:00
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
2020-11-23 22:10:45 +01:00
local compare_player_pos = function(player)
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
2020-11-17 15:03:05 +01: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
local c_y = position.y
local t_y = gap_between_zones.highest_pos.y
2022-01-16 20:37:27 +01:00
local spidertron_warning_position = gap_between_zones.neg_gap + 50
if c_y - t_y <= spidertron_warning_position then
local surface = player.surface
surface.create_entity(
2022-04-05 19:27:46 +02:00
{
name = 'flying-text',
position = position,
2022-04-07 00:17:41 +02:00
text = 'Warning! You are too far away from the main locomotive!',
2022-04-05 19:27:46 +02:00
color = {r = 0.9, g = 0.0, b = 0.0}
}
)
2022-01-16 20:37:27 +01:00
end
2020-11-17 15:03:05 +01:00
if c_y - t_y <= gap_between_zones.neg_gap then
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')
Task.set_timeout_in_ticks(30, spidertron_too_far, {player = player})
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))
2020-05-23 21:18:18 +02:00
local location = distance_to_center
2022-04-07 00:17:41 +02:00
if location < zone_settings.zone_depth * bonus - 10 then
2020-05-23 21:18:18 +02:00
return
end
2020-06-03 20:09:00 +02:00
local breach_wall_warning = Public.get('breach_wall_warning')
2022-04-07 00:17:41 +02:00
local max = zone_settings.zone_depth * bonus
local breach_max = zone_settings.zone_depth * breached_wall
2020-06-03 20:09:00 +02:00
local breach_max_times = location >= breach_max
local max_times = location >= max
if max_times then
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
}
2022-11-24 15:00:59 +01: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
2023-09-05 00:03:55 +02:00
if not Collapse.get_start_now() then
2021-11-23 20:28:23 +01:00
clear_breach_text_and_render()
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
2023-09-05 00:03:55 +02:00
if Collapse.get_start_now() 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
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
2023-11-06 09:03:19 +01: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