mirror of
https://github.com/Refactorio/RedMew.git
synced 2025-01-18 03:21:47 +02:00
Fixed coin mining and behavior in Diggy
This commit is contained in:
parent
8f2b92f56f
commit
2a8a047c64
@ -1,6 +1,8 @@
|
||||
local Event = require 'utils.event'
|
||||
local Global = require 'utils.global'
|
||||
local Game = require 'utils.game'
|
||||
local pairs = pairs
|
||||
local sqrt = math.sqrt
|
||||
|
||||
local player_last_position = {}
|
||||
local player_walk_distances = {}
|
||||
@ -69,7 +71,6 @@ end
|
||||
|
||||
local function picked_up_item(event)
|
||||
local stack = event.item_stack
|
||||
|
||||
if stack.name == 'coin' then
|
||||
local player_index = event.player_index
|
||||
player_coin_earned[player_index] = player_coin_earned[player_index] + stack.count
|
||||
@ -77,7 +78,7 @@ local function picked_up_item(event)
|
||||
end
|
||||
|
||||
local function tick()
|
||||
for _, p in ipairs(game.connected_players) do
|
||||
for _, p in pairs(game.connected_players) do
|
||||
if (p.afk_time < 30 or p.walking_state.walking) and p.vehicle == nil then
|
||||
local index = p.index
|
||||
local last_pos = player_last_position[index]
|
||||
@ -86,7 +87,7 @@ local function tick()
|
||||
local d_x = last_pos.x - pos.x
|
||||
local d_y = last_pos.y - pos.y
|
||||
|
||||
player_walk_distances[index] = player_walk_distances[index] + math.sqrt(d_x * d_x + d_y * d_y)
|
||||
player_walk_distances[index] = player_walk_distances[index] + sqrt(d_x * d_x + d_y * d_y)
|
||||
player_last_position[index] = pos
|
||||
end
|
||||
end
|
||||
@ -94,6 +95,7 @@ end
|
||||
|
||||
Event.add(defines.events.on_player_created, player_created)
|
||||
Event.add(defines.events.on_player_died, player_died)
|
||||
Event.add(defines.events.on_player_mined_item, picked_up_item)
|
||||
Event.add(defines.events.on_picked_up_item, picked_up_item)
|
||||
Event.on_nth_tick(62, tick)
|
||||
|
||||
|
@ -111,7 +111,7 @@ local Config = {
|
||||
},
|
||||
|
||||
-- Adds the ability to drop coins and track how many are sent into space
|
||||
ArtefactHunting = {
|
||||
CoinGathering = {
|
||||
enabled = true,
|
||||
|
||||
-- value between 0 and 1, higher value means stronger variance between coordinates
|
||||
|
@ -6,16 +6,18 @@
|
||||
local Event = require 'utils.event'
|
||||
local Game = require 'utils.game'
|
||||
local ScoreTable = require 'map_gen.Diggy.ScoreTable'
|
||||
local PlayerStats = require 'features.player_stats'
|
||||
local Debug = require 'map_gen.Diggy.Debug'
|
||||
local Template = require 'map_gen.Diggy.Template'
|
||||
local Perlin = require 'map_gen.shared.perlin_noise'
|
||||
local random = math.random
|
||||
local ceil = math.ceil
|
||||
local pairs = pairs
|
||||
local Gui = require 'utils.gui'
|
||||
local utils = require 'utils.core'
|
||||
|
||||
-- this
|
||||
local ArtefactHunting = {}
|
||||
local CoinGathering = {}
|
||||
|
||||
local coin_color = {r = 255, g = 215, b = 0}
|
||||
|
||||
@ -29,10 +31,10 @@ local function redraw_table(data)
|
||||
for name, value in pairs(ScoreTable.all()) do
|
||||
local table = list.add({type = 'table', column_count = 2})
|
||||
|
||||
local key = table.add({type = 'label', name = 'Diggy.ArtefactHunting.Frame.List.Key', caption = name})
|
||||
local key = table.add({type = 'label', name = 'Diggy.CoinGathering.Frame.List.Key', caption = name})
|
||||
key.style.minimal_width = 175
|
||||
|
||||
local val = table.add({type = 'label', name = 'Diggy.ArtefactHunting.Frame.List.Val', caption = utils.comma_value(value)})
|
||||
local val = table.add({type = 'label', name = 'Diggy.CoinGathering.Frame.List.Val', caption = utils.comma_value(value)})
|
||||
val.style.minimal_width = 225
|
||||
end
|
||||
end
|
||||
@ -41,7 +43,7 @@ end
|
||||
local function toggle(event)
|
||||
local player = event.player
|
||||
local center = player.gui.left
|
||||
local frame = center['Diggy.ArtefactHunting.Frame']
|
||||
local frame = center['Diggy.CoinGathering.Frame']
|
||||
|
||||
if (frame and event.trigger == nil) then
|
||||
Gui.destroy(frame)
|
||||
@ -52,12 +54,12 @@ local function toggle(event)
|
||||
return
|
||||
end
|
||||
|
||||
frame = center.add({name = 'Diggy.ArtefactHunting.Frame', type = 'frame', direction = 'vertical'})
|
||||
frame = center.add({name = 'Diggy.CoinGathering.Frame', type = 'frame', direction = 'vertical'})
|
||||
|
||||
local scroll_pane = frame.add({type = 'scroll-pane'})
|
||||
scroll_pane.style.maximal_height = 400
|
||||
|
||||
frame.add({ type = 'button', name = 'Diggy.ArtefactHunting.Button', caption = 'Close'})
|
||||
frame.add({type = 'button', name = 'Diggy.CoinGathering.Button', caption = 'Close'})
|
||||
|
||||
local data = {
|
||||
frame = frame,
|
||||
@ -71,20 +73,20 @@ end
|
||||
|
||||
local function on_player_created(event)
|
||||
Game.get_player_by_index(event.player_index).gui.top.add({
|
||||
name = 'Diggy.ArtefactHunting.Button',
|
||||
name = 'Diggy.CoinGathering.Button',
|
||||
type = 'sprite-button',
|
||||
sprite = 'item/steel-axe',
|
||||
})
|
||||
end
|
||||
|
||||
Gui.on_click('Diggy.ArtefactHunting.Button', toggle)
|
||||
Gui.on_custom_close('Diggy.ArtefactHunting.Frame', function (event)
|
||||
Gui.on_click('Diggy.CoinGathering.Button', toggle)
|
||||
Gui.on_custom_close('Diggy.CoinGathering.Frame', function (event)
|
||||
event.element.destroy()
|
||||
end)
|
||||
|
||||
function ArtefactHunting.update_gui()
|
||||
function CoinGathering.update_gui()
|
||||
for _, p in pairs(game.connected_players) do
|
||||
local frame = p.gui.left['Diggy.ArtefactHunting.Frame']
|
||||
local frame = p.gui.left['Diggy.CoinGathering.Frame']
|
||||
|
||||
if frame and frame.valid then
|
||||
local data = {player = p, trigger = 'update_gui'}
|
||||
@ -93,19 +95,17 @@ function ArtefactHunting.update_gui()
|
||||
end
|
||||
end
|
||||
|
||||
--[[--
|
||||
Registers all event handlers.
|
||||
]]
|
||||
function ArtefactHunting.register(config)
|
||||
function CoinGathering.register(config)
|
||||
Event.add(defines.events.on_player_created, on_player_created)
|
||||
Event.on_nth_tick(61, ArtefactHunting.update_gui)
|
||||
Event.on_nth_tick(61, CoinGathering.update_gui)
|
||||
|
||||
ScoreTable.reset('Coins sent to space')
|
||||
|
||||
local seed
|
||||
local noise_variance = config.noise_variance
|
||||
local function get_noise(surface, x, y)
|
||||
seed = seed or surface.map_gen_settings.seed + surface.index + 300
|
||||
return Perlin.noise(x * config.noise_variance * 0.9, y * config.noise_variance * 1.1, seed)
|
||||
return Perlin.noise(x * noise_variance * 0.9, y * noise_variance * 1.1, seed)
|
||||
end
|
||||
|
||||
local distance_required = config.minimal_treasure_chest_distance * config.minimal_treasure_chest_distance
|
||||
@ -148,22 +148,6 @@ function ArtefactHunting.register(config)
|
||||
end)
|
||||
|
||||
local modifiers = config.alien_coin_modifiers
|
||||
|
||||
local function picked_up_coins(player_index, count)
|
||||
local text
|
||||
if count == 1 then
|
||||
text = '+1 coin'
|
||||
ScoreTable.increment('Collected coins')
|
||||
else
|
||||
text = '+' .. count ..' coins'
|
||||
ScoreTable.add('Collected coins', count)
|
||||
end
|
||||
|
||||
Game.print_player_floating_text(player_index, text, coin_color)
|
||||
end
|
||||
|
||||
ScoreTable.reset('Collected coins')
|
||||
|
||||
local alien_coin_drop_chance = config.alien_coin_drop_chance
|
||||
|
||||
Event.add(defines.events.on_entity_died, function (event)
|
||||
@ -187,32 +171,27 @@ function ArtefactHunting.register(config)
|
||||
})
|
||||
end)
|
||||
|
||||
Event.add(defines.events.on_picked_up_item, function (event)
|
||||
local stack = event.item_stack
|
||||
if stack.name ~= 'coin' then
|
||||
return
|
||||
end
|
||||
|
||||
picked_up_coins(event.player_index, stack.count)
|
||||
end)
|
||||
|
||||
local mining_coin_chance = config.mining_coin_chance
|
||||
local mining_coin_amount_min = config.mining_coin_amount.min
|
||||
local mining_coin_amount_max = config.mining_coin_amount.max
|
||||
Event.add(defines.events.on_pre_player_mined_item, function (event)
|
||||
if event.entity.type ~= 'simple-entity' then
|
||||
local entity = event.entity
|
||||
if entity.type ~= 'simple-entity' then
|
||||
return
|
||||
end
|
||||
|
||||
if random() > config.mining_coin_chance then
|
||||
if random() > mining_coin_chance then
|
||||
return
|
||||
end
|
||||
|
||||
local count = random(config.mining_coin_amount.min, config.mining_coin_amount.max)
|
||||
local player_index = event.player_index
|
||||
|
||||
Game.get_player_by_index(player_index).insert({name = 'coin', count = count})
|
||||
picked_up_coins(player_index, count)
|
||||
entity.surface.create_entity({
|
||||
name = 'item-on-ground',
|
||||
position = entity.position,
|
||||
stack = {name = 'coin', count = random(mining_coin_amount_min, mining_coin_amount_max)}
|
||||
})
|
||||
end)
|
||||
|
||||
if (config.display_chest_locations) then
|
||||
if config.display_chest_locations then
|
||||
Event.add(defines.events.on_chunk_generated, function (event)
|
||||
local surface = event.surface
|
||||
local area = event.area
|
||||
@ -229,8 +208,4 @@ function ArtefactHunting.register(config)
|
||||
end
|
||||
end
|
||||
|
||||
function ArtefactHunting.get_extra_map_info(config)
|
||||
return 'Artefact Hunting, find precious coins while mining and launch them to the surface!'
|
||||
end
|
||||
|
||||
return ArtefactHunting
|
||||
return CoinGathering
|
@ -42,7 +42,6 @@ function Scenario.register()
|
||||
return
|
||||
end
|
||||
|
||||
global.config.player_list.show_coin_column = false
|
||||
global.config.fish_market.enabled = false
|
||||
|
||||
local extra_map_info = ''
|
||||
|
Loading…
Reference in New Issue
Block a user