1
0
mirror of https://github.com/ComfyFactory/ComfyFactorio.git synced 2024-12-30 23:17:53 +02:00

mountain fortress and rpg updates

This commit is contained in:
Gerkiz 2021-05-04 19:51:02 +02:00
parent 6a95cb2108
commit 2065118aca
6 changed files with 91 additions and 18 deletions

View File

@ -13,6 +13,7 @@ local fallout_width = 64
local fallout_debris = {}
for x = fallout_width * -1 - 32, fallout_width + 32, 1 do
if x < -31 or x > 31 then
for y = fallout_width * -1 - 32, fallout_width + 32, 1 do
local position = {x = x, y = y}
local fallout = sqrt(position.x ^ 2 + position.y ^ 2)
@ -21,6 +22,7 @@ for x = fallout_width * -1 - 32, fallout_width + 32, 1 do
end
end
end
end
local size_of_debris = #fallout_debris
local reconstruct_all_trains =
@ -32,7 +34,7 @@ local reconstruct_all_trains =
)
local function get_tile_name()
local main_tile_name = 'tutorial-grid'
local main_tile_name = 'black-refined-concrete'
local modded = is_game_modded()
if modded then
if game.active_mods['Krastorio2'] then
@ -200,6 +202,50 @@ local function input_filtered(wagon_inventory, chest, chest_inventory, free_slot
end
end
local remove_lights_token =
Token.register(
function(data)
local id = data.id
if id then
rendering.destroy(id)
end
end
)
function Public.glimpse_of_lights(icw)
local surface = WPT.get('loco_surface')
if not surface or not surface.valid then
return
end
local hazardous_debris = icw.hazardous_debris
if not hazardous_debris then
return
end
local text = rendering.draw_text
local position = fallout_debris[random(1, size_of_debris)]
local p = {x = position[1], y = position[2]}
local get_tile = surface.get_tile(p)
if get_tile.valid and get_tile.name == 'out-of-map' then
local id =
text {
text = '',
surface = surface,
target = position,
color = {r = 1, g = 1, b = 0},
orientation = random(0, 100) * 0.01,
scale = 0.4,
font = 'heading-1',
alignment = 'center',
scale_with_zoom = false
}
Task.set_timeout_in_ticks(300, remove_lights_token, {id = id})
end
end
function Public.hazardous_debris(icw)
local speed = icw.speed
local surface = WPT.get('loco_surface')
@ -214,15 +260,6 @@ function Public.hazardous_debris(icw)
local create = surface.create_entity
for _ = 1, 16 * speed, 1 do
local position = fallout_debris[random(1, size_of_debris)]
local p = {x = position[1], y = position[2]}
local get_tile = surface.get_tile(p)
if get_tile.valid and get_tile.name == 'out-of-map' then
create({name = 'blue-laser', position = position, force = 'neutral', target = {position[1], position[2] + fallout_width * 2}, speed = speed})
end
end
for _ = 1, 16 * speed, 1 do
local position = fallout_debris[random(1, size_of_debris)]
local p = {x = position[1], y = position[2]}

View File

@ -97,6 +97,7 @@ local function on_tick()
if tick % 10 == 0 then
Functions.item_transfer(icw)
Functions.hazardous_debris(icw)
Functions.glimpse_of_lights(icw)
end
if tick % 240 == 0 then
Functions.update_minimap(icw)

View File

@ -1084,7 +1084,7 @@ local function gui_click(event)
player.name .. ' has bought the locomotive health modifier for ' .. format_number(item.price, true) .. ' coins.'
}
)
this.locomotive_max_health = this.locomotive_max_health + 4000 * item.stack
this.locomotive_max_health = this.locomotive_max_health + (this.locomotive_max_health * 0.5 * item.stack)
local m = this.locomotive_health / this.locomotive_max_health
if this.carriages then

View File

@ -64,6 +64,10 @@ function Public.add(surface, position, chest)
container.insert({name = 'coin', count = random(1, 128)})
elseif random(1, 128) == 1 then
container.insert({name = 'coin', count = random(1, 256)})
elseif random(1, 256) == 1 then
container.insert({name = 'coin', count = random(1, 512)})
elseif random(1, 512) == 1 then
container.insert({name = 'coin', count = random(1, 1024)})
end
for _ = 1, 3, 1 do

View File

@ -4,6 +4,8 @@ local Gui = require 'utils.gui'
local Color = require 'utils.color_presets'
local Token = require 'utils.token'
local Alert = require 'utils.alert'
local Task = require 'utils.task'
local Token = require 'utils.token'
local Public = {}
@ -734,6 +736,35 @@ function Public.global_pool(players, count)
return
end
local damage_player_over_time_token =
Token.register(
function(data)
local player = data.player
local damage = data.damage
if not player.character or not player.character.valid then
return
end
player.character.health = player.character.health - damage
player.character.surface.create_entity({name = 'water-splash', position = player.position})
end
)
--- Damages a player over time.
function Public.damage_player_over_time(player, amount, damage)
if not player or not player.valid then
return
end
amount = amount or 5
damage = damage or 10
local tick = 20
for _ = 1, amount, 1 do
Task.set_timeout_in_ticks(tick, damage_player_over_time_token, {player = player, damage = damage})
tick = tick + 15
damage = damage + 10
end
end
--- Distributes the global xp pool to every connected player.
function Public.distribute_pool()
local count = #game.connected_players

View File

@ -1098,8 +1098,8 @@ local function on_player_used_capsule(event)
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)
rpg_t[player.index].mana = 0
player.character.health = 10
player.character.surface.create_entity({name = 'water-splash', position = player.position})
Functions.damage_player_over_time(player, 10)
player.play_sound {path = 'utility/armor_insert', volume_modifier = 1}
p(({'rpg_main.warped_ok'}), Color.info)
rpg_t[player.index].mana = rpg_t[player.index].mana - object.mana_cost
elseif projectile_types[obj_name] then -- projectiles