mirror of
https://github.com/sirrobzeroone/elepower.git
synced 2024-12-03 12:03:46 +01:00
Heat exchanger for nuclear power
This commit is contained in:
parent
334a78c6cc
commit
2201104df1
@ -1,5 +1,5 @@
|
|||||||
|
|
||||||
local function get_formspec(power, percent, buffer)
|
local function get_formspec_default(power, percent, buffer)
|
||||||
return "size[8,8.5]"..
|
return "size[8,8.5]"..
|
||||||
default.gui_bg..
|
default.gui_bg..
|
||||||
default.gui_bg_img..
|
default.gui_bg_img..
|
||||||
@ -32,6 +32,13 @@ function ele.register_fluid_generator(nodename, nodedef)
|
|||||||
break
|
break
|
||||||
end
|
end
|
||||||
|
|
||||||
|
-- Allow for custom formspec
|
||||||
|
local get_formspec = get_formspec_default
|
||||||
|
if nodedef.get_formspec then
|
||||||
|
get_formspec = nodedef.get_formspec
|
||||||
|
nodedef.get_formspec = nil
|
||||||
|
end
|
||||||
|
|
||||||
local defaults = {
|
local defaults = {
|
||||||
groups = {
|
groups = {
|
||||||
fluid_container = 1,
|
fluid_container = 1,
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
|
|
||||||
local function get_formspec(power, percent)
|
local function get_formspec_default(power, percent)
|
||||||
return "size[8,8.5]"..
|
return "size[8,8.5]"..
|
||||||
default.gui_bg..
|
default.gui_bg..
|
||||||
default.gui_bg_img..
|
default.gui_bg_img..
|
||||||
@ -26,6 +26,13 @@ function elepm.register_fuel_generator(nodename, nodedef)
|
|||||||
nodedef.groups["tubedevice"] = 1
|
nodedef.groups["tubedevice"] = 1
|
||||||
nodedef.groups["tubedevice_receiver"] = 1
|
nodedef.groups["tubedevice_receiver"] = 1
|
||||||
|
|
||||||
|
-- Allow for custom formspec
|
||||||
|
local get_formspec = get_formspec_default
|
||||||
|
if nodedef.get_formspec then
|
||||||
|
get_formspec = nodedef.get_formspec
|
||||||
|
nodedef.get_formspec = nil
|
||||||
|
end
|
||||||
|
|
||||||
nodedef.on_timer = function (pos, elapsed)
|
nodedef.on_timer = function (pos, elapsed)
|
||||||
local meta = minetest.get_meta(pos)
|
local meta = minetest.get_meta(pos)
|
||||||
|
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
|
|
||||||
local function get_formspec(power)
|
local function get_formspec_default(power)
|
||||||
return "size[8,8.5]"..
|
return "size[8,8.5]"..
|
||||||
default.gui_bg..
|
default.gui_bg..
|
||||||
default.gui_bg_img..
|
default.gui_bg_img..
|
||||||
@ -42,6 +42,13 @@ function elepm.register_storage(nodename, nodedef)
|
|||||||
|
|
||||||
nodedef.can_dig = can_dig
|
nodedef.can_dig = can_dig
|
||||||
|
|
||||||
|
-- Allow for custom formspec
|
||||||
|
local get_formspec = get_formspec_default
|
||||||
|
if nodedef.get_formspec then
|
||||||
|
get_formspec = nodedef.get_formspec
|
||||||
|
nodedef.get_formspec = nil
|
||||||
|
end
|
||||||
|
|
||||||
nodedef.on_timer = function (pos, elapsed)
|
nodedef.on_timer = function (pos, elapsed)
|
||||||
local meta = minetest.get_meta(pos)
|
local meta = minetest.get_meta(pos)
|
||||||
local refresh = false
|
local refresh = false
|
||||||
|
@ -1,7 +1,19 @@
|
|||||||
|
|
||||||
|
local function get_formspec(power, percent, buffer)
|
||||||
|
return "size[8,8.5]"..
|
||||||
|
default.gui_bg..
|
||||||
|
default.gui_bg_img..
|
||||||
|
default.gui_slots..
|
||||||
|
ele.formspec.power_meter(power)..
|
||||||
|
ele.formspec.fluid_bar(7, 0, buffer)..
|
||||||
|
"list[current_player;main;0,4.25;8,1;]"..
|
||||||
|
"list[current_player;main;0,5.5;8,3;8]"..
|
||||||
|
default.get_hotbar_bg(0, 4.25)
|
||||||
|
end
|
||||||
|
|
||||||
ele.register_fluid_generator("elepower_machines:steam_turbine", {
|
ele.register_fluid_generator("elepower_machines:steam_turbine", {
|
||||||
description = "Steam Turbine",
|
description = "Steam Turbine",
|
||||||
ele_usage = 64,
|
ele_usage = 128,
|
||||||
tiles = {
|
tiles = {
|
||||||
"elepower_machine_top.png^elepower_power_port.png", "elepower_machine_base.png", "elepower_machine_side.png",
|
"elepower_machine_top.png^elepower_power_port.png", "elepower_machine_base.png", "elepower_machine_side.png",
|
||||||
"elepower_machine_side.png", "elepower_turbine_side.png", "elepower_turbine_side.png",
|
"elepower_machine_side.png", "elepower_turbine_side.png", "elepower_turbine_side.png",
|
||||||
@ -22,4 +34,6 @@ ele.register_fluid_generator("elepower_machines:steam_turbine", {
|
|||||||
},
|
},
|
||||||
tube = false,
|
tube = false,
|
||||||
ele_no_automatic_ports = true,
|
ele_no_automatic_ports = true,
|
||||||
|
fuel_burn_time = 2,
|
||||||
|
get_formspec = get_formspec,
|
||||||
})
|
})
|
||||||
|
100
elepower_nuclear/machines/heat_exchanger.lua
Normal file
100
elepower_nuclear/machines/heat_exchanger.lua
Normal file
@ -0,0 +1,100 @@
|
|||||||
|
|
||||||
|
local function get_formspec(heat, cold, water, steam)
|
||||||
|
return "size[8,8.5]"..
|
||||||
|
default.gui_bg..
|
||||||
|
default.gui_bg_img..
|
||||||
|
default.gui_slots..
|
||||||
|
ele.formspec.fluid_bar(0, 0, heat)..
|
||||||
|
ele.formspec.fluid_bar(1, 0, cold)..
|
||||||
|
"image[3.5,1;1,1;gui_furnace_arrow_bg.png^[transformR270]"..
|
||||||
|
ele.formspec.fluid_bar(6, 0, water)..
|
||||||
|
ele.formspec.fluid_bar(7, 0, steam)..
|
||||||
|
"list[context;dst;5,1;1,1;]"..
|
||||||
|
"list[current_player;main;0,4.25;8,1;]"..
|
||||||
|
"list[current_player;main;0,5.5;8,3;8]"..
|
||||||
|
"listring[context;dst]"..
|
||||||
|
"listring[current_player;main]"..
|
||||||
|
default.get_hotbar_bg(0, 4.25)
|
||||||
|
end
|
||||||
|
|
||||||
|
local function heat_exchanger_timer(pos)
|
||||||
|
local meta = minetest.get_meta(pos)
|
||||||
|
local change = false
|
||||||
|
|
||||||
|
local heat = fluid_lib.get_buffer_data(pos, "heat")
|
||||||
|
local cold = fluid_lib.get_buffer_data(pos, "cold")
|
||||||
|
local water = fluid_lib.get_buffer_data(pos, "water")
|
||||||
|
local steam = fluid_lib.get_buffer_data(pos, "steam")
|
||||||
|
|
||||||
|
-- See if we have enough hot coolant
|
||||||
|
if heat.amount >= 1000 then
|
||||||
|
local water_convert = math.min(water.amount, 1000)
|
||||||
|
if steam.amount + water_convert > steam.capacity then
|
||||||
|
water_convert = steam.capacity - steam.amount
|
||||||
|
end
|
||||||
|
|
||||||
|
if water_convert > 0 then
|
||||||
|
if cold.amount + 1000 < cold.capacity then
|
||||||
|
-- Conversion
|
||||||
|
heat.amount = heat.amount - 1000
|
||||||
|
cold.amount = cold.amount + 1000
|
||||||
|
|
||||||
|
water.amount = water.amount - water_convert
|
||||||
|
steam.amount = steam.amount + water_convert
|
||||||
|
|
||||||
|
change = true
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
if change then
|
||||||
|
meta:set_string("cold_fluid", "elepower_nuclear:coolant_source")
|
||||||
|
meta:set_string("steam_fluid", "elepower_dynamics:steam")
|
||||||
|
|
||||||
|
meta:set_int("heat_fluid_storage", heat.amount)
|
||||||
|
meta:set_int("cold_fluid_storage", cold.amount)
|
||||||
|
|
||||||
|
meta:set_int("water_fluid_storage", water.amount)
|
||||||
|
meta:set_int("steam_fluid_storage", steam.amount)
|
||||||
|
end
|
||||||
|
|
||||||
|
meta:set_string("formspec", get_formspec(heat, cold, water, steam))
|
||||||
|
|
||||||
|
return false
|
||||||
|
end
|
||||||
|
|
||||||
|
ele.register_machine("elepower_nuclear:heat_exchanger", {
|
||||||
|
description = "Shielded Heat Exchanger\nFor use in nuclear power plants",
|
||||||
|
tiles = {
|
||||||
|
"elenuclear_machine_top.png", "elepower_lead_block.png", "elenuclear_machine_side.png",
|
||||||
|
"elenuclear_machine_side.png", "elenuclear_machine_side.png", "elenuclear_heat_exchanger.png",
|
||||||
|
},
|
||||||
|
groups = {cracky = 3, fluid_container = 1},
|
||||||
|
fluid_buffers = {
|
||||||
|
heat = {
|
||||||
|
capacity = 8000,
|
||||||
|
accepts = {"elepower_nuclear:hot_coolant_source"},
|
||||||
|
drainable = false,
|
||||||
|
},
|
||||||
|
cold = {
|
||||||
|
capacity = 8000,
|
||||||
|
accepts = {"elepower_nuclear:coolant_source"},
|
||||||
|
drainable = true,
|
||||||
|
},
|
||||||
|
water = {
|
||||||
|
capacity = 16000,
|
||||||
|
accepts = {"default:water_source"},
|
||||||
|
drainable = false,
|
||||||
|
},
|
||||||
|
steam = {
|
||||||
|
capacity = 16000,
|
||||||
|
accepts = {"elepower_dynamics:steam"},
|
||||||
|
drainable = true,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
on_construct = function (pos)
|
||||||
|
local meta = minetest.get_meta(pos)
|
||||||
|
meta:set_string("formspec", get_formspec())
|
||||||
|
end,
|
||||||
|
on_timer = heat_exchanger_timer,
|
||||||
|
})
|
@ -3,4 +3,5 @@ local mp = elenuclear.modpath .. "/machines/"
|
|||||||
|
|
||||||
dofile(mp.."enrichment_plant.lua")
|
dofile(mp.."enrichment_plant.lua")
|
||||||
dofile(mp.."fission_reactor.lua")
|
dofile(mp.."fission_reactor.lua")
|
||||||
|
dofile(mp.."heat_exchanger.lua")
|
||||||
|
|
||||||
|
Binary file not shown.
Before Width: | Height: | Size: 524 B After Width: | Height: | Size: 1.9 KiB |
Loading…
Reference in New Issue
Block a user