1
0
mirror of https://github.com/ComfyFactory/ComfyFactorio.git synced 2025-01-10 00:43:27 +02:00
ComfyFactorio/maps/mountain_fortress_v3/breached_wall.lua
2020-11-17 15:03:05 +01:00

259 lines
8.2 KiB
Lua

local Collapse = require 'modules.collapse'
local Terrain = require 'maps.mountain_fortress_v3.terrain'
local Balance = require 'maps.mountain_fortress_v3.balance'
local RPG_Settings = require 'modules.rpg.table'
local Functions = require 'modules.rpg.functions'
local WPT = require 'maps.mountain_fortress_v3.table'
local Alert = require 'utils.alert'
local Event = require 'utils.event'
local Task = require 'utils.task'
local Token = require 'utils.token'
local BM = require 'maps.mountain_fortress_v3.blood_moon'
local raise_event = script.raise_event
local floor = math.floor
local random = math.random
local sqrt = math.sqrt
local z = {
[3] = true,
[6] = true,
[12] = true,
[15] = true,
[16] = true,
[18] = true,
[22] = true
}
local collapse_message =
Token.register(
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
)
local spidertron_unlocked =
Token.register(
function()
local message = ({'breached_wall.spidertron_unlocked'})
Alert.alert_all_players(30, message, nil, 'achievement/tech-maniac', 0.1)
end
)
--[[
local calculate_hp = function(zone)
return 2 + 0.2 * zone - 1 * floor(zone / 20)
end ]]
local first_player_to_zone =
Token.register(
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)
end
)
local artillery_warning =
Token.register(
function()
local message = ({'breached_wall.artillery_warning'})
Alert.alert_all_players(10, message)
end
)
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 compare_player_and_train = function(player, entity)
local position = player.position
local locomotive = WPT.get('locomotive')
if not locomotive or not locomotive.valid then
return
end
local c_y = position.y
local t_y = locomotive.position.y
local gap_between_zones = WPT.get('gap_between_zones')
if c_y - t_y <= gap_between_zones.neg_gap then
if entity.health then
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
local function distance(player)
local index = player.index
local bonus = RPG_Settings.get_value_from_player(index, 'bonus')
local rpg_extra = RPG_Settings.get('rpg_extra')
local breached_wall = WPT.get('breached_wall')
local bonus_xp_on_join = WPT.get('bonus_xp_on_join')
local enable_arties = WPT.get('enable_arties')
local s = WPT.get('validate_spider')
if s[index] then
local e = s[index]
if not (e and e.valid) then
s[index] = nil
end
compare_player_and_train(player, s[index])
end
local distance_to_center = floor(sqrt(player.position.x ^ 2 + player.position.y ^ 2))
local location = distance_to_center
if location < Terrain.level_depth * bonus - 10 then
return
end
local max = Terrain.level_depth * bonus
local breach_max = Terrain.level_depth * breached_wall
local breach_max_times = location >= breach_max
local max_times = location >= max
if max_times then
if breach_max_times then
rpg_extra.breached_walls = rpg_extra.breached_walls + 1
rpg_extra.reward_new_players = bonus_xp_on_join * rpg_extra.breached_walls
WPT.set().breached_wall = breached_wall + 1
WPT.set().placed_trains_in_zone.placed = 0
WPT.set().biters.amount = 0
WPT.set('blood_moon', false)
WPT.set().placed_trains_in_zone.randomized = false
WPT.set().placed_trains_in_zone.positions = {}
raise_event(Balance.events.breached_wall, {})
--[[ global.biter_health_boost = calculate_hp(breached_wall) ]]
if WPT.get('breached_wall') == WPT.get('spidertron_unlocked_at_wave') then
local main_market_items = WPT.get('main_market_items')
if not main_market_items['spidertron'] then
local rng = random(70000, 120000)
main_market_items['spidertron'] = {
stack = 1,
value = 'coin',
price = rng,
tooltip = 'Chonk Spidertron',
upgrade = false,
static = true
}
Task.set_timeout_in_ticks(150, spidertron_unlocked)
end
end
if breached_wall % 2 == 0 then
local blood_moon = WPT.get('blood_moon')
local t = game.tick
local s = player.surface
if not blood_moon then
BM.set_daytime(s, t, true)
WPT.set('blood_moon', true)
end
else
local s = player.surface
s.brightness_visual_weights = {
a = 1,
b = 0,
g = 0,
r = 0
}
s.daytime = 0.7
s.freeze_daytime = false
end
local data = {
player = player,
breached_wall = breached_wall
}
Task.set_timeout_in_ticks(360, first_player_to_zone, data)
if breached_wall == 5 then
if enable_arties == 6 then
Task.set_timeout_in_ticks(360, artillery_warning)
end
end
end
if not Collapse.start_now() then
Collapse.start_now(true)
local data = {
position = Collapse.get_position()
}
Task.set_timeout_in_ticks(550, collapse_message, data)
end
RPG_Settings.set_value_to_player(index, 'bonus', bonus + 1)
local b = RPG_Settings.get_value_from_player(index, 'bonus')
if b == 6 or b == 16 then
RPG_Settings.set_value_to_player(index, 'scrap_zone', true)
elseif not (b == 6 or b == 16) then
local has_scrap = RPG_Settings.get_value_from_player(index, 'scrap_zone')
if has_scrap then
RPG_Settings.set_value_to_player(index, 'scrap_zone', false)
end
end
if z[b] then
RPG_Settings.set_value_to_player(index, 'forest_zone', true)
elseif not z[b] then
RPG_Settings.set_value_to_player(index, 'forest_zone', false)
end
Functions.gain_xp(player, bonus_xp_on_join * bonus)
local message = ({'breached_wall.wall_breached', bonus})
Alert.alert_player_warning(player, 10, message)
return
end
end
local function on_player_changed_position(event)
local player = game.get_player(event.player_index)
local map_name = 'mountain_fortress_v3'
if string.sub(player.surface.name, 0, #map_name) ~= map_name then
return
end
distance(player)
end
local function on_player_driving_changed_state(event)
local player = game.players[event.player_index]
if not (player and player.valid) then
return
end
local entity = event.entity
if not (entity and entity.valid) then
return
end
local s = WPT.get('validate_spider')
if entity.name == 'spidertron' 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
Event.add(defines.events.on_player_changed_position, on_player_changed_position)
Event.add(defines.events.on_player_driving_changed_state, on_player_driving_changed_state)