mirror of
https://github.com/ComfyFactory/ComfyFactorio.git
synced 2025-01-24 03:47:58 +02:00
commit
9ade0b7293
@ -48,7 +48,7 @@ local STD_BASE_CONTROL = 'lua52c+factorio+factorio_control+factorio_defines+fact
|
|||||||
--[Assume Factorio Control stage as default]--
|
--[Assume Factorio Control stage as default]--
|
||||||
-------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------
|
||||||
std = STD_CONTROL
|
std = STD_CONTROL
|
||||||
globals = {'print', '_DEBUG', '_CHEATS', '_DUMP_ENV', 'ServerCommands', 'Debug', '_LIFECYCLE', '_STAGE', 'get_game_version'}
|
globals = {'print', '_DEBUG', '_CHEATS', '_DUMP_ENV', 'ServerCommands', 'Debug', '_LIFECYCLE', '_STAGE', 'get_game_version', 'is_loaded'}
|
||||||
max_line_length = LINE_LENGTH
|
max_line_length = LINE_LENGTH
|
||||||
|
|
||||||
not_globals = NOT_GLOBALS
|
not_globals = NOT_GLOBALS
|
||||||
|
@ -158,6 +158,9 @@ commands.add_command(
|
|||||||
|
|
||||||
local function process_bot_answers(event)
|
local function process_bot_answers(event)
|
||||||
local player = game.players[event.player_index]
|
local player = game.players[event.player_index]
|
||||||
|
if player.admin then
|
||||||
|
return
|
||||||
|
end
|
||||||
local message = event.message
|
local message = event.message
|
||||||
message = string.lower(message)
|
message = string.lower(message)
|
||||||
for word in string.gmatch(message, '%g+') do
|
for word in string.gmatch(message, '%g+') do
|
||||||
|
@ -160,7 +160,7 @@ local poll_function = {
|
|||||||
end
|
end
|
||||||
end,
|
end,
|
||||||
['comfy_panel_poll_no_notify_toggle'] = function(event)
|
['comfy_panel_poll_no_notify_toggle'] = function(event)
|
||||||
local poll = package.loaded['comfy_panel.poll']
|
local poll = is_loaded('comfy_panel.poll')
|
||||||
local poll_table = poll.get_no_notify_players()
|
local poll_table = poll.get_no_notify_players()
|
||||||
if event.element.switch_state == 'left' then
|
if event.element.switch_state == 'left' then
|
||||||
poll_table[event.player_index] = false
|
poll_table[event.player_index] = false
|
||||||
@ -186,7 +186,7 @@ local antigrief_functions = {
|
|||||||
|
|
||||||
local fortress_functions = {
|
local fortress_functions = {
|
||||||
['comfy_panel_disable_fullness'] = function(event)
|
['comfy_panel_disable_fullness'] = function(event)
|
||||||
local Fullness = package.loaded['modules.check_fullness']
|
local Fullness = is_loaded('modules.check_fullness')
|
||||||
local this = Fullness.get()
|
local this = Fullness.get()
|
||||||
if event.element.switch_state == 'left' then
|
if event.element.switch_state == 'left' then
|
||||||
this.fullness_enabled = true
|
this.fullness_enabled = true
|
||||||
@ -197,7 +197,7 @@ local fortress_functions = {
|
|||||||
end
|
end
|
||||||
end,
|
end,
|
||||||
['comfy_panel_offline_players'] = function(event)
|
['comfy_panel_offline_players'] = function(event)
|
||||||
local WPT = package.loaded['maps.mountain_fortress_v3.table']
|
local WPT = is_loaded('maps.mountain_fortress_v3.table')
|
||||||
local this = WPT.get()
|
local this = WPT.get()
|
||||||
if event.element.switch_state == 'left' then
|
if event.element.switch_state == 'left' then
|
||||||
this.offline_players_enabled = true
|
this.offline_players_enabled = true
|
||||||
@ -208,7 +208,7 @@ local fortress_functions = {
|
|||||||
end
|
end
|
||||||
end,
|
end,
|
||||||
['comfy_panel_collapse_grace'] = function(event)
|
['comfy_panel_collapse_grace'] = function(event)
|
||||||
local WPT = package.loaded['maps.mountain_fortress_v3.table']
|
local WPT = is_loaded('maps.mountain_fortress_v3.table')
|
||||||
local this = WPT.get()
|
local this = WPT.get()
|
||||||
if event.element.switch_state == 'left' then
|
if event.element.switch_state == 'left' then
|
||||||
this.collapse_grace = true
|
this.collapse_grace = true
|
||||||
@ -219,7 +219,7 @@ local fortress_functions = {
|
|||||||
end
|
end
|
||||||
end,
|
end,
|
||||||
['comfy_panel_spill_items_to_surface'] = function(event)
|
['comfy_panel_spill_items_to_surface'] = function(event)
|
||||||
local WPT = package.loaded['maps.mountain_fortress_v3.table']
|
local WPT = is_loaded('maps.mountain_fortress_v3.table')
|
||||||
local this = WPT.get()
|
local this = WPT.get()
|
||||||
if event.element.switch_state == 'left' then
|
if event.element.switch_state == 'left' then
|
||||||
this.spill_items_to_surface = true
|
this.spill_items_to_surface = true
|
||||||
@ -230,7 +230,7 @@ local fortress_functions = {
|
|||||||
end
|
end
|
||||||
end,
|
end,
|
||||||
['comfy_panel_void_or_tile'] = function(event)
|
['comfy_panel_void_or_tile'] = function(event)
|
||||||
local WPT = package.loaded['maps.mountain_fortress_v3.table']
|
local WPT = is_loaded('maps.mountain_fortress_v3.table')
|
||||||
local this = WPT.get()
|
local this = WPT.get()
|
||||||
if event.element.switch_state == 'left' then
|
if event.element.switch_state == 'left' then
|
||||||
this.void_or_tile = 'out-of-map'
|
this.void_or_tile = 'out-of-map'
|
||||||
@ -241,7 +241,7 @@ local fortress_functions = {
|
|||||||
end
|
end
|
||||||
end,
|
end,
|
||||||
['comfy_panel_trusted_only_car_tanks'] = function(event)
|
['comfy_panel_trusted_only_car_tanks'] = function(event)
|
||||||
local WPT = package.loaded['maps.mountain_fortress_v3.table']
|
local WPT = is_loaded('maps.mountain_fortress_v3.table')
|
||||||
local this = WPT.get()
|
local this = WPT.get()
|
||||||
if event.element.switch_state == 'left' then
|
if event.element.switch_state == 'left' then
|
||||||
this.trusted_only_car_tanks = true
|
this.trusted_only_car_tanks = true
|
||||||
@ -337,8 +337,8 @@ local build_config_gui = (function(player, frame)
|
|||||||
scroll_pane.add({type = 'line'})
|
scroll_pane.add({type = 'line'})
|
||||||
end
|
end
|
||||||
|
|
||||||
if package.loaded['comfy_panel.poll'] then
|
local poll = is_loaded('comfy_panel.poll')
|
||||||
local poll = package.loaded['comfy_panel.poll']
|
if poll then
|
||||||
local poll_table = poll.get_no_notify_players()
|
local poll_table = poll.get_no_notify_players()
|
||||||
switch_state = 'right'
|
switch_state = 'right'
|
||||||
if not poll_table[player.index] then
|
if not poll_table[player.index] then
|
||||||
@ -380,7 +380,7 @@ local build_config_gui = (function(player, frame)
|
|||||||
'Disables the Logistic System research.\nRequester, buffer or active-provider containers can not be built.'
|
'Disables the Logistic System research.\nRequester, buffer or active-provider containers can not be built.'
|
||||||
)
|
)
|
||||||
|
|
||||||
if package.loaded['comfy_panel.poll'] then
|
if poll then
|
||||||
scroll_pane.add({type = 'line'})
|
scroll_pane.add({type = 'line'})
|
||||||
switch_state = 'right'
|
switch_state = 'right'
|
||||||
if global.comfy_panel_config.poll_trusted then
|
if global.comfy_panel_config.poll_trusted then
|
||||||
@ -407,7 +407,7 @@ local build_config_gui = (function(player, frame)
|
|||||||
add_switch(scroll_pane, switch_state, 'comfy_panel_disable_antigrief', 'Antigrief', 'Left = Enables antigrief / Right = Disables antigrief')
|
add_switch(scroll_pane, switch_state, 'comfy_panel_disable_antigrief', 'Antigrief', 'Left = Enables antigrief / Right = Disables antigrief')
|
||||||
scroll_pane.add({type = 'line'})
|
scroll_pane.add({type = 'line'})
|
||||||
|
|
||||||
if package.loaded['maps.biter_battles_v2.main'] then
|
if is_loaded('maps.biter_battles_v2.main') then
|
||||||
label = scroll_pane.add({type = 'label', caption = 'Biter Battles Settings'})
|
label = scroll_pane.add({type = 'label', caption = 'Biter Battles Settings'})
|
||||||
label.style.font = 'default-bold'
|
label.style.font = 'default-bold'
|
||||||
label.style.padding = 0
|
label.style.padding = 0
|
||||||
@ -450,7 +450,7 @@ local build_config_gui = (function(player, frame)
|
|||||||
scroll_pane.add({type = 'line'})
|
scroll_pane.add({type = 'line'})
|
||||||
end
|
end
|
||||||
|
|
||||||
if package.loaded['maps.mountain_fortress_v3.main'] then
|
if is_loaded('maps.mountain_fortress_v3.main') then
|
||||||
label = scroll_pane.add({type = 'label', caption = 'Mountain Fortress Settings'})
|
label = scroll_pane.add({type = 'label', caption = 'Mountain Fortress Settings'})
|
||||||
label.style.font = 'default-bold'
|
label.style.font = 'default-bold'
|
||||||
label.style.padding = 0
|
label.style.padding = 0
|
||||||
@ -460,7 +460,7 @@ local build_config_gui = (function(player, frame)
|
|||||||
label.style.vertical_align = 'bottom'
|
label.style.vertical_align = 'bottom'
|
||||||
label.style.font_color = Color.green
|
label.style.font_color = Color.green
|
||||||
|
|
||||||
local Fullness = package.loaded['modules.check_fullness']
|
local Fullness = is_loaded('modules.check_fullness')
|
||||||
local full = Fullness.get()
|
local full = Fullness.get()
|
||||||
switch_state = 'right'
|
switch_state = 'right'
|
||||||
if full.fullness_enabled then
|
if full.fullness_enabled then
|
||||||
@ -470,7 +470,7 @@ local build_config_gui = (function(player, frame)
|
|||||||
|
|
||||||
scroll_pane.add({type = 'line'})
|
scroll_pane.add({type = 'line'})
|
||||||
|
|
||||||
local WPT = package.loaded['maps.mountain_fortress_v3.table']
|
local WPT = is_loaded('maps.mountain_fortress_v3.table')
|
||||||
local this = WPT.get()
|
local this = WPT.get()
|
||||||
switch_state = 'right'
|
switch_state = 'right'
|
||||||
if this.offline_players_enabled then
|
if this.offline_players_enabled then
|
||||||
@ -576,7 +576,7 @@ local function on_gui_switch_state_changed(event)
|
|||||||
end
|
end
|
||||||
fortress_functions[event.element.name](event)
|
fortress_functions[event.element.name](event)
|
||||||
return
|
return
|
||||||
elseif package.loaded['comfy_panel.poll'] then
|
elseif is_loaded('comfy_panel.poll') then
|
||||||
local is_spamming = SpamProtection.is_spamming(player)
|
local is_spamming = SpamProtection.is_spamming(player)
|
||||||
if is_spamming then
|
if is_spamming then
|
||||||
return
|
return
|
||||||
|
@ -10,6 +10,8 @@ draw_map_scores would be a function with the player and the frame as arguments
|
|||||||
|
|
||||||
]]
|
]]
|
||||||
local Event = require 'utils.event'
|
local Event = require 'utils.event'
|
||||||
|
local Server = require 'utils.server'
|
||||||
|
local CommandFrame = require 'commands.misc'
|
||||||
local SpamProtection = require 'utils.spam_protection'
|
local SpamProtection = require 'utils.spam_protection'
|
||||||
|
|
||||||
comfy_panel_tabs = {}
|
comfy_panel_tabs = {}
|
||||||
@ -34,7 +36,9 @@ end
|
|||||||
|
|
||||||
function Public.comfy_panel_clear_screen_gui(player)
|
function Public.comfy_panel_clear_screen_gui(player)
|
||||||
for _, child in pairs(player.gui.screen.children) do
|
for _, child in pairs(player.gui.screen.children) do
|
||||||
child.destroy()
|
if child.name ~= CommandFrame.bottom_guis_frame then
|
||||||
|
child.visible = false
|
||||||
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
@ -83,7 +87,18 @@ local function main_frame(player)
|
|||||||
local tabbed_pane = frame.add({type = 'tabbed-pane', name = 'tabbed_pane'})
|
local tabbed_pane = frame.add({type = 'tabbed-pane', name = 'tabbed_pane'})
|
||||||
|
|
||||||
for name, func in pairs(tabs) do
|
for name, func in pairs(tabs) do
|
||||||
if func.admin == true then
|
if func.only_server_sided then
|
||||||
|
local secs = Server.get_current_time()
|
||||||
|
if secs then
|
||||||
|
local tab = tabbed_pane.add({type = 'tab', caption = name})
|
||||||
|
local frame = tabbed_pane.add({type = 'frame', name = name, direction = 'vertical'})
|
||||||
|
frame.style.minimal_height = 480
|
||||||
|
frame.style.maximal_height = 480
|
||||||
|
frame.style.minimal_width = 800
|
||||||
|
frame.style.maximal_width = 800
|
||||||
|
tabbed_pane.add_tab(tab, frame)
|
||||||
|
end
|
||||||
|
elseif func.admin == true then
|
||||||
if player.admin then
|
if player.admin then
|
||||||
local tab = tabbed_pane.add({type = 'tab', caption = name})
|
local tab = tabbed_pane.add({type = 'tab', caption = name})
|
||||||
local frame = tabbed_pane.add({type = 'frame', name = name, direction = 'vertical'})
|
local frame = tabbed_pane.add({type = 'frame', name = name, direction = 'vertical'})
|
||||||
@ -155,6 +170,7 @@ local function on_gui_click(event)
|
|||||||
if player.gui.left.comfy_panel then
|
if player.gui.left.comfy_panel then
|
||||||
player.gui.left.comfy_panel.destroy()
|
player.gui.left.comfy_panel.destroy()
|
||||||
Public.comfy_panel_restore_left_gui(player)
|
Public.comfy_panel_restore_left_gui(player)
|
||||||
|
Public.comfy_panel_restore_screen_gui(player)
|
||||||
return
|
return
|
||||||
else
|
else
|
||||||
Public.comfy_panel_clear_screen_gui(player)
|
Public.comfy_panel_clear_screen_gui(player)
|
||||||
|
@ -29,16 +29,33 @@ function Public.get_table()
|
|||||||
return this
|
return this
|
||||||
end
|
end
|
||||||
|
|
||||||
function Public.init_player_table(player)
|
function Public.reset_tbl()
|
||||||
|
this.score_table['player'] = {
|
||||||
|
players = {}
|
||||||
|
}
|
||||||
|
end
|
||||||
|
|
||||||
|
function Public.init_player_table(player, reset)
|
||||||
if not player then
|
if not player then
|
||||||
return
|
return
|
||||||
end
|
end
|
||||||
|
if reset then
|
||||||
|
this.score_table[player.force.name].players[player.name] = {
|
||||||
|
built_entities = 0,
|
||||||
|
deaths = 0,
|
||||||
|
killscore = 0,
|
||||||
|
mined_entities = 0
|
||||||
|
}
|
||||||
|
end
|
||||||
|
|
||||||
if not this.score_table[player.force.name] then
|
if not this.score_table[player.force.name] then
|
||||||
this.score_table[player.force.name] = {}
|
this.score_table[player.force.name] = {}
|
||||||
end
|
end
|
||||||
|
|
||||||
if not this.score_table[player.force.name].players then
|
if not this.score_table[player.force.name].players then
|
||||||
this.score_table[player.force.name].players = {}
|
this.score_table[player.force.name].players = {}
|
||||||
end
|
end
|
||||||
|
|
||||||
if not this.score_table[player.force.name].players[player.name] then
|
if not this.score_table[player.force.name].players[player.name] then
|
||||||
this.score_table[player.force.name].players[player.name] = {
|
this.score_table[player.force.name].players[player.name] = {
|
||||||
built_entities = 0,
|
built_entities = 0,
|
||||||
|
@ -4,9 +4,13 @@ local Server = require 'utils.server'
|
|||||||
local Color = require 'utils.color_presets'
|
local Color = require 'utils.color_presets'
|
||||||
local Event = require 'utils.event'
|
local Event = require 'utils.event'
|
||||||
local Global = require 'utils.global'
|
local Global = require 'utils.global'
|
||||||
|
local Gui = require 'utils.gui'
|
||||||
|
|
||||||
local this = {
|
local this = {
|
||||||
players = {}
|
players = {},
|
||||||
|
activate_custom_buttons = false,
|
||||||
|
bottom_right = false,
|
||||||
|
bottom_quickbar_button = {}
|
||||||
}
|
}
|
||||||
|
|
||||||
Global.register(
|
Global.register(
|
||||||
@ -18,6 +22,10 @@ Global.register(
|
|||||||
|
|
||||||
local Public = {}
|
local Public = {}
|
||||||
|
|
||||||
|
local bottom_guis_frame = Gui.uid_name()
|
||||||
|
local clear_corpse_button_name = Gui.uid_name()
|
||||||
|
local bottom_quickbar_button_name = Gui.uid_name()
|
||||||
|
|
||||||
commands.add_command(
|
commands.add_command(
|
||||||
'spaghetti',
|
'spaghetti',
|
||||||
'Does spaghett.',
|
'Does spaghett.',
|
||||||
@ -340,51 +348,73 @@ commands.add_command(
|
|||||||
end
|
end
|
||||||
)
|
)
|
||||||
|
|
||||||
|
local function clear_corpses(cmd)
|
||||||
|
local player
|
||||||
|
local trusted = Session.get_trusted_table()
|
||||||
|
local param
|
||||||
|
if cmd and cmd.player then
|
||||||
|
player = cmd.player
|
||||||
|
param = 50
|
||||||
|
elseif cmd then
|
||||||
|
player = game.player
|
||||||
|
param = tonumber(cmd.parameter)
|
||||||
|
end
|
||||||
|
|
||||||
|
if not player or not player.valid then
|
||||||
|
return
|
||||||
|
end
|
||||||
|
local p = player.print
|
||||||
|
if not trusted[player.name] then
|
||||||
|
if not player.admin then
|
||||||
|
p('[ERROR] Only admins and trusted weebs are allowed to run this command!', Color.fail)
|
||||||
|
return
|
||||||
|
end
|
||||||
|
end
|
||||||
|
if param == nil then
|
||||||
|
player.print('[ERROR] Must specify radius!', Color.fail)
|
||||||
|
return
|
||||||
|
end
|
||||||
|
if param < 0 then
|
||||||
|
player.print('[ERROR] Value is too low.', Color.fail)
|
||||||
|
return
|
||||||
|
end
|
||||||
|
if param > 500 then
|
||||||
|
player.print('[ERROR] Value is too big.', Color.fail)
|
||||||
|
return
|
||||||
|
end
|
||||||
|
local pos = player.position
|
||||||
|
|
||||||
|
local i = 0
|
||||||
|
|
||||||
|
local radius = {{x = (pos.x + -param), y = (pos.y + -param)}, {x = (pos.x + param), y = (pos.y + param)}}
|
||||||
|
|
||||||
|
for _, entity in pairs(player.surface.find_entities_filtered {area = radius, type = 'corpse'}) do
|
||||||
|
if entity.corpse_expires then
|
||||||
|
entity.destroy()
|
||||||
|
i = i + 1
|
||||||
|
end
|
||||||
|
end
|
||||||
|
local corpse = 'corpse'
|
||||||
|
|
||||||
|
if i > 1 then
|
||||||
|
corpse = 'corpses'
|
||||||
|
end
|
||||||
|
if i == 0 then
|
||||||
|
player.print('[color=blue][Cleaner][/color] No corpses to clear!', Color.warning)
|
||||||
|
else
|
||||||
|
player.print('[color=blue][Cleaner][/color] Cleared ' .. i .. ' ' .. corpse .. '!', Color.success)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
commands.add_command(
|
commands.add_command(
|
||||||
'clear-corpses',
|
'clear-corpses',
|
||||||
'Clears all the biter corpses..',
|
'Clears all the biter corpses..',
|
||||||
function(cmd)
|
function(cmd)
|
||||||
local player = game.player
|
clear_corpses(cmd)
|
||||||
local trusted = Session.get_trusted_table()
|
|
||||||
local param = tonumber(cmd.parameter)
|
|
||||||
|
|
||||||
if not player or not player.valid then
|
|
||||||
return
|
|
||||||
end
|
|
||||||
local p = player.print
|
|
||||||
if not trusted[player.name] then
|
|
||||||
if not player.admin then
|
|
||||||
p('[ERROR] Only admins and trusted weebs are allowed to run this command!', Color.fail)
|
|
||||||
return
|
|
||||||
end
|
|
||||||
end
|
|
||||||
if param == nil then
|
|
||||||
player.print('[ERROR] Must specify radius!', Color.fail)
|
|
||||||
return
|
|
||||||
end
|
|
||||||
if param < 0 then
|
|
||||||
player.print('[ERROR] Value is too low.', Color.fail)
|
|
||||||
return
|
|
||||||
end
|
|
||||||
if param > 500 then
|
|
||||||
player.print('[ERROR] Value is too big.', Color.fail)
|
|
||||||
return
|
|
||||||
end
|
|
||||||
local pos = player.position
|
|
||||||
|
|
||||||
local radius = {{x = (pos.x + -param), y = (pos.y + -param)}, {x = (pos.x + param), y = (pos.y + param)}}
|
|
||||||
for _, entity in pairs(player.surface.find_entities_filtered {area = radius, type = 'corpse'}) do
|
|
||||||
if entity.corpse_expires then
|
|
||||||
entity.destroy()
|
|
||||||
end
|
|
||||||
end
|
|
||||||
player.print('Cleared biter-corpses.', Color.success)
|
|
||||||
end
|
end
|
||||||
)
|
)
|
||||||
|
|
||||||
local on_player_joined_game = function(event)
|
local on_player_joined_game = function(player)
|
||||||
local player = game.players[event.player_index]
|
|
||||||
|
|
||||||
if this.creative_enabled then
|
if this.creative_enabled then
|
||||||
if not this.players[player.index] then
|
if not this.players[player.index] then
|
||||||
Public.insert_all_items(player)
|
Public.insert_all_items(player)
|
||||||
@ -447,6 +477,17 @@ function Public.get(key)
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
function Public.set(key, value)
|
||||||
|
if key and (value or value == false) then
|
||||||
|
this[key] = value
|
||||||
|
return this[key]
|
||||||
|
elseif key then
|
||||||
|
return this[key]
|
||||||
|
else
|
||||||
|
return this
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
Event.on_init(
|
Event.on_init(
|
||||||
function()
|
function()
|
||||||
this.creative_are_you_sure = false
|
this.creative_are_you_sure = false
|
||||||
@ -464,6 +505,169 @@ function Public.reset()
|
|||||||
this.players = {}
|
this.players = {}
|
||||||
end
|
end
|
||||||
|
|
||||||
Event.add(defines.events.on_player_joined_game, on_player_joined_game)
|
----! Gui Functions ! ----
|
||||||
|
|
||||||
|
local function create_frame(player, rebuild)
|
||||||
|
local gui = player.gui
|
||||||
|
local frame = gui.screen[bottom_guis_frame]
|
||||||
|
if frame and frame.valid then
|
||||||
|
if rebuild then
|
||||||
|
frame.destroy()
|
||||||
|
else
|
||||||
|
return frame
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
frame =
|
||||||
|
player.gui.screen.add {
|
||||||
|
type = 'frame',
|
||||||
|
name = bottom_guis_frame,
|
||||||
|
direction = 'vertical'
|
||||||
|
}
|
||||||
|
frame.style.padding = 3
|
||||||
|
frame.style.minimal_height = 96
|
||||||
|
frame.style.top_padding = 4
|
||||||
|
|
||||||
|
local inner_frame =
|
||||||
|
frame.add {
|
||||||
|
type = 'frame',
|
||||||
|
direction = 'vertical'
|
||||||
|
}
|
||||||
|
inner_frame.style = 'quick_bar_inner_panel'
|
||||||
|
|
||||||
|
inner_frame.add {
|
||||||
|
type = 'sprite-button',
|
||||||
|
sprite = 'entity/behemoth-biter',
|
||||||
|
name = clear_corpse_button_name,
|
||||||
|
tooltip = {'commands.clear_corpse'},
|
||||||
|
style = 'quick_bar_page_button'
|
||||||
|
}
|
||||||
|
|
||||||
|
local bottom_quickbar_button =
|
||||||
|
inner_frame.add {
|
||||||
|
type = 'sprite-button',
|
||||||
|
name = bottom_quickbar_button_name,
|
||||||
|
style = 'quick_bar_page_button'
|
||||||
|
}
|
||||||
|
|
||||||
|
this.bottom_quickbar_button[player.index] = {name = bottom_quickbar_button_name, frame = bottom_quickbar_button}
|
||||||
|
|
||||||
|
if this.bottom_quickbar_button.sprite and this.bottom_quickbar_button.tooltip then
|
||||||
|
bottom_quickbar_button.sprite = this.bottom_quickbar_button.sprite
|
||||||
|
bottom_quickbar_button.tooltip = this.bottom_quickbar_button.tooltip
|
||||||
|
end
|
||||||
|
|
||||||
|
return frame
|
||||||
|
end
|
||||||
|
|
||||||
|
local function set_location(player)
|
||||||
|
local frame = create_frame(player)
|
||||||
|
local resolution = player.display_resolution
|
||||||
|
local scale = player.display_scale
|
||||||
|
|
||||||
|
if this.bottom_right then
|
||||||
|
frame.location = {
|
||||||
|
x = (resolution.width / 2) - ((54 + -528) * scale),
|
||||||
|
y = (resolution.height - (96 * scale))
|
||||||
|
}
|
||||||
|
else
|
||||||
|
local experimental = get_game_version()
|
||||||
|
if experimental then
|
||||||
|
frame.location = {
|
||||||
|
x = (resolution.width / 2) - ((54 + 445) * scale),
|
||||||
|
y = (resolution.height - (96 * scale))
|
||||||
|
}
|
||||||
|
else
|
||||||
|
frame.location = {
|
||||||
|
x = (resolution.width / 2) - ((54 + 258) * scale),
|
||||||
|
y = (resolution.height - (96 * scale))
|
||||||
|
}
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
--- Activates the custom buttons
|
||||||
|
---@param boolean
|
||||||
|
function Public.activate_custom_buttons(value)
|
||||||
|
if value then
|
||||||
|
this.activate_custom_buttons = value
|
||||||
|
else
|
||||||
|
this.activate_custom_buttons = false
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
--- Sets the buttons to be aligned bottom right
|
||||||
|
---@param boolean
|
||||||
|
function Public.bottom_right(value)
|
||||||
|
if value then
|
||||||
|
this.bottom_right = value
|
||||||
|
else
|
||||||
|
this.bottom_right = false
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
Gui.on_click(
|
||||||
|
clear_corpse_button_name,
|
||||||
|
function(event)
|
||||||
|
clear_corpses(event)
|
||||||
|
end
|
||||||
|
)
|
||||||
|
|
||||||
|
Event.add(
|
||||||
|
defines.events.on_player_joined_game,
|
||||||
|
function(event)
|
||||||
|
local player = game.players[event.player_index]
|
||||||
|
on_player_joined_game(player)
|
||||||
|
|
||||||
|
if this.activate_custom_buttons then
|
||||||
|
set_location(player)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
)
|
||||||
|
|
||||||
|
Event.add(
|
||||||
|
defines.events.on_player_display_resolution_changed,
|
||||||
|
function(event)
|
||||||
|
local player = game.get_player(event.player_index)
|
||||||
|
if this.activate_custom_buttons then
|
||||||
|
set_location(player)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
)
|
||||||
|
|
||||||
|
Event.add(
|
||||||
|
defines.events.on_player_respawned,
|
||||||
|
function(event)
|
||||||
|
local player = game.get_player(event.player_index)
|
||||||
|
if this.activate_custom_buttons then
|
||||||
|
set_location(player)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
)
|
||||||
|
|
||||||
|
Event.add(
|
||||||
|
defines.events.on_player_died,
|
||||||
|
function(event)
|
||||||
|
local player = game.get_player(event.player_index)
|
||||||
|
if this.activate_custom_buttons then
|
||||||
|
local frame = player.gui.screen[bottom_guis_frame]
|
||||||
|
if frame and frame.valid then
|
||||||
|
frame.destroy()
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
)
|
||||||
|
|
||||||
|
Event.add(
|
||||||
|
defines.events.on_player_display_scale_changed,
|
||||||
|
function(event)
|
||||||
|
local player = game.get_player(event.player_index)
|
||||||
|
if this.activate_custom_buttons then
|
||||||
|
set_location(player)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
)
|
||||||
|
|
||||||
|
Public.bottom_guis_frame = bottom_guis_frame
|
||||||
|
|
||||||
return Public
|
return Public
|
||||||
|
@ -15,6 +15,7 @@ require 'utils.datastore.jail_data'
|
|||||||
require 'utils.datastore.quickbar_data'
|
require 'utils.datastore.quickbar_data'
|
||||||
require 'utils.datastore.message_on_join_data'
|
require 'utils.datastore.message_on_join_data'
|
||||||
require 'utils.datastore.player_tag_data'
|
require 'utils.datastore.player_tag_data'
|
||||||
|
require 'utils.profiler'
|
||||||
require 'chatbot'
|
require 'chatbot'
|
||||||
require 'commands'
|
require 'commands'
|
||||||
require 'antigrief'
|
require 'antigrief'
|
||||||
@ -216,6 +217,7 @@ require 'modules.autostash'
|
|||||||
---------------------------------------------------------------
|
---------------------------------------------------------------
|
||||||
|
|
||||||
---------------- MOSTLY TERRAIN LAYOUTS HERE ----------------
|
---------------- MOSTLY TERRAIN LAYOUTS HERE ----------------
|
||||||
|
--require 'terrain_layouts.winter'
|
||||||
--require 'terrain_layouts.caves'
|
--require 'terrain_layouts.caves'
|
||||||
--require 'terrain_layouts.cone_to_east'
|
--require 'terrain_layouts.cone_to_east'
|
||||||
--require 'terrain_layouts.biters_and_resources_east'
|
--require 'terrain_layouts.biters_and_resources_east'
|
||||||
|
2
locale/de/commands.cfg
Normal file
2
locale/de/commands.cfg
Normal file
@ -0,0 +1,2 @@
|
|||||||
|
[commands]
|
||||||
|
clear_corpse=Klicken Sie hier, um Leichen zu löschen!
|
@ -1,107 +0,0 @@
|
|||||||
[mountain_fortress_v3]
|
|
||||||
map_info_main_caption=M O U N T A I N F O R T R E S S V3
|
|
||||||
map_info_sub_caption= ~~ diggy diggy choo choo ~~
|
|
||||||
map_info_text=The biters have caught the scent of fish in the cargo wagon.\nGuide the choo into the mountain and protect it as long as possible!\nThis however will not be an easy task,\nsince their strength and numbers increase over time.\n\nIn additon, the southern grounds collapse over time.\n\nDelve deep for greater treasures, but also face increased dangers.\nMining productivity research, will overhaul your mining equipment,\nreinforcing your pickaxe as well as increasing the size of your backpack.\n\nAs you dig, you will encounter impassable dark chasms or rivers.\nArtillery will try to shoot you down! Dig fast, dig north!\n\nSome explosives may cause parts of the ceiling to crumble, filling the void, creating new ways.\nAll they need is a container and a well aimed shot.\n\nEnter the cargo wagon to reveal the wagon surface!\n\nRandom buildings that generate resources can be found throughout the world.\n\nPlacing steel-chests near cargo-wagons enables you to quickly move content.\n\nStaying inside the locomotive aura prevents biters from spawning when mining entities.\n\nRPG GUI is disabled inside the locomotive.\nDisconnecting wagons is disabled.\nYou can´t cancel crafting when standing inside the locomotive aura.\n\nDon't try to run north with your Spidertron if the train is not near you.\nYou have been warned.\n\nGood luck on your journey!
|
|
||||||
|
|
||||||
[breached_wall]
|
|
||||||
collapse_start=[color=blue]Mapkeeper:[/color]\nWarning, Collapse has begun!
|
|
||||||
spidertron_unlocked=[color=blue]Mapkeeper:[/color]\nAttention! Spidertron has been unlocked at the main market!
|
|
||||||
wall_breached=[color=blue]Mapkeeper:[/color]\nSurvivor! Well done. You have completed zone __1__!
|
|
||||||
first_to_reach=[color=blue]Mapkeeper:[/color]\n__1__ was the first to reach zone __2__.
|
|
||||||
artillery_warning=[color=blue]Mapkeeper:[/color]\nWarning, Artillery have been spotted north!
|
|
||||||
cheating_through=__1__ tried to cheat their way north with their spidertron!
|
|
||||||
|
|
||||||
[entity]
|
|
||||||
treasure_1=You notice an old crate within the rubble. It's filled with treasure!
|
|
||||||
treasure_2=You find a chest underneath the broken rocks. It's filled with goodies!
|
|
||||||
treasure_3=We has found the precious!
|
|
||||||
treasure_rare_1=Your magic improves. You have found a chest that is filled with rare treasures!
|
|
||||||
treasure_rare_2=Oh how wonderful. You found a chest underneath the broken rocks. It's filled with rare goodies!
|
|
||||||
treasure_rare_3=You're a wizard! We have found the rare precious!
|
|
||||||
defeated_1=[color=blue]Mapkeeper:[/color]\nOh no, the biters nom'ed the train away!\nBetter luck next time.
|
|
||||||
defeated_2=[color=blue]Mapkeeper:[/color]\nI'm not 100% sure, but - apparently the train was chewed away.\nBetter luck next time.
|
|
||||||
defeated_3=[color=blue]Mapkeeper:[/color]\nYou had one objective - defend the train *-*\nBetter luck next time.
|
|
||||||
defeated_4=[color=blue]Mapkeeper:[/color]\nLooks like we're resetting cause you did not defend the train ._.\nBetter luck next time.
|
|
||||||
reset_game=*** Soft-reset is disabled! Server will restart from scenario to load new changes. ***
|
|
||||||
notify_restart=Soft-reset is disabled! Server will restart from scenario to load new changes.
|
|
||||||
shutdown_game=*** Soft-reset is disabled! Server will shutdown. Most likely because of updates. ***
|
|
||||||
notify_shutdown=Soft-reset is disabled! Server will shutdown. Most likely because of updates.
|
|
||||||
train_taking_damage=[color=blue]Comfylatron:[/color]\nTrain is taking heavy damage.\nDeploying defense mechanisms.
|
|
||||||
entity_limit_reached=__1__ limit reached. Purchase more slots at the market!
|
|
||||||
found_car=__1__ has found a car underneath the rumble!
|
|
||||||
|
|
||||||
|
|
||||||
[gui]
|
|
||||||
global_pool_tooltip=Dig, handcraft or run to increase the pool!
|
|
||||||
global_pool_amount=Amount of XP that is stored inside the global xp pool.\nRaw Value: __1__
|
|
||||||
amount_harvested=Amount of trees/rocks harvested.
|
|
||||||
biters_killed=Amount of biters killed.
|
|
||||||
land_mine_placed=Amount of land-mines that can be built.
|
|
||||||
chest_placed=Amount of chests that can be placed near train.
|
|
||||||
flamethrowers_placed=Amount of flamethrower-turrets that can be built.
|
|
||||||
train_upgrades=Amount of train upgrades.
|
|
||||||
info_tooltip=Shows statistics!
|
|
||||||
hide_minimap=Hide locomotive minimap!
|
|
||||||
current_pickaxe_tier=The team currently has the __1__ pickaxe tier.\nBonus speed is: __2__%
|
|
||||||
|
|
||||||
[locomotive]
|
|
||||||
upgrades=Upgrades:
|
|
||||||
items=Items:
|
|
||||||
shoo=^-^ Please don´t shoo at me ^-^
|
|
||||||
not_trusted=You need to be trusted to purchase this.
|
|
||||||
coins_left=Coins left: __1__
|
|
||||||
market_name=Market
|
|
||||||
search_text=Search:
|
|
||||||
quantity_text=Quantity:
|
|
||||||
limit_reached=Max limit reached!
|
|
||||||
chests_full=You can't purchase more chests.
|
|
||||||
chest_bought_info=__1__ __2__ has bought the chest limit upgrade for __3__ coins.
|
|
||||||
health_bought_info=__1__ __2__ has bought the locomotive health modifier for __3__ coins.
|
|
||||||
aura_bought_info=__1__ __2__ has bought the locomotive xp aura modifier for __3__ coins.
|
|
||||||
xp_bought_info=__1__ __2__ has bought the XP points modifier for __3__ coins.
|
|
||||||
reroll_bought_info=__1__ __2__ has rerolled the market items for __3__ coins.
|
|
||||||
pickaxe_bought_info=__1__ __2__ has upgraded the teams pickaxe to tier __3__ for __4__ coins.
|
|
||||||
explosive_bullet_bought_info=__1__ __2__ has bought the explosive bullet modifier for __3__ coins.
|
|
||||||
one_flamethrower_bought_info=__1__ __2__ has bought a flamethrower-turret slot for __3__ coins.
|
|
||||||
multiple_flamethrower_bought_info=__1__ __2__ has bought __3__ flamethrower-turret slot for __4__ coins.
|
|
||||||
landmine_bought_info=__1__ __2__ has bought a landmine slot for __3__ coins.
|
|
||||||
rpg_reset_bought_info=__1__ __2__ decided to recycle their RPG skills and start over for __3__ coins.
|
|
||||||
full_inventory=Your pockets are now filled to the brim. So you've only bought __1__ __2__(s).
|
|
||||||
change_returned=Shopkeeper has returned your change, for which you are infinitely grateful.
|
|
||||||
notify_full_inventory_1=Your inventory is full. Try to stash your loot somewhere first.
|
|
||||||
notify_full_inventory_2=Your inventory is full. Join the warrior club today! Pump that STR stat some more!
|
|
||||||
new_items_at_market=New items have been unlocked at the locomotive market!
|
|
||||||
|
|
||||||
|
|
||||||
[main_market]
|
|
||||||
chest=Upgrades the amount of chests that can be placed outside.\nCan be purchased multiple times.
|
|
||||||
locomotive_max_health=Upgrades the train health.\nCan be purchased multiple times.
|
|
||||||
locomotive_xp_aura=Upgrades the XP aura that is around the train.
|
|
||||||
xp_points_boost=Upgrades the amount of XP points you get inside the XP aura
|
|
||||||
explosive_bullets=Upgrades ordinary SMG ammo to explosive bullets.
|
|
||||||
reroll_market_items=Will reroll the items in the market and shuffle prices.
|
|
||||||
purchase_pickaxe=Upgrade the teams Pickaxe to tier: __1__
|
|
||||||
sold_out=Sold out!
|
|
||||||
flamethrower_turret=Upgrades the amount of flamethrowers that can be placed.
|
|
||||||
land_mine=Upgrades the amount of landmines that can be placed.
|
|
||||||
skill_reset=For when you have picked the wrong RPG path and want to start over.\nPoints will be kept.
|
|
||||||
car=Portable Car Surface\nCan be killed easily.
|
|
||||||
tank=Portable Tank Surface\nChonk tank, can resist heavy damage.
|
|
||||||
tank_cannon_na=Tank Cannon\nAvailable after wave 650.
|
|
||||||
tank_machine_gun_na=Tank Machine Gun\nAvailable after wave 400.
|
|
||||||
vehicle_machine_gun_na=Car Machine Gun\nAvailable after wave 200.
|
|
||||||
|
|
||||||
[main]
|
|
||||||
death_message_1=__1__ should have watched where they walked!
|
|
||||||
death_message_2=__1__ was not careful enough!
|
|
||||||
death_message_3=__1__ angered the overlords!
|
|
||||||
death_message_4=__1__ tried to walk the simple path!
|
|
||||||
death_message_5=__1__ melted away!
|
|
||||||
death_message_6=__1__ got obliterated!
|
|
||||||
death_message_7=__1__ tried to cheat their way north!
|
|
||||||
forcefield=Forcefield does not approve.
|
|
||||||
greeting=[color=blue]Comfylatron:[/color]\nGreetings, __1__!\nPlease read the map info.
|
|
||||||
cleaner=[color=blue]Cleaner:[/color]\n__1__ has left his goodies! Be quick and fetch them!
|
|
||||||
reset_in=Game will __1__ in __2__ seconds!
|
|
||||||
diff_set=Difficulty has been set! Game has been set to: [color=green]__1__[/color]
|
|
||||||
diff_tooltip=Wave Defense is based on amount of players.\nXP Extra reward points: __1__.\nMining speed boosted: __2__.\nRunning speed boosted: __3__.\nCrafting speed boosted: __4__.\nCoin amount per harvest: __5__.\nFlame Turret limit: __6__.\nLandmine limit: __7__.\nLocomotive health: __8__.\nHidden Treasure has __9__ chance to spawn.\nGrace period: __10__ minutes\nSpidertrons unlocks at zone __11__.
|
|
@ -1,103 +0,0 @@
|
|||||||
[rpg_main]
|
|
||||||
no_valid_surface=No surface name given
|
|
||||||
flame_boots_worn_out=Your flame boots have worn out.
|
|
||||||
flame_mana_remaining=Mana remaining: __1__
|
|
||||||
one_punch_text=ONE PUNCH
|
|
||||||
mana_casting_too_fast=There was a lot more to magic, as __1__ quickly found out, than waving their wand and saying a few funny words.
|
|
||||||
low_level=You lack the level to cast this spell.
|
|
||||||
not_inside_pos=You wave your wand but realize that it´s out of reach.
|
|
||||||
no_mana=You don´t have enough mana to cast this spell.
|
|
||||||
suicidal_comfylatron=You wave your wand and __1__ is on the run!
|
|
||||||
warped_ok=Warped home with minor bruises.
|
|
||||||
object_spawned=You wave your wand and __1__ appears.
|
|
||||||
out_of_reach=Can´t create entity at given location.
|
|
||||||
|
|
||||||
[rpg_functions]
|
|
||||||
max_level=[color=blue]Level Limit:[/color]\nYou have hit the max level for the current zone.
|
|
||||||
pool_reward=[color=blue]Global Pool Reward:[/color]\n __1__ received nothing. Reason: AFK
|
|
||||||
|
|
||||||
[rpg_gui]
|
|
||||||
gain_info_tooltip=XP gain from mining, moving, crafting, repairing and combat.
|
|
||||||
allocate_info=Right-click to allocate __1__ points.\nShift + click to allocate all points.
|
|
||||||
player_name=Hello __1__!
|
|
||||||
class_info=You're a __1__.
|
|
||||||
settings_frame=Configure your RPG player-settings here!
|
|
||||||
level_limit=Current max level limit for this zone is: __1__\nIncreases by breaching walls/zones.
|
|
||||||
settings_name=SETTINGS
|
|
||||||
level_name=LEVEL
|
|
||||||
experience_name=EXPERIENCE
|
|
||||||
next_level_name=NEXT LEVEL
|
|
||||||
strength_name=STRENGTH
|
|
||||||
strength_tooltip=Increases inventory slots, mining speed.\nIncreases melee damage and amount of robot followers.
|
|
||||||
magic_name=MAGIC
|
|
||||||
magic_tooltip=Increases reach distance.\nIncreases repair speed. Enables spawning entities.
|
|
||||||
dexterity_name=DEXTERITY
|
|
||||||
dexterity_tooltip=Increases running and crafting speed.
|
|
||||||
vitality_name=VITALITY
|
|
||||||
vitality_tooltip=Increases health.\nIncreases melee life on-hit.
|
|
||||||
points_to_dist=POINTS TO\nDISTRIBUTE
|
|
||||||
life_name=LIFE
|
|
||||||
life_tooltip=Your current health
|
|
||||||
life_increase=Current life. Increase it by adding vitality.
|
|
||||||
life_maximum=This is your maximum life.
|
|
||||||
shield_name=SHIELD
|
|
||||||
shield_no_shield=You don't have any shield.
|
|
||||||
shield_no_armor=This is your current shield. You aren't wearing any armor.
|
|
||||||
shield_tooltip=Shield protects you and heightens your resistance.
|
|
||||||
shield_current=Current shield value of the equipment.
|
|
||||||
shield_max=Maximum shield value.
|
|
||||||
mana_name=MANA
|
|
||||||
mana_bonus=MANA\nBONUS
|
|
||||||
mana_regen_bonus=Mana regen bonus: __1__
|
|
||||||
mana_tooltip=Mana lets you spawn entities by eating fish.
|
|
||||||
mana_regen_current=This is your current mana. You can increase the regen by increasing your magic skills.
|
|
||||||
mana_max_limit=This is your max mana. You have reached the max mana limit.
|
|
||||||
mana_max=This is your max mana. You can increase the regen by increasing your magic skills.
|
|
||||||
mining_name=MINING\nSPEED
|
|
||||||
slot_name=SLOT\nBONUS
|
|
||||||
melee_name=MELEE\nDAMAGE
|
|
||||||
one_punch_chance=Life on-hit: __1__\nOne punch chance: __2__ %
|
|
||||||
one_punch_disabled=One Punch is disabled.
|
|
||||||
bonus_tooltip=Reach distance bonus: __1__\nBuild distance bonus: __2__\nItem drop distance bonus: __3__\nLoot pickup distance bonus: __4__\nItem pickup distance bonus: __5__\nResource reach distance bonus: __6__\nRepair speed: __7__
|
|
||||||
reach_distance=REACH\nDISTANCE
|
|
||||||
crafting_speed=CRAFTING\nSPEED
|
|
||||||
running_speed=RUNNING\nSPEED
|
|
||||||
health_bonus_name=HEALTH\nBONUS
|
|
||||||
health_tooltip=Health regen bonus: __1__
|
|
||||||
|
|
||||||
|
|
||||||
[rpg_settings]
|
|
||||||
name=RPG Settings
|
|
||||||
save_changes=Save changes
|
|
||||||
discard_changes=Discard changes
|
|
||||||
not_trusted=Not trusted.\nChecked: true\nUnchecked: false
|
|
||||||
low_level=Level requirement: __1__
|
|
||||||
used_up=All used up!
|
|
||||||
no_mana=Not enough mana!
|
|
||||||
mana_label=Mana Settings:
|
|
||||||
tooltip_check=Checked: true\nUnchecked: false
|
|
||||||
info_text_label=Common RPG settings. These settings are per player basis.
|
|
||||||
health_text_label=Show health/mana bar?
|
|
||||||
health_only_text_label=Show health bar?
|
|
||||||
reset_text_label=Reset your skillpoints?
|
|
||||||
reset_tooltip=ONE-TIME reset if you picked the wrong path (this will keep your points)
|
|
||||||
reach_text_label=Enable reach bonus?
|
|
||||||
reach_text_tooltip=Don´t feeling like picking up others people loot?\nYou can toggle it here.
|
|
||||||
movement_text_label=Enable movement speed bonus?
|
|
||||||
movement_text_tooltip=Don´t feeling like running like the flash?\nYou can toggle it here.
|
|
||||||
stone_path_label=Enable stone-path when mining?
|
|
||||||
stone_path_tooltip=Enabling this will automatically create stone-path when you mine.
|
|
||||||
one_punch_label=Enable one-punch?
|
|
||||||
one_punch_tooltip=Enabling this will have a chance of one-punching biters.
|
|
||||||
one_punch_globally=Enabled globally.
|
|
||||||
flameboots_label=Enable flame boots?
|
|
||||||
flameboots_tooltip=When the bullets simply don´t bite.
|
|
||||||
magic_label=Enable spawning with raw-fish?
|
|
||||||
magic_tooltip=When simply constructing items is not enough.\nNOTE! Use Raw-fish to cast spells.
|
|
||||||
magic_spell=Select what entity to spawn
|
|
||||||
magic_item_requirement=__1__ [item=__2__] requires __3__ mana to cast. Level: __4__\n
|
|
||||||
magic_entity_requirement=__1__ [entity=__2__] requires __3__ mana to cast. Level: __4__\n
|
|
||||||
magic_special_requirement=__1__ __2__ requires __3__ mana to cast. Level: __4__\n
|
|
||||||
allocation_settings_label=Allocations Settings:
|
|
||||||
allocation_label=Select what skill to auto-allocate.
|
|
||||||
allocation_tooltip=This will automatically allocate all available points to the given node.
|
|
2
locale/en/commands.cfg
Normal file
2
locale/en/commands.cfg
Normal file
@ -0,0 +1,2 @@
|
|||||||
|
[commands]
|
||||||
|
clear_corpse=Click to clear corpses!
|
@ -43,6 +43,8 @@ train_upgrades=Amount of train upgrades.
|
|||||||
info_tooltip=Shows statistics!
|
info_tooltip=Shows statistics!
|
||||||
hide_minimap=Hide locomotive minimap!
|
hide_minimap=Hide locomotive minimap!
|
||||||
current_pickaxe_tier=The team currently has the __1__ pickaxe tier.\nBonus speed is: __2__%
|
current_pickaxe_tier=The team currently has the __1__ pickaxe tier.\nBonus speed is: __2__%
|
||||||
|
map_on=Automatically show map ON
|
||||||
|
map_off=OFF
|
||||||
|
|
||||||
[locomotive]
|
[locomotive]
|
||||||
upgrades=Upgrades:
|
upgrades=Upgrades:
|
||||||
|
@ -101,3 +101,20 @@ magic_special_requirement=__1__ __2__ requires __3__ mana to cast. Level: __4__\
|
|||||||
allocation_settings_label=Allocations Settings:
|
allocation_settings_label=Allocations Settings:
|
||||||
allocation_label=Select what skill to auto-allocate.
|
allocation_label=Select what skill to auto-allocate.
|
||||||
allocation_tooltip=This will automatically allocate all available points to the given node.
|
allocation_tooltip=This will automatically allocate all available points to the given node.
|
||||||
|
|
||||||
|
|
||||||
|
[spells]
|
||||||
|
acid_stream=Bitter Spew
|
||||||
|
railgun_beam=Shoop Da Whoop!!
|
||||||
|
raw_fish=Conjure Raw-fish
|
||||||
|
comfylatron=Suicidal Comfylatron
|
||||||
|
distractor=Distractor Capsule
|
||||||
|
warp=Warp Gate
|
||||||
|
|
||||||
|
|
||||||
|
[allocations]
|
||||||
|
deactivated=Deactivated
|
||||||
|
str=Strength
|
||||||
|
mag=Magicka
|
||||||
|
dex=Dexterity
|
||||||
|
vit=Vitality
|
||||||
|
2
locale/ru/commands.cfg
Normal file
2
locale/ru/commands.cfg
Normal file
@ -0,0 +1,2 @@
|
|||||||
|
[commands]
|
||||||
|
clear_corpse=Нажмите, чтобы убрать трупы!
|
@ -1,108 +0,0 @@
|
|||||||
[mountain_fortress_v3]
|
|
||||||
map_info_main_caption=M O U N T A I N F O R T R E S S V3
|
|
||||||
map_info_sub_caption= ~~ diggy diggy choo choo ~~
|
|
||||||
map_info_text=The biters have caught the scent of fish in the cargo wagon.\nGuide the choo into the mountain and protect it as long as possible!\nThis however will not be an easy task,\nsince their strength and numbers increase over time.\n\nIn additon, the southern grounds collapse over time.\n\nDelve deep for greater treasures, but also face increased dangers.\nMining productivity research, will overhaul your mining equipment,\nreinforcing your pickaxe as well as increasing the size of your backpack.\n\nAs you dig, you will encounter impassable dark chasms or rivers.\nArtillery will try to shoot you down! Dig fast, dig north!\n\nSome explosives may cause parts of the ceiling to crumble, filling the void, creating new ways.\nAll they need is a container and a well aimed shot.\n\nEnter the cargo wagon to reveal the wagon surface!\n\nRandom buildings that generate resources can be found throughout the world.\n\nPlacing steel-chests near cargo-wagons enables you to quickly move content.\n\nStaying inside the locomotive aura prevents biters from spawning when mining entities.\n\nRPG GUI is disabled inside the locomotive.\nDisconnecting wagons is disabled.\nYou can´t cancel crafting when standing inside the locomotive aura.\n\nDon't try to run north with your Spidertron if the train is not near you.\nYou have been warned.\n\nGood luck on your journey!
|
|
||||||
|
|
||||||
|
|
||||||
[breached_wall]
|
|
||||||
collapse_start=[color=blue]Mapkeeper:[/color]\nWarning, Collapse has begun!
|
|
||||||
spidertron_unlocked=[color=blue]Mapkeeper:[/color]\nAttention! Spidertron has been unlocked at the main market!
|
|
||||||
wall_breached=[color=blue]Mapkeeper:[/color]\nSurvivor! Well done. You have completed zone __1__!
|
|
||||||
first_to_reach=[color=blue]Mapkeeper:[/color]\n__1__ was the first to reach zone __2__.
|
|
||||||
artillery_warning=[color=blue]Mapkeeper:[/color]\nWarning, Artillery have been spotted north!
|
|
||||||
cheating_through=__1__ tried to cheat their way north with their spidertron!
|
|
||||||
|
|
||||||
[entity]
|
|
||||||
treasure_1=You notice an old crate within the rubble. It's filled with treasure!
|
|
||||||
treasure_2=You find a chest underneath the broken rocks. It's filled with goodies!
|
|
||||||
treasure_3=We has found the precious!
|
|
||||||
treasure_rare_1=Your magic improves. You have found a chest that is filled with rare treasures!
|
|
||||||
treasure_rare_2=Oh how wonderful. You found a chest underneath the broken rocks. It's filled with rare goodies!
|
|
||||||
treasure_rare_3=You're a wizard! We have found the rare precious!
|
|
||||||
defeated_1=[color=blue]Mapkeeper:[/color]\nOh no, the biters nom'ed the train away!\nBetter luck next time.
|
|
||||||
defeated_2=[color=blue]Mapkeeper:[/color]\nI'm not 100% sure, but - apparently the train was chewed away.\nBetter luck next time.
|
|
||||||
defeated_3=[color=blue]Mapkeeper:[/color]\nYou had one objective - defend the train *-*\nBetter luck next time.
|
|
||||||
defeated_4=[color=blue]Mapkeeper:[/color]\nLooks like we're resetting cause you did not defend the train ._.\nBetter luck next time.
|
|
||||||
reset_game=*** Soft-reset is disabled! Server will restart from scenario to load new changes. ***
|
|
||||||
notify_restart=Soft-reset is disabled! Server will restart from scenario to load new changes.
|
|
||||||
shutdown_game=*** Soft-reset is disabled! Server will shutdown. Most likely because of updates. ***
|
|
||||||
notify_shutdown=Soft-reset is disabled! Server will shutdown. Most likely because of updates.
|
|
||||||
train_taking_damage=[color=blue]Comfylatron:[/color]\nTrain is taking heavy damage.\nDeploying defense mechanisms.
|
|
||||||
entity_limit_reached=__1__ limit reached. Purchase more slots at the market!
|
|
||||||
found_car=__1__ has found a car underneath the rumble!
|
|
||||||
|
|
||||||
|
|
||||||
[gui]
|
|
||||||
global_pool_tooltip=Dig, handcraft or run to increase the pool!
|
|
||||||
global_pool_amount=Amount of XP that is stored inside the global xp pool.\nRaw Value: __1__
|
|
||||||
amount_harvested=Amount of trees/rocks harvested.
|
|
||||||
biters_killed=Amount of biters killed.
|
|
||||||
land_mine_placed=Amount of land-mines that can be built.
|
|
||||||
chest_placed=Amount of chests that can be placed near train.
|
|
||||||
flamethrowers_placed=Amount of flamethrower-turrets that can be built.
|
|
||||||
train_upgrades=Amount of train upgrades.
|
|
||||||
info_tooltip=Shows statistics!
|
|
||||||
hide_minimap=Hide locomotive minimap!
|
|
||||||
current_pickaxe_tier=The team currently has the __1__ pickaxe tier.\nBonus speed is: __2__%
|
|
||||||
|
|
||||||
[locomotive]
|
|
||||||
upgrades=Upgrades:
|
|
||||||
items=Items:
|
|
||||||
shoo=^-^ Please don´t shoo at me ^-^
|
|
||||||
not_trusted=You need to be trusted to purchase this.
|
|
||||||
coins_left=Coins left: __1__
|
|
||||||
market_name=Market
|
|
||||||
search_text=Search:
|
|
||||||
quantity_text=Quantity:
|
|
||||||
limit_reached=Max limit reached!
|
|
||||||
chests_full=You can't purchase more chests.
|
|
||||||
chest_bought_info=__1__ __2__ has bought the chest limit upgrade for __3__ coins.
|
|
||||||
health_bought_info=__1__ __2__ has bought the locomotive health modifier for __3__ coins.
|
|
||||||
aura_bought_info=__1__ __2__ has bought the locomotive xp aura modifier for __3__ coins.
|
|
||||||
xp_bought_info=__1__ __2__ has bought the XP points modifier for __3__ coins.
|
|
||||||
reroll_bought_info=__1__ __2__ has rerolled the market items for __3__ coins.
|
|
||||||
pickaxe_bought_info=__1__ __2__ has upgraded the teams pickaxe to tier __3__ for __4__ coins.
|
|
||||||
explosive_bullet_bought_info=__1__ __2__ has bought the explosive bullet modifier for __3__ coins.
|
|
||||||
one_flamethrower_bought_info=__1__ __2__ has bought a flamethrower-turret slot for __3__ coins.
|
|
||||||
multiple_flamethrower_bought_info=__1__ __2__ has bought __3__ flamethrower-turret slot for __4__ coins.
|
|
||||||
landmine_bought_info=__1__ __2__ has bought a landmine slot for __3__ coins.
|
|
||||||
rpg_reset_bought_info=__1__ __2__ decided to recycle their RPG skills and start over for __3__ coins.
|
|
||||||
full_inventory=Your pockets are now filled to the brim. So you've only bought __1__ __2__(s).
|
|
||||||
change_returned=Shopkeeper has returned your change, for which you are infinitely grateful.
|
|
||||||
notify_full_inventory_1=Your inventory is full. Try to stash your loot somewhere first.
|
|
||||||
notify_full_inventory_2=Your inventory is full. Join the warrior club today! Pump that STR stat some more!
|
|
||||||
new_items_at_market=New items have been unlocked at the locomotive market!
|
|
||||||
|
|
||||||
|
|
||||||
[main_market]
|
|
||||||
chest=Upgrades the amount of chests that can be placed outside.\nCan be purchased multiple times.
|
|
||||||
locomotive_max_health=Upgrades the train health.\nCan be purchased multiple times.
|
|
||||||
locomotive_xp_aura=Upgrades the XP aura that is around the train.
|
|
||||||
xp_points_boost=Upgrades the amount of XP points you get inside the XP aura
|
|
||||||
explosive_bullets=Upgrades ordinary SMG ammo to explosive bullets.
|
|
||||||
reroll_market_items=Will reroll the items in the market and shuffle prices.
|
|
||||||
purchase_pickaxe=Upgrade the teams Pickaxe to tier: __1__
|
|
||||||
sold_out=Sold out!
|
|
||||||
flamethrower_turret=Upgrades the amount of flamethrowers that can be placed.
|
|
||||||
land_mine=Upgrades the amount of landmines that can be placed.
|
|
||||||
skill_reset=For when you have picked the wrong RPG path and want to start over.\nPoints will be kept.
|
|
||||||
car=Portable Car Surface\nCan be killed easily.
|
|
||||||
tank=Portable Tank Surface\nChonk tank, can resist heavy damage.
|
|
||||||
tank_cannon_na=Tank Cannon\nAvailable after wave 650.
|
|
||||||
tank_machine_gun_na=Tank Machine Gun\nAvailable after wave 400.
|
|
||||||
vehicle_machine_gun_na=Car Machine Gun\nAvailable after wave 200.
|
|
||||||
|
|
||||||
[main]
|
|
||||||
death_message_1=__1__ should have watched where they walked!
|
|
||||||
death_message_2=__1__ was not careful enough!
|
|
||||||
death_message_3=__1__ angered the overlords!
|
|
||||||
death_message_4=__1__ tried to walk the simple path!
|
|
||||||
death_message_5=__1__ melted away!
|
|
||||||
death_message_6=__1__ got obliterated!
|
|
||||||
death_message_7=__1__ tried to cheat their way north!
|
|
||||||
forcefield=Forcefield does not approve.
|
|
||||||
greeting=[color=blue]Comfylatron:[/color]\nGreetings, __1__!\nPlease read the map info.
|
|
||||||
cleaner=[color=blue]Cleaner:[/color]\n__1__ has left his goodies! Be quick and fetch them!
|
|
||||||
reset_in=Game will __1__ in __2__ seconds!
|
|
||||||
diff_set=Difficulty has been set! Game has been set to: [color=green]__1__[/color]
|
|
||||||
diff_tooltip=Wave Defense is based on amount of players.\nXP Extra reward points: __1__.\nMining speed boosted: __2__.\nRunning speed boosted: __3__.\nCrafting speed boosted: __4__.\nCoin amount per harvest: __5__.\nFlame Turret limit: __6__.\nLandmine limit: __7__.\nLocomotive health: __8__.\nHidden Treasure has __9__ chance to spawn.\nGrace period: __10__ minutes\nSpidertrons unlocks at zone __11__.
|
|
@ -1,103 +0,0 @@
|
|||||||
[rpg_main]
|
|
||||||
no_valid_surface=No surface name given
|
|
||||||
flame_boots_worn_out=Your flame boots have worn out.
|
|
||||||
flame_mana_remaining=Mana remaining: __1__
|
|
||||||
one_punch_text=ONE PUNCH
|
|
||||||
mana_casting_too_fast=There was a lot more to magic, as __1__ quickly found out, than waving their wand and saying a few funny words.
|
|
||||||
low_level=You lack the level to cast this spell.
|
|
||||||
not_inside_pos=You wave your wand but realize that it´s out of reach.
|
|
||||||
no_mana=You don´t have enough mana to cast this spell.
|
|
||||||
suicidal_comfylatron=You wave your wand and __1__ is on the run!
|
|
||||||
warped_ok=Warped home with minor bruises.
|
|
||||||
object_spawned=You wave your wand and __1__ appears.
|
|
||||||
out_of_reach=Can´t create entity at given location.
|
|
||||||
|
|
||||||
[rpg_functions]
|
|
||||||
max_level=[color=blue]Level Limit:[/color]\nYou have hit the max level for the current zone.
|
|
||||||
pool_reward=[color=blue]Global Pool Reward:[/color]\n __1__ received nothing. Reason: AFK
|
|
||||||
|
|
||||||
[rpg_gui]
|
|
||||||
gain_info_tooltip=XP gain from mining, moving, crafting, repairing and combat.
|
|
||||||
allocate_info=Right-click to allocate __1__ points.\nShift + click to allocate all points.
|
|
||||||
player_name=Hello __1__!
|
|
||||||
class_info=You're a __1__.
|
|
||||||
settings_frame=Configure your RPG player-settings here!
|
|
||||||
level_limit=Current max level limit for this zone is: __1__\nIncreases by breaching walls/zones.
|
|
||||||
settings_name=SETTINGS
|
|
||||||
level_name=LEVEL
|
|
||||||
experience_name=EXPERIENCE
|
|
||||||
next_level_name=NEXT LEVEL
|
|
||||||
strength_name=STRENGTH
|
|
||||||
strength_tooltip=Increases inventory slots, mining speed.\nIncreases melee damage and amount of robot followers.
|
|
||||||
magic_name=MAGIC
|
|
||||||
magic_tooltip=Increases reach distance.\nIncreases repair speed. Enables spawning entities.
|
|
||||||
dexterity_name=DEXTERITY
|
|
||||||
dexterity_tooltip=Increases running and crafting speed.
|
|
||||||
vitality_name=VITALITY
|
|
||||||
vitality_tooltip=Increases health.\nIncreases melee life on-hit.
|
|
||||||
points_to_dist=POINTS TO\nDISTRIBUTE
|
|
||||||
life_name=LIFE
|
|
||||||
life_tooltip=Your current health
|
|
||||||
life_increase=Current life. Increase it by adding vitality.
|
|
||||||
life_maximum=This is your maximum life.
|
|
||||||
shield_name=SHIELD
|
|
||||||
shield_no_shield=You don't have any shield.
|
|
||||||
shield_no_armor=This is your current shield. You aren't wearing any armor.
|
|
||||||
shield_tooltip=Shield protects you and heightens your resistance.
|
|
||||||
shield_current=Current shield value of the equipment.
|
|
||||||
shield_max=Maximum shield value.
|
|
||||||
mana_name=MANA
|
|
||||||
mana_bonus=MANA\nBONUS
|
|
||||||
mana_regen_bonus=Mana regen bonus: __1__
|
|
||||||
mana_tooltip=Mana lets you spawn entities by eating fish.
|
|
||||||
mana_regen_current=This is your current mana. You can increase the regen by increasing your magic skills.
|
|
||||||
mana_max_limit=This is your max mana. You have reached the max mana limit.
|
|
||||||
mana_max=This is your max mana. You can increase the regen by increasing your magic skills.
|
|
||||||
mining_name=MINING\nSPEED
|
|
||||||
slot_name=SLOT\nBONUS
|
|
||||||
melee_name=MELEE\nDAMAGE
|
|
||||||
one_punch_chance=Life on-hit: __1__\nOne punch chance: __2__ %
|
|
||||||
one_punch_disabled=One Punch is disabled.
|
|
||||||
bonus_tooltip=Reach distance bonus: __1__\nBuild distance bonus: __2__\nItem drop distance bonus: __3__\nLoot pickup distance bonus: __4__\nItem pickup distance bonus: __5__\nResource reach distance bonus: __6__\nRepair speed: __7__
|
|
||||||
reach_distance=REACH\nDISTANCE
|
|
||||||
crafting_speed=CRAFTING\nSPEED
|
|
||||||
running_speed=RUNNING\nSPEED
|
|
||||||
health_bonus_name=HEALTH\nBONUS
|
|
||||||
health_tooltip=Health regen bonus: __1__
|
|
||||||
|
|
||||||
|
|
||||||
[rpg_settings]
|
|
||||||
name=RPG Settings
|
|
||||||
save_changes=Save changes
|
|
||||||
discard_changes=Discard changes
|
|
||||||
not_trusted=Not trusted.\nChecked: true\nUnchecked: false
|
|
||||||
low_level=Level requirement: __1__
|
|
||||||
used_up=All used up!
|
|
||||||
no_mana=Not enough mana!
|
|
||||||
mana_label=Mana Settings:
|
|
||||||
tooltip_check=Checked: true\nUnchecked: false
|
|
||||||
info_text_label=Common RPG settings. These settings are per player basis.
|
|
||||||
health_text_label=Show health/mana bar?
|
|
||||||
health_only_text_label=Show health bar?
|
|
||||||
reset_text_label=Reset your skillpoints?
|
|
||||||
reset_tooltip=ONE-TIME reset if you picked the wrong path (this will keep your points)
|
|
||||||
reach_text_label=Enable reach bonus?
|
|
||||||
reach_text_tooltip=Don´t feeling like picking up others people loot?\nYou can toggle it here.
|
|
||||||
movement_text_label=Enable movement speed bonus?
|
|
||||||
movement_text_tooltip=Don´t feeling like running like the flash?\nYou can toggle it here.
|
|
||||||
stone_path_label=Enable stone-path when mining?
|
|
||||||
stone_path_tooltip=Enabling this will automatically create stone-path when you mine.
|
|
||||||
one_punch_label=Enable one-punch?
|
|
||||||
one_punch_tooltip=Enabling this will have a chance of one-punching biters.
|
|
||||||
one_punch_globally=Enabled globally.
|
|
||||||
flameboots_label=Enable flame boots?
|
|
||||||
flameboots_tooltip=When the bullets simply don´t bite.
|
|
||||||
magic_label=Enable spawning with raw-fish?
|
|
||||||
magic_tooltip=When simply constructing items is not enough.\nNOTE! Use Raw-fish to cast spells.
|
|
||||||
magic_spell=Select what entity to spawn
|
|
||||||
magic_item_requirement=__1__ [item=__2__] requires __3__ mana to cast. Level: __4__\n
|
|
||||||
magic_entity_requirement=__1__ [entity=__2__] requires __3__ mana to cast. Level: __4__\n
|
|
||||||
magic_special_requirement=__1__ __2__ requires __3__ mana to cast. Level: __4__\n
|
|
||||||
allocation_settings_label=Allocations Settings:
|
|
||||||
allocation_label=Select what skill to auto-allocate.
|
|
||||||
allocation_tooltip=This will automatically allocate all available points to the given node.
|
|
2
locale/zh-CN/commands.cfg
Normal file
2
locale/zh-CN/commands.cfg
Normal file
@ -0,0 +1,2 @@
|
|||||||
|
[commands]
|
||||||
|
clear_corpse=点击删除尸体!
|
45
locale/zh-CN/crab_defender.cfg
Normal file
45
locale/zh-CN/crab_defender.cfg
Normal file
@ -0,0 +1,45 @@
|
|||||||
|
[crab_defender]
|
||||||
|
map_info_main_caption=-- Crab Defender --
|
||||||
|
map_info_sub_caption= ~~ the battle for crab-earth ~~
|
||||||
|
map_info_text=The biters are trying to take over the crab world.\nFend them off as long as possible!\nThis however will not be an easy task,\nsince their strength and resistance increases constantly over time.\n\nYour ultimate goal is to evacuate all the fishes that are in the crab-y lakes to crab planet!\nPut them in your rocket's cargo and launch them into space.\nDon't worry, you will still get space science.\n\nThe Market will gladly take any coin you might find.\nAdditional turret slots can be bought at the market.\nSeveral unique upgrades are available too.\nResearching tanks will unlock the artillery technology early.\nAny container bearing dangerous goods, like ammo, grenades or barrels,\ncauses heavy explosions when it breaks.\nMaybe this can be used to our advantage.\n\nBiters will only attack from both sides of the crab claws, be fast with the defenses!\n\nBiters are intelligent,\nthey have placed some sort of anti-inhabitant system so walking on the white-colored tile hurts you.
|
||||||
|
boss_message=Boss Wave __1__ - - __2__
|
||||||
|
50=The Big Anti-crab Gang
|
||||||
|
100=Crabzilla
|
||||||
|
150=The Spitter Squad
|
||||||
|
200=The Wall Nibblers
|
||||||
|
250=Conveyor Munchers
|
||||||
|
300=Furnace Freezers
|
||||||
|
350=Crabby Cabel Chewers
|
||||||
|
400=Power Pole Thieves
|
||||||
|
450=Assembler Annihilators
|
||||||
|
500=Inserter Crunchers
|
||||||
|
550=Crab Engineer Eaters
|
||||||
|
600=Belt Unbalancers
|
||||||
|
650=Turret Devourers
|
||||||
|
700=Pipe Perforators
|
||||||
|
750=Desync Bros
|
||||||
|
800=Ratio Randomizers
|
||||||
|
850=Wire Chompers
|
||||||
|
900=The Bus Mixers
|
||||||
|
950=Roundabout Deadlockers
|
||||||
|
1000=Happy Tree Friends
|
||||||
|
1050=Uranium Digesters
|
||||||
|
1100=Bot Banishers
|
||||||
|
1150=Chest Crushers
|
||||||
|
1200=Cargo Wagon Scratchers
|
||||||
|
1250=Transport Belt Surfers
|
||||||
|
1300=Pumpjack Pulverizers
|
||||||
|
1350=Radar Ravagers
|
||||||
|
1400=Mall Deconstrutors
|
||||||
|
1450=Lamp Dimmers
|
||||||
|
1500=Roboport Disablers
|
||||||
|
1550=Signal Spammers
|
||||||
|
1600=Brick Tramplers
|
||||||
|
1650=Drill Destroyers
|
||||||
|
1700=Gearwheel Grinders
|
||||||
|
1750=Crab Inhabitant Seekers
|
||||||
|
1800=Circuit Breakers
|
||||||
|
1850=Bullet Absorbers
|
||||||
|
1900=Oil Guzzlers
|
||||||
|
1950=Belt Rotators
|
||||||
|
2000=Bluescreen Factor
|
45
locale/zh-CN/fish_defender_v2.cfg
Normal file
45
locale/zh-CN/fish_defender_v2.cfg
Normal file
@ -0,0 +1,45 @@
|
|||||||
|
[fish_defender_v2]
|
||||||
|
map_info_main_caption=--Fish Defender v2--
|
||||||
|
map_info_sub_caption= ~~blb blubby blub~~
|
||||||
|
map_info_text=The biters have caught the scent of fish in the market.\nFend them off as long as possible!\nThis however will not be an easy task,\nsince their strength and resistance increases constantly over time.\n\nYour ultimate goal is to evacuate all the fish to cat planet!\nPut them in your rocket's cargo and launch them into space.\nDon't worry, you will still get space science.\n\nThe Market will gladly take any coin you might find.\nAdditional turret slots can be bought at the market.\nSeveral unique upgrades are available too.\nResearching tanks will unlock the artillery technology early.\nAny container bearing dangerous goods, like ammo, grenades or barrels,\ncauses heavy explosions when it breaks.\nMaybe this can be used to our advantage.\n\nBiters will only attack in the middle until wave is greater than 80.
|
||||||
|
boss_message=Boss Wave __1__ - - __2__
|
||||||
|
50=The Big Biter Gang
|
||||||
|
100=Biterzilla
|
||||||
|
150=The Spitter Squad
|
||||||
|
200=The Wall Nibblers
|
||||||
|
250=Conveyor Munchers
|
||||||
|
300=Furnace Freezers
|
||||||
|
350=Cable Chewers
|
||||||
|
400=Power Pole Thieves
|
||||||
|
450=Assembler Annihilators
|
||||||
|
500=Inserter Crunchers
|
||||||
|
550=Engineer Eaters
|
||||||
|
600=Belt Unbalancers
|
||||||
|
650=Turret Devourers
|
||||||
|
700=Pipe Perforators
|
||||||
|
750=Desync Bros
|
||||||
|
800=Ratio Randomizers
|
||||||
|
850=Wire Chompers
|
||||||
|
900=The Bus Mixers
|
||||||
|
950=Roundabout Deadlockers
|
||||||
|
1000=Happy Tree Friends
|
||||||
|
1050=Uranium Digesters
|
||||||
|
1100=Bot Banishers
|
||||||
|
1150=Chest Crushers
|
||||||
|
1200=Cargo Wagon Scratchers
|
||||||
|
1250=Transport Belt Surfers
|
||||||
|
1300=Pumpjack Pulverizers
|
||||||
|
1350=Radar Ravagers
|
||||||
|
1400=Mall Deconstrutors
|
||||||
|
1450=Lamp Dimmers
|
||||||
|
1500=Roboport Disablers
|
||||||
|
1550=Signal Spammers
|
||||||
|
1600=Brick Tramplers
|
||||||
|
1650=Drill Destroyers
|
||||||
|
1700=Gearwheel Grinders
|
||||||
|
1750=Silo Seekers
|
||||||
|
1800=Circuit Breakers
|
||||||
|
1850=Bullet Absorbers
|
||||||
|
1900=Oil Guzzlers
|
||||||
|
1950=Belt Rotators
|
||||||
|
2000=Bluescreen Factor
|
313
locale/zh-CN/locale.cfg
Normal file
313
locale/zh-CN/locale.cfg
Normal file
@ -0,0 +1,313 @@
|
|||||||
|
description=一个以不同地图的整体编辑为特色的古怪场景,来自不同的创作者。\n\n如何激活地图:\n1. 选项卡放入场景的文件夹中。 (..\Factorio\scenarios\ComfyFactorio)\n2. 用文本编辑器打开文件 "control.lua"\n3. 搜索 ---- enable maps here ----\n4. 移除 -- 你要激活的地图前的注释。\n5. 如果场景是从多人服务器下载或保存的,请删除 "blueprint.zip"\n6. 回到游戏中,放松一下。
|
||||||
|
|
||||||
|
[biter_battles]
|
||||||
|
map_info= - - 虫子大作战 - -\n\n 虫子注意到你在火箭发射井里秘密囤鱼。\n 你的任务是保护你的火箭发射井, 同时击败其他团队。\n\n 高科技发展将生产很强的进化因子,它会随着时间,增强你对面的虫子\n 带领你的团队胜利。\n\n 这里没有直接pvp战斗。\n 水平界面的液体是抵御虫子的。\n 那一边是不可以被探建设机器人开发。\n 随机地图布局,以提供公平竞争。\n\n 东西方向没有虫巢,\n 为工厂扩建和基地建设留下空间。\n 南北方向是虫子的领地。\n\n 图形用户界面主要是为每个团队的虫子统计两种不一样的主要信息。--这句话原英文难翻译,就这样理解了。\n\n - 进化 -\n 当它们有足够的进化因子。虫子会进化 --原文都是食物,我统一理解为进化因子\n 选择游戏难度可以提升到100%以上,\n 增强他们更多的伤害和生命。\n\n - 危险 -\n 阻碍虫子攻击。当虫子被杀时减少。\n 攻击虫子能带来持续的“危险收益”,同时也能产生即时的危险。\n 高难度会导致更强的攻击。值为零或以下不会主动攻击。
|
||||||
|
|
||||||
|
[cave_miner]
|
||||||
|
map_info_main_caption= - - C A V E M I N E R - -
|
||||||
|
map_info_sub_caption=~diggy diggy hole~
|
||||||
|
map_info_text=Delve deep for greater treasures, but also face increased dangers.\n\nThe team's pickaxe and backpack can be upgraded at the market.\nThe prices may be rerolled by spending some fish.\nBiter evolution scales with depth.\n\nBreaking rocks is exhausting and might make you hungry.\nSo don´t forget to eat some fish once in a while to stay well fed.\nBe careful, eating too much might have it´s consequences too.\n\nAs you dig, you will encounter impassable dark chasms or rivers.\nSome explosives may cause parts of the ceiling to crumble, filling the void, creating new ways.\nAll they need is a container and a well aimed shot.\n\nDarkness is a hazard in the mines, stay near your lamps..
|
||||||
|
|
||||||
|
[desert_oasis]
|
||||||
|
map_info_main_caption=--Desert Oasis--
|
||||||
|
map_info_sub_caption=Survival in the dry sands.
|
||||||
|
map_info_text=This is a harsh world, the heat is unbearable and the sand is sharp like diamonds.\nMake sure to stay properly hydrated.\nDrink some water from a pond, or sip it out of a barrel to stay refreshed.\n\nWe shall not attempt to travel without a proper vehicle.\nMany building foundations are not possible to be set up outside of the oasis.\nRailways between them however should be possible.\n\nLuckily the ship's moisture meter module did survive the crash.\nIt may come in handy!
|
||||||
|
|
||||||
|
[expanse]
|
||||||
|
map_info_main_caption=-- E x p a n s e --
|
||||||
|
map_info_sub_caption=
|
||||||
|
map_info_text=The blue chests are hungry.\nFeed them and they will reward you with more land.\n\nThe friendly infini tree will provide you with all the wood you ever wanted.\nThe everlasting rock with be happy to provide resources for you.\n\nIf you find yourself stuck, put a reroll token, the small plane toy, in the chest to get a new offer.\nUnlocking chests may drop additional tokens.
|
||||||
|
|
||||||
|
[fish_defender]
|
||||||
|
map_info_main_caption=--Fish Defender--
|
||||||
|
map_info_sub_caption= *blb blubby blub*
|
||||||
|
map_info_text=The biters have caught the scent of fish in the market.\nFend them off as long as possible!\nThis however will not be an easy task,\nsince their strength and resistance increases constantly over time.\n\nYour ultimate goal is to evacuate all the fish to cat planet!\nPut them in your rocket's cargo and launch them into space.\nDon't worry, you will still get space science.\n\nThe Market will gladly take any coin you might find.\nAdditional turret slots can be bought at the market.\nSeveral unique upgrades are available too.\nResearching tanks will unlock the artillery technology early.\nAny container bearing dangerous goods, like ammo, grenades or barrels,\ncauses heavy explosions when it breaks.\nMaybe this can be used to our advantage.
|
||||||
|
boss_message=Boss Wave __1__ - - __2__
|
||||||
|
50=The Big Biter Gang
|
||||||
|
100=Biterzilla
|
||||||
|
150=The Spitter Squad
|
||||||
|
200=The Wall Nibblers
|
||||||
|
250=Conveyor Munchers
|
||||||
|
300=Furnace Freezers
|
||||||
|
350=Cable Chewers
|
||||||
|
400=Power Pole Thieves
|
||||||
|
450=Assembler Annihilators
|
||||||
|
500=Inserter Crunchers
|
||||||
|
550=Engineer Eaters
|
||||||
|
600=Belt Unbalancers
|
||||||
|
650=Turret Devourers
|
||||||
|
700=Pipe Perforators
|
||||||
|
750=Desync Bros
|
||||||
|
800=Ratio Randomizers
|
||||||
|
850=Wire Chompers
|
||||||
|
900=The Bus Mixers
|
||||||
|
950=Roundabout Deadlockers
|
||||||
|
1000=Happy Tree Friends
|
||||||
|
1050=Uranium Digesters
|
||||||
|
1100=Bot Banishers
|
||||||
|
1150=Chest Crushers
|
||||||
|
1200=Cargo Wagon Scratchers
|
||||||
|
1250=Transport Belt Surfers
|
||||||
|
1300=Pumpjack Pulverizers
|
||||||
|
1350=Radar Ravagers
|
||||||
|
1400=Mall Deconstrutors
|
||||||
|
1450=Lamp Dimmers
|
||||||
|
1500=Roboport Disablers
|
||||||
|
1550=Signal Spammers
|
||||||
|
1600=Brick Tramplers
|
||||||
|
1650=Drill Destroyers
|
||||||
|
1700=Gearwheel Grinders
|
||||||
|
1750=Silo Seekers
|
||||||
|
1800=Circuit Breakers
|
||||||
|
1850=Bullet Absorbers
|
||||||
|
1900=Oil Guzzlers
|
||||||
|
1950=Belt Rotators
|
||||||
|
2000=Bluescreen Factor
|
||||||
|
|
||||||
|
[dungeons]
|
||||||
|
map_info_main_caption=D U N G E O N S
|
||||||
|
map_info_sub_caption= ~You put your robe and wizard hat on. You are still in a dungeon.~
|
||||||
|
map_info_text=Expand into the depths for treasure.\nEverytime a new room is discovered, the depth-meter in your left top will increase.\n\nEnemies get more chonky.\nResources yield more ore.\nLoot gets more shiny.\n\nYou can use the green smelly dungeon sewers for long range transports.\n\nHow far can you make it?
|
||||||
|
depth=~ Depth __1__ ~
|
||||||
|
depth_tooltip=Evolution: __1__%\nEnemy Health: __2__%\nEnemy Damage: __3__%
|
||||||
|
|
||||||
|
[dungeons_tiered]
|
||||||
|
map_info_main_caption=D U N G E O N S
|
||||||
|
map_info_sub_caption= ~You put your robe and wizard hat on. You are still in a dungeon.~
|
||||||
|
map_info_text=Expand into the depths for treasure.\nEverytime a new room is discovered, the depth-meter in your left top will increase.\n\nEnemies get more chonky.\nResources yield more ore.\nLoot gets more shiny.\n\nBut for real challenge and real shinies, you need to go also deeper.\nUse arrow buttons on top to change floors!\n\nHow far can you make it?
|
||||||
|
descend=Descend to lower floor.\nEach floor has stronger enemies and better treasure.\nRIGHT-CLICK: Descend 5 floors.\nSHIFT-CLICK: Desscend to lowest accessible Floor.
|
||||||
|
ascend=Ascend to higher floor.\nRIGHT-CLICK: Ascend 5 floors.\nSHIFT-CLICK: Ascend to Floor 0.
|
||||||
|
depth=~ Floor __1__ | Depth __2__ ~
|
||||||
|
depth_tooltip=Evolution: __1__%\nEnemy Health: __2__%\nEnemy Damage: __3__%\nLoot Value: __4__\nTreasure rooms found: __5__ / 5\nHidden Technologies: __6__
|
||||||
|
max_depth=You are on deepest level already!
|
||||||
|
min_depth=You are on highest level already!
|
||||||
|
only_on_spawn=You can change floors only on spawn.
|
||||||
|
level_required=You need level __1__ for travelling to next floor!
|
||||||
|
floor_size_required=You need to explore at least 60 rooms on this floor to access next floor!
|
||||||
|
travel_down=You have descended to deeper part of dungeon.
|
||||||
|
travel_up=You have ascended to previous part of dungeon.
|
||||||
|
first_visit=__1__ [lvl __2__] was first to reach Floor __3__!
|
||||||
|
too_small=The dungeon needs to be bigger for continuing in this direction.
|
||||||
|
treasure_room=Treasure room was found on Floor __1__!
|
||||||
|
tech_unlock=__1__ unlock was found on Floor __2__!
|
||||||
|
boss_arena=!!Dungeon Bosses!!\nRequires level 5 to join.\n\nCurrent boss level: __1__\nBoss bonus HP: __2__%\nBoss bonus damage: __3__%\nRewards: cca __4__ XP\n\nUp to four players can fight at once.
|
||||||
|
arena_occupied=Arena is in use! Wait for previous player to end his fight!
|
||||||
|
arena_level_needed=You need level 5 to join the arena!
|
||||||
|
robots_following=You cannot enter arena with robots following you!
|
||||||
|
arena_level_max=You defeated all the bosses already!
|
||||||
|
player_lost=[ARENA]: __1__ lost his battle to Boss lvl __2__!
|
||||||
|
player_won=[ARENA]: __1__ defeated the Boss lvl __2__!
|
||||||
|
spidertron_not_allowed=Spidertrons are not allowed in first 20 floors!
|
||||||
|
|
||||||
|
[mountain_fortress]
|
||||||
|
map_info_main_caption=M O U N T A I N F O R T R E S S
|
||||||
|
map_info_sub_caption= ..diggy diggy choo choo..
|
||||||
|
map_info_text=The biters have caught the scent of fish in the cargo wagon.\nGuide the choo into the mountain and protect it as long as possible!\nThis however will not be an easy task,\nsince their strength and numbers increase over time.\n\nIn additon, the southern grounds collapse over time.\n\nDelve deep for greater treasures, but also face increased dangers.\nMining productivity research, will overhaul your mining equipment,\nreinforcing your pickaxe as well as increasing the size of your backpack.\n\nAs you dig, you will encounter impassable dark chasms or rivers.\nSome explosives may cause parts of the ceiling to crumble, filling the void, creating new ways.\nAll they need is a container and a well aimed shot.\n\nYou may find some supply goods, if you enter the wagon.\nGood luck on your journey!
|
||||||
|
|
||||||
|
[chronosphere]
|
||||||
|
map_info_main_caption=C H R O N O S P H E R E
|
||||||
|
map_info_sub_caption= ..Comfylatron gone wild..
|
||||||
|
map_info_text=Comfylatron has seized the Fish Train and turned it into a time machine.\n Your job as his slave is:\n\n[1] Keep train alive at all costs.\n[2] Gather resources while travelling through different locations.\n[3a] Press enter on cargo wagons to enter the insides of train.\n[3b] Press enter on cars to exit the train.\n[4] Charging the accumulators inside the train speeds up the jump, but creates HUGE pollution, aggravating the biters.\n[5] Items inserted into the blue chests get teleported into the train.\n[6] Some planets are poor, some are rich, and some are just too dangerous.\n\nLoot, but also evolution, grows with jumps performed.\n During jump, personnel and their inventories will be teleported in, but anything left behind outside won't.\nEarly jumps award 25 硬币 per minute spared (until the 25th jump).\nObtaining mining productivity research grants inventory space and hand-mining speed.\n\nGood luck. Don't let biters ruin the show!
|
||||||
|
planet_jump=Destination: __1__, Ore richness: __2__, Daynight cycle: __3__
|
||||||
|
|
||||||
|
message_danger1=Comfylatron: We have a problem! We got disrupted in mid-jump, only part of energy got used, and here we landed. It might have been a trap!
|
||||||
|
message_danger2=Comfylatron: Battery is unstable, we need to survive until it gets full without additional charging.
|
||||||
|
message_danger3=Robot voice: INTRUDER ALERT! Lifeforms detected!! Must eliminate!!
|
||||||
|
message_danger4=Robot voice: Nuclear missiles armed. Launch countdown enabled.
|
||||||
|
message_rampup50=Comfylatron: Biters start to adapt to our presence, getting stronger every second...
|
||||||
|
message_overstay=Comfylatron: We took so long to get off that planet, our future destinations have evolved a little...
|
||||||
|
message_jump180=Comfylatron: Train is fully charged! Countdown sequence enabled. 180 seconds 'till jump!
|
||||||
|
message_jump60=Comfylatron: Nearly there! Grab what you can, we're leaving in 60 seconds!
|
||||||
|
message_jump30=Comfylatron: You'd better hurry up! 30 seconds remaining!!
|
||||||
|
message_jump10=Comfylatron: Jump in __1__ seconds!
|
||||||
|
message_jump=Comfylatron: Wheeee! Time jump underway! This is Jump number __1__
|
||||||
|
message_poison_defense=Comfylatron: Triggering poison defense. Let's kill everything!
|
||||||
|
message_nuke=Warning: Nuclear missiles launched.
|
||||||
|
message_accident=Comfylatron: Offline player had an accident, and their corpse fell to the ground near the locomotive.
|
||||||
|
message_silo=Nuclear silo destroyed. You looted __1__ atomic bombs. Comfylatron seized them for your own safety.
|
||||||
|
message_game_won_restart=Comfylatron: WAIT whaat? Looks like we did not fixed the train properly and it teleported us back in time...sigh...so let's do this again, and now properly.
|
||||||
|
message_fishmarket1=Comfylatron: So here we are. Fish Market. When they ordered the fish, they told us this location was safe. Guess we'll have to make it so.
|
||||||
|
message_fishmarket2=Comfylatron: I hope you have enough nukes. That satellite gave us some space knowledge!
|
||||||
|
message_fishmarket3=Comfylatron: Hey I found these nukes we looted before... you can take them.
|
||||||
|
message_lava=Comfylatron: OOF this one is a bit hot. Better keep your distance! Or try some bricks to protect from lava? And have seen those biters? They BATHE in fire!
|
||||||
|
message_choppy=Comfylatron: OwO what are those strange trees?!? They have ore fruits! WTF!
|
||||||
|
message_game_lost1=The Chronotrain was destroyed!
|
||||||
|
message_game_lost2=Comfylatron is going to kill you for that... he has a time machine after all!
|
||||||
|
message_evolve=Comfylatron: Biters start to adapt to us. And they appear to have some hive mind system to share it. If we stay too long, biters elsewhere will be stronger, waiting on us!
|
||||||
|
message_quest1=Comfylatron: You know...I have big quest. Deliver fish to fish market. But this train is broken. Please help me fix the train computer!
|
||||||
|
message_quest3=Comfylatron: Ah, we need to give this machine more power and better navigation chipset. Please bring me some additional things.
|
||||||
|
message_quest5=Comfylatron: Finally found the main issue. We will need to rebuild whole processor. Exactly what I feared of. Just a few more things...
|
||||||
|
message_quest6=Comfylatron: And, I've got the last part of the CPU brain done. Now we just need to synchronize our time correctly and we are done! Bring me satellite and rocket silo.
|
||||||
|
message_game_won1=Comfylatron: Thank you all for helping me with fish delivery. It was tough ride. And now that the biters are dead, the fish will be safe here forever...
|
||||||
|
message_comfylatron_desync=Comfylatron: I got you that time! Back to work, __1__!
|
||||||
|
|
||||||
|
difficulty1=Too easy!Low pollution, less enemies, etc...
|
||||||
|
difficulty2=Still easy!Low pollution, less enemies, etc...
|
||||||
|
difficulty3=Nearly easy!Low pollution, less enemies, etc...
|
||||||
|
difficulty4=Normal. Everything just about right...
|
||||||
|
difficulty5=A bit hard. More pollution, more enemies, etc...
|
||||||
|
difficulty6=Just about hard. More pollution, more enemies, etc...
|
||||||
|
difficulty7=Perfectly playable. Maybe. More pollution, more enemies, etc...
|
||||||
|
|
||||||
|
map_1=Terra Ferrata
|
||||||
|
map_2=Malachite Hills
|
||||||
|
map_3=Granite Plains
|
||||||
|
map_4=Petroleum Basin
|
||||||
|
map_5=Pitchblende Mountain
|
||||||
|
map_6=Mixed Deposits
|
||||||
|
map_7=Biter Homelands
|
||||||
|
map_8=Gangue Dumps
|
||||||
|
map_9=Antracite Valley
|
||||||
|
map_10=Ancient Battlefield
|
||||||
|
map_11=Cave Systems
|
||||||
|
map_12=Strange Forest
|
||||||
|
map_13=Riverlands
|
||||||
|
map_14=Burning Hell
|
||||||
|
map_15=Starting Area
|
||||||
|
map_16=Hedge Maze
|
||||||
|
map_17=Fish Market
|
||||||
|
map_18=Methane Swamps
|
||||||
|
map_19=ERROR DESTINATION NOT FOUND
|
||||||
|
ore_richness_very_rich=Very Rich
|
||||||
|
ore_richness_rich=Rich
|
||||||
|
ore_richness_normal=Normal
|
||||||
|
ore_richness_poor=Poor
|
||||||
|
ore_richness_very_poor=Very Poor
|
||||||
|
ore_richness_none=None
|
||||||
|
daynight_static=Static
|
||||||
|
daynight_normal=Normal
|
||||||
|
daynight_slow=Slow
|
||||||
|
daynight_superslow=Super slow
|
||||||
|
daynight_fast=Fast
|
||||||
|
daynight_superfast=Super fast
|
||||||
|
|
||||||
|
upgrade_train_armor=Train Armor
|
||||||
|
upgrade_train_armor_message=Comfylatron: Train's max HP upgraded.
|
||||||
|
upgrade_train_armor_tooltip=+2500 Train Max HP. Max level: __1__ Current Max HP: __2__
|
||||||
|
upgrade_filter=Pollution Filter
|
||||||
|
upgrade_filter_message=Comfylatron: Train's pollution filter upgraded.
|
||||||
|
upgrade_filter_tooltip=Train Pollution Filter. Dampens pollution from machines inside the train and from charging the chrono engine.\nCurrent pollution transfer factor: __1__%
|
||||||
|
upgrade_accumulators=Accumulators
|
||||||
|
upgrade_accumulators_message=Comfylatron: Train's accumulator capacity upgraded.
|
||||||
|
upgrade_accumulators_tooltip=Add an additional row of accumulators to the Chronotrain, increasing the maximum charging rate.
|
||||||
|
upgrade_loot_pickup=Loot Pickup Range
|
||||||
|
upgrade_loot_pickup_message=Comfylatron: Players install additional red inserters on their shoulders. Item pickup range increased.
|
||||||
|
upgrade_loot_pickup_tooltip=Add loot pickup distance to players. Current: +__1__ tiles range
|
||||||
|
upgrade_inventory_size=Character Inventory Size
|
||||||
|
upgrade_inventory_size_message=Comfylatron: Players can now carry more trash in their unsorted inventories.
|
||||||
|
upgrade_inventory_size_tooltip=Add +10 inventory slots to all players.
|
||||||
|
upgrade_repair=Train Repair Speed
|
||||||
|
upgrade_repair_message=Comfylatron: The Chronotrain can now repair with an additional repair kit at once.
|
||||||
|
upgrade_repair_tooltip=Train now gets repaired with more tools at once from the Repair Chest. Current: +__1__
|
||||||
|
upgrade_water=Piping System
|
||||||
|
upgrade_water_message=Comfylatron: Train now has a piping system for additional water sources in each wagon.
|
||||||
|
upgrade_water_tooltip=Add piping through wagon sides to create water sources for each wagon.
|
||||||
|
upgrade_output=Output System
|
||||||
|
upgrade_output_message=Comfylatron: Train has been upgraded with output chests.
|
||||||
|
upgrade_output_tooltip=Adds output chests to wagons 2 and 3 which send items to the external wagon storage.
|
||||||
|
upgrade_storage=Train Storage
|
||||||
|
upgrade_storage_message=Comfylatron: The inside of the train has upgraded storage.
|
||||||
|
upgrade_storage_tooltip=Add or upgrade storage chests to line the edges of the insides of the Chronotrain.
|
||||||
|
upgrade_poison=Poison Defense
|
||||||
|
upgrade_poison_message=Comfylatron: I don't believe in your defensive skills. I loaded another emergency poison defense into the locomotive...
|
||||||
|
upgrade_poison_tooltip=Emergency poison defense. Triggers automatically when the Chronotrain has low HP.\nMax charges : 4. Recharge timer for next use: __1__ min.
|
||||||
|
upgrade_fusion=Fusion Reactor
|
||||||
|
upgrade_fusion_message=Comfylatron: One personal fusion reactor ready.
|
||||||
|
upgrade_fusion_tooltip=Creates one Fusion Reactor.
|
||||||
|
upgrade_mk2=Power Armor MK2
|
||||||
|
upgrade_mk2_message=Comfylatron: I upgraded an armor to MK2.
|
||||||
|
upgrade_mk2_tooltip=Creates one Power Armor MK2
|
||||||
|
upgrade_computer1=Comfylatron's Quest 1
|
||||||
|
upgrade_computer1_tooltip=Progresses main quest.\nNext destinations won't ever have "very poor" ore distribution.
|
||||||
|
upgrade_computer1_message=Comfylatron: OK, now I can fix the train navigation... This should get rid of very poor worlds at least. It still needs more work, though. I'll come back later.
|
||||||
|
upgrade_computer2=Comfylatron's Quest 2
|
||||||
|
upgrade_computer2_message=Comfylatron: Perfect! Now we have train reactor, and happily for you all, we should be able to avoid poor worlds altogether! Find out what's next after the jump ;)
|
||||||
|
upgrade_computer2_tooltip=Progresses main quest.\nNext destinations won't ever have "poor" ore distribution.
|
||||||
|
upgrade_computer3=Comfylatron's Quest 3
|
||||||
|
upgrade_computer3_message=Comfylatron: That's __1__ / 10 processor parts done!
|
||||||
|
upgrade_computer3_tooltip=Progresses main quest.\nAfter completing 10th part, the final map can be unlocked.
|
||||||
|
upgrade_computer4=Comfylatron's Final Quest
|
||||||
|
upgrade_computer4_message=Comfylatron: TIME SYNCHRONIZED... CALCULATING SPACETIME DESTINATION... Done! Power up the chrono engines once more and let me deliver the fish finally. This trip is getting long.
|
||||||
|
upgrade_computer4_tooltip=Progresses main quest.\nBy unlocking this, the next destination is Fish Market.\nBe sure to be ready, there's no way back!
|
||||||
|
|
||||||
|
gui_1=ChronoJumps:
|
||||||
|
gui_2=Charge:
|
||||||
|
gui_3=Charged in:
|
||||||
|
gui_3_1=Best Case:
|
||||||
|
gui_3_2=Nuclear missiles launched in:
|
||||||
|
gui_3_3=JUMP IN:
|
||||||
|
gui_4=Local Evolution:
|
||||||
|
gui_planet_button=Area Info
|
||||||
|
gui_upgrades_button=Upgrades
|
||||||
|
gui_upgrades_1=Purchase upgrades by placing items in the chests at the top of the train interior.
|
||||||
|
gui_upgrades_2=Upgrading can take a few seconds.
|
||||||
|
gui_upgrades_switch_left=Upgrades
|
||||||
|
gui_upgrades_switch_right=Quests
|
||||||
|
gui_upgrades_jumps=Required minimal jump number
|
||||||
|
gui_planet_0=Name: __1__
|
||||||
|
gui_planet_1=Detected ore distribution:
|
||||||
|
gui_planet_2=Ore Amounts: __1__
|
||||||
|
gui_planet_3=Local evolution: __1__%
|
||||||
|
gui_planet_4=Global evolution bonuses:
|
||||||
|
gui_planet_4_1=+__1__% evolution, +__2__% damage
|
||||||
|
gui_planet_5=Day/night cycle: __1__
|
||||||
|
gui_planet_6=Overstay in: __1__ min, __2__s
|
||||||
|
gui_planet_7=Overstay applies after jump __1__
|
||||||
|
gui_overstayed=Overstayed!
|
||||||
|
gui_not_overstayed=Avoided overstay.
|
||||||
|
minimap=Outside View
|
||||||
|
minimap_button_tooltip=Open or close Outside View window.
|
||||||
|
minimap_tooltip=LMB: Increase zoom level.\nRMB: Decrease zoom level.\nMMB: Toggle camera size.\nMap button on top to hide/show
|
||||||
|
map_on=Automatically show map ON
|
||||||
|
map_off=OFF
|
||||||
|
|
||||||
|
|
||||||
|
[rocks_yield_ore_veins]
|
||||||
|
coal=煤
|
||||||
|
iron-ore=铁
|
||||||
|
copper-ore=铜
|
||||||
|
uranium-ore=铀
|
||||||
|
stone=石
|
||||||
|
mixed=混合
|
||||||
|
angels-ore1=saphirite
|
||||||
|
angels-ore2=jivolite
|
||||||
|
angels-ore3=stiratite
|
||||||
|
angels-ore4=crotinnium
|
||||||
|
angels-ore5=rubyte
|
||||||
|
angels-ore6=bobmonium
|
||||||
|
giant=巨大
|
||||||
|
huge=庞大
|
||||||
|
big=大量
|
||||||
|
small=少量
|
||||||
|
tiny=微少
|
||||||
|
player_print=你发现一些__1__的东西在石堆下. 是一片__2__的__3__矿脉!! __4__
|
||||||
|
game_print= __1__发现了一片__2__的__3__矿脉! __4__
|
||||||
|
|
||||||
|
[rocks_yield_ore_veins_colors]
|
||||||
|
coal=乌黑
|
||||||
|
iron-ore=闪亮
|
||||||
|
copper-ore=闪光
|
||||||
|
uranium-ore=灼热
|
||||||
|
stone=坚硬
|
||||||
|
mixed=闪烁
|
||||||
|
angels-ore1=蓝色
|
||||||
|
angels-ore2=黄色
|
||||||
|
angels-ore3=奇怪
|
||||||
|
angels-ore4=闪亮
|
||||||
|
angels-ore5=深红色
|
||||||
|
angels-ore6=棕土色
|
||||||
|
|
||||||
|
[wave_defense]
|
||||||
|
gui_1=第一波次
|
||||||
|
gui_2=波次:
|
||||||
|
gui_3=危险:
|
||||||
|
tooltip_1=高难度会增强虫子.\n虫子强度: __1__%\n开始: __2__~
|
||||||
|
tooltip_2=增加 / 一会儿
|
||||||
|
|
||||||
|
[native_war]
|
||||||
|
map_info= - - N A T I V E W A R - -\n\n Defeat the enemy team Market !\n\nFeed your market with science to spawn waves of native biters and spitters !\nThey will soon after swarm to the opposing team Market !\n\nThe corridor is stewn with worms.\nRebuy dead worms and upgrade them to stem the opposing waves !\n\nExcess energy will activate a beam.\nBeam will progress with more excess energy.\nNatives will spawn according to the beam position.\n\nUse radars to spy opponent's base.\nUse your experience to improve damage and resistance of your biters.\nSpace science packs give extra life to your biters.\nConstruction robots may not build over the wall.\n
|
||||||
|
|
||||||
|
[territorial_control]
|
||||||
|
map_info_main_caption=T E R R I T O R I A L C O N T R O L
|
||||||
|
map_info_sub_caption= ..alone in the darkness..
|
||||||
|
map_info_text=Citizen Log #468-2A-3287, Freelancer Trent. \n\nTo whoever is reading this message, \nAny natural resources are rare and the ones worth while are too hard for me to reach. \nLuckily, the wrecks yield all kinds of useful scraps, but also various dangers. \nAlmost lost half a leg some days ago while digging out some scrap. \nThe wildlife is extremely aggressive, especially at the time of night. \nMost of these insect appearing like creatures seem to live underground. \nStay near your light sources, if you want to have a chance of surviving here! \n\n###Log End###
|
2
locale/zh-CN/modules.cfg
Normal file
2
locale/zh-CN/modules.cfg
Normal file
@ -0,0 +1,2 @@
|
|||||||
|
[modules]
|
||||||
|
charging_station_tooltip=从附近的蓄电池为装甲设备充电!\n仅对功率超过3MJ的装甲才有效。
|
108
locale/zh-CN/mtn_fortress_v3.cfg
Normal file
108
locale/zh-CN/mtn_fortress_v3.cfg
Normal file
@ -0,0 +1,108 @@
|
|||||||
|
[mountain_fortress_v3]
|
||||||
|
map_info_main_caption==山地要塞V3
|
||||||
|
map_info_sub_caption= ..……呜~呜~,框哧~框哧~框哧……..
|
||||||
|
map_info_text=\n 汉化有限,大部分靠词典翻译,跟个人理解。。请勿吐槽!!!!\n\n。。~~~~~~~~~~~~~~~~汉化作者KK_KK~~~~~~~~~~~~~~~~~\n\n虫子已经发现了火车,它们正在集结\n 引导火车向山里前进,保护它直到你倒下\n 虫子的属性跟数量会随着时间而增加\n 进行科技研究,升级你的装备\n 提升团队矿镐等级以及背包大小\n 继续向深处挖,里面有很多宝藏,也会有危险,\n 悬崖跟河流可以用炸药和箱子,可以填补空白\n 火车里有市场这是主要的物品来源,包括团队升级都在里面\n 地图的各地都有随机生产资源的建筑\n 祝你旅游愉快\n 虫子波数总共1000波,(不一定准确,翻译大概是这意思)\n\n~~~~~~~~~~~~~~~~持续汉化中~~~~~~~~~~~~~~~~
|
||||||
|
|
||||||
|
[breached_wall]
|
||||||
|
collapse_start= [color=blue] 地图管理员:[/color] \n警告,已经开始!
|
||||||
|
spidertron_unlocked=[color=blue]地图管理员:[/color]\注意! 机器蜘蛛已在主要市场解锁!
|
||||||
|
wall_breached=[color=blue]Mapkeeper:[/color]\n! 幸存者!做得好.您已完成 __1__区!
|
||||||
|
first_to_reach=[color=blue]Mapkeeper:[/color]\n__1__是第一个到达区域__2__的人.
|
||||||
|
artillery_warning=[color=blue]Mapkeeper:[/color]\n警告,北部已发现火炮!
|
||||||
|
cheating_through=__1__ 他们试图作弊用机器蜘蛛向北前进!
|
||||||
|
|
||||||
|
[entity]
|
||||||
|
treasure_1=您注意到废墟中有一个旧箱子.它充满了宝藏!
|
||||||
|
treasure_2=您在破碎的岩石下面找到一个箱子.它充满了好吃的东西!
|
||||||
|
treasure_3=我们已经找到了珍贵的东西!
|
||||||
|
treasure_rare_1=您的魔力提高了.您已经发现一个装满稀有珍宝的箱子!
|
||||||
|
treasure_rare_2=哦,太好了.您在破碎的岩石下面发现了一个箱子.它充满了稀有的东西!
|
||||||
|
treasure_rare_3=您是魔法师!我们发现了稀有的珍贵!
|
||||||
|
defeated_1=[color=blue]Mapkeeper:[/color]\n哦,不,这些虫子打坏了火车轨道!\n下次运气更好.
|
||||||
|
defeated_2=[color=blue]Mapkeeper:[/color]\n我不确定100%,但是-显然火车被击毁了.\n下次运气更好.away.
|
||||||
|
defeated_3=[color=blue]Mapkeeper:[/color]\n您有一个目标-保卫火车 *-*\n下次运气更好.
|
||||||
|
defeated_4=[color=blue]Mapkeeper:[/color]\n看起来我们正在重置,因为您没有捍卫火车._.\n下次运气更好.
|
||||||
|
reset_game=***禁用软重置!服务器将从方案重新启动以加载新更改. ***
|
||||||
|
notify_restart=禁用软件重置!服务器将从方案重新启动以加载新更改.
|
||||||
|
shutdown_game=***禁用软重置!服务器将关闭.最有可能是因为更新. ***
|
||||||
|
notify_shutdown=禁用软件重置!服务器将关闭.最有可能是因为更新.
|
||||||
|
train_taking_damage=[color=blue]Comfylatron:[/color]\n火车正遭受严重伤害.\n部署防御机制.
|
||||||
|
entity_limit_reached=__1__ 已达到限制.在市场上购买更多插槽!
|
||||||
|
found_car=__1__ 在隆隆声中发现了一辆汽车!\n
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
[gui]
|
||||||
|
global_pool_tooltip=挖掘,手工制作或运行增加资源!
|
||||||
|
global_pool_amount=存储经验在全局经验池里.\n当前值: __1__
|
||||||
|
amount_harvested=得到的树木/岩石数量.
|
||||||
|
biters_killed=杀死虫子的数量.
|
||||||
|
land_mine_placed=制造的地雷数量.
|
||||||
|
chest_placed=可以放在火车附近箱子的数量.
|
||||||
|
flamethrowers_placed=火焰喷射器跟炮塔的数量.
|
||||||
|
train_upgrades=列车等级.
|
||||||
|
info_tooltip=显示数值!
|
||||||
|
hide_minimap=隐藏火车迷你地图!
|
||||||
|
current_pickaxe_tier=团队当前 __1__ 斧头等级.\n奖励速度是: __2__%
|
||||||
|
|
||||||
|
[locomotive]
|
||||||
|
upgrades=提升:
|
||||||
|
items=物品:
|
||||||
|
shoo=^-^ 请不要对我开枪 ^-^
|
||||||
|
not_trusted=您需要被信任才能购买.
|
||||||
|
coins_left=剩余硬币: __1__
|
||||||
|
market_name=市场
|
||||||
|
search_text=搜索:
|
||||||
|
quantity_text=数量:
|
||||||
|
limit_reached=已达到最大限制!
|
||||||
|
chests_full=您不能购买更多的箱子.
|
||||||
|
chest_bought_info=__1__ __2__ 购买护甲的极限提升 __3__ 硬币.
|
||||||
|
health_bought_info=__1__ __2__ 购买火车生命恢复道具 __3__ 硬币.
|
||||||
|
aura_bought_info=__1__ __2__ 购买火车经验光环升级 __3__ 硬币.
|
||||||
|
xp_bought_info=__1__ __2__ 购买经验值升级 __3__ 硬币.
|
||||||
|
reroll_bought_info=__1__ __2__ 重置市场物品 __3__ 硬币.
|
||||||
|
pickaxe_bought_info=__1__ __2__ 升级矿镐等级__3__ 给 __4__ 硬币.
|
||||||
|
explosive_bullet_bought_info=__1__ __2__ 购买火焰弹升级 __3__ 硬币.
|
||||||
|
one_flamethrower_bought_info=__1__ __2__ 购买火焰喷射器-炮塔 __3__ 硬币.
|
||||||
|
multiple_flamethrower_bought_info=__1__ __2__ 购买 __3__ 火焰喷射器-炮塔 __4__ 硬币.
|
||||||
|
landmine_bought_info=__1__ __2__ 购买地雷 __3__ 硬币.
|
||||||
|
rpg_reset_bought_info=__1__ __2__ 重置玩家技能点 __3__ 硬币.
|
||||||
|
full_inventory=你的背包现在装满了。所以你只买了 __1__ __2__(s).
|
||||||
|
change_returned=店主已退回您的零钱,对此我们深表感谢.\n
|
||||||
|
notify_full_inventory_1=您的库存已满.试着先把你的战利品放在某个地方.
|
||||||
|
notify_full_inventory_2=您的库存已满. 立即加入战士团队!力量蓄力会更多!
|
||||||
|
new_items_at_market=火车市场已经解锁了新物品!
|
||||||
|
|
||||||
|
|
||||||
|
[main_market]
|
||||||
|
chest=提高了可以在外面放置的箱子数量.\n可以多次购买.
|
||||||
|
locomotive_max_health=升级火车生命.\n可以多次购买
|
||||||
|
locomotive_xp_aura=升级火车周围的经验光环。
|
||||||
|
xp_points_boost=升级您在经验光环中获得的经验值
|
||||||
|
explosive_bullets=将普通的SMG弹药升级为爆炸子弹.
|
||||||
|
reroll_market_items=重置市场的商品并调整价格.
|
||||||
|
purchase_pickaxe=将团队镐升级到等级:__1__
|
||||||
|
sold_out=售罄!
|
||||||
|
flamethrower_turret=升级可以放置的火焰喷射器的数量.
|
||||||
|
land_mine=升级可以放置的地雷数量.
|
||||||
|
skill_reset=重置玩家技能点.\n将保留积分.
|
||||||
|
car=便携汽车操作\n可以更容易打死.
|
||||||
|
tank=便携坦克操作\n大坦克, 可以抵抗严重伤害.
|
||||||
|
tank_cannon_na=坦克炮\n在650波之后可用.
|
||||||
|
tank_machine_gun_na=坦克机枪\n在4000波之后可用.
|
||||||
|
vehicle_machine_gun_na=汽车机枪\n在200波后可用.
|
||||||
|
|
||||||
|
[main]
|
||||||
|
death_message_1=__1__ 应该看着他们走的地方!
|
||||||
|
death_message_2=__1__ 不够小心!
|
||||||
|
death_message_3=__1__ 激怒了领主!
|
||||||
|
death_message_4=__1__ 试图走作弊路径!
|
||||||
|
death_message_5=__1__ 消失了!
|
||||||
|
death_message_6=__1__ 被淘汰了!
|
||||||
|
death_message_7=__1__ 试图向北作弊!
|
||||||
|
forcefield=强制不通过.
|
||||||
|
greeting=[color=blue]Comfylatron:[/color]\n你好, __1__!\n请阅读地图信息.
|
||||||
|
cleaner=[color=blue]Cleaner:[/color]\n__1__ 留下了他的好东西!快取走它们!
|
||||||
|
reset_in=游戏将 __1__ 在 __2__ 秒!
|
||||||
|
diff_set=设置了难度! 游戏已设置为: [color=green]__1__[/color]
|
||||||
|
diff_tooltip=防守波次根据玩家数量.\n额外奖励经验:__1__.\n提升采矿速度:__2__.\n运行速度提升:__3__.\n提升生产速度:__4__.\n每次收获的硬币数量:__5__.\n火焰炮塔极限:__6__.\n地雷极限:__7__.\n机车健康:__8__.\n隐藏宝藏有__9__几率产生.\n宽限期:__10__分钟\n机器蜘蛛在__11__区域解锁.
|
119
locale/zh-CN/rpg.cfg
Normal file
119
locale/zh-CN/rpg.cfg
Normal file
@ -0,0 +1,119 @@
|
|||||||
|
[rpg_main]
|
||||||
|
no_valid_surface=无指定操作名
|
||||||
|
flame_boots_worn_out=你的火焰鞋穿坏.
|
||||||
|
flame_mana_remaining=剩余魔法:__1__
|
||||||
|
one_punch_text=暴击
|
||||||
|
mana_casting_too_fast= __1__ 魔法还有很多, 像 __1__ 迅速创建出, 然后挥舞着他们的魔杖,说一些难以理解的词.
|
||||||
|
low_level=等级不够.
|
||||||
|
not_inside_pos=你挥动你的魔杖, 但意识到它不能达到.
|
||||||
|
no_mana=你没有足够的魔力.
|
||||||
|
suicidal_comfylatron=您挥舞着魔杖,__1__在运行!
|
||||||
|
warped_ok=有轻微伤害自己的行为.
|
||||||
|
object_spawned=__1__正在制造.\n 你挥动你的魔杖和 __1__ 出现.
|
||||||
|
out_of_reach=无法在给制定位置创建物体.
|
||||||
|
|
||||||
|
[rpg_functions]
|
||||||
|
max_level=[color=blue]等级限制:[/color]\n 您已达到当前区域的最大级别。
|
||||||
|
pool_reward=[color=blue]全局池奖励:[/color]\n __1__什么也没收到.原因:挂机
|
||||||
|
|
||||||
|
[rpg_gui]
|
||||||
|
gain_info_tooltip=经验从采矿,移动,制作,修理和战斗中获得的收益。
|
||||||
|
allocate_info=鼠标右键分配 __1__ 技能点.\nShift + 鼠标单击可分配所有点。
|
||||||
|
player_name=你好 __1__ !
|
||||||
|
class_info=您是__1__.!
|
||||||
|
settings_frame=在这里改变你的角色配置!
|
||||||
|
level_limit=此区域的当前最大级别限制为:__1__ 通过突破墙壁/区域来增加。
|
||||||
|
settings_name=设置
|
||||||
|
level_name=等级
|
||||||
|
experience_name=经验
|
||||||
|
next_level_name=下一个级别
|
||||||
|
strength_name=力量
|
||||||
|
strength_tooltip=增加库存数量,挖掘速度.\n增加近战伤害和机器人追随者数量。
|
||||||
|
magic_name=魔法
|
||||||
|
magic_tooltip=距离增加。\n提高修复速度。启用实体生成。
|
||||||
|
dexterity_name=敏捷
|
||||||
|
dexterity_tooltip=提高运行和制作速度。
|
||||||
|
vitality_name=耐力
|
||||||
|
vitality_tooltip=增加生命值。\n增加命中时的近战生命。
|
||||||
|
points_to_dist=分配\n技能点
|
||||||
|
life_name=生命
|
||||||
|
life_tooltip=当前的健康状况
|
||||||
|
life_increase=现在的生命值。通过增加活力来增加它。
|
||||||
|
life_maximum=这是你最大的生命。
|
||||||
|
shield_name=护盾
|
||||||
|
shield_no_shield=你没有护盾。
|
||||||
|
shield_no_armor=这是你现在的护盾。你没有穿护甲。
|
||||||
|
shield_tooltip=护甲保护你,提高你的抵抗力。
|
||||||
|
shield_current=人物当前护甲值。
|
||||||
|
shield_max=最大护甲值。
|
||||||
|
mana_name=魔力
|
||||||
|
mana_bonus=魔力\n加成
|
||||||
|
mana_regen_bonus=魔力恢复加成: __1__
|
||||||
|
mana_tooltip=可以通过吃鱼来恢复魔力
|
||||||
|
mana_regen_current=这是你现在的魔力。你可以通过增加你的魔法技能来增加恢复。
|
||||||
|
mana_max_limit=这是你的最大魔力值。你已经达到了最大法力极限。
|
||||||
|
mana_max=这是你的最大魔力值。你可以通过增加你的魔法技能来增加恢复。
|
||||||
|
mining_name=挖掘\n速度
|
||||||
|
slot_name=背包\n加成
|
||||||
|
melee_name=近战\n伤害
|
||||||
|
one_punch_chance=命中生命: __1__\n暴击几率: __2__ %
|
||||||
|
one_punch_disabled=暴击被禁用
|
||||||
|
bonus_tooltip=到达距离加成: __1__\n建筑距离加成: __2__\n物品投掷距离加成: __3__\n拾取战利品距离加成: __4__\n物品拾取距离加成: __5__\n资源到达距离加成: __6__\n修理速度: __7__
|
||||||
|
reach_distance=到达\n距离
|
||||||
|
crafting_speed=制作\n速度
|
||||||
|
running_speed=跑路\n速度
|
||||||
|
health_bonus_name=生命\n加成
|
||||||
|
health_tooltip=生命回复加成: __1__
|
||||||
|
|
||||||
|
|
||||||
|
[rpg_settings]
|
||||||
|
name=RPG settings
|
||||||
|
save_changes=保存更改
|
||||||
|
discard_changes=放弃更改
|
||||||
|
not_trusted=不可选.
|
||||||
|
low_level=等级要求: __1__
|
||||||
|
used_up=全部用完!
|
||||||
|
no_mana=魔法不足!
|
||||||
|
mana_label=魔力设置:
|
||||||
|
tooltip_check=选中: true\n未选中: false
|
||||||
|
info_text_label=通用RPG设置。玩家的基本设置。
|
||||||
|
health_text_label=显示生命/魔力条?
|
||||||
|
health_only_text_label=显示生命条?
|
||||||
|
reset_text_label=重置技能点?
|
||||||
|
reset_tooltip=重置-如果您选择了错误的路径(这将保留你的技能点)
|
||||||
|
reach_text_label=启用到达加成?
|
||||||
|
reach_text_tooltip=不想捡别人抢的东西吗?\n你可以在这里切换。
|
||||||
|
movement_text_label=启用移动速度加成?
|
||||||
|
movement_text_tooltip=不想像闪电一样奔跑吗?\n你可以在这里切换。
|
||||||
|
stone_path_label=采矿时启用石路?
|
||||||
|
stone_path_tooltip=启用此选项将在您挖掘时自动创建石头路径。
|
||||||
|
one_punch_label=启用暴击?
|
||||||
|
one_punch_tooltip=启用此选项将有一次击打敌人的机会。
|
||||||
|
one_punch_globally=启用全局。
|
||||||
|
flameboots_label=启用火焰靴?
|
||||||
|
flameboots_tooltip=当子弹未击中。
|
||||||
|
magic_label=启用鲜鱼大量刷出?
|
||||||
|
magic_tooltip=当简单的建设项目不够。\ n注意!用生鱼施法。
|
||||||
|
magic_spell=选择要生成的物体
|
||||||
|
magic_item_requirement=__1__ [item=__2__] 需要 __3__ 施展魔法。 等级: __4__\n
|
||||||
|
magic_entity_requirement=__1__ [entity=__2__] 需要 __3__ 施展魔法. 等级: __4__\n
|
||||||
|
magic_special_requirement=__1__ __2__ 需要 __3__ 施展魔法. 等级: __4__\n
|
||||||
|
allocation_settings_label=分配设置:
|
||||||
|
allocation_label=选择要自动分配的技能。
|
||||||
|
allocation_tooltip=这将自动将所有可用的点分配给给定的节点。
|
||||||
|
|
||||||
|
[spells]
|
||||||
|
acid_stream=Bitter Spew
|
||||||
|
railgun_beam=Shoop Da Whoop!!
|
||||||
|
raw_fish=Conjure Raw-fish
|
||||||
|
comfylatron=Suicidal Comfylatron
|
||||||
|
distractor=Distractor Capsule
|
||||||
|
warp=Warp Gate
|
||||||
|
|
||||||
|
|
||||||
|
[allocations]
|
||||||
|
deactivated=Deactivated
|
||||||
|
str=Strength
|
||||||
|
mag=Magicka
|
||||||
|
dex=Dexterity
|
||||||
|
vit=Vitality
|
@ -20,7 +20,7 @@ end
|
|||||||
local function floaty_hearts(entity, c)
|
local function floaty_hearts(entity, c)
|
||||||
local position = {x = entity.position.x - 0.75, y = entity.position.y - 1}
|
local position = {x = entity.position.x - 0.75, y = entity.position.y - 1}
|
||||||
local b = 1.35
|
local b = 1.35
|
||||||
for a = 1, c, 1 do
|
for _ = 1, c, 1 do
|
||||||
local p = {
|
local p = {
|
||||||
(position.x + 0.4) + (b * -1 + random(0, b * 20) * 0.1),
|
(position.x + 0.4) + (b * -1 + random(0, b * 20) * 0.1),
|
||||||
position.y + (b * -1 + random(0, b * 20) * 0.1)
|
position.y + (b * -1 + random(0, b * 20) * 0.1)
|
||||||
|
@ -36,9 +36,7 @@ commands.add_command(
|
|||||||
|
|
||||||
if not this.reset_are_you_sure then
|
if not this.reset_are_you_sure then
|
||||||
this.reset_are_you_sure = true
|
this.reset_are_you_sure = true
|
||||||
p(
|
p('[WARNING] This command will disable the soft-reset feature, run this command again if you really want to do this!')
|
||||||
'[WARNING] This command will disable the soft-reset feature, run this command again if you really want to do this!'
|
|
||||||
)
|
|
||||||
return
|
return
|
||||||
end
|
end
|
||||||
|
|
||||||
@ -61,7 +59,6 @@ commands.add_command(
|
|||||||
end
|
end
|
||||||
elseif param == 'restartnow' then
|
elseif param == 'restartnow' then
|
||||||
this.reset_are_you_sure = nil
|
this.reset_are_you_sure = nil
|
||||||
p(player.name .. ' has restarted the game.')
|
|
||||||
Server.start_scenario('Mountain_Fortress_v3')
|
Server.start_scenario('Mountain_Fortress_v3')
|
||||||
return
|
return
|
||||||
elseif param == 'shutdown' then
|
elseif param == 'shutdown' then
|
||||||
|
@ -17,7 +17,9 @@ local ExplosiveBullets = require 'maps.mountain_fortress_v3.explosive_gun_bullet
|
|||||||
local Collapse = require 'modules.collapse'
|
local Collapse = require 'modules.collapse'
|
||||||
local Alert = require 'utils.alert'
|
local Alert = require 'utils.alert'
|
||||||
local Task = require 'utils.task'
|
local Task = require 'utils.task'
|
||||||
|
local Score = require 'comfy_panel.score'
|
||||||
local Token = require 'utils.token'
|
local Token = require 'utils.token'
|
||||||
|
local HS = require 'maps.mountain_fortress_v3.highscore'
|
||||||
|
|
||||||
-- tables
|
-- tables
|
||||||
local WPT = require 'maps.mountain_fortress_v3.table'
|
local WPT = require 'maps.mountain_fortress_v3.table'
|
||||||
@ -76,7 +78,6 @@ local protect_types = {
|
|||||||
['fluid-wagon'] = true,
|
['fluid-wagon'] = true,
|
||||||
['locomotive'] = true,
|
['locomotive'] = true,
|
||||||
['reactor'] = true,
|
['reactor'] = true,
|
||||||
['car'] = true,
|
|
||||||
['spidertron'] = true
|
['spidertron'] = true
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -86,26 +87,41 @@ local reset_game =
|
|||||||
local this = data.this
|
local this = data.this
|
||||||
local Reset_map = data.reset_map
|
local Reset_map = data.reset_map
|
||||||
if this.soft_reset then
|
if this.soft_reset then
|
||||||
|
HS.set_scores()
|
||||||
this.game_reset_tick = nil
|
this.game_reset_tick = nil
|
||||||
Reset_map()
|
Reset_map()
|
||||||
return
|
return
|
||||||
end
|
end
|
||||||
if this.restart then
|
if this.restart then
|
||||||
|
HS.set_scores()
|
||||||
local message = ({'entity.reset_game'})
|
local message = ({'entity.reset_game'})
|
||||||
Server.to_discord_bold(message)
|
Server.to_discord_bold(message, true)
|
||||||
Server.start_scenario('Mountain_Fortress_v3')
|
Server.start_scenario('Mountain_Fortress_v3')
|
||||||
this.announced_message = true
|
this.announced_message = true
|
||||||
return
|
return
|
||||||
end
|
end
|
||||||
if this.shutdown then
|
if this.shutdown then
|
||||||
|
HS.set_scores()
|
||||||
local message = ({'entity.shutdown_game'})
|
local message = ({'entity.shutdown_game'})
|
||||||
Server.to_discord_bold(message)
|
Server.to_discord_bold(message, true)
|
||||||
Server.stop_scenario()
|
Server.stop_scenario()
|
||||||
return
|
return
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
)
|
)
|
||||||
|
|
||||||
|
local function exists()
|
||||||
|
local carriages = WPT.get('carriages')
|
||||||
|
local t = {}
|
||||||
|
for i = 1, #carriages do
|
||||||
|
local e = carriages[i]
|
||||||
|
if (e and e.valid) then
|
||||||
|
t[e.unit_number] = true
|
||||||
|
end
|
||||||
|
end
|
||||||
|
return t
|
||||||
|
end
|
||||||
|
|
||||||
local function get_random_weighted(weighted_table, item_index, weight_index)
|
local function get_random_weighted(weighted_table, item_index, weight_index)
|
||||||
local total_weight = 0
|
local total_weight = 0
|
||||||
item_index = item_index or 1
|
item_index = item_index or 1
|
||||||
@ -261,19 +277,6 @@ local function protect_entities(event)
|
|||||||
return false
|
return false
|
||||||
end
|
end
|
||||||
|
|
||||||
local function exists()
|
|
||||||
local carriages = WPT.get('carriages')
|
|
||||||
local t = {}
|
|
||||||
for i = 1, #carriages do
|
|
||||||
local e = carriages[i]
|
|
||||||
if not (e and e.valid) then
|
|
||||||
return
|
|
||||||
end
|
|
||||||
t[e.unit_number] = true
|
|
||||||
end
|
|
||||||
return t
|
|
||||||
end
|
|
||||||
|
|
||||||
local units = exists()
|
local units = exists()
|
||||||
if is_protected(entity) then
|
if is_protected(entity) then
|
||||||
if (event.cause and event.cause.valid) then
|
if (event.cause and event.cause.valid) then
|
||||||
@ -853,8 +856,9 @@ local function on_player_repaired_entity(event)
|
|||||||
return
|
return
|
||||||
end
|
end
|
||||||
local entity = event.entity
|
local entity = event.entity
|
||||||
local locomotive = WPT.get('locomotive')
|
local units = exists()
|
||||||
if entity == locomotive then
|
|
||||||
|
if units[entity.unit_number] then
|
||||||
local player = game.players[event.player_index]
|
local player = game.players[event.player_index]
|
||||||
local repair_speed = Functions.get_magicka(player)
|
local repair_speed = Functions.get_magicka(player)
|
||||||
if repair_speed <= 0 then
|
if repair_speed <= 0 then
|
||||||
@ -971,6 +975,123 @@ local function on_entity_died(event)
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
local function get_sorted_list(column_name, score_list)
|
||||||
|
for _ = 1, #score_list, 1 do
|
||||||
|
for y = 1, #score_list, 1 do
|
||||||
|
if not score_list[y + 1] then
|
||||||
|
break
|
||||||
|
end
|
||||||
|
if score_list[y][column_name] < score_list[y + 1][column_name] then
|
||||||
|
local key = score_list[y]
|
||||||
|
score_list[y] = score_list[y + 1]
|
||||||
|
score_list[y + 1] = key
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
return score_list
|
||||||
|
end
|
||||||
|
|
||||||
|
local function get_mvps(force)
|
||||||
|
local get_score = Score.get_table().score_table
|
||||||
|
if not get_score[force] then
|
||||||
|
return false
|
||||||
|
end
|
||||||
|
local score = get_score[force]
|
||||||
|
local score_list = {}
|
||||||
|
for _, p in pairs(game.players) do
|
||||||
|
if score.players[p.name] then
|
||||||
|
local killscore = 0
|
||||||
|
if score.players[p.name].killscore then
|
||||||
|
killscore = score.players[p.name].killscore
|
||||||
|
end
|
||||||
|
local built_entities = 0
|
||||||
|
if score.players[p.name].built_entities then
|
||||||
|
built_entities = score.players[p.name].built_entities
|
||||||
|
end
|
||||||
|
local mined_entities = 0
|
||||||
|
if score.players[p.name].mined_entities then
|
||||||
|
mined_entities = score.players[p.name].mined_entities
|
||||||
|
end
|
||||||
|
table.insert(score_list, {name = p.name, killscore = killscore, built_entities = built_entities, mined_entities = mined_entities})
|
||||||
|
end
|
||||||
|
end
|
||||||
|
local mvp = {}
|
||||||
|
score_list = get_sorted_list('killscore', score_list)
|
||||||
|
mvp.killscore = {name = score_list[1].name, score = score_list[1].killscore}
|
||||||
|
score_list = get_sorted_list('mined_entities', score_list)
|
||||||
|
mvp.mined_entities = {name = score_list[1].name, score = score_list[1].mined_entities}
|
||||||
|
score_list = get_sorted_list('built_entities', score_list)
|
||||||
|
mvp.built_entities = {name = score_list[1].name, score = score_list[1].built_entities}
|
||||||
|
return mvp
|
||||||
|
end
|
||||||
|
|
||||||
|
local function show_mvps(player)
|
||||||
|
local get_score = Score.get_table().score_table
|
||||||
|
local wave_defense_table = WD.get_table()
|
||||||
|
if not get_score then
|
||||||
|
return
|
||||||
|
end
|
||||||
|
if player.gui.left['mvps'] then
|
||||||
|
return
|
||||||
|
end
|
||||||
|
local frame = player.gui.left.add({type = 'frame', name = 'mvps', direction = 'vertical'})
|
||||||
|
local l = frame.add({type = 'label', caption = 'MVPs:'})
|
||||||
|
l.style.font = 'default-listbox'
|
||||||
|
l.style.font_color = {r = 0.55, g = 0.55, b = 0.99}
|
||||||
|
|
||||||
|
local t = frame.add({type = 'table', column_count = 2})
|
||||||
|
local mvp = get_mvps('player')
|
||||||
|
if mvp then
|
||||||
|
local wave_defense = t.add({type = 'label', caption = 'Highest Wave >> '})
|
||||||
|
wave_defense.style.font = 'default-listbox'
|
||||||
|
wave_defense.style.font_color = {r = 0.22, g = 0.77, b = 0.44}
|
||||||
|
local wave_defense_text = t.add({type = 'label', caption = 'This rounds highest wave was: ' .. wave_defense_table.wave_number})
|
||||||
|
wave_defense_text.style.font = 'default-bold'
|
||||||
|
wave_defense_text.style.font_color = {r = 0.33, g = 0.66, b = 0.9}
|
||||||
|
|
||||||
|
local defender_label = t.add({type = 'label', caption = 'Defender >> '})
|
||||||
|
defender_label.style.font = 'default-listbox'
|
||||||
|
defender_label.style.font_color = {r = 0.22, g = 0.77, b = 0.44}
|
||||||
|
local defender_label_text = t.add({type = 'label', caption = mvp.killscore.name .. ' with a killing score of ' .. mvp.killscore.score .. ' kills!'})
|
||||||
|
defender_label_text.style.font = 'default-bold'
|
||||||
|
defender_label_text.style.font_color = {r = 0.33, g = 0.66, b = 0.9}
|
||||||
|
|
||||||
|
local builder_label = t.add({type = 'label', caption = 'Builder >> '})
|
||||||
|
builder_label.style.font = 'default-listbox'
|
||||||
|
builder_label.style.font_color = {r = 0.22, g = 0.77, b = 0.44}
|
||||||
|
local builder_label_text = t.add({type = 'label', caption = mvp.built_entities.name .. ' built ' .. mvp.built_entities.score .. ' things!'})
|
||||||
|
builder_label_text.style.font = 'default-bold'
|
||||||
|
builder_label_text.style.font_color = {r = 0.33, g = 0.66, b = 0.9}
|
||||||
|
|
||||||
|
local miners_label = t.add({type = 'label', caption = 'Miners >> '})
|
||||||
|
miners_label.style.font = 'default-listbox'
|
||||||
|
miners_label.style.font_color = {r = 0.22, g = 0.77, b = 0.44}
|
||||||
|
local miners_label_text = t.add({type = 'label', caption = mvp.mined_entities.name .. ' mined a total of ' .. mvp.mined_entities.score .. ' entities!'})
|
||||||
|
miners_label_text.style.font = 'default-bold'
|
||||||
|
miners_label_text.style.font_color = {r = 0.33, g = 0.66, b = 0.9}
|
||||||
|
|
||||||
|
local sent_to_discord = WPT.get('sent_to_discord')
|
||||||
|
|
||||||
|
if not sent_to_discord then
|
||||||
|
local result = {}
|
||||||
|
table.insert(result, 'HIGHEST WAVE: \\n')
|
||||||
|
table.insert(result, wave_defense_table.wave_number .. '\\n')
|
||||||
|
table.insert(result, '\\n')
|
||||||
|
table.insert(result, 'MVP Defender: \\n')
|
||||||
|
table.insert(result, mvp.killscore.name .. ' with a killing score of ' .. mvp.killscore.score .. ' kills!\\n')
|
||||||
|
table.insert(result, '\\n')
|
||||||
|
table.insert(result, 'MVP Builder: \\n')
|
||||||
|
table.insert(result, mvp.built_entities.name .. ' built ' .. mvp.built_entities.score .. ' things!\\n')
|
||||||
|
table.insert(result, '\\n')
|
||||||
|
table.insert(result, 'MVP Miners: \\n')
|
||||||
|
table.insert(result, mvp.mined_entities.name .. ' mined a total of ' .. mvp.mined_entities.score .. ' entities!\\n')
|
||||||
|
local message = table.concat(result)
|
||||||
|
Server.to_discord_embed(message)
|
||||||
|
WPT.set('sent_to_discord', true)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
function Public.unstuck_player(index)
|
function Public.unstuck_player(index)
|
||||||
local player = game.get_player(index)
|
local player = game.get_player(index)
|
||||||
local surface = player.surface
|
local surface = player.surface
|
||||||
@ -990,6 +1111,7 @@ function Public.loco_died()
|
|||||||
return
|
return
|
||||||
end
|
end
|
||||||
Collapse.start_now(false)
|
Collapse.start_now(false)
|
||||||
|
|
||||||
if not locomotive.valid then
|
if not locomotive.valid then
|
||||||
local this = WPT.get()
|
local this = WPT.get()
|
||||||
if this.announced_message then
|
if this.announced_message then
|
||||||
@ -1054,6 +1176,7 @@ function Public.loco_died()
|
|||||||
position = this.locomotive.position
|
position = this.locomotive.position
|
||||||
}
|
}
|
||||||
Alert.alert_all_players_location(pos, msg)
|
Alert.alert_all_players_location(pos, msg)
|
||||||
|
Server.to_discord_bold(msg, true)
|
||||||
game.forces.enemy.set_friend('player', true)
|
game.forces.enemy.set_friend('player', true)
|
||||||
game.forces.player.set_friend('enemy', true)
|
game.forces.player.set_friend('enemy', true)
|
||||||
|
|
||||||
@ -1074,6 +1197,7 @@ function Public.loco_died()
|
|||||||
this.game_reset_tick = 5400
|
this.game_reset_tick = 5400
|
||||||
for _, player in pairs(game.connected_players) do
|
for _, player in pairs(game.connected_players) do
|
||||||
player.play_sound {path = 'utility/game_lost', volume_modifier = 0.75}
|
player.play_sound {path = 'utility/game_lost', volume_modifier = 0.75}
|
||||||
|
show_mvps(player)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -763,6 +763,25 @@ function Public.remove_offline_players()
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
local function calc_players()
|
||||||
|
local players = game.connected_players
|
||||||
|
local check_afk_players = WPT.get('check_afk_players')
|
||||||
|
if not check_afk_players then
|
||||||
|
return #players
|
||||||
|
end
|
||||||
|
local total = 0
|
||||||
|
for i = 1, #players do
|
||||||
|
local player = players[i]
|
||||||
|
if player.afk_time < 36000 then
|
||||||
|
total = total + 1
|
||||||
|
end
|
||||||
|
end
|
||||||
|
if total <= 0 then
|
||||||
|
total = 1
|
||||||
|
end
|
||||||
|
return total
|
||||||
|
end
|
||||||
|
|
||||||
function Public.set_difficulty()
|
function Public.set_difficulty()
|
||||||
local game_lost = WPT.get('game_lost')
|
local game_lost = WPT.get('game_lost')
|
||||||
if game_lost then
|
if game_lost then
|
||||||
@ -772,7 +791,9 @@ function Public.set_difficulty()
|
|||||||
local wave_defense_table = WD.get_table()
|
local wave_defense_table = WD.get_table()
|
||||||
local collapse_amount = WPT.get('collapse_amount')
|
local collapse_amount = WPT.get('collapse_amount')
|
||||||
local collapse_speed = WPT.get('collapse_speed')
|
local collapse_speed = WPT.get('collapse_speed')
|
||||||
local player_count = #game.connected_players
|
local difficulty = WPT.get('difficulty')
|
||||||
|
local player_count = calc_players()
|
||||||
|
|
||||||
if not Diff.difficulty_vote_value then
|
if not Diff.difficulty_vote_value then
|
||||||
Diff.difficulty_vote_value = 0.1
|
Diff.difficulty_vote_value = 0.1
|
||||||
end
|
end
|
||||||
@ -786,10 +807,11 @@ function Public.set_difficulty()
|
|||||||
-- threat gain / wave
|
-- threat gain / wave
|
||||||
wave_defense_table.threat_gain_multiplier = 1.2 + player_count * Diff.difficulty_vote_value * 0.1
|
wave_defense_table.threat_gain_multiplier = 1.2 + player_count * Diff.difficulty_vote_value * 0.1
|
||||||
|
|
||||||
local amount = player_count * 0.40 + 2
|
-- local amount = player_count * 0.40 + 2 -- too high?
|
||||||
|
local amount = player_count * difficulty.multiply + 2
|
||||||
amount = floor(amount)
|
amount = floor(amount)
|
||||||
if amount > 20 then
|
if amount > difficulty.highest then
|
||||||
amount = 20
|
amount = difficulty.highest -- lowered from 20 to 15
|
||||||
end
|
end
|
||||||
|
|
||||||
wave_defense_table.wave_interval = 3600 - player_count * 60
|
wave_defense_table.wave_interval = 3600 - player_count * 60
|
||||||
@ -806,11 +828,13 @@ function Public.set_difficulty()
|
|||||||
if collapse_speed then
|
if collapse_speed then
|
||||||
Collapse.set_speed(collapse_speed)
|
Collapse.set_speed(collapse_speed)
|
||||||
else
|
else
|
||||||
if player_count >= 8 and player_count <= 12 then
|
if player_count >= 1 and player_count <= 8 then
|
||||||
|
Collapse.set_speed(9)
|
||||||
|
elseif player_count > 8 and player_count <= 20 then
|
||||||
Collapse.set_speed(8)
|
Collapse.set_speed(8)
|
||||||
elseif player_count >= 20 and player_count <= 24 then
|
elseif player_count > 20 and player_count <= 35 then
|
||||||
Collapse.set_speed(6)
|
Collapse.set_speed(6)
|
||||||
elseif player_count >= 35 then
|
elseif player_count > 35 then
|
||||||
Collapse.set_speed(5)
|
Collapse.set_speed(5)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
@ -818,9 +842,14 @@ end
|
|||||||
|
|
||||||
function Public.render_direction(surface)
|
function Public.render_direction(surface)
|
||||||
local counter = WPT.get('soft_reset_counter')
|
local counter = WPT.get('soft_reset_counter')
|
||||||
|
local winter_mode = WPT.get('winter_mode')
|
||||||
|
local text = 'Welcome to Mountain Fortress v3!'
|
||||||
|
if winter_mode then
|
||||||
|
text = 'Welcome to Wintery Mountain Fortress v3!'
|
||||||
|
end
|
||||||
if counter then
|
if counter then
|
||||||
rendering.draw_text {
|
rendering.draw_text {
|
||||||
text = 'Welcome to Mountain Fortress v3!\nRun: ' .. counter,
|
text = text .. '\nRun: ' .. counter,
|
||||||
surface = surface,
|
surface = surface,
|
||||||
target = {-0, 10},
|
target = {-0, 10},
|
||||||
color = {r = 0.98, g = 0.66, b = 0.22},
|
color = {r = 0.98, g = 0.66, b = 0.22},
|
||||||
@ -831,7 +860,7 @@ function Public.render_direction(surface)
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
rendering.draw_text {
|
rendering.draw_text {
|
||||||
text = 'Welcome to Mountain Fortress v3!',
|
text = text,
|
||||||
surface = surface,
|
surface = surface,
|
||||||
target = {-0, 10},
|
target = {-0, 10},
|
||||||
color = {r = 0.98, g = 0.66, b = 0.22},
|
color = {r = 0.98, g = 0.66, b = 0.22},
|
||||||
@ -1139,6 +1168,13 @@ function Public.is_creativity_mode_on()
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
function Public.disable_creative()
|
||||||
|
local creative_enabled = Commands.get('creative_enabled')
|
||||||
|
if creative_enabled then
|
||||||
|
Commands.set('creative_enabled', false)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
function Public.on_pre_player_left_game(event)
|
function Public.on_pre_player_left_game(event)
|
||||||
local offline_players_enabled = WPT.get('offline_players_enabled')
|
local offline_players_enabled = WPT.get('offline_players_enabled')
|
||||||
if not offline_players_enabled then
|
if not offline_players_enabled then
|
||||||
|
@ -15,6 +15,14 @@ local queue_task = Task.queue_task
|
|||||||
local tiles_per_call = 8
|
local tiles_per_call = 8
|
||||||
local total_calls = ceil(1024 / tiles_per_call)
|
local total_calls = ceil(1024 / tiles_per_call)
|
||||||
local regen_decoratives = false
|
local regen_decoratives = false
|
||||||
|
local wintery_type = {
|
||||||
|
['simple-entity'] = true,
|
||||||
|
['tree'] = true,
|
||||||
|
['fish'] = true,
|
||||||
|
['market'] = true,
|
||||||
|
['locomotive'] = true,
|
||||||
|
['cargo-wagon'] = true
|
||||||
|
}
|
||||||
|
|
||||||
-- Set to false by modules that want to control the on_chunk_generated event themselves.
|
-- Set to false by modules that want to control the on_chunk_generated event themselves.
|
||||||
Public.enable_register_events = true
|
Public.enable_register_events = true
|
||||||
@ -266,6 +274,44 @@ local function do_place_buildings(data)
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
local function wintery(ent, extra_lights)
|
||||||
|
local winter_mode = WPT.get('winter_mode')
|
||||||
|
if not winter_mode then
|
||||||
|
return false
|
||||||
|
end
|
||||||
|
local colors = {{255, 0, 0}, {0, 255, 0}, {0, 0, 255}}
|
||||||
|
local function add_light(e)
|
||||||
|
local color = colors[math.random(1, 3)]
|
||||||
|
local scale = extra_lights or 1
|
||||||
|
rendering.draw_light(
|
||||||
|
{
|
||||||
|
sprite = 'utility/light_small',
|
||||||
|
orientation = 1,
|
||||||
|
scale = scale,
|
||||||
|
intensity = 1,
|
||||||
|
minimum_darkness = 0,
|
||||||
|
oriented = false,
|
||||||
|
color = color,
|
||||||
|
target = e,
|
||||||
|
target_offset = {0, -0.5},
|
||||||
|
surface = e.surface
|
||||||
|
}
|
||||||
|
)
|
||||||
|
end
|
||||||
|
if not (ent and ent.valid) then
|
||||||
|
return
|
||||||
|
end
|
||||||
|
if wintery_type[ent.type] then
|
||||||
|
if ent.type == 'simple-entity' then
|
||||||
|
if random(1, 8) ~= 1 then
|
||||||
|
return
|
||||||
|
end
|
||||||
|
end
|
||||||
|
add_light(ent)
|
||||||
|
end
|
||||||
|
return true
|
||||||
|
end
|
||||||
|
|
||||||
local function do_place_entities(data)
|
local function do_place_entities(data)
|
||||||
local surface = data.surface
|
local surface = data.surface
|
||||||
local entity
|
local entity
|
||||||
@ -274,6 +320,7 @@ local function do_place_entities(data)
|
|||||||
if e.collision then
|
if e.collision then
|
||||||
if surface.can_place_entity(e) then
|
if surface.can_place_entity(e) then
|
||||||
entity = surface.create_entity(e)
|
entity = surface.create_entity(e)
|
||||||
|
wintery(entity)
|
||||||
if entity and e.direction then
|
if entity and e.direction then
|
||||||
entity.direction = e.direction
|
entity.direction = e.direction
|
||||||
end
|
end
|
||||||
@ -297,6 +344,7 @@ local function do_place_entities(data)
|
|||||||
end
|
end
|
||||||
else
|
else
|
||||||
entity = surface.create_entity(e)
|
entity = surface.create_entity(e)
|
||||||
|
wintery(entity)
|
||||||
if entity and e.direction then
|
if entity and e.direction then
|
||||||
entity.direction = e.direction
|
entity.direction = e.direction
|
||||||
end
|
end
|
||||||
@ -528,4 +576,6 @@ end
|
|||||||
|
|
||||||
Event.add(defines.events.on_chunk_generated, on_chunk)
|
Event.add(defines.events.on_chunk_generated, on_chunk)
|
||||||
|
|
||||||
|
Public.wintery = wintery
|
||||||
|
|
||||||
return Public
|
return Public
|
||||||
|
@ -3,9 +3,13 @@ local Global = require 'utils.global'
|
|||||||
local Server = require 'utils.server'
|
local Server = require 'utils.server'
|
||||||
local Token = require 'utils.token'
|
local Token = require 'utils.token'
|
||||||
local Tabs = require 'comfy_panel.main'
|
local Tabs = require 'comfy_panel.main'
|
||||||
|
local Score = require 'comfy_panel.score'
|
||||||
local WPT = require 'maps.mountain_fortress_v3.table'
|
local WPT = require 'maps.mountain_fortress_v3.table'
|
||||||
|
local WD = require 'modules.wave_defense.table'
|
||||||
|
local Core = require 'utils.core'
|
||||||
|
|
||||||
local score_dataset = 'highscores'
|
local score_dataset = 'highscores'
|
||||||
|
local score_key = 'mountain_fortress_v3_scores'
|
||||||
local set_data = Server.set_data
|
local set_data = Server.set_data
|
||||||
local try_get_data = Server.try_get_data
|
local try_get_data = Server.try_get_data
|
||||||
|
|
||||||
@ -34,6 +38,247 @@ local biters = {
|
|||||||
'big-spitter',
|
'big-spitter',
|
||||||
'behemoth-spitter'
|
'behemoth-spitter'
|
||||||
}
|
}
|
||||||
|
|
||||||
|
local function get_lowest(tbl, column_name)
|
||||||
|
local t = {}
|
||||||
|
for _, value in pairs(tbl) do
|
||||||
|
insert(t, value[column_name])
|
||||||
|
end
|
||||||
|
table.sort(
|
||||||
|
t,
|
||||||
|
function(a, b)
|
||||||
|
return a < b
|
||||||
|
end
|
||||||
|
)
|
||||||
|
if t[1] then
|
||||||
|
return t[1]
|
||||||
|
else
|
||||||
|
return 100
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
local function get_highest(tbl, column_name)
|
||||||
|
local t = {}
|
||||||
|
for _, value in pairs(tbl) do
|
||||||
|
insert(t, value[column_name])
|
||||||
|
end
|
||||||
|
table.sort(
|
||||||
|
t,
|
||||||
|
function(a, b)
|
||||||
|
return a > b
|
||||||
|
end
|
||||||
|
)
|
||||||
|
if t[1] then
|
||||||
|
return t[1]
|
||||||
|
else
|
||||||
|
return 10
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
local function contains(tbl, key, string, rtn)
|
||||||
|
for index, value in pairs(tbl) do
|
||||||
|
if value[key] and value[key] == string then
|
||||||
|
if rtn then
|
||||||
|
return index
|
||||||
|
else
|
||||||
|
return true
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
return false
|
||||||
|
end
|
||||||
|
|
||||||
|
local function sort_list(method, column_name, score_list)
|
||||||
|
local comparators = {
|
||||||
|
['ascending'] = function(a, b)
|
||||||
|
return a[column_name] < b[column_name]
|
||||||
|
end,
|
||||||
|
['descending'] = function(a, b)
|
||||||
|
return a[column_name] > b[column_name]
|
||||||
|
end
|
||||||
|
}
|
||||||
|
table.sort(score_list, comparators[method])
|
||||||
|
return score_list
|
||||||
|
end
|
||||||
|
|
||||||
|
local function get_sorted_list(column_name, score_list)
|
||||||
|
local sl = {}
|
||||||
|
local i = 0
|
||||||
|
score_list = sort_list('descending', column_name, score_list)
|
||||||
|
|
||||||
|
for key, player in ipairs(score_list) do
|
||||||
|
sl[key] = player
|
||||||
|
i = i + 1
|
||||||
|
if i == 20 then
|
||||||
|
return sl
|
||||||
|
end
|
||||||
|
end
|
||||||
|
return sl
|
||||||
|
end
|
||||||
|
|
||||||
|
local function get_mvps()
|
||||||
|
local new_score_table = Score.get_table().score_table
|
||||||
|
if not new_score_table['player'] then
|
||||||
|
return false
|
||||||
|
end
|
||||||
|
local old_score = this.score_table['player']
|
||||||
|
local score = new_score_table['player']
|
||||||
|
local score_list = {}
|
||||||
|
local mvp = old_score.players
|
||||||
|
|
||||||
|
for _, p in pairs(game.players) do
|
||||||
|
if score.players[p.name] then
|
||||||
|
local killscore = 0
|
||||||
|
if score.players[p.name].killscore then
|
||||||
|
killscore = score.players[p.name].killscore
|
||||||
|
end
|
||||||
|
local built_entities = 0
|
||||||
|
if score.players[p.name].built_entities then
|
||||||
|
built_entities = score.players[p.name].built_entities
|
||||||
|
end
|
||||||
|
local mined_entities = 0
|
||||||
|
if score.players[p.name].mined_entities then
|
||||||
|
mined_entities = score.players[p.name].mined_entities
|
||||||
|
end
|
||||||
|
local deaths = 0
|
||||||
|
if score.players[p.name].deaths then
|
||||||
|
deaths = score.players[p.name].deaths
|
||||||
|
end
|
||||||
|
|
||||||
|
insert(score_list, {name = p.name, killscore = killscore, built_entities = built_entities, deaths = deaths, mined_entities = mined_entities})
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
local score_list_k = get_sorted_list('killscore', score_list)
|
||||||
|
local score_list_m = get_sorted_list('mined_entities', score_list)
|
||||||
|
local score_list_b = get_sorted_list('built_entities', score_list)
|
||||||
|
local score_list_d = get_sorted_list('deaths', score_list)
|
||||||
|
local lowest_k = get_lowest(mvp, 'killscore')
|
||||||
|
local lowest_m = get_lowest(mvp, 'mined_entities')
|
||||||
|
local lowest_b = get_lowest(mvp, 'built_entities')
|
||||||
|
local highest_d = get_highest(mvp, 'deaths')
|
||||||
|
|
||||||
|
for i = 1, 30 do
|
||||||
|
local kill_list = score_list_k[i]
|
||||||
|
local mined_list = score_list_m[i]
|
||||||
|
local build_list = score_list_b[i]
|
||||||
|
local death_list = score_list_d[i]
|
||||||
|
|
||||||
|
if kill_list then
|
||||||
|
if not contains(mvp, 'name', kill_list.name) then
|
||||||
|
if kill_list.killscore >= lowest_k then
|
||||||
|
if death_list and death_list.deaths < highest_d then
|
||||||
|
insert(
|
||||||
|
mvp,
|
||||||
|
{
|
||||||
|
name = kill_list.name,
|
||||||
|
killscore = kill_list.killscore,
|
||||||
|
deaths = death_list.deaths
|
||||||
|
}
|
||||||
|
)
|
||||||
|
else
|
||||||
|
insert(
|
||||||
|
mvp,
|
||||||
|
{
|
||||||
|
name = kill_list.name,
|
||||||
|
killscore = kill_list.killscore
|
||||||
|
}
|
||||||
|
)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
else
|
||||||
|
local index = contains(mvp, 'name', kill_list.name, true)
|
||||||
|
if index then
|
||||||
|
if mvp[index].killscore and kill_list.killscore > mvp[index].killscore then
|
||||||
|
mvp[index].killscore = kill_list.killscore
|
||||||
|
end
|
||||||
|
if death_list and mvp[index].deaths and death_list.deaths < mvp[index].deaths then
|
||||||
|
mvp[index].deaths = death_list.deaths
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
if mined_list then
|
||||||
|
if not contains(mvp, 'name', mined_list.name) then
|
||||||
|
if mined_list.mined_entities >= lowest_m then
|
||||||
|
if death_list and death_list.deaths < highest_d then
|
||||||
|
insert(
|
||||||
|
mvp,
|
||||||
|
{
|
||||||
|
name = mined_list.name,
|
||||||
|
mined_entities = mined_list.mined_entities,
|
||||||
|
deaths = death_list.deaths
|
||||||
|
}
|
||||||
|
)
|
||||||
|
else
|
||||||
|
insert(
|
||||||
|
mvp,
|
||||||
|
{
|
||||||
|
name = mined_list.name,
|
||||||
|
mined_entities = mined_list.mined_entities
|
||||||
|
}
|
||||||
|
)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
else
|
||||||
|
local index = contains(mvp, 'name', mined_list.name, true)
|
||||||
|
if index then
|
||||||
|
if mvp[index].mined_entities and mined_list.mined_entities > mvp[index].mined_entities then
|
||||||
|
mvp[index].mined_entities = mined_list.mined_entities
|
||||||
|
end
|
||||||
|
if death_list and mvp[index].deaths and death_list.deaths < mvp[index].deaths then
|
||||||
|
mvp[index].deaths = death_list.deaths
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
if build_list then
|
||||||
|
if not contains(mvp, 'name', build_list.name) then
|
||||||
|
if build_list.built_entities >= lowest_b then
|
||||||
|
if death_list and death_list.deaths < highest_d then
|
||||||
|
insert(
|
||||||
|
mvp,
|
||||||
|
{
|
||||||
|
name = build_list.name,
|
||||||
|
built_entities = build_list.built_entities,
|
||||||
|
deaths = death_list.deaths
|
||||||
|
}
|
||||||
|
)
|
||||||
|
else
|
||||||
|
insert(
|
||||||
|
mvp,
|
||||||
|
{
|
||||||
|
name = build_list.name,
|
||||||
|
built_entities = build_list.built_entities
|
||||||
|
}
|
||||||
|
)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
else
|
||||||
|
local index = contains(mvp, 'name', build_list.name, true)
|
||||||
|
if index then
|
||||||
|
if mvp[index].built_entities and build_list.built_entities > mvp[index].built_entities then
|
||||||
|
mvp[index].built_entities = build_list.built_entities
|
||||||
|
end
|
||||||
|
if death_list and mvp[index].deaths and death_list.deaths < mvp[index].deaths then
|
||||||
|
mvp[index].deaths = death_list.deaths
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
if mvp['GodGamer'] then
|
||||||
|
mvp['GodGamer'] = nil
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
if #mvp <= 0 then
|
||||||
|
return false
|
||||||
|
end
|
||||||
|
|
||||||
|
return mvp
|
||||||
|
end
|
||||||
|
|
||||||
local function get_total_biter_killcount(force)
|
local function get_total_biter_killcount(force)
|
||||||
local count = 0
|
local count = 0
|
||||||
for _, biter in pairs(biters) do
|
for _, biter in pairs(biters) do
|
||||||
@ -42,24 +287,61 @@ local function get_total_biter_killcount(force)
|
|||||||
return count
|
return count
|
||||||
end
|
end
|
||||||
|
|
||||||
local function get_additional_stats(key)
|
local function write_additional_stats(key)
|
||||||
if not this.score_table['player'] then
|
|
||||||
this.score_table['player'] = {}
|
|
||||||
end
|
|
||||||
|
|
||||||
local player = game.forces.player
|
local player = game.forces.player
|
||||||
local breached_zone = WPT.get('breached_wall')
|
local new_breached_zone = WPT.get('breached_wall')
|
||||||
local c = get_total_biter_killcount(player)
|
local new_wave_number = WD.get('wave_number')
|
||||||
|
local new_biters_killed = get_total_biter_killcount(player)
|
||||||
|
local new_rockets_launched = player.rockets_launched
|
||||||
|
local new_total_time = game.ticks_played
|
||||||
local t = this.score_table['player']
|
local t = this.score_table['player']
|
||||||
t.rockets_launched = player.rockets_launched
|
|
||||||
t.biters_killed = c
|
if this.score_table['player'] then
|
||||||
if breached_zone == 1 then
|
local old_wave = this.score_table['player'].wave_number
|
||||||
t.breached_zone = breached_zone
|
local old_biters_killed = this.score_table['player'].biters_killed
|
||||||
else
|
local old_breached_zone = this.score_table['player'].breached_zone
|
||||||
t.breached_zone = breached_zone - 1
|
local old_rockets_launched = this.score_table['player'].rockets_launched
|
||||||
|
local old_total_time = this.score_table['player'].total_time
|
||||||
|
local old_players = this.score_table['player'].players
|
||||||
|
if new_wave_number > old_wave then
|
||||||
|
t.wave_number = new_wave_number
|
||||||
|
else
|
||||||
|
t.wave_number = old_wave
|
||||||
|
end
|
||||||
|
if new_biters_killed > old_biters_killed then
|
||||||
|
t.biters_killed = new_biters_killed
|
||||||
|
else
|
||||||
|
t.biters_killed = old_biters_killed
|
||||||
|
end
|
||||||
|
if new_breached_zone > old_breached_zone then
|
||||||
|
t.breached_zone = new_breached_zone
|
||||||
|
else
|
||||||
|
t.breached_zone = old_breached_zone
|
||||||
|
end
|
||||||
|
if new_rockets_launched > old_rockets_launched then
|
||||||
|
t.rockets_launched = new_rockets_launched
|
||||||
|
else
|
||||||
|
t.rockets_launched = old_rockets_launched
|
||||||
|
end
|
||||||
|
if new_total_time > old_total_time then
|
||||||
|
t.total_time = new_total_time
|
||||||
|
else
|
||||||
|
t.total_time = old_total_time
|
||||||
|
end
|
||||||
|
|
||||||
|
local new_stats = get_mvps()
|
||||||
|
if new_stats then
|
||||||
|
t.players = new_stats
|
||||||
|
else
|
||||||
|
t.players = old_players
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
set_data(score_dataset, key, t)
|
this.score_table['player'] = t
|
||||||
|
|
||||||
|
if key then
|
||||||
|
set_data(score_dataset, key, t)
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
local get_scores =
|
local get_scores =
|
||||||
@ -76,21 +358,27 @@ local get_scores =
|
|||||||
|
|
||||||
function Public.get_scores()
|
function Public.get_scores()
|
||||||
local secs = Server.get_current_time()
|
local secs = Server.get_current_time()
|
||||||
local key = 'mountain_fortress_v3_scores'
|
|
||||||
if not secs then
|
if not secs then
|
||||||
return
|
return
|
||||||
else
|
else
|
||||||
try_get_data(score_dataset, key, get_scores)
|
try_get_data(score_dataset, score_key, get_scores)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
function Public.set_scores(key)
|
function Public.set_scores()
|
||||||
local secs = Server.get_current_time()
|
local secs = Server.get_current_time()
|
||||||
key = tostring(key)
|
|
||||||
if not secs then
|
if not secs then
|
||||||
return
|
return
|
||||||
else
|
else
|
||||||
get_additional_stats(key)
|
write_additional_stats(score_key)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
local function on_init()
|
||||||
|
local secs = Server.get_current_time()
|
||||||
|
if not secs then
|
||||||
|
write_additional_stats()
|
||||||
|
return
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
@ -110,50 +398,35 @@ local function get_score_list()
|
|||||||
return score_list
|
return score_list
|
||||||
end
|
end
|
||||||
for p, _ in pairs(score_force.players) do
|
for p, _ in pairs(score_force.players) do
|
||||||
if score_force.players[p] then
|
local score = score_force.players[p]
|
||||||
local score = score_force.players[p]
|
insert(
|
||||||
insert(
|
score_list,
|
||||||
score_list,
|
{
|
||||||
{
|
name = score and score.name,
|
||||||
name = p,
|
killscore = score and score.killscore or 0,
|
||||||
killscore = score.killscore or 0,
|
deaths = score and score.deaths or 20,
|
||||||
deaths = score.deaths or 0,
|
built_entities = score and score.built_entities or 0,
|
||||||
built_entities = score.built_entities or 0,
|
mined_entities = score and score.mined_entities or 0
|
||||||
mined_entities = score.mined_entities or 0
|
}
|
||||||
}
|
)
|
||||||
)
|
|
||||||
end
|
|
||||||
end
|
end
|
||||||
return score_list
|
return score_list
|
||||||
end
|
end
|
||||||
|
|
||||||
local function get_sorted_list(method, column_name, score_list)
|
|
||||||
local comparators = {
|
|
||||||
['ascending'] = function(a, b)
|
|
||||||
return a[column_name] < b[column_name]
|
|
||||||
end,
|
|
||||||
['descending'] = function(a, b)
|
|
||||||
return a[column_name] > b[column_name]
|
|
||||||
end
|
|
||||||
}
|
|
||||||
table.sort(score_list, comparators[method])
|
|
||||||
return score_list
|
|
||||||
end
|
|
||||||
|
|
||||||
local function add_global_stats(frame)
|
local function add_global_stats(frame)
|
||||||
local score = this.score_table['player']
|
local score = this.score_table['player']
|
||||||
|
|
||||||
local t = frame.add {type = 'table', column_count = 6}
|
local t = frame.add {type = 'table', column_count = 6}
|
||||||
|
|
||||||
local l = t.add {type = 'label', caption = 'Rockets launched: '}
|
local l = t.add {type = 'label', caption = 'Rockets: '}
|
||||||
l.style.font = 'default-game'
|
l.style.font = 'default-game'
|
||||||
l.style.font_color = {r = 175, g = 75, b = 255}
|
l.style.font_color = {r = 175, g = 75, b = 255}
|
||||||
l.style.minimal_width = 140
|
l.style.minimal_width = 100
|
||||||
|
|
||||||
local l = t.add {type = 'label', caption = score.rockets_launched}
|
local l = t.add {type = 'label', caption = score.rockets_launched}
|
||||||
l.style.font = 'default-listbox'
|
l.style.font = 'heading-2'
|
||||||
l.style.font_color = {r = 0.9, g = 0.9, b = 0.9}
|
l.style.font_color = {r = 0.9, g = 0.9, b = 0.9}
|
||||||
l.style.minimal_width = 123
|
l.style.minimal_width = 100
|
||||||
|
|
||||||
local l = t.add {type = 'label', caption = 'Dead bugs: '}
|
local l = t.add {type = 'label', caption = 'Dead bugs: '}
|
||||||
l.style.font = 'default-game'
|
l.style.font = 'default-game'
|
||||||
@ -161,19 +434,42 @@ local function add_global_stats(frame)
|
|||||||
l.style.minimal_width = 100
|
l.style.minimal_width = 100
|
||||||
|
|
||||||
local l = t.add {type = 'label', caption = score.biters_killed}
|
local l = t.add {type = 'label', caption = score.biters_killed}
|
||||||
l.style.font = 'default-listbox'
|
l.style.font = 'heading-2'
|
||||||
l.style.font_color = {r = 0.9, g = 0.9, b = 0.9}
|
l.style.font_color = {r = 0.9, g = 0.9, b = 0.9}
|
||||||
l.style.minimal_width = 145
|
l.style.minimal_width = 100
|
||||||
|
|
||||||
local l = t.add {type = 'label', caption = 'Breached zones: '}
|
local l = t.add {type = 'label', caption = 'Breached zones: '}
|
||||||
l.style.font = 'default-game'
|
l.style.font = 'default-game'
|
||||||
l.style.font_color = {r = 0, g = 128, b = 0}
|
l.style.font_color = {r = 0, g = 128, b = 0}
|
||||||
l.style.minimal_width = 100
|
l.style.minimal_width = 100
|
||||||
|
local zone = score.breached_zone - 1
|
||||||
local l = t.add {type = 'label', caption = score.breached_zone - 1}
|
if score.breached_zone == 0 then
|
||||||
l.style.font = 'default-listbox'
|
zone = 0
|
||||||
|
end
|
||||||
|
local l = t.add {type = 'label', caption = zone}
|
||||||
|
l.style.font = 'heading-2'
|
||||||
l.style.font_color = {r = 0.9, g = 0.9, b = 0.9}
|
l.style.font_color = {r = 0.9, g = 0.9, b = 0.9}
|
||||||
l.style.minimal_width = 145
|
l.style.minimal_width = 100
|
||||||
|
|
||||||
|
local l = t.add {type = 'label', caption = 'Highest wave: '}
|
||||||
|
l.style.font = 'default-game'
|
||||||
|
l.style.font_color = {r = 128, g = 128, b = 0.9}
|
||||||
|
l.style.minimal_width = 100
|
||||||
|
|
||||||
|
local l = t.add {type = 'label', caption = score.wave_number}
|
||||||
|
l.style.font = 'heading-2'
|
||||||
|
l.style.font_color = {r = 0.9, g = 0.9, b = 0.9}
|
||||||
|
l.style.minimal_width = 100
|
||||||
|
|
||||||
|
local l = t.add {type = 'label', caption = 'Last run total time: '}
|
||||||
|
l.style.font = 'default-game'
|
||||||
|
l.style.font_color = {r = 0.9, g = 128, b = 128}
|
||||||
|
l.style.minimal_width = 100
|
||||||
|
|
||||||
|
local l = t.add {type = 'label', caption = Core.format_time(score.total_time)}
|
||||||
|
l.style.font = 'heading-2'
|
||||||
|
l.style.font_color = {r = 0.9, g = 0.9, b = 0.9}
|
||||||
|
l.style.minimal_width = 100
|
||||||
end
|
end
|
||||||
|
|
||||||
local show_score = (function(player, frame)
|
local show_score = (function(player, frame)
|
||||||
@ -185,7 +481,7 @@ local show_score = (function(player, frame)
|
|||||||
sFlow.horizontal_align = 'center'
|
sFlow.horizontal_align = 'center'
|
||||||
sFlow.vertical_align = 'center'
|
sFlow.vertical_align = 'center'
|
||||||
|
|
||||||
local stats = flow.add {type = 'label', caption = 'Previous game statistics!'}
|
local stats = flow.add {type = 'label', caption = 'Highest score so far:'}
|
||||||
local s_stats = stats.style
|
local s_stats = stats.style
|
||||||
s_stats.font = 'heading-1'
|
s_stats.font = 'heading-1'
|
||||||
s_stats.font_color = {r = 0.98, g = 0.66, b = 0.22}
|
s_stats.font_color = {r = 0.98, g = 0.66, b = 0.22}
|
||||||
@ -238,9 +534,7 @@ local show_score = (function(player, frame)
|
|||||||
-- Score list
|
-- Score list
|
||||||
local score_list = get_score_list()
|
local score_list = get_score_list()
|
||||||
|
|
||||||
if #game.connected_players > 1 then
|
score_list = sort_list(sorting_pref.method, sorting_pref.column, score_list)
|
||||||
score_list = get_sorted_list(sorting_pref.method, sorting_pref.column, score_list)
|
|
||||||
end
|
|
||||||
|
|
||||||
-- New pane for scores (while keeping headers at same position)
|
-- New pane for scores (while keeping headers at same position)
|
||||||
local scroll_pane =
|
local scroll_pane =
|
||||||
@ -273,12 +567,18 @@ local show_score = (function(player, frame)
|
|||||||
b = p.color.b * 0.6 + 0.4,
|
b = p.color.b * 0.6 + 0.4,
|
||||||
a = 1
|
a = 1
|
||||||
}
|
}
|
||||||
|
|
||||||
|
local k = entry.killscore > 0 and entry.killscore or 'Not MVP'
|
||||||
|
local d = entry.deaths < 10 and entry.deaths or 'Not MVP'
|
||||||
|
local b = entry.built_entities > 0 and entry.built_entities or 'Not MVP'
|
||||||
|
local m = entry.mined_entities > 0 and entry.mined_entities or 'Not MVP'
|
||||||
|
|
||||||
local line = {
|
local line = {
|
||||||
{caption = entry.name, color = special_color},
|
{caption = entry.name, color = special_color},
|
||||||
{caption = tostring(entry.killscore)},
|
{caption = tostring(k)},
|
||||||
{caption = tostring(entry.deaths)},
|
{caption = tostring(d)},
|
||||||
{caption = tostring(entry.built_entities)},
|
{caption = tostring(b)},
|
||||||
{caption = tostring(entry.mined_entities)}
|
{caption = tostring(m)}
|
||||||
}
|
}
|
||||||
local default_color = {r = 0.9, g = 0.9, b = 0.9}
|
local default_color = {r = 0.9, g = 0.9, b = 0.9}
|
||||||
|
|
||||||
@ -297,8 +597,6 @@ local show_score = (function(player, frame)
|
|||||||
end -- foreach entry
|
end -- foreach entry
|
||||||
end) -- show_score
|
end) -- show_score
|
||||||
|
|
||||||
comfy_panel_tabs['HighScore'] = {gui = show_score, admin = false}
|
|
||||||
|
|
||||||
local function on_gui_click(event)
|
local function on_gui_click(event)
|
||||||
if not event then
|
if not event then
|
||||||
return
|
return
|
||||||
@ -315,18 +613,12 @@ local function on_gui_click(event)
|
|||||||
if not frame then
|
if not frame then
|
||||||
return
|
return
|
||||||
end
|
end
|
||||||
if frame.name ~= 'HighScore' then
|
if frame.name ~= 'Highscore' then
|
||||||
return
|
return
|
||||||
end
|
end
|
||||||
|
|
||||||
local name = event.element.name
|
local name = event.element.name
|
||||||
|
|
||||||
-- Handles click on the checkbox, for floating score
|
|
||||||
if name == 'show_floating_killscore_texts' then
|
|
||||||
global.show_floating_killscore[player.name] = event.element.state
|
|
||||||
return
|
|
||||||
end
|
|
||||||
|
|
||||||
-- Handles click on a score header
|
-- Handles click on a score header
|
||||||
local element_to_column = {
|
local element_to_column = {
|
||||||
['score_killscore'] = 'killscore',
|
['score_killscore'] = 'killscore',
|
||||||
@ -362,6 +654,20 @@ local function on_player_left_game(event)
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
Server.on_data_set_changed(
|
||||||
|
score_dataset,
|
||||||
|
function(data)
|
||||||
|
if data.key == score_key then
|
||||||
|
if data.value then
|
||||||
|
this.score_table['player'] = data.value
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
)
|
||||||
|
|
||||||
|
comfy_panel_tabs['Highscore'] = {gui = show_score, admin = false, only_server_sided = true}
|
||||||
|
|
||||||
|
Event.on_init(on_init)
|
||||||
Event.add(defines.events.on_player_left_game, on_player_left_game)
|
Event.add(defines.events.on_player_left_game, on_player_left_game)
|
||||||
Event.add(defines.events.on_player_joined_game, on_player_joined_game)
|
Event.add(defines.events.on_player_joined_game, on_player_joined_game)
|
||||||
Event.add(defines.events.on_gui_click, on_gui_click)
|
Event.add(defines.events.on_gui_click, on_gui_click)
|
||||||
|
@ -3,6 +3,7 @@ local Color = require 'utils.color_presets'
|
|||||||
local Task = require 'utils.task'
|
local Task = require 'utils.task'
|
||||||
local Token = require 'utils.token'
|
local Token = require 'utils.token'
|
||||||
local IC_Gui = require 'maps.mountain_fortress_v3.ic.gui'
|
local IC_Gui = require 'maps.mountain_fortress_v3.ic.gui'
|
||||||
|
local WPT = require 'maps.mountain_fortress_v3.table'
|
||||||
|
|
||||||
local Public = {}
|
local Public = {}
|
||||||
local main_tile_name = 'black-refined-concrete'
|
local main_tile_name = 'black-refined-concrete'
|
||||||
@ -517,10 +518,14 @@ local function get_player_data(ic, player)
|
|||||||
if ic.players[player.index] then
|
if ic.players[player.index] then
|
||||||
return player_data
|
return player_data
|
||||||
end
|
end
|
||||||
|
local fallback = WPT.get('active_surface_index')
|
||||||
|
if not fallback then
|
||||||
|
fallback = 1
|
||||||
|
end
|
||||||
|
|
||||||
ic.players[player.index] = {
|
ic.players[player.index] = {
|
||||||
surface = 1,
|
surface = 1,
|
||||||
fallback_surface = 1,
|
fallback_surface = tonumber(fallback),
|
||||||
notified = false
|
notified = false
|
||||||
}
|
}
|
||||||
return ic.players[player.index]
|
return ic.players[player.index]
|
||||||
|
@ -305,10 +305,16 @@ local function get_player_data(icw, player)
|
|||||||
return player_data
|
return player_data
|
||||||
end
|
end
|
||||||
|
|
||||||
|
local fallback = WPT.get('active_surface_index')
|
||||||
|
if not fallback then
|
||||||
|
fallback = 1
|
||||||
|
end
|
||||||
|
|
||||||
icw.players[player.index] = {
|
icw.players[player.index] = {
|
||||||
surface = 1,
|
surface = 1,
|
||||||
fallback_surface = 1,
|
fallback_surface = tonumber(fallback),
|
||||||
zoom = 0.30,
|
zoom = 0.30,
|
||||||
|
auto = true,
|
||||||
map_size = 360
|
map_size = 360
|
||||||
}
|
}
|
||||||
return icw.players[player.index]
|
return icw.players[player.index]
|
||||||
@ -960,17 +966,30 @@ function Public.item_transfer(icw)
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
function Public.toggle_auto(icw, player)
|
||||||
|
local player_data = get_player_data(icw, player)
|
||||||
|
local switch = player.gui.left.icw_main_frame['icw_auto_switch']
|
||||||
|
if switch.switch_state == 'left' then
|
||||||
|
player_data.auto = true
|
||||||
|
elseif switch.switch_state == 'right' then
|
||||||
|
player_data.auto = false
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
function Public.draw_minimap(icw, player, surface, position)
|
function Public.draw_minimap(icw, player, surface, position)
|
||||||
if not (surface and surface.valid) then
|
if not (surface and surface.valid) then
|
||||||
return
|
return
|
||||||
end
|
end
|
||||||
|
local player_data = get_player_data(icw, player)
|
||||||
local frame = player.gui.left.icw_main_frame
|
local frame = player.gui.left.icw_main_frame
|
||||||
if not frame then
|
if not frame then
|
||||||
frame = player.gui.left.add({type = 'frame', direction = 'vertical', name = 'icw_main_frame', caption = 'Minimap'})
|
frame = player.gui.left.add({type = 'frame', direction = 'vertical', name = 'icw_main_frame', caption = 'Minimap'})
|
||||||
end
|
end
|
||||||
local element = frame['icw_sub_frame']
|
local element = frame['icw_sub_frame']
|
||||||
|
if not frame.icw_auto_switch then
|
||||||
|
frame.add({type = 'switch', name = 'icw_auto_switch', allow_none_state = false, left_label_caption = {'gui.map_on'}, right_label_caption = {'gui.map_off'}})
|
||||||
|
end
|
||||||
if not element then
|
if not element then
|
||||||
local player_data = get_player_data(icw, player)
|
|
||||||
element =
|
element =
|
||||||
player.gui.left.icw_main_frame.add(
|
player.gui.left.icw_main_frame.add(
|
||||||
{
|
{
|
||||||
@ -987,14 +1006,16 @@ function Public.draw_minimap(icw, player, surface, position)
|
|||||||
element.style.minimal_width = player_data.map_size
|
element.style.minimal_width = player_data.map_size
|
||||||
return
|
return
|
||||||
end
|
end
|
||||||
|
|
||||||
element.position = position
|
element.position = position
|
||||||
end
|
end
|
||||||
|
|
||||||
function Public.update_minimap(icw)
|
function Public.update_minimap(icw)
|
||||||
for k, player in pairs(game.connected_players) do
|
for k, player in pairs(game.connected_players) do
|
||||||
|
local player_data = get_player_data(icw, player)
|
||||||
if player.character and player.character.valid then
|
if player.character and player.character.valid then
|
||||||
local wagon = get_wagon_for_entity(icw, player.character)
|
local wagon = get_wagon_for_entity(icw, player.character)
|
||||||
if wagon then
|
if wagon and player_data.auto then
|
||||||
Public.draw_minimap(icw, player, wagon.entity.surface, wagon.entity.position)
|
Public.draw_minimap(icw, player, wagon.entity.surface, wagon.entity.position)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
@ -1069,4 +1090,6 @@ function Public.on_player_or_robot_built_tile(event)
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
Public.get_player_data = get_player_data
|
||||||
|
|
||||||
return Public
|
return Public
|
||||||
|
@ -116,6 +116,23 @@ local function on_init()
|
|||||||
Public.reset()
|
Public.reset()
|
||||||
end
|
end
|
||||||
|
|
||||||
|
local function on_gui_switch_state_changed(event)
|
||||||
|
local element = event.element
|
||||||
|
local player = game.players[event.player_index]
|
||||||
|
if not (player and player.valid) then
|
||||||
|
return
|
||||||
|
end
|
||||||
|
|
||||||
|
if not element.valid then
|
||||||
|
return
|
||||||
|
end
|
||||||
|
|
||||||
|
if element.name == 'icw_auto_switch' then
|
||||||
|
local icw = ICW.get()
|
||||||
|
Functions.toggle_auto(icw, player)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
function Public.register_wagon(wagon_entity)
|
function Public.register_wagon(wagon_entity)
|
||||||
local icw = ICW.get()
|
local icw = ICW.get()
|
||||||
return Functions.create_wagon(icw, wagon_entity)
|
return Functions.create_wagon(icw, wagon_entity)
|
||||||
@ -135,5 +152,6 @@ Event.add(defines.events.on_gui_closed, on_gui_closed)
|
|||||||
Event.add(defines.events.on_gui_opened, on_gui_opened)
|
Event.add(defines.events.on_gui_opened, on_gui_opened)
|
||||||
Event.add(defines.events.on_player_built_tile, on_player_or_robot_built_tile)
|
Event.add(defines.events.on_player_built_tile, on_player_or_robot_built_tile)
|
||||||
Event.add(defines.events.on_robot_built_tile, on_player_or_robot_built_tile)
|
Event.add(defines.events.on_robot_built_tile, on_player_or_robot_built_tile)
|
||||||
|
Event.add(defines.events.on_gui_switch_state_changed, on_gui_switch_state_changed)
|
||||||
|
|
||||||
return Public
|
return Public
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
local Event = require 'utils.event'
|
local Event = require 'utils.event'
|
||||||
--local Power = require 'maps.mountain_fortress_v3.power'
|
--local Power = require 'maps.mountain_fortress_v3.power'
|
||||||
local Market = require 'maps.mountain_fortress_v3.basic_markets'
|
local Market = require 'maps.mountain_fortress_v3.basic_markets'
|
||||||
|
local Generate = require 'maps.mountain_fortress_v3.generate'
|
||||||
local ICW = require 'maps.mountain_fortress_v3.icw.main'
|
local ICW = require 'maps.mountain_fortress_v3.icw.main'
|
||||||
local WPT = require 'maps.mountain_fortress_v3.table'
|
local WPT = require 'maps.mountain_fortress_v3.table'
|
||||||
local WD = require 'modules.wave_defense.table'
|
local WD = require 'modules.wave_defense.table'
|
||||||
@ -200,6 +201,12 @@ function Public.add_player_to_permission_group(player, group, forced)
|
|||||||
return
|
return
|
||||||
end
|
end
|
||||||
|
|
||||||
|
local gulag = game.permissions.get_group('gulag')
|
||||||
|
local tbl = gulag and gulag.players
|
||||||
|
if tbl[player.index] then
|
||||||
|
return
|
||||||
|
end
|
||||||
|
|
||||||
if player.admin then
|
if player.admin then
|
||||||
return
|
return
|
||||||
end
|
end
|
||||||
@ -560,6 +567,10 @@ local function redraw_market_items(gui, player, search_text)
|
|||||||
local inventory = player.get_main_inventory()
|
local inventory = player.get_main_inventory()
|
||||||
local player_item_count
|
local player_item_count
|
||||||
|
|
||||||
|
if not (gui and gui.valid) then
|
||||||
|
return
|
||||||
|
end
|
||||||
|
|
||||||
gui.add(
|
gui.add(
|
||||||
{
|
{
|
||||||
type = 'label',
|
type = 'label',
|
||||||
@ -1380,6 +1391,8 @@ local function create_market(data, rebuild)
|
|||||||
|
|
||||||
this.market = surface.create_entity {name = 'market', position = center_position, force = 'player'}
|
this.market = surface.create_entity {name = 'market', position = center_position, force = 'player'}
|
||||||
|
|
||||||
|
Generate.wintery(this.market, 5.5)
|
||||||
|
|
||||||
rendering.draw_text {
|
rendering.draw_text {
|
||||||
text = 'Market',
|
text = 'Market',
|
||||||
surface = surface,
|
surface = surface,
|
||||||
@ -1473,7 +1486,7 @@ local function on_built_entity(event)
|
|||||||
if linked_to == chest_limit_outside_upgrades then
|
if linked_to == chest_limit_outside_upgrades then
|
||||||
return
|
return
|
||||||
end
|
end
|
||||||
outside_chests[entity.unit_number] = entity
|
outside_chests[entity.unit_number] = {chest = entity, position = entity.position, linked = train.unit_number}
|
||||||
|
|
||||||
if not increased then
|
if not increased then
|
||||||
chests_linked_to[train.unit_number].count = linked_to + 1
|
chests_linked_to[train.unit_number].count = linked_to + 1
|
||||||
@ -1482,7 +1495,7 @@ local function on_built_entity(event)
|
|||||||
goto continue
|
goto continue
|
||||||
end
|
end
|
||||||
else
|
else
|
||||||
outside_chests[entity.unit_number] = entity
|
outside_chests[entity.unit_number] = {chest = entity, position = entity.position, linked = train.unit_number}
|
||||||
chests_linked_to[train.unit_number] = {count = 1}
|
chests_linked_to[train.unit_number] = {count = 1}
|
||||||
end
|
end
|
||||||
|
|
||||||
@ -1505,7 +1518,7 @@ local function on_built_entity(event)
|
|||||||
end
|
end
|
||||||
|
|
||||||
if next(outside_chests) == nil then
|
if next(outside_chests) == nil then
|
||||||
outside_chests[entity.unit_number] = entity
|
outside_chests[entity.unit_number] = {chest = entity, position = entity.position, linked = train.unit_number}
|
||||||
chests_linked_to[train.unit_number] = {count = 1}
|
chests_linked_to[train.unit_number] = {count = 1}
|
||||||
chests_linked_to[train.unit_number][entity.unit_number] = true
|
chests_linked_to[train.unit_number][entity.unit_number] = true
|
||||||
|
|
||||||
@ -1550,22 +1563,47 @@ end
|
|||||||
|
|
||||||
local function divide_contents()
|
local function divide_contents()
|
||||||
local outside_chests = WPT.get('outside_chests')
|
local outside_chests = WPT.get('outside_chests')
|
||||||
|
local chests_linked_to = WPT.get('chests_linked_to')
|
||||||
local target_chest
|
local target_chest
|
||||||
|
|
||||||
for key, chest in pairs(outside_chests) do
|
if not next(outside_chests) then
|
||||||
if not chest or not chest.valid then
|
goto final
|
||||||
return
|
end
|
||||||
|
|
||||||
|
for key, data in pairs(outside_chests) do
|
||||||
|
local chest = data.chest
|
||||||
|
local area = {
|
||||||
|
left_top = {x = data.position.x - 4, y = data.position.y - 4},
|
||||||
|
right_bottom = {x = data.position.x + 4, y = data.position.y + 4}
|
||||||
|
}
|
||||||
|
if not (chest and chest.valid) then
|
||||||
|
if chests_linked_to[data.linked] then
|
||||||
|
if chests_linked_to[data.linked][key] then
|
||||||
|
chests_linked_to[data.linked][key] = nil
|
||||||
|
chests_linked_to[data.linked].count = chests_linked_to[data.linked].count - 1
|
||||||
|
if chests_linked_to[data.linked].count <= 0 then
|
||||||
|
chests_linked_to[data.linked] = nil
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
outside_chests[key] = nil
|
||||||
|
goto continue
|
||||||
end
|
end
|
||||||
|
|
||||||
local area = {
|
|
||||||
left_top = {x = chest.position.x - 4, y = chest.position.y - 4},
|
|
||||||
right_bottom = {x = chest.position.x + 4, y = chest.position.y + 4}
|
|
||||||
}
|
|
||||||
local success, entity = contains_positions(area)
|
local success, entity = contains_positions(area)
|
||||||
if success then
|
if success then
|
||||||
target_chest = entity
|
target_chest = entity
|
||||||
else
|
else
|
||||||
return
|
if chests_linked_to[data.linked] then
|
||||||
|
if chests_linked_to[data.linked][key] then
|
||||||
|
chests_linked_to[data.linked][key] = nil
|
||||||
|
chests_linked_to[data.linked].count = chests_linked_to[data.linked].count - 1
|
||||||
|
if chests_linked_to[data.linked].count <= 0 then
|
||||||
|
chests_linked_to[data.linked] = nil
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
goto continue
|
||||||
end
|
end
|
||||||
|
|
||||||
local chest1 = chest.get_inventory(defines.inventory.chest)
|
local chest1 = chest.get_inventory(defines.inventory.chest)
|
||||||
@ -1578,7 +1616,9 @@ local function divide_contents()
|
|||||||
chest1.remove({name = item, count = c})
|
chest1.remove({name = item, count = c})
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
::continue::
|
||||||
end
|
end
|
||||||
|
::final::
|
||||||
end
|
end
|
||||||
|
|
||||||
local function place_market()
|
local function place_market()
|
||||||
@ -1840,35 +1880,42 @@ function Public.locomotive_spawn(surface, position)
|
|||||||
this.locomotive_cargo = surface.create_entity({name = 'cargo-wagon', position = {position.x, position.y + 3}, force = 'player'})
|
this.locomotive_cargo = surface.create_entity({name = 'cargo-wagon', position = {position.x, position.y + 3}, force = 'player'})
|
||||||
this.locomotive_cargo.get_inventory(defines.inventory.cargo_wagon).insert({name = 'raw-fish', count = 8})
|
this.locomotive_cargo.get_inventory(defines.inventory.cargo_wagon).insert({name = 'raw-fish', count = 8})
|
||||||
|
|
||||||
rendering.draw_light(
|
local winter_mode_locomotive = Generate.wintery(this.locomotive, 5.5)
|
||||||
{
|
if not winter_mode_locomotive then
|
||||||
sprite = 'utility/light_medium',
|
rendering.draw_light(
|
||||||
scale = 5.5,
|
{
|
||||||
intensity = 1,
|
sprite = 'utility/light_medium',
|
||||||
minimum_darkness = 0,
|
scale = 5.5,
|
||||||
oriented = true,
|
intensity = 1,
|
||||||
color = {255, 255, 255},
|
minimum_darkness = 0,
|
||||||
target = this.locomotive,
|
oriented = true,
|
||||||
surface = surface,
|
color = {255, 255, 255},
|
||||||
visible = true,
|
target = this.locomotive,
|
||||||
only_in_alt_mode = false
|
surface = surface,
|
||||||
}
|
visible = true,
|
||||||
)
|
only_in_alt_mode = false
|
||||||
|
}
|
||||||
|
)
|
||||||
|
end
|
||||||
|
|
||||||
rendering.draw_light(
|
local winter_mode_cargo = Generate.wintery(this.locomotive_cargo, 5.5)
|
||||||
{
|
|
||||||
sprite = 'utility/light_medium',
|
if not winter_mode_cargo then
|
||||||
scale = 5.5,
|
rendering.draw_light(
|
||||||
intensity = 1,
|
{
|
||||||
minimum_darkness = 0,
|
sprite = 'utility/light_medium',
|
||||||
oriented = true,
|
scale = 5.5,
|
||||||
color = {255, 255, 255},
|
intensity = 1,
|
||||||
target = this.locomotive_cargo,
|
minimum_darkness = 0,
|
||||||
surface = surface,
|
oriented = true,
|
||||||
visible = true,
|
color = {255, 255, 255},
|
||||||
only_in_alt_mode = false
|
target = this.locomotive_cargo,
|
||||||
}
|
surface = surface,
|
||||||
)
|
visible = true,
|
||||||
|
only_in_alt_mode = false
|
||||||
|
}
|
||||||
|
)
|
||||||
|
end
|
||||||
|
|
||||||
local data = {
|
local data = {
|
||||||
surface = surface,
|
surface = surface,
|
||||||
|
@ -3,7 +3,7 @@ require 'modules.rpg.main'
|
|||||||
local Functions = require 'maps.mountain_fortress_v3.functions'
|
local Functions = require 'maps.mountain_fortress_v3.functions'
|
||||||
local BuriedEnemies = require 'maps.mountain_fortress_v3.buried_enemies'
|
local BuriedEnemies = require 'maps.mountain_fortress_v3.buried_enemies'
|
||||||
|
|
||||||
-- local HS = require 'maps.mountain_fortress_v3.highscore'
|
local HS = require 'maps.mountain_fortress_v3.highscore'
|
||||||
local IC = require 'maps.mountain_fortress_v3.ic.table'
|
local IC = require 'maps.mountain_fortress_v3.ic.table'
|
||||||
local Autostash = require 'modules.autostash'
|
local Autostash = require 'modules.autostash'
|
||||||
local Group = require 'comfy_panel.group'
|
local Group = require 'comfy_panel.group'
|
||||||
@ -31,6 +31,7 @@ local Token = require 'utils.token'
|
|||||||
local Alert = require 'utils.alert'
|
local Alert = require 'utils.alert'
|
||||||
local AntiGrief = require 'antigrief'
|
local AntiGrief = require 'antigrief'
|
||||||
local Commands = require 'commands.misc'
|
local Commands = require 'commands.misc'
|
||||||
|
local Modifiers = require 'player_modifiers'
|
||||||
require 'maps.mountain_fortress_v3.rocks_yield_ore_veins'
|
require 'maps.mountain_fortress_v3.rocks_yield_ore_veins'
|
||||||
|
|
||||||
require 'maps.mountain_fortress_v3.generate'
|
require 'maps.mountain_fortress_v3.generate'
|
||||||
@ -102,8 +103,11 @@ function Public.reset_map()
|
|||||||
|
|
||||||
Autostash.insert_into_furnace(true)
|
Autostash.insert_into_furnace(true)
|
||||||
Autostash.insert_into_wagon(true)
|
Autostash.insert_into_wagon(true)
|
||||||
|
Autostash.bottom_button(true)
|
||||||
BuriedEnemies.reset()
|
BuriedEnemies.reset()
|
||||||
Commands.reset()
|
Commands.reset()
|
||||||
|
Commands.activate_custom_buttons(true)
|
||||||
|
Commands.bottom_right(false)
|
||||||
|
|
||||||
Poll.reset()
|
Poll.reset()
|
||||||
ICW.reset()
|
ICW.reset()
|
||||||
@ -134,6 +138,10 @@ function Public.reset_map()
|
|||||||
|
|
||||||
local surface = game.surfaces[this.active_surface_index]
|
local surface = game.surfaces[this.active_surface_index]
|
||||||
|
|
||||||
|
if this.winter_mode then
|
||||||
|
surface.daytime = 0.45
|
||||||
|
end
|
||||||
|
|
||||||
Explosives.set_surface_whitelist({[surface.name] = true})
|
Explosives.set_surface_whitelist({[surface.name] = true})
|
||||||
|
|
||||||
game.forces.player.set_spawn_position({-27, 25}, surface)
|
game.forces.player.set_spawn_position({-27, 25}, surface)
|
||||||
@ -151,11 +159,17 @@ function Public.reset_map()
|
|||||||
|
|
||||||
PL.show_roles_in_list(true)
|
PL.show_roles_in_list(true)
|
||||||
|
|
||||||
|
Score.reset_tbl()
|
||||||
|
|
||||||
local players = game.connected_players
|
local players = game.connected_players
|
||||||
for i = 1, #players do
|
for i = 1, #players do
|
||||||
local player = players[i]
|
local player = players[i]
|
||||||
Score.init_player_table(player)
|
Score.init_player_table(player, true)
|
||||||
Commands.insert_all_items(player)
|
Commands.insert_all_items(player)
|
||||||
|
Modifiers.reset_player_modifiers(player)
|
||||||
|
if player.gui.left['mvps'] then
|
||||||
|
player.gui.left['mvps'].destroy()
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
Difficulty.reset_difficulty_poll({difficulty_poll_closing_timeout = game.tick + 36000})
|
Difficulty.reset_difficulty_poll({difficulty_poll_closing_timeout = game.tick + 36000})
|
||||||
@ -192,6 +206,7 @@ function Public.reset_map()
|
|||||||
WD.set_disable_threat_below_zero(true)
|
WD.set_disable_threat_below_zero(true)
|
||||||
|
|
||||||
Functions.set_difficulty()
|
Functions.set_difficulty()
|
||||||
|
Functions.disable_creative()
|
||||||
|
|
||||||
if not surface.is_chunk_generated({-20, 22}) then
|
if not surface.is_chunk_generated({-20, 22}) then
|
||||||
surface.request_to_generate_chunks({-20, 22}, 0.1)
|
surface.request_to_generate_chunks({-20, 22}, 0.1)
|
||||||
@ -203,6 +218,8 @@ function Public.reset_map()
|
|||||||
Task.start_queue()
|
Task.start_queue()
|
||||||
Task.set_queue_speed(16)
|
Task.set_queue_speed(16)
|
||||||
|
|
||||||
|
HS.get_scores()
|
||||||
|
|
||||||
this.chunk_load_tick = game.tick + 1200
|
this.chunk_load_tick = game.tick + 1200
|
||||||
this.game_lost = false
|
this.game_lost = false
|
||||||
end
|
end
|
||||||
@ -253,13 +270,16 @@ local has_the_game_ended = function()
|
|||||||
|
|
||||||
game.print(({'main.reset_in', cause_msg, this.game_reset_tick / 60}), {r = 0.22, g = 0.88, b = 0.22})
|
game.print(({'main.reset_in', cause_msg, this.game_reset_tick / 60}), {r = 0.22, g = 0.88, b = 0.22})
|
||||||
end
|
end
|
||||||
|
|
||||||
if this.soft_reset and this.game_reset_tick == 0 then
|
if this.soft_reset and this.game_reset_tick == 0 then
|
||||||
this.game_reset_tick = nil
|
this.game_reset_tick = nil
|
||||||
|
HS.set_scores()
|
||||||
Public.reset_map()
|
Public.reset_map()
|
||||||
return
|
return
|
||||||
end
|
end
|
||||||
if this.restart and this.game_reset_tick == 0 then
|
if this.restart and this.game_reset_tick == 0 then
|
||||||
if not this.announced_message then
|
if not this.announced_message then
|
||||||
|
HS.set_scores()
|
||||||
game.print(({'entity.notify_restart'}), {r = 0.22, g = 0.88, b = 0.22})
|
game.print(({'entity.notify_restart'}), {r = 0.22, g = 0.88, b = 0.22})
|
||||||
local message = 'Soft-reset is disabled! Server will restart from scenario to load new changes.'
|
local message = 'Soft-reset is disabled! Server will restart from scenario to load new changes.'
|
||||||
Server.to_discord_bold(table.concat {'*** ', message, ' ***'})
|
Server.to_discord_bold(table.concat {'*** ', message, ' ***'})
|
||||||
@ -270,6 +290,7 @@ local has_the_game_ended = function()
|
|||||||
end
|
end
|
||||||
if this.shutdown and this.game_reset_tick == 0 then
|
if this.shutdown and this.game_reset_tick == 0 then
|
||||||
if not this.announced_message then
|
if not this.announced_message then
|
||||||
|
HS.set_scores()
|
||||||
game.print(({'entity.notify_shutdown'}), {r = 0.22, g = 0.88, b = 0.22})
|
game.print(({'entity.notify_shutdown'}), {r = 0.22, g = 0.88, b = 0.22})
|
||||||
local message = 'Soft-reset is disabled! Server will shutdown. Most likely because of updates.'
|
local message = 'Soft-reset is disabled! Server will shutdown. Most likely because of updates.'
|
||||||
Server.to_discord_bold(table.concat {'*** ', message, ' ***'})
|
Server.to_discord_bold(table.concat {'*** ', message, ' ***'})
|
||||||
@ -327,7 +348,7 @@ local compare_collapse_and_train = function()
|
|||||||
local collapse_pos = Collapse.get_position()
|
local collapse_pos = Collapse.get_position()
|
||||||
local locomotive = WPT.get('locomotive')
|
local locomotive = WPT.get('locomotive')
|
||||||
local carriages = WPT.get('carriages')
|
local carriages = WPT.get('carriages')
|
||||||
if not locomotive or not locomotive.valid then
|
if not (locomotive and locomotive.valid) then
|
||||||
return
|
return
|
||||||
end
|
end
|
||||||
|
|
||||||
@ -342,12 +363,10 @@ local compare_collapse_and_train = function()
|
|||||||
|
|
||||||
if c_y - t_y <= gap_between_zones.gap then
|
if c_y - t_y <= gap_between_zones.gap then
|
||||||
Functions.set_difficulty()
|
Functions.set_difficulty()
|
||||||
gap_between_zones.set = false
|
else
|
||||||
return
|
Collapse.set_speed(1)
|
||||||
|
Collapse.set_amount(4)
|
||||||
end
|
end
|
||||||
|
|
||||||
Collapse.set_speed(1)
|
|
||||||
Collapse.set_amount(4)
|
|
||||||
end
|
end
|
||||||
|
|
||||||
local collapse_after_wave_100 = function()
|
local collapse_after_wave_100 = function()
|
||||||
|
@ -193,6 +193,13 @@ function Public.reset_table()
|
|||||||
-- this.void_or_tile = 'lab-dark-2'
|
-- this.void_or_tile = 'lab-dark-2'
|
||||||
this.void_or_tile = 'out-of-map'
|
this.void_or_tile = 'out-of-map'
|
||||||
this.validate_spider = {}
|
this.validate_spider = {}
|
||||||
|
this.check_afk_players = true
|
||||||
|
this.winter_mode = false
|
||||||
|
this.sent_to_discord = false
|
||||||
|
this.difficulty = {
|
||||||
|
multiply = 0.25,
|
||||||
|
highest = 10
|
||||||
|
}
|
||||||
|
|
||||||
--!reset player tables
|
--!reset player tables
|
||||||
for _, player in pairs(this.players) do
|
for _, player in pairs(this.players) do
|
||||||
|
@ -2427,6 +2427,11 @@ Event.add(
|
|||||||
return
|
return
|
||||||
end
|
end
|
||||||
|
|
||||||
|
local winter_mode = WPT.get('winter_mode')
|
||||||
|
if winter_mode then
|
||||||
|
rendering.draw_sprite({sprite = "tile/lab-white", x_scale = 32, y_scale = 32, target = left_top, surface = surface, tint = {r = 0.6, g = 0.6, b = 0.6, a = 0.6}, render_layer = "ground"})
|
||||||
|
end
|
||||||
|
|
||||||
if left_top.y == -128 and left_top.x == -128 then
|
if left_top.y == -128 and left_top.x == -128 then
|
||||||
local pl = WPT.get().locomotive.position
|
local pl = WPT.get().locomotive.position
|
||||||
for _, entity in pairs(surface.find_entities_filtered({area = {{pl.x - 5, pl.y - 6}, {pl.x + 5, pl.y + 10}}, type = 'simple-entity'})) do
|
for _, entity in pairs(surface.find_entities_filtered({area = {{pl.x - 5, pl.y - 6}, {pl.x + 5, pl.y + 10}}, type = 'simple-entity'})) do
|
||||||
|
@ -3,6 +3,7 @@
|
|||||||
|
|
||||||
local Global = require 'utils.global'
|
local Global = require 'utils.global'
|
||||||
local Event = require 'utils.event'
|
local Event = require 'utils.event'
|
||||||
|
local Misc = require 'commands.misc'
|
||||||
local math_floor = math.floor
|
local math_floor = math.floor
|
||||||
local print_color = {r = 120, g = 255, b = 0}
|
local print_color = {r = 120, g = 255, b = 0}
|
||||||
|
|
||||||
@ -11,6 +12,7 @@ local this = {
|
|||||||
whitelist = {},
|
whitelist = {},
|
||||||
insert_into_furnace = false,
|
insert_into_furnace = false,
|
||||||
insert_into_wagon = false,
|
insert_into_wagon = false,
|
||||||
|
bottom_button = false,
|
||||||
small_radius = 2
|
small_radius = 2
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -439,23 +441,38 @@ local function create_gui_button(player)
|
|||||||
else
|
else
|
||||||
tooltip = 'Sort your inventory into nearby chests.\nLMB: Everything, excluding quickbar items.\nRMB: Only ores to nearby chests.'
|
tooltip = 'Sort your inventory into nearby chests.\nLMB: Everything, excluding quickbar items.\nRMB: Only ores to nearby chests.'
|
||||||
end
|
end
|
||||||
local b =
|
if this.bottom_button then
|
||||||
player.gui.top.add(
|
local data = Misc.get('bottom_quickbar_button')
|
||||||
{
|
-- save it for later use
|
||||||
type = 'sprite-button',
|
data.tooltip = tooltip
|
||||||
sprite = 'item/wooden-chest',
|
data.sprite = 'item/wooden-chest'
|
||||||
name = 'auto_stash',
|
|
||||||
tooltip = tooltip
|
if data[player.index] then
|
||||||
}
|
data = data[player.index]
|
||||||
)
|
if data.frame and data.frame.valid then
|
||||||
b.style.font_color = {r = 0.11, g = 0.8, b = 0.44}
|
data.frame.sprite = 'item/wooden-chest'
|
||||||
b.style.font = 'heading-1'
|
data.frame.tooltip = tooltip
|
||||||
b.style.minimal_height = 40
|
end
|
||||||
b.style.maximal_width = 40
|
end
|
||||||
b.style.minimal_width = 38
|
else
|
||||||
b.style.maximal_height = 38
|
local b =
|
||||||
b.style.padding = 1
|
player.gui.top.add(
|
||||||
b.style.margin = 0
|
{
|
||||||
|
type = 'sprite-button',
|
||||||
|
sprite = 'item/wooden-chest',
|
||||||
|
name = 'auto_stash',
|
||||||
|
tooltip = tooltip
|
||||||
|
}
|
||||||
|
)
|
||||||
|
b.style.font_color = {r = 0.11, g = 0.8, b = 0.44}
|
||||||
|
b.style.font = 'heading-1'
|
||||||
|
b.style.minimal_height = 40
|
||||||
|
b.style.maximal_width = 40
|
||||||
|
b.style.minimal_width = 38
|
||||||
|
b.style.maximal_height = 38
|
||||||
|
b.style.padding = 1
|
||||||
|
b.style.margin = 0
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
local function do_whitelist()
|
local function do_whitelist()
|
||||||
@ -485,8 +502,18 @@ local function on_gui_click(event)
|
|||||||
if not event.element.valid then
|
if not event.element.valid then
|
||||||
return
|
return
|
||||||
end
|
end
|
||||||
if event.element.name == 'auto_stash' then
|
local player = game.players[event.player_index]
|
||||||
auto_stash(game.players[event.player_index], event)
|
local name = 'auto_stash'
|
||||||
|
if this.bottom_button then
|
||||||
|
local data = Misc.get('bottom_quickbar_button')
|
||||||
|
if data[player.index] then
|
||||||
|
data = data[player.index]
|
||||||
|
name = data.name
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
if event.element.name == name then
|
||||||
|
auto_stash(player, event)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
@ -506,6 +533,14 @@ function Public.insert_into_wagon(value)
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
function Public.bottom_button(value)
|
||||||
|
if value then
|
||||||
|
this.bottom_button = value
|
||||||
|
else
|
||||||
|
this.bottom_button = false
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
Event.on_configuration_changed = function()
|
Event.on_configuration_changed = function()
|
||||||
do_whitelist()
|
do_whitelist()
|
||||||
log('[Autostash] on_configuration_changed was called, rebuilding resource whitelist.')
|
log('[Autostash] on_configuration_changed was called, rebuilding resource whitelist.')
|
||||||
|
@ -12,7 +12,7 @@ local entity_types = {
|
|||||||
["unit-spawner"] = true,
|
["unit-spawner"] = true,
|
||||||
}
|
}
|
||||||
|
|
||||||
if package.loaded['maps.biter_hatchery.terrain'] then entity_types["unit-spawner"] = nil end
|
if is_loaded('maps.biter_hatchery.terrain') then entity_types["unit-spawner"] = nil end
|
||||||
|
|
||||||
local function clean_table()
|
local function clean_table()
|
||||||
--Perform a table cleanup every 1000 boosts
|
--Perform a table cleanup every 1000 boosts
|
||||||
@ -84,7 +84,7 @@ local function on_entity_damaged(event)
|
|||||||
local biter = event.entity
|
local biter = event.entity
|
||||||
if not (biter and biter.valid) then return end
|
if not (biter and biter.valid) then return end
|
||||||
if not entity_types[biter.type] then return end
|
if not entity_types[biter.type] then return end
|
||||||
|
|
||||||
local biter_health_boost_units = global.biter_health_boost_units
|
local biter_health_boost_units = global.biter_health_boost_units
|
||||||
|
|
||||||
local unit_number = biter.unit_number
|
local unit_number = biter.unit_number
|
||||||
@ -111,7 +111,7 @@ local function on_entity_damaged(event)
|
|||||||
|
|
||||||
--Reduce health pool
|
--Reduce health pool
|
||||||
health_pool[1] = health_pool[1] - event.final_damage_amount
|
health_pool[1] = health_pool[1] - event.final_damage_amount
|
||||||
|
|
||||||
--Set entity health relative to health pool
|
--Set entity health relative to health pool
|
||||||
biter.health = health_pool[1] * health_pool[2]
|
biter.health = health_pool[1] * health_pool[2]
|
||||||
|
|
||||||
|
@ -1,19 +1,19 @@
|
|||||||
local event = require 'utils.event'
|
local event = require 'utils.event'
|
||||||
|
|
||||||
local function on_console_chat(event)
|
local function on_console_chat(event)
|
||||||
if not event.message then return end
|
if not event.message then return end
|
||||||
if not event.player_index then return end
|
if not event.player_index then return end
|
||||||
local player = game.players[event.player_index]
|
local player = game.players[event.player_index]
|
||||||
if not player.character then return end
|
if not player.character then return end
|
||||||
|
|
||||||
local y_offset = -4
|
local y_offset = -4
|
||||||
if package.loaded['modules.rpg'] then y_offset = -4.5 end
|
if is_loaded('modules.rpg') then y_offset = -4.5 end
|
||||||
|
|
||||||
if global.player_floaty_chat[player.index] then
|
if global.player_floaty_chat[player.index] then
|
||||||
rendering.destroy(global.player_floaty_chat[player.index])
|
rendering.destroy(global.player_floaty_chat[player.index])
|
||||||
global.player_floaty_chat[player.index] = nil
|
global.player_floaty_chat[player.index] = nil
|
||||||
end
|
end
|
||||||
|
|
||||||
local players = {}
|
local players = {}
|
||||||
for _, p in pairs(game.connected_players) do
|
for _, p in pairs(game.connected_players) do
|
||||||
if player.force.index == p.force.index then
|
if player.force.index == p.force.index then
|
||||||
@ -21,7 +21,7 @@ local function on_console_chat(event)
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
if #players == 0 then return end
|
if #players == 0 then return end
|
||||||
|
|
||||||
global.player_floaty_chat[player.index] = rendering.draw_text{
|
global.player_floaty_chat[player.index] = rendering.draw_text{
|
||||||
text = event.message,
|
text = event.message,
|
||||||
surface = player.surface,
|
surface = player.surface,
|
||||||
@ -47,4 +47,4 @@ local function on_init(event)
|
|||||||
end
|
end
|
||||||
|
|
||||||
event.on_init(on_init)
|
event.on_init(on_init)
|
||||||
event.add(defines.events.on_console_chat, on_console_chat)
|
event.add(defines.events.on_console_chat, on_console_chat)
|
||||||
|
@ -100,8 +100,8 @@ end
|
|||||||
|
|
||||||
local function level_up(player)
|
local function level_up(player)
|
||||||
local rpg_t = RPG.get('rpg_t')
|
local rpg_t = RPG.get('rpg_t')
|
||||||
local RPG_GUI = package.loaded['modules.rpg.gui']
|
local RPG_GUI = is_loaded('modules.rpg.gui')
|
||||||
local names = RPG.auto_allocate_nodes
|
local names = RPG.auto_allocate_nodes_func
|
||||||
|
|
||||||
local distribute_points_gain = 0
|
local distribute_points_gain = 0
|
||||||
for i = rpg_t[player.index].level + 1, #experience_levels, 1 do
|
for i = rpg_t[player.index].level + 1, #experience_levels, 1 do
|
||||||
@ -173,8 +173,7 @@ function Public.suicidal_comfylatron(pos, surface)
|
|||||||
text = text
|
text = text
|
||||||
}
|
}
|
||||||
)
|
)
|
||||||
local nearest_player_unit =
|
local nearest_player_unit = surface.find_nearest_enemy({position = e.position, max_distance = 512, force = 'player'})
|
||||||
surface.find_nearest_enemy({position = e.position, max_distance = 512, force = 'player'})
|
|
||||||
|
|
||||||
if nearest_player_unit and nearest_player_unit.active and nearest_player_unit.force.name ~= 'player' then
|
if nearest_player_unit and nearest_player_unit.active and nearest_player_unit.force.name ~= 'player' then
|
||||||
e.set_command(
|
e.set_command(
|
||||||
@ -337,11 +336,7 @@ function Public.update_health(player)
|
|||||||
|
|
||||||
if rpg_extra.enable_health_and_mana_bars then
|
if rpg_extra.enable_health_and_mana_bars then
|
||||||
if rpg_t[player.index].show_bars then
|
if rpg_t[player.index].show_bars then
|
||||||
local max_life =
|
local max_life = math.floor(player.character.prototype.max_health + player.character_health_bonus + player.force.character_health_bonus)
|
||||||
math.floor(
|
|
||||||
player.character.prototype.max_health + player.character_health_bonus +
|
|
||||||
player.force.character_health_bonus
|
|
||||||
)
|
|
||||||
if not rpg_t[player.index].health_bar then
|
if not rpg_t[player.index].health_bar then
|
||||||
rpg_t[player.index].health_bar = create_healthbar(player, 0.5)
|
rpg_t[player.index].health_bar = create_healthbar(player, 0.5)
|
||||||
elseif not rendering.is_valid(rpg_t[player.index].health_bar) then
|
elseif not rendering.is_valid(rpg_t[player.index].health_bar) then
|
||||||
@ -395,36 +390,28 @@ end
|
|||||||
|
|
||||||
function Public.level_up_effects(player)
|
function Public.level_up_effects(player)
|
||||||
local position = {x = player.position.x - 0.75, y = player.position.y - 1}
|
local position = {x = player.position.x - 0.75, y = player.position.y - 1}
|
||||||
player.surface.create_entity(
|
player.surface.create_entity({name = 'flying-text', position = position, text = '+LVL ', color = level_up_floating_text_color})
|
||||||
{name = 'flying-text', position = position, text = '+LVL ', color = level_up_floating_text_color}
|
|
||||||
)
|
|
||||||
local b = 0.75
|
local b = 0.75
|
||||||
for _ = 1, 5, 1 do
|
for _ = 1, 5, 1 do
|
||||||
local p = {
|
local p = {
|
||||||
(position.x + 0.4) + (b * -1 + math.random(0, b * 20) * 0.1),
|
(position.x + 0.4) + (b * -1 + math.random(0, b * 20) * 0.1),
|
||||||
position.y + (b * -1 + math.random(0, b * 20) * 0.1)
|
position.y + (b * -1 + math.random(0, b * 20) * 0.1)
|
||||||
}
|
}
|
||||||
player.surface.create_entity(
|
player.surface.create_entity({name = 'flying-text', position = p, text = '✚', color = {255, math.random(0, 100), 0}})
|
||||||
{name = 'flying-text', position = p, text = '✚', color = {255, math.random(0, 100), 0}}
|
|
||||||
)
|
|
||||||
end
|
end
|
||||||
player.play_sound {path = 'utility/achievement_unlocked', volume_modifier = 0.40}
|
player.play_sound {path = 'utility/achievement_unlocked', volume_modifier = 0.40}
|
||||||
end
|
end
|
||||||
|
|
||||||
function Public.xp_effects(player)
|
function Public.xp_effects(player)
|
||||||
local position = {x = player.position.x - 0.75, y = player.position.y - 1}
|
local position = {x = player.position.x - 0.75, y = player.position.y - 1}
|
||||||
player.surface.create_entity(
|
player.surface.create_entity({name = 'flying-text', position = position, text = '+XP', color = level_up_floating_text_color})
|
||||||
{name = 'flying-text', position = position, text = '+XP', color = level_up_floating_text_color}
|
|
||||||
)
|
|
||||||
local b = 0.75
|
local b = 0.75
|
||||||
for _ = 1, 5, 1 do
|
for _ = 1, 5, 1 do
|
||||||
local p = {
|
local p = {
|
||||||
(position.x + 0.4) + (b * -1 + math.random(0, b * 20) * 0.1),
|
(position.x + 0.4) + (b * -1 + math.random(0, b * 20) * 0.1),
|
||||||
position.y + (b * -1 + math.random(0, b * 20) * 0.1)
|
position.y + (b * -1 + math.random(0, b * 20) * 0.1)
|
||||||
}
|
}
|
||||||
player.surface.create_entity(
|
player.surface.create_entity({name = 'flying-text', position = p, text = '✚', color = {255, math.random(0, 100), 0}})
|
||||||
{name = 'flying-text', position = p, text = '✚', color = {255, math.random(0, 100), 0}}
|
|
||||||
)
|
|
||||||
end
|
end
|
||||||
player.play_sound {path = 'utility/achievement_unlocked', volume_modifier = 0.40}
|
player.play_sound {path = 'utility/achievement_unlocked', volume_modifier = 0.40}
|
||||||
end
|
end
|
||||||
@ -489,7 +476,7 @@ function Public.rpg_reset_player(player, one_time_reset)
|
|||||||
player.set_controller({type = defines.controllers.god})
|
player.set_controller({type = defines.controllers.god})
|
||||||
player.create_character()
|
player.create_character()
|
||||||
end
|
end
|
||||||
local RPG_GUI = package.loaded['modules.rpg.gui']
|
local RPG_GUI = is_loaded('modules.rpg.gui')
|
||||||
local rpg_t = RPG.get('rpg_t')
|
local rpg_t = RPG.get('rpg_t')
|
||||||
local rpg_extra = RPG.get('rpg_extra')
|
local rpg_extra = RPG.get('rpg_extra')
|
||||||
if one_time_reset then
|
if one_time_reset then
|
||||||
|
@ -962,7 +962,6 @@ local function on_player_used_capsule(event)
|
|||||||
return
|
return
|
||||||
end
|
end
|
||||||
|
|
||||||
local object_name = object.name
|
|
||||||
local obj_name = object.obj_to_create
|
local obj_name = object.obj_to_create
|
||||||
|
|
||||||
local position = event.position
|
local position = event.position
|
||||||
@ -1009,7 +1008,7 @@ local function on_player_used_capsule(event)
|
|||||||
end
|
end
|
||||||
if object.obj_to_create == 'suicidal_comfylatron' then
|
if object.obj_to_create == 'suicidal_comfylatron' then
|
||||||
Functions.suicidal_comfylatron(position, surface)
|
Functions.suicidal_comfylatron(position, surface)
|
||||||
p(({'rpg_main.suicidal_comfylatron', object_name}), Color.success)
|
p(({'rpg_main.suicidal_comfylatron', 'Suicidal Comfylatron'}), Color.success)
|
||||||
rpg_t[player.index].mana = rpg_t[player.index].mana - object.mana_cost
|
rpg_t[player.index].mana = rpg_t[player.index].mana - object.mana_cost
|
||||||
elseif object.obj_to_create == 'warp-gate' then
|
elseif object.obj_to_create == 'warp-gate' then
|
||||||
player.teleport(surface.find_non_colliding_position('character', game.forces.player.get_spawn_position(surface), 3, 0, 5), surface)
|
player.teleport(surface.find_non_colliding_position('character', game.forces.player.get_spawn_position(surface), 3, 0, 5), surface)
|
||||||
@ -1057,7 +1056,7 @@ local function on_player_used_capsule(event)
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
local msg = player.name .. ' casted ' .. object.name .. '. '
|
local msg = player.name .. ' casted ' .. object.obj_to_create .. '. '
|
||||||
|
|
||||||
rpg_t[player.index].last_spawned = game.tick + object.tick
|
rpg_t[player.index].last_spawned = game.tick + object.tick
|
||||||
Functions.update_mana(player)
|
Functions.update_mana(player)
|
||||||
|
@ -123,7 +123,7 @@ function Public.extra_settings(player)
|
|||||||
reset_gui_input.tooltip = ({'rpg_settings.not_trusted'})
|
reset_gui_input.tooltip = ({'rpg_settings.not_trusted'})
|
||||||
goto continue
|
goto continue
|
||||||
end
|
end
|
||||||
if rpg_t[player.index].level <= 50 then
|
if rpg_t[player.index].level < 50 then
|
||||||
reset_gui_input.enabled = false
|
reset_gui_input.enabled = false
|
||||||
reset_gui_input.tooltip = ({'rpg_settings.low_level', 50})
|
reset_gui_input.tooltip = ({'rpg_settings.low_level', 50})
|
||||||
reset_label.tooltip = ({'rpg_settings.low_level', 50})
|
reset_label.tooltip = ({'rpg_settings.low_level', 50})
|
||||||
@ -157,10 +157,7 @@ function Public.extra_settings(player)
|
|||||||
magic_pickup_input_style.height = 35
|
magic_pickup_input_style.height = 35
|
||||||
magic_pickup_input_style.vertical_align = 'center'
|
magic_pickup_input_style.vertical_align = 'center'
|
||||||
local reach_mod
|
local reach_mod
|
||||||
if
|
if player_modifiers.disabled_modifier[player.index] and player_modifiers.disabled_modifier[player.index].character_item_pickup_distance_bonus then
|
||||||
player_modifiers.disabled_modifier[player.index] and
|
|
||||||
player_modifiers.disabled_modifier[player.index].character_item_pickup_distance_bonus
|
|
||||||
then
|
|
||||||
reach_mod = not player_modifiers.disabled_modifier[player.index].character_item_pickup_distance_bonus
|
reach_mod = not player_modifiers.disabled_modifier[player.index].character_item_pickup_distance_bonus
|
||||||
else
|
else
|
||||||
reach_mod = true
|
reach_mod = true
|
||||||
@ -187,10 +184,7 @@ function Public.extra_settings(player)
|
|||||||
movement_speed_input_style.height = 35
|
movement_speed_input_style.height = 35
|
||||||
movement_speed_input_style.vertical_align = 'center'
|
movement_speed_input_style.vertical_align = 'center'
|
||||||
local speed_mod
|
local speed_mod
|
||||||
if
|
if player_modifiers.disabled_modifier[player.index] and player_modifiers.disabled_modifier[player.index].character_running_speed_modifier then
|
||||||
player_modifiers.disabled_modifier[player.index] and
|
|
||||||
player_modifiers.disabled_modifier[player.index].character_running_speed_modifier
|
|
||||||
then
|
|
||||||
speed_mod = not player_modifiers.disabled_modifier[player.index].character_running_speed_modifier
|
speed_mod = not player_modifiers.disabled_modifier[player.index].character_running_speed_modifier
|
||||||
else
|
else
|
||||||
speed_mod = true
|
speed_mod = true
|
||||||
@ -232,7 +226,7 @@ function Public.extra_settings(player)
|
|||||||
end
|
end
|
||||||
stone_path_gui_input = create_input_element(stone_path_input, 'boolean', stone_path)
|
stone_path_gui_input = create_input_element(stone_path_input, 'boolean', stone_path)
|
||||||
|
|
||||||
if rpg_t[player.index].level <= 20 then
|
if rpg_t[player.index].level < 20 then
|
||||||
stone_path_gui_input.enabled = false
|
stone_path_gui_input.enabled = false
|
||||||
stone_path_gui_input.tooltip = ({'rpg_settings.low_level', 20})
|
stone_path_gui_input.tooltip = ({'rpg_settings.low_level', 20})
|
||||||
stone_path_label.tooltip = ({'rpg_settings.low_level', 20})
|
stone_path_label.tooltip = ({'rpg_settings.low_level', 20})
|
||||||
@ -274,7 +268,7 @@ function Public.extra_settings(player)
|
|||||||
one_punch_gui_input.enabled = false
|
one_punch_gui_input.enabled = false
|
||||||
one_punch_gui_input.tooltip = ({'rpg_settings.one_punch_globally'})
|
one_punch_gui_input.tooltip = ({'rpg_settings.one_punch_globally'})
|
||||||
else
|
else
|
||||||
if rpg_t[player.index].level <= 30 then
|
if rpg_t[player.index].level < 30 then
|
||||||
one_punch_gui_input.enabled = false
|
one_punch_gui_input.enabled = false
|
||||||
one_punch_gui_input.tooltip = ({'rpg_settings.low_level', 30})
|
one_punch_gui_input.tooltip = ({'rpg_settings.low_level', 30})
|
||||||
else
|
else
|
||||||
@ -312,7 +306,7 @@ function Public.extra_settings(player)
|
|||||||
flame_boots_gui_input = create_input_element(flame_boots_input, 'boolean', flame_mod)
|
flame_boots_gui_input = create_input_element(flame_boots_input, 'boolean', flame_mod)
|
||||||
|
|
||||||
if rpg_t[player.index].mana > 50 then
|
if rpg_t[player.index].mana > 50 then
|
||||||
if rpg_t[player.index].level <= 100 then
|
if rpg_t[player.index].level < 100 then
|
||||||
flame_boots_gui_input.enabled = false
|
flame_boots_gui_input.enabled = false
|
||||||
flame_boots_gui_input.tooltip = ({'rpg_settings.low_level', 100})
|
flame_boots_gui_input.tooltip = ({'rpg_settings.low_level', 100})
|
||||||
flame_boots_label.tooltip = ({'rpg_settings.low_level', 100})
|
flame_boots_label.tooltip = ({'rpg_settings.low_level', 100})
|
||||||
|
@ -4,7 +4,7 @@ function Public.conjure_items()
|
|||||||
local spells = {}
|
local spells = {}
|
||||||
|
|
||||||
spells[#spells + 1] = {
|
spells[#spells + 1] = {
|
||||||
name = 'Stone Wall',
|
name = {'entity-name.stone-wall'},
|
||||||
obj_to_create = 'stone-wall',
|
obj_to_create = 'stone-wall',
|
||||||
level = 10,
|
level = 10,
|
||||||
type = 'item',
|
type = 'item',
|
||||||
@ -14,7 +14,7 @@ function Public.conjure_items()
|
|||||||
}
|
}
|
||||||
|
|
||||||
spells[#spells + 1] = {
|
spells[#spells + 1] = {
|
||||||
name = 'Wooden Chest',
|
name = {'entity-name.wooden-chest'},
|
||||||
obj_to_create = 'wooden-chest',
|
obj_to_create = 'wooden-chest',
|
||||||
level = 2,
|
level = 2,
|
||||||
type = 'item',
|
type = 'item',
|
||||||
@ -23,7 +23,7 @@ function Public.conjure_items()
|
|||||||
enabled = true
|
enabled = true
|
||||||
}
|
}
|
||||||
spells[#spells + 1] = {
|
spells[#spells + 1] = {
|
||||||
name = 'Iron Chest',
|
name = {'entity-name.iron-chest'},
|
||||||
obj_to_create = 'iron-chest',
|
obj_to_create = 'iron-chest',
|
||||||
level = 10,
|
level = 10,
|
||||||
type = 'item',
|
type = 'item',
|
||||||
@ -32,7 +32,7 @@ function Public.conjure_items()
|
|||||||
enabled = true
|
enabled = true
|
||||||
}
|
}
|
||||||
spells[#spells + 1] = {
|
spells[#spells + 1] = {
|
||||||
name = 'Steel Chest',
|
name = {'entity-name.steel-chest'},
|
||||||
obj_to_create = 'steel-chest',
|
obj_to_create = 'steel-chest',
|
||||||
level = 15,
|
level = 15,
|
||||||
type = 'item',
|
type = 'item',
|
||||||
@ -41,7 +41,7 @@ function Public.conjure_items()
|
|||||||
enabled = true
|
enabled = true
|
||||||
}
|
}
|
||||||
spells[#spells + 1] = {
|
spells[#spells + 1] = {
|
||||||
name = 'Transport Belt',
|
name = {'entity-name.transport-belt'},
|
||||||
obj_to_create = 'transport-belt',
|
obj_to_create = 'transport-belt',
|
||||||
level = 3,
|
level = 3,
|
||||||
type = 'item',
|
type = 'item',
|
||||||
@ -50,7 +50,7 @@ function Public.conjure_items()
|
|||||||
enabled = true
|
enabled = true
|
||||||
}
|
}
|
||||||
spells[#spells + 1] = {
|
spells[#spells + 1] = {
|
||||||
name = 'Fast Transport Belt',
|
name = {'entity-name.fast-transport-belt'},
|
||||||
obj_to_create = 'fast-transport-belt',
|
obj_to_create = 'fast-transport-belt',
|
||||||
level = 20,
|
level = 20,
|
||||||
type = 'item',
|
type = 'item',
|
||||||
@ -59,7 +59,7 @@ function Public.conjure_items()
|
|||||||
enabled = true
|
enabled = true
|
||||||
}
|
}
|
||||||
spells[#spells + 1] = {
|
spells[#spells + 1] = {
|
||||||
name = 'Express Transport Belt',
|
name = {'entity-name.express-transport-belt'},
|
||||||
obj_to_create = 'express-transport-belt',
|
obj_to_create = 'express-transport-belt',
|
||||||
level = 60,
|
level = 60,
|
||||||
type = 'item',
|
type = 'item',
|
||||||
@ -68,7 +68,7 @@ function Public.conjure_items()
|
|||||||
enabled = true
|
enabled = true
|
||||||
}
|
}
|
||||||
spells[#spells + 1] = {
|
spells[#spells + 1] = {
|
||||||
name = 'Underground Belt',
|
name = {'entity-name.underground-belt'},
|
||||||
obj_to_create = 'underground-belt',
|
obj_to_create = 'underground-belt',
|
||||||
level = 3,
|
level = 3,
|
||||||
type = 'item',
|
type = 'item',
|
||||||
@ -77,7 +77,7 @@ function Public.conjure_items()
|
|||||||
enabled = true
|
enabled = true
|
||||||
}
|
}
|
||||||
spells[#spells + 1] = {
|
spells[#spells + 1] = {
|
||||||
name = 'Fast Underground Belt',
|
name = {'entity-name.fast-underground-belt'},
|
||||||
obj_to_create = 'fast-underground-belt',
|
obj_to_create = 'fast-underground-belt',
|
||||||
level = 20,
|
level = 20,
|
||||||
type = 'item',
|
type = 'item',
|
||||||
@ -86,7 +86,7 @@ function Public.conjure_items()
|
|||||||
enabled = true
|
enabled = true
|
||||||
}
|
}
|
||||||
spells[#spells + 1] = {
|
spells[#spells + 1] = {
|
||||||
name = 'Express Underground Belt',
|
name = {'entity-name.express-underground-belt'},
|
||||||
obj_to_create = 'express-underground-belt',
|
obj_to_create = 'express-underground-belt',
|
||||||
level = 60,
|
level = 60,
|
||||||
type = 'item',
|
type = 'item',
|
||||||
@ -95,7 +95,7 @@ function Public.conjure_items()
|
|||||||
enabled = true
|
enabled = true
|
||||||
}
|
}
|
||||||
spells[#spells + 1] = {
|
spells[#spells + 1] = {
|
||||||
name = 'Sandy Rock',
|
name = {'entity-name.sand-rock-big'},
|
||||||
obj_to_create = 'sand-rock-big',
|
obj_to_create = 'sand-rock-big',
|
||||||
level = 80,
|
level = 80,
|
||||||
type = 'entity',
|
type = 'entity',
|
||||||
@ -104,7 +104,7 @@ function Public.conjure_items()
|
|||||||
enabled = true
|
enabled = true
|
||||||
}
|
}
|
||||||
spells[#spells + 1] = {
|
spells[#spells + 1] = {
|
||||||
name = 'Smol Biter',
|
name = {'entity-name.small-biter'},
|
||||||
obj_to_create = 'small-biter',
|
obj_to_create = 'small-biter',
|
||||||
level = 50,
|
level = 50,
|
||||||
biter = true,
|
biter = true,
|
||||||
@ -114,7 +114,7 @@ function Public.conjure_items()
|
|||||||
enabled = true
|
enabled = true
|
||||||
}
|
}
|
||||||
spells[#spells + 1] = {
|
spells[#spells + 1] = {
|
||||||
name = 'Smol Spitter',
|
name = {'entity-name.small-spitter'},
|
||||||
obj_to_create = 'small-spitter',
|
obj_to_create = 'small-spitter',
|
||||||
level = 50,
|
level = 50,
|
||||||
biter = true,
|
biter = true,
|
||||||
@ -124,7 +124,7 @@ function Public.conjure_items()
|
|||||||
enabled = true
|
enabled = true
|
||||||
}
|
}
|
||||||
spells[#spells + 1] = {
|
spells[#spells + 1] = {
|
||||||
name = 'Medium Biter',
|
name = {'entity-name.medium-biter'},
|
||||||
obj_to_create = 'medium-biter',
|
obj_to_create = 'medium-biter',
|
||||||
level = 70,
|
level = 70,
|
||||||
biter = true,
|
biter = true,
|
||||||
@ -134,7 +134,7 @@ function Public.conjure_items()
|
|||||||
enabled = true
|
enabled = true
|
||||||
}
|
}
|
||||||
spells[#spells + 1] = {
|
spells[#spells + 1] = {
|
||||||
name = 'Medium Spitter',
|
name = {'entity-name.medium-spitter'},
|
||||||
obj_to_create = 'medium-spitter',
|
obj_to_create = 'medium-spitter',
|
||||||
level = 70,
|
level = 70,
|
||||||
type = 'entity',
|
type = 'entity',
|
||||||
@ -143,7 +143,7 @@ function Public.conjure_items()
|
|||||||
enabled = true
|
enabled = true
|
||||||
}
|
}
|
||||||
spells[#spells + 1] = {
|
spells[#spells + 1] = {
|
||||||
name = 'Bitter Spawner',
|
name = {'entity-name.biter-spawner'},
|
||||||
obj_to_create = 'biter-spawner',
|
obj_to_create = 'biter-spawner',
|
||||||
level = 100,
|
level = 100,
|
||||||
biter = true,
|
biter = true,
|
||||||
@ -153,7 +153,7 @@ function Public.conjure_items()
|
|||||||
enabled = true
|
enabled = true
|
||||||
}
|
}
|
||||||
spells[#spells + 1] = {
|
spells[#spells + 1] = {
|
||||||
name = 'Spitter Spawner',
|
name = {'entity-name.spitter-spawner'},
|
||||||
obj_to_create = 'spitter-spawner',
|
obj_to_create = 'spitter-spawner',
|
||||||
level = 100,
|
level = 100,
|
||||||
biter = true,
|
biter = true,
|
||||||
@ -163,7 +163,7 @@ function Public.conjure_items()
|
|||||||
enabled = true
|
enabled = true
|
||||||
}
|
}
|
||||||
spells[#spells + 1] = {
|
spells[#spells + 1] = {
|
||||||
name = 'AOE Grenade',
|
name = {'item-name.grenade'},
|
||||||
obj_to_create = 'grenade',
|
obj_to_create = 'grenade',
|
||||||
target = true,
|
target = true,
|
||||||
amount = 1,
|
amount = 1,
|
||||||
@ -176,7 +176,7 @@ function Public.conjure_items()
|
|||||||
enabled = true
|
enabled = true
|
||||||
}
|
}
|
||||||
spells[#spells + 1] = {
|
spells[#spells + 1] = {
|
||||||
name = 'Big AOE Grenade',
|
name = {'item-name.cluster-grenade'},
|
||||||
obj_to_create = 'cluster-grenade',
|
obj_to_create = 'cluster-grenade',
|
||||||
target = true,
|
target = true,
|
||||||
amount = 2,
|
amount = 2,
|
||||||
@ -189,7 +189,7 @@ function Public.conjure_items()
|
|||||||
enabled = true
|
enabled = true
|
||||||
}
|
}
|
||||||
spells[#spells + 1] = {
|
spells[#spells + 1] = {
|
||||||
name = 'Pointy Rocket',
|
name = {'item-name.rocket'},
|
||||||
obj_to_create = 'rocket',
|
obj_to_create = 'rocket',
|
||||||
range = 240,
|
range = 240,
|
||||||
target = true,
|
target = true,
|
||||||
@ -203,7 +203,7 @@ function Public.conjure_items()
|
|||||||
enabled = true
|
enabled = true
|
||||||
}
|
}
|
||||||
spells[#spells + 1] = {
|
spells[#spells + 1] = {
|
||||||
name = 'Bitter Spew',
|
name = {'spells.acid_stream'},
|
||||||
obj_to_create = 'acid-stream-spitter-big',
|
obj_to_create = 'acid-stream-spitter-big',
|
||||||
target = true,
|
target = true,
|
||||||
amount = 2,
|
amount = 2,
|
||||||
@ -217,7 +217,7 @@ function Public.conjure_items()
|
|||||||
enabled = true
|
enabled = true
|
||||||
}
|
}
|
||||||
spells[#spells + 1] = {
|
spells[#spells + 1] = {
|
||||||
name = 'Shoop Da Whoop!!',
|
name = {'spells.railgun_beam'},
|
||||||
obj_to_create = 'railgun-beam',
|
obj_to_create = 'railgun-beam',
|
||||||
target = false,
|
target = false,
|
||||||
amount = 3,
|
amount = 3,
|
||||||
@ -231,7 +231,7 @@ function Public.conjure_items()
|
|||||||
enabled = true
|
enabled = true
|
||||||
}
|
}
|
||||||
spells[#spells + 1] = {
|
spells[#spells + 1] = {
|
||||||
name = 'Conjure Raw-fish',
|
name = {'spells.raw_fish'},
|
||||||
obj_to_create = 'fish',
|
obj_to_create = 'fish',
|
||||||
target = false,
|
target = false,
|
||||||
amount = 4,
|
amount = 4,
|
||||||
@ -245,7 +245,7 @@ function Public.conjure_items()
|
|||||||
enabled = true
|
enabled = true
|
||||||
}
|
}
|
||||||
spells[#spells + 1] = {
|
spells[#spells + 1] = {
|
||||||
name = 'Suicidal Comfylatron',
|
name = {'spells.comfylatron'},
|
||||||
obj_to_create = 'suicidal_comfylatron',
|
obj_to_create = 'suicidal_comfylatron',
|
||||||
target = false,
|
target = false,
|
||||||
amount = 4,
|
amount = 4,
|
||||||
@ -259,7 +259,7 @@ function Public.conjure_items()
|
|||||||
enabled = true
|
enabled = true
|
||||||
}
|
}
|
||||||
spells[#spells + 1] = {
|
spells[#spells + 1] = {
|
||||||
name = 'Distractor Capsule',
|
name = {'spells.distractor'},
|
||||||
obj_to_create = 'distractor-capsule',
|
obj_to_create = 'distractor-capsule',
|
||||||
target = true,
|
target = true,
|
||||||
amount = 1,
|
amount = 1,
|
||||||
@ -273,7 +273,7 @@ function Public.conjure_items()
|
|||||||
enabled = true
|
enabled = true
|
||||||
}
|
}
|
||||||
spells[#spells + 1] = {
|
spells[#spells + 1] = {
|
||||||
name = 'Warp Gate',
|
name = {'spells.warp'},
|
||||||
obj_to_create = 'warp-gate',
|
obj_to_create = 'warp-gate',
|
||||||
target = true,
|
target = true,
|
||||||
force = 'player',
|
force = 'player',
|
||||||
|
@ -59,6 +59,14 @@ Public.classes = {
|
|||||||
}
|
}
|
||||||
|
|
||||||
Public.auto_allocate_nodes = {
|
Public.auto_allocate_nodes = {
|
||||||
|
{'allocations.deactivated'},
|
||||||
|
{'allocations.str'},
|
||||||
|
{'allocations.mag'},
|
||||||
|
{'allocations.dex'},
|
||||||
|
{'allocations.vit'}
|
||||||
|
}
|
||||||
|
|
||||||
|
Public.auto_allocate_nodes_func = {
|
||||||
'Deactivated',
|
'Deactivated',
|
||||||
'Strength',
|
'Strength',
|
||||||
'Magicka',
|
'Magicka',
|
||||||
|
@ -485,10 +485,10 @@ end
|
|||||||
|
|
||||||
local function increase_biter_damage()
|
local function increase_biter_damage()
|
||||||
local Difficulty
|
local Difficulty
|
||||||
if package.loaded['modules.difficulty_vote_by_amount'] then
|
if is_loaded('modules.difficulty_vote_by_amount') then
|
||||||
Difficulty = require 'modules.difficulty_vote_by_amount'
|
Difficulty = is_loaded('modules.difficulty_vote_by_amount')
|
||||||
elseif package.loaded['modules.difficulty_vote'] then
|
elseif is_loaded('modules.difficulty_vote') then
|
||||||
Difficulty = require 'modules.difficulty_vote'
|
Difficulty = is_loaded('modules.difficulty_vote')
|
||||||
end
|
end
|
||||||
if not Difficulty then
|
if not Difficulty then
|
||||||
return
|
return
|
||||||
|
@ -51,15 +51,26 @@ function Public.update_player_modifiers(player)
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
function Public.reset_player_modifiers(player)
|
||||||
|
if player and player.valid then
|
||||||
|
this[player.index] = {}
|
||||||
|
if this.disabled_modifier[player.index] then
|
||||||
|
this.disabled_modifier[player.index] = {}
|
||||||
|
end
|
||||||
|
for _, modifier in pairs(modifiers) do
|
||||||
|
this[player.index][modifier] = {}
|
||||||
|
end
|
||||||
|
Public.update_player_modifiers(player)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
local function on_player_joined_game(event)
|
local function on_player_joined_game(event)
|
||||||
if this[event.player_index] then
|
local player = game.get_player(event.player_index)
|
||||||
Public.update_player_modifiers(game.players[event.player_index])
|
if this[player.index] then
|
||||||
|
Public.update_player_modifiers(player)
|
||||||
return
|
return
|
||||||
end
|
end
|
||||||
this[event.player_index] = {}
|
Public.reset_player_modifiers(player)
|
||||||
for _, modifier in pairs(modifiers) do
|
|
||||||
this[event.player_index][modifier] = {}
|
|
||||||
end
|
|
||||||
end
|
end
|
||||||
|
|
||||||
local function on_player_respawned(event)
|
local function on_player_respawned(event)
|
||||||
|
36
terrain_layouts/winter.lua
Normal file
36
terrain_layouts/winter.lua
Normal file
@ -0,0 +1,36 @@
|
|||||||
|
local colors = {{255, 0, 0}, {0, 255, 0}, {0, 0, 255}}
|
||||||
|
local function add_light(e)
|
||||||
|
local color = colors[math.random(1, 3)]
|
||||||
|
local light_nr = rendering.draw_light({sprite="utility/light_small", orientation=1, scale=1, intensity=1, minimum_darkness=0, oriented=false, color=color, target=e, target_offset={0, -0.5}, surface=e.surface})
|
||||||
|
end
|
||||||
|
|
||||||
|
local function on_chunk_generated(event)
|
||||||
|
local surface = event.surface
|
||||||
|
local seed = surface.map_gen_settings.seed
|
||||||
|
local left_top_x = event.area.left_top.x
|
||||||
|
local left_top_y = event.area.left_top.y
|
||||||
|
local set_tiles = surface.set_tiles
|
||||||
|
local get_tile = surface.get_tile
|
||||||
|
|
||||||
|
local entities = surface.find_entities_filtered({type = {"simple-entity", "tree", "fish"}, area = event.area})
|
||||||
|
if #entities > 1 then table.shuffle_table(entities) end
|
||||||
|
for k, e in pairs(entities) do
|
||||||
|
add_light(e)
|
||||||
|
if k > 7 then break end
|
||||||
|
end
|
||||||
|
|
||||||
|
rendering.draw_sprite({sprite = "tile/lab-white", x_scale = 32, y_scale = 32, target = event.area.left_top, surface = surface, tint = {r = 0.6, g = 0.6, b = 0.6, a = 0.6}, render_layer = "ground"})
|
||||||
|
end
|
||||||
|
|
||||||
|
local function on_init()
|
||||||
|
local surface = game.surfaces.nauvis
|
||||||
|
surface.daytime = 0.43
|
||||||
|
surface.freeze_daytime = true
|
||||||
|
end
|
||||||
|
|
||||||
|
local Event = require 'utils.event'
|
||||||
|
Event.on_init(on_init)
|
||||||
|
Event.add(defines.events.on_chunk_generated, on_chunk_generated)
|
||||||
|
Event.add(defines.events.on_player_joined_game, on_player_joined_game)
|
||||||
|
Event.add(defines.events.on_player_mined_entity, on_player_mined_entity)
|
||||||
|
Event.add(defines.events.on_entity_died, on_entity_died)
|
@ -23,3 +23,12 @@ function get_game_version()
|
|||||||
return false
|
return false
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
function is_loaded(module)
|
||||||
|
local res = package.loaded[module]
|
||||||
|
if res then
|
||||||
|
return res
|
||||||
|
else
|
||||||
|
return false
|
||||||
|
end
|
||||||
|
end
|
||||||
|
@ -41,8 +41,7 @@ function Public.show(container)
|
|||||||
|
|
||||||
for name, file in pairs(loaded) do
|
for name, file in pairs(loaded) do
|
||||||
if not ignore[name] then
|
if not ignore[name] then
|
||||||
local file_label =
|
local file_label = left_panel.add({type = 'flow'}).add {type = 'label', name = file_label_name, caption = name}
|
||||||
left_panel.add({type = 'flow'}).add {type = 'label', name = file_label_name, caption = name}
|
|
||||||
Gui.set_data(file_label, file)
|
Gui.set_data(file_label, file)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
@ -107,8 +106,7 @@ Gui.on_click(
|
|||||||
|
|
||||||
if file_type == 'table' then
|
if file_type == 'table' then
|
||||||
for k, v in pairs(file) do
|
for k, v in pairs(file) do
|
||||||
local label =
|
local label = top_panel.add({type = 'flow'}).add {type = 'label', name = variable_label_name, caption = k}
|
||||||
top_panel.add({type = 'flow'}).add {type = 'label', name = variable_label_name, caption = k}
|
|
||||||
Gui.set_data(label, v)
|
Gui.set_data(label, v)
|
||||||
end
|
end
|
||||||
elseif file_type == 'function' then
|
elseif file_type == 'function' then
|
||||||
@ -134,8 +132,7 @@ Gui.on_click(
|
|||||||
if variable_type == 'table' then
|
if variable_type == 'table' then
|
||||||
Gui.clear(top_panel)
|
Gui.clear(top_panel)
|
||||||
for k, v in pairs(variable) do
|
for k, v in pairs(variable) do
|
||||||
local label =
|
local label = top_panel.add({type = 'flow'}).add {type = 'label', name = variable_label_name, caption = k}
|
||||||
top_panel.add({type = 'flow'}).add {type = 'label', name = variable_label_name, caption = k}
|
|
||||||
Gui.set_data(label, v)
|
Gui.set_data(label, v)
|
||||||
end
|
end
|
||||||
return
|
return
|
||||||
|
@ -2,6 +2,7 @@ local table_sort = table.sort
|
|||||||
local string_rep = string.rep
|
local string_rep = string.rep
|
||||||
local string_format = string.format
|
local string_format = string.format
|
||||||
local debug_getinfo = debug.getinfo
|
local debug_getinfo = debug.getinfo
|
||||||
|
local Color = require 'utils.color_presets'
|
||||||
|
|
||||||
local Profiler = {
|
local Profiler = {
|
||||||
-- Call
|
-- Call
|
||||||
@ -9,6 +10,13 @@ local Profiler = {
|
|||||||
IsRunning = false
|
IsRunning = false
|
||||||
}
|
}
|
||||||
|
|
||||||
|
-- we can have this on runtime,
|
||||||
|
-- but never ever can a player run this without notifying us.
|
||||||
|
local allowed = {
|
||||||
|
['Gerkiz'] = true,
|
||||||
|
['mewmew'] = true
|
||||||
|
}
|
||||||
|
|
||||||
local ignoredFunctions = {
|
local ignoredFunctions = {
|
||||||
[debug.sethook] = true
|
[debug.sethook] = true
|
||||||
}
|
}
|
||||||
@ -18,10 +26,40 @@ local namedSources = {
|
|||||||
}
|
}
|
||||||
|
|
||||||
local function startCommand(command)
|
local function startCommand(command)
|
||||||
Profiler.Start(command.parameter ~= nil)
|
local player = game.player
|
||||||
|
if player then
|
||||||
|
if player ~= nil then
|
||||||
|
if not player.admin then
|
||||||
|
local p = player.print
|
||||||
|
p('[ERROR] Only admins are allowed to run this command!', Color.fail)
|
||||||
|
return
|
||||||
|
else
|
||||||
|
if allowed[player.name] then
|
||||||
|
Profiler.Start(command.parameter ~= nil)
|
||||||
|
elseif _DEBUG then
|
||||||
|
Profiler.Start(command.parameter ~= nil)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
end
|
end
|
||||||
local function stopCommand(command)
|
local function stopCommand(command)
|
||||||
Profiler.Stop(command.parameter ~= nil, nil)
|
local player = game.player
|
||||||
|
if player then
|
||||||
|
if player ~= nil then
|
||||||
|
if not player.admin then
|
||||||
|
local p = player.print
|
||||||
|
p('[ERROR] Only admins are allowed to run this command!', Color.fail)
|
||||||
|
return
|
||||||
|
else
|
||||||
|
if allowed[player.name] then
|
||||||
|
Profiler.Stop(command.parameter ~= nil, nil)
|
||||||
|
elseif _DEBUG then
|
||||||
|
Profiler.Stop(command.parameter ~= nil, nil)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
end
|
end
|
||||||
ignoredFunctions[startCommand] = true
|
ignoredFunctions[startCommand] = true
|
||||||
ignoredFunctions[stopCommand] = true
|
ignoredFunctions[stopCommand] = true
|
||||||
@ -167,8 +205,7 @@ local function DumpTree(averageMs)
|
|||||||
call.profiler.divide(call.calls)
|
call.profiler.divide(call.calls)
|
||||||
end
|
end
|
||||||
|
|
||||||
str[line + 1] =
|
str[line + 1] = string_format('\n%s%dx %s. %s ', string_rep('\t', depth), call.calls, call.name, averageMs and 'Average' or 'Total')
|
||||||
string_format('\n%s%dx %s. %s ', string_rep('\t', depth), call.calls, call.name, averageMs and 'Average' or 'Total')
|
|
||||||
str[line + 2] = call.profiler
|
str[line + 2] = call.profiler
|
||||||
line = line + 2
|
line = line + 2
|
||||||
|
|
||||||
|
@ -33,7 +33,11 @@ end
|
|||||||
|
|
||||||
function Public.is_spamming(player, value_to_compare)
|
function Public.is_spamming(player, value_to_compare)
|
||||||
if not this.prevent_spam[player.index] then
|
if not this.prevent_spam[player.index] then
|
||||||
return
|
return false
|
||||||
|
end
|
||||||
|
|
||||||
|
if game.tick_paused then
|
||||||
|
return false -- game is paused - shoo
|
||||||
end
|
end
|
||||||
|
|
||||||
local tick = game.tick
|
local tick = game.tick
|
||||||
|
Loading…
x
Reference in New Issue
Block a user