complete rework of power distribution
This commit is contained in:
parent
6bfd108bf1
commit
443a5e9f21
280
basis/power.lua
280
basis/power.lua
@ -56,167 +56,165 @@ local function side_to_dir(pos, side)
|
|||||||
return dir
|
return dir
|
||||||
end
|
end
|
||||||
|
|
||||||
function techage.next_pos(pos, side)
|
function techage.get_pos(pos, side)
|
||||||
local dir = side_to_dir(pos, side)
|
local dir = side_to_dir(pos, side)
|
||||||
return tubelib2.get_pos(pos, dir)
|
return tubelib2.get_pos(pos, dir)
|
||||||
end
|
end
|
||||||
|
|
||||||
-- Calculate the power consumption on the given network
|
local function dbg(name, pos, val)
|
||||||
local function power_consumption(pos, dir)
|
local node = minetest.get_node(pos)
|
||||||
print("power_consumption")
|
print(name.." ("..node.name..") "..dump(val))
|
||||||
if pos_already_reached(pos) then return 0 end
|
|
||||||
local mem = tubelib2.get_mem(pos)
|
|
||||||
local conn = mem.connections or {}
|
|
||||||
local this = TP(pos)
|
|
||||||
local val = this.power_consumption(pos, tubelib2.Turn180Deg[dir])
|
|
||||||
for out_dir,item in pairs(conn) do
|
|
||||||
-- Not in the opposite direction
|
|
||||||
if out_dir ~= tubelib2.Turn180Deg[dir or 0] then
|
|
||||||
if item.pos then
|
|
||||||
this = TP(item.pos)
|
|
||||||
if this and this.power_consumption then
|
|
||||||
val = val + this.power_consumption(item.pos, item.in_dir)
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
return val
|
|
||||||
end
|
end
|
||||||
|
|
||||||
local function turn_tube_on(pos, dir, network, on)
|
local power_consumption = nil
|
||||||
if on then
|
|
||||||
network:switch_tube_line(pos, dir, "on")
|
local function call_read_power_consumption(pos, in_dir)
|
||||||
|
if not pos_already_reached(pos) then
|
||||||
|
local this = TP(pos)
|
||||||
|
if this and this.read_power_consumption then
|
||||||
|
dbg("power_consumption", pos, this.read_power_consumption(pos, in_dir))
|
||||||
|
return this.read_power_consumption(pos, in_dir)
|
||||||
else
|
else
|
||||||
network:switch_tube_line(pos, dir, "off")
|
return power_consumption(pos, in_dir)
|
||||||
end
|
end
|
||||||
end
|
|
||||||
|
|
||||||
local function turn_on(pos, dir, on)
|
|
||||||
if pos_already_reached(pos) then return end
|
|
||||||
local mem = tubelib2.get_mem(pos)
|
|
||||||
local conn = mem.connections or {}
|
|
||||||
local this = TP(pos)
|
|
||||||
if this and this.turn_on then
|
|
||||||
this.turn_on(pos, dir, on)
|
|
||||||
end
|
|
||||||
for out_dir,item in pairs(conn) do
|
|
||||||
-- Not in the opposite direction
|
|
||||||
if out_dir ~= tubelib2.Turn180Deg[dir or 0] then
|
|
||||||
if item.pos then
|
|
||||||
local this = TP(item.pos)
|
|
||||||
if this and this.turn_on and this.valid_power_dir then
|
|
||||||
local mem = tubelib2.get_mem(item.pos)
|
|
||||||
if this.valid_power_dir(item.pos, mem, item.in_dir) then
|
|
||||||
this.turn_on(item.pos, item.in_dir, on)
|
|
||||||
end
|
|
||||||
end
|
|
||||||
if this and this.animated_power_network then
|
|
||||||
turn_tube_on(pos, out_dir, this.power_network, on)
|
|
||||||
end
|
|
||||||
turn_on(item.pos, item.in_dir, on)
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
|
|
||||||
-- To be called delayed from any node, after any change.
|
|
||||||
-- The result is stored in mem.power_result
|
|
||||||
local function check_power_consumption(pos, dir)
|
|
||||||
local mem = tubelib2.get_mem(pos)
|
|
||||||
Route = {}
|
|
||||||
local sum = power_consumption(pos, dir)
|
|
||||||
if sum < 1 then
|
|
||||||
Route = {}
|
|
||||||
turn_on(pos, nil, false)
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
--
|
|
||||||
-- Generator with one power output side
|
|
||||||
--
|
|
||||||
function techage.calc_power_consumption(pos, mem, max_power)
|
|
||||||
mem.power_produce = max_power
|
|
||||||
Route = {}
|
|
||||||
local sum = power_consumption(pos, mem.power_dir)
|
|
||||||
mem.power_result = sum
|
|
||||||
return sum
|
|
||||||
end
|
|
||||||
|
|
||||||
function techage.generator_on(pos, mem)
|
|
||||||
if mem.power_result > 0 then
|
|
||||||
Route = {}
|
|
||||||
turn_on(pos, nil, true)
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
function techage.generator_off(pos, mem)
|
|
||||||
mem.power_produce = 0
|
|
||||||
Route = {}
|
|
||||||
turn_on(pos, nil, false)
|
|
||||||
end
|
|
||||||
|
|
||||||
function techage.generator_power_consumption(pos, dir)
|
|
||||||
local mem = tubelib2.get_mem(pos)
|
|
||||||
if dir == tubelib2.Turn180Deg[mem.power_dir or 0] then
|
|
||||||
return mem.power_produce or 0
|
|
||||||
end
|
end
|
||||||
return 0
|
return 0
|
||||||
end
|
end
|
||||||
|
|
||||||
function techage.generator_after_place_node(pos)
|
-- Calculate the power consumption on the given network
|
||||||
|
power_consumption = function(pos, in_dir)
|
||||||
|
local sum = call_read_power_consumption(pos, in_dir)
|
||||||
|
--local sum = 0
|
||||||
|
local mem = tubelib2.get_mem(pos)
|
||||||
|
local conn = mem.connections or {}
|
||||||
|
for out_dir,item in pairs(conn) do
|
||||||
|
if item.pos then
|
||||||
|
sum = sum + call_read_power_consumption(item.pos, item.in_dir)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
return sum
|
||||||
|
end
|
||||||
|
|
||||||
|
-- Switch active/passive tube nodes
|
||||||
|
local function turn_tube_on(pos, in_dir, network, on)
|
||||||
|
local out_dir = tubelib2.Turn180Deg[in_dir]
|
||||||
|
if on then
|
||||||
|
network:switch_tube_line(pos, out_dir, "on")
|
||||||
|
else
|
||||||
|
network:switch_tube_line(pos, out_dir, "off")
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
|
||||||
|
local turn_on = nil
|
||||||
|
|
||||||
|
local function call_turn_on(pos, in_dir, sum)
|
||||||
|
if not pos_already_reached(pos) then
|
||||||
|
local this = TP(pos)
|
||||||
|
if this and this.turn_on then
|
||||||
|
this.turn_on(pos, in_dir, sum)
|
||||||
|
end
|
||||||
|
if this and this.animated_power_network then
|
||||||
|
turn_tube_on(pos, in_dir, this.power_network, sum > 0)
|
||||||
|
else
|
||||||
|
turn_on(pos, in_dir, sum)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
-- turn nodes on if sum > 0
|
||||||
|
turn_on = function(pos, in_dir, sum)
|
||||||
|
call_turn_on(pos, in_dir, sum)
|
||||||
|
local mem = tubelib2.get_mem(pos)
|
||||||
|
local conn = mem.connections or {}
|
||||||
|
for out_dir,item in pairs(conn) do
|
||||||
|
if item.pos then
|
||||||
|
call_turn_on(item.pos, item.in_dir, sum)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
|
||||||
|
-- Starts the overall power consumption and depending on that turns all nodes on/off
|
||||||
|
local function start_network_power_consumption(pos, in_dir)
|
||||||
|
print("start_network_power_consumption")
|
||||||
|
local mem = tubelib2.get_mem(pos)
|
||||||
|
Route = {}
|
||||||
|
local sum = power_consumption(pos, in_dir)
|
||||||
|
Route = {}
|
||||||
|
turn_on(pos, in_dir, sum)
|
||||||
|
print("consumption = "..sum)
|
||||||
|
end
|
||||||
|
|
||||||
|
--
|
||||||
|
-- Generator functions for nodes with one power side (view from the outside)
|
||||||
|
--
|
||||||
|
techage.generator = {}
|
||||||
|
|
||||||
|
function techage.generator.after_place_node(pos)
|
||||||
local mem = tubelib2.init_mem(pos)
|
local mem = tubelib2.init_mem(pos)
|
||||||
mem.power_dir = side_to_dir(pos, TP(pos).power_side or 'R')
|
-- Power_dir is in-dir
|
||||||
mem.power_produce = 0 -- will be set via generator_on
|
mem.power_dir = tubelib2.Turn180Deg[side_to_dir(pos, TP(pos).power_side or 'R')]
|
||||||
mem.power_result = 0
|
mem.power_produce = 0
|
||||||
TP(pos).power_network:after_place_node(pos)
|
TP(pos).power_network:after_place_node(pos)
|
||||||
return mem
|
return mem
|
||||||
end
|
end
|
||||||
|
|
||||||
function techage.generator_after_tube_update(node, pos, out_dir, peer_pos, peer_in_dir)
|
function techage.generator.after_tube_update(node, pos, out_dir, peer_pos, peer_in_dir)
|
||||||
-- check if contact side is correct
|
-- check if contact side is correct
|
||||||
local mem = tubelib2.get_mem(pos)
|
local mem = tubelib2.get_mem(pos)
|
||||||
if out_dir == mem.power_dir then
|
if tubelib2.Turn180Deg[out_dir] == mem.power_dir then
|
||||||
if not peer_in_dir then
|
if not peer_in_dir then
|
||||||
mem.connections = {} -- del connection
|
mem.connections = {} -- del connection
|
||||||
else
|
else
|
||||||
-- Generator accept one dir only
|
-- Generator accept one dir only
|
||||||
mem.connections = {[out_dir] = {pos = peer_pos, in_dir = peer_in_dir}}
|
mem.connections = {[out_dir] = {pos = peer_pos, in_dir = peer_in_dir}}
|
||||||
end
|
end
|
||||||
minetest.after(0.2, check_power_consumption, pos)
|
-- To be called delayed, so that all network connections have been established
|
||||||
|
minetest.after(0.2, start_network_power_consumption, pos, mem.power_dir)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
function techage.generator_on_destruct(pos)
|
function techage.generator.turn_power_on(pos, power_capacity)
|
||||||
techage.generator_off(pos, tubelib2.get_mem(pos))
|
local mem = tubelib2.get_mem(pos)
|
||||||
|
mem.power_capacity = power_capacity
|
||||||
|
-- Starts the overall power consumption and depending on that turns all nodes on/off
|
||||||
|
start_network_power_consumption(pos, mem.power_dir)
|
||||||
end
|
end
|
||||||
|
|
||||||
function techage.generator_after_dig_node(pos, oldnode)
|
-- Power network callback function
|
||||||
|
function techage.generator.read_power_consumption(pos, in_dir)
|
||||||
|
local mem = tubelib2.get_mem(pos)
|
||||||
|
print("generator.read_power_consumption", in_dir, mem.power_dir, mem.power_capacity)
|
||||||
|
if in_dir == mem.power_dir then
|
||||||
|
return mem.power_capacity or 0
|
||||||
|
end
|
||||||
|
return 0
|
||||||
|
end
|
||||||
|
|
||||||
|
function techage.generator.after_dig_node(pos, oldnode)
|
||||||
TN(oldnode).power_network:after_dig_node(pos)
|
TN(oldnode).power_network:after_dig_node(pos)
|
||||||
tubelib2.del_mem(pos)
|
tubelib2.del_mem(pos)
|
||||||
end
|
end
|
||||||
|
|
||||||
function techage.generator_formspec_level(mem)
|
function techage.generator.formspec_level(mem)
|
||||||
print("generator_formspec_level", mem.power_result, mem.power_produce)
|
|
||||||
local percent = ((mem.power_result or 0) * 100) / (mem.power_produce or 1)
|
local percent = ((mem.power_result or 0) * 100) / (mem.power_produce or 1)
|
||||||
return "techage_form_level_bg.png^[lowpart:"..percent..":techage_form_level_fg.png]"
|
return "techage_form_level_bg.png^[lowpart:"..percent..":techage_form_level_fg.png]"
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
||||||
--
|
--
|
||||||
-- Distributor with 6 power input/output sides
|
-- Distributor functions for nodes with 6 power sides (view from the outside)
|
||||||
--
|
--
|
||||||
function techage.distributor_power_consumption(pos, dir)
|
techage.distributor = {}
|
||||||
return power_consumption(pos, dir) - TP(pos).power_consume
|
|
||||||
end
|
|
||||||
|
|
||||||
function techage.distributor_after_place_node(pos, placer)
|
function techage.distributor.after_place_node(pos, placer)
|
||||||
local mem = tubelib2.init_mem(pos)
|
local mem = tubelib2.init_mem(pos)
|
||||||
TP(pos).power_network:after_place_node(pos)
|
TP(pos).power_network:after_place_node(pos)
|
||||||
return mem
|
return mem
|
||||||
end
|
end
|
||||||
|
|
||||||
function techage.distributor_after_tube_update(node, pos, out_dir, peer_pos, peer_in_dir)
|
function techage.distributor.after_tube_update(node, pos, out_dir, peer_pos, peer_in_dir)
|
||||||
local mem = tubelib2.get_mem(pos)
|
local mem = tubelib2.get_mem(pos)
|
||||||
mem.connections = mem.connections or {}
|
mem.connections = mem.connections or {}
|
||||||
if not peer_in_dir then
|
if not peer_in_dir then
|
||||||
@ -224,37 +222,41 @@ function techage.distributor_after_tube_update(node, pos, out_dir, peer_pos, pee
|
|||||||
else
|
else
|
||||||
mem.connections[out_dir] = {pos = peer_pos, in_dir = peer_in_dir}
|
mem.connections[out_dir] = {pos = peer_pos, in_dir = peer_in_dir}
|
||||||
end
|
end
|
||||||
minetest.after(0.2, check_power_consumption, pos)
|
-- To be called delayed, so that all network connections have been established
|
||||||
|
minetest.after(0.2, start_network_power_consumption, pos)
|
||||||
end
|
end
|
||||||
|
|
||||||
function techage.distributor_after_dig_node(pos, oldnode)
|
--function techage.distributor.read_power_consumption(pos, in_dir)
|
||||||
|
-- return power_consumption(pos, in_dir) - TP(pos).power_consumption
|
||||||
|
--end
|
||||||
|
|
||||||
|
--function techage.distributor.turn_on(pos, in_dir, sum)
|
||||||
|
-- return turn_on(pos, in_dir, sum)
|
||||||
|
--end
|
||||||
|
|
||||||
|
function techage.distributor.after_dig_node(pos, oldnode)
|
||||||
TN(oldnode).power_network:after_dig_node(pos)
|
TN(oldnode).power_network:after_dig_node(pos)
|
||||||
tubelib2.del_mem(pos)
|
tubelib2.del_mem(pos)
|
||||||
end
|
end
|
||||||
|
|
||||||
--
|
--
|
||||||
-- Consumer Nodes
|
-- Consumer functions with variable number of power sides (view from the outside)
|
||||||
--
|
--
|
||||||
function techage.consumer_power_consumption(pos, dir)
|
techage.consumer = {}
|
||||||
local mem = tubelib2.get_mem(pos)
|
|
||||||
if not TP(pos).valid_power_dir(pos, mem, dir) then return 0 end
|
|
||||||
mem.power_consume = mem.power_consume or 0
|
|
||||||
return -mem.power_consume
|
|
||||||
end
|
|
||||||
|
|
||||||
function techage.consumer_after_place_node(pos, placer)
|
function techage.consumer.after_place_node(pos, placer)
|
||||||
local mem = tubelib2.init_mem(pos)
|
local mem = tubelib2.init_mem(pos)
|
||||||
if TP(pos).power_side then
|
-- Power_dir is in-dir
|
||||||
-- For the consumer, power_dir is in-dir
|
mem.power_dir = tubelib2.Turn180Deg[side_to_dir(pos, TP(pos).power_side or 'L')]
|
||||||
mem.power_dir = tubelib2.Turn180Deg[side_to_dir(pos, TP(pos).power_side)]
|
mem.power_consumption = 0
|
||||||
end
|
|
||||||
TP(pos).power_network:after_place_node(pos)
|
TP(pos).power_network:after_place_node(pos)
|
||||||
return mem
|
return mem
|
||||||
end
|
end
|
||||||
|
|
||||||
function techage.consumer_after_tube_update(node, pos, out_dir, peer_pos, peer_in_dir)
|
function techage.consumer.after_tube_update(node, pos, out_dir, peer_pos, peer_in_dir)
|
||||||
local mem = tubelib2.get_mem(pos)
|
local mem = tubelib2.get_mem(pos)
|
||||||
mem.connections = mem.connections or {}
|
mem.connections = mem.connections or {}
|
||||||
|
-- Check direction
|
||||||
if not TP(pos).valid_power_dir(pos, mem, tubelib2.Turn180Deg[out_dir]) then return end
|
if not TP(pos).valid_power_dir(pos, mem, tubelib2.Turn180Deg[out_dir]) then return end
|
||||||
-- Only one connection is allowed, which can be overwritten, if necessary.
|
-- Only one connection is allowed, which can be overwritten, if necessary.
|
||||||
if not peer_pos or not next(mem.connections) or mem.connections[out_dir] then
|
if not peer_pos or not next(mem.connections) or mem.connections[out_dir] then
|
||||||
@ -264,14 +266,26 @@ function techage.consumer_after_tube_update(node, pos, out_dir, peer_pos, peer_i
|
|||||||
mem.connections = {[out_dir] = {pos = peer_pos, in_dir = peer_in_dir}}
|
mem.connections = {[out_dir] = {pos = peer_pos, in_dir = peer_in_dir}}
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
minetest.after(0.2, check_power_consumption, pos)
|
-- To be called delayed, so that all network connections have been established
|
||||||
|
minetest.after(0.2, start_network_power_consumption, pos, mem.power_dir)
|
||||||
end
|
end
|
||||||
|
|
||||||
function techage.consumer_check_power_consumption(pos)
|
function techage.consumer.turn_power_on(pos, power_consumption)
|
||||||
minetest.after(0.2, check_power_consumption, pos)
|
local mem = tubelib2.get_mem(pos)
|
||||||
|
mem.power_consumption = power_consumption
|
||||||
|
-- Starts the overall power consumption and depending on that turns all nodes on/off
|
||||||
|
start_network_power_consumption(pos, mem.power_dir)
|
||||||
end
|
end
|
||||||
|
|
||||||
function techage.consumer_after_dig_node(pos, oldnode)
|
-- Power network callback function
|
||||||
|
function techage.consumer.read_power_consumption(pos, in_dir)
|
||||||
|
local mem = tubelib2.get_mem(pos)
|
||||||
|
-- Check direction
|
||||||
|
if not TP(pos).valid_power_dir(pos, mem, in_dir) then return 0 end
|
||||||
|
return -(mem.power_consumption or 0)
|
||||||
|
end
|
||||||
|
|
||||||
|
function techage.consumer.after_dig_node(pos, oldnode)
|
||||||
TN(oldnode).power_network:after_dig_node(pos)
|
TN(oldnode).power_network:after_dig_node(pos)
|
||||||
tubelib2.del_mem(pos)
|
tubelib2.del_mem(pos)
|
||||||
end
|
end
|
||||||
|
@ -28,7 +28,7 @@ local Cable = tubelib2.Tube:new({
|
|||||||
show_infotext = false,
|
show_infotext = false,
|
||||||
force_to_use_tubes = true,
|
force_to_use_tubes = true,
|
||||||
primary_node_names = {"techage:electric_cableS", "techage:electric_cableA"},
|
primary_node_names = {"techage:electric_cableS", "techage:electric_cableA"},
|
||||||
secondary_node_names = {"techage:lamp", "techage:lamp_on", "techage:power",
|
secondary_node_names = {"techage:lamp", "techage:lamp_on", "techage:power", "techage:generator",
|
||||||
"techage:ele_consumer", "techage:ele_consumer_on"},
|
"techage:ele_consumer", "techage:ele_consumer_on"},
|
||||||
after_place_tube = function(pos, param2, tube_type, num_tubes)
|
after_place_tube = function(pos, param2, tube_type, num_tubes)
|
||||||
minetest.swap_node(pos, {name = "techage:electric_cable"..tube_type, param2 = param2 % 32})
|
minetest.swap_node(pos, {name = "techage:electric_cable"..tube_type, param2 = param2 % 32})
|
||||||
@ -135,6 +135,7 @@ minetest.register_node("techage:electric_cableA", {
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
local distributor = techage.distributor
|
||||||
|
|
||||||
local size = 3/32
|
local size = 3/32
|
||||||
local Boxes = {
|
local Boxes = {
|
||||||
@ -152,20 +153,21 @@ techage.register_junction("techage:electric_junction", 2/8, Boxes, techage.Elect
|
|||||||
groups = {snappy = 2, choppy = 2, oddly_breakable_by_hand = 3, techage_trowel = 1},
|
groups = {snappy = 2, choppy = 2, oddly_breakable_by_hand = 3, techage_trowel = 1},
|
||||||
sounds = default.node_sound_defaults(),
|
sounds = default.node_sound_defaults(),
|
||||||
techage = {
|
techage = {
|
||||||
power_consumption = techage.distributor_power_consumption,
|
read_power_consumption = distributor.read_power_consumption,
|
||||||
|
turn_on = distributor.turn_on,
|
||||||
power_network = techage.ElectricCable,
|
power_network = techage.ElectricCable,
|
||||||
power_consume = 0,
|
power_consumption = 0,
|
||||||
},
|
},
|
||||||
description = "Electricity Junction Box",
|
description = "Electricity Junction Box",
|
||||||
tiles = {"techage_electric_junction.png"},
|
tiles = {"techage_electric_junction.png"},
|
||||||
groups = {snappy = 2, choppy = 2, oddly_breakable_by_hand = 3, techage_trowel = 1},
|
groups = {snappy = 2, choppy = 2, oddly_breakable_by_hand = 3, techage_trowel = 1},
|
||||||
sounds = default.node_sound_defaults(),
|
sounds = default.node_sound_defaults(),
|
||||||
|
|
||||||
after_place_node = techage.distributor_after_place_node,
|
after_place_node = distributor.after_place_node,
|
||||||
after_dig_node = techage.distributor_after_dig_node,
|
after_dig_node = distributor.after_dig_node,
|
||||||
|
|
||||||
after_tube_update = function(node, pos, out_dir, peer_pos, peer_in_dir)
|
after_tube_update = function(node, pos, out_dir, peer_pos, peer_in_dir)
|
||||||
techage.distributor_after_tube_update(node, pos, out_dir, peer_pos, peer_in_dir)
|
distributor.after_tube_update(node, pos, out_dir, peer_pos, peer_in_dir)
|
||||||
local mem = tubelib2.get_mem(pos)
|
local mem = tubelib2.get_mem(pos)
|
||||||
local name = "techage:electric_junction"..techage.junction_type(mem.connections)
|
local name = "techage:electric_junction"..techage.junction_type(mem.connections)
|
||||||
minetest.swap_node(pos, {name = name, param2 = 0})
|
minetest.swap_node(pos, {name = name, param2 = 0})
|
||||||
|
@ -24,7 +24,9 @@ local function formspec(self, pos, mem)
|
|||||||
end
|
end
|
||||||
|
|
||||||
local function can_start(pos, mem, state)
|
local function can_start(pos, mem, state)
|
||||||
|
print("can_start")
|
||||||
local sum = techage.calc_power_consumption(pos, mem, 8)
|
local sum = techage.calc_power_consumption(pos, mem, 8)
|
||||||
|
print("sum", sum)
|
||||||
if sum > 0 then
|
if sum > 0 then
|
||||||
M(pos):set_string("infotext", "On:"..sum.." / "..8)
|
M(pos):set_string("infotext", "On:"..sum.." / "..8)
|
||||||
return true
|
return true
|
||||||
@ -33,6 +35,7 @@ local function can_start(pos, mem, state)
|
|||||||
end
|
end
|
||||||
|
|
||||||
local function start_node(pos, mem, state)
|
local function start_node(pos, mem, state)
|
||||||
|
print("start_node")
|
||||||
techage.generator_on(pos, mem)
|
techage.generator_on(pos, mem)
|
||||||
end
|
end
|
||||||
|
|
||||||
@ -42,7 +45,7 @@ local function stop_node(pos, mem, state)
|
|||||||
end
|
end
|
||||||
|
|
||||||
local State = techage.NodeStates:new({
|
local State = techage.NodeStates:new({
|
||||||
node_name_passive = "techage:power",
|
node_name_passive = "techage:generator",
|
||||||
cycle_time = CYCLE_TIME,
|
cycle_time = CYCLE_TIME,
|
||||||
standby_ticks = STANDBY_TICKS,
|
standby_ticks = STANDBY_TICKS,
|
||||||
has_item_meter = true,
|
has_item_meter = true,
|
||||||
@ -65,7 +68,7 @@ local function distibuting(pos, mem)
|
|||||||
end
|
end
|
||||||
|
|
||||||
local function node_timer(pos, elapsed)
|
local function node_timer(pos, elapsed)
|
||||||
print("node_timer")
|
--print("node_timer")
|
||||||
local mem = tubelib2.get_mem(pos)
|
local mem = tubelib2.get_mem(pos)
|
||||||
distibuting(pos, mem)
|
distibuting(pos, mem)
|
||||||
return State:is_active(mem)
|
return State:is_active(mem)
|
||||||
@ -100,8 +103,8 @@ local function on_rightclick(pos)
|
|||||||
M(pos):set_string("formspec", formspec(State, pos, mem))
|
M(pos):set_string("formspec", formspec(State, pos, mem))
|
||||||
end
|
end
|
||||||
|
|
||||||
minetest.register_node("techage:power", {
|
minetest.register_node("techage:generator", {
|
||||||
description = "TechAge Power",
|
description = "TechAge Generator",
|
||||||
tiles = {
|
tiles = {
|
||||||
-- up, down, right, left, back, front
|
-- up, down, right, left, back, front
|
||||||
'techage_electric_button.png^techage_electric_power.png',
|
'techage_electric_button.png^techage_electric_power.png',
|
||||||
|
@ -3,10 +3,13 @@ local S = function(pos) if pos then return minetest.pos_to_string(pos) end end
|
|||||||
local P = minetest.string_to_pos
|
local P = minetest.string_to_pos
|
||||||
local M = minetest.get_meta
|
local M = minetest.get_meta
|
||||||
|
|
||||||
local POWER_CONSUME = 1
|
local POWER_CONSUMPTION = 2
|
||||||
|
local POWER_CAPACITY = 8
|
||||||
|
|
||||||
|
|
||||||
local Cable = techage.ElectricCable
|
local Cable = techage.ElectricCable
|
||||||
|
local consumer = techage.consumer
|
||||||
|
local generator = techage.generator
|
||||||
|
|
||||||
local function swap_node(pos, name)
|
local function swap_node(pos, name)
|
||||||
local node = minetest.get_node(pos)
|
local node = minetest.get_node(pos)
|
||||||
@ -17,20 +20,35 @@ local function swap_node(pos, name)
|
|||||||
minetest.swap_node(pos, node)
|
minetest.swap_node(pos, node)
|
||||||
end
|
end
|
||||||
|
|
||||||
-- To be able to check if power connection is on the
|
|
||||||
-- correct node side (mem.power_dir == in_dir)
|
|
||||||
local function valid_power_dir(pos, mem, in_dir)
|
local function valid_power_dir(pos, mem, in_dir)
|
||||||
--print("valid_power_dir", mem.power_dir, in_dir)
|
--print("valid_power_dir", mem.power_dir, in_dir)
|
||||||
return true
|
return true
|
||||||
end
|
end
|
||||||
|
|
||||||
local function lamp_turn_on(pos, in_dir, on)
|
local function lamp_turn_on_clbk(pos, in_dir, sum)
|
||||||
if on then
|
local mem = tubelib2.get_mem(pos)
|
||||||
|
if sum > 0 and mem.running then
|
||||||
swap_node(pos, "techage:lamp_on")
|
swap_node(pos, "techage:lamp_on")
|
||||||
else
|
else
|
||||||
swap_node(pos, "techage:lamp")
|
swap_node(pos, "techage:lamp")
|
||||||
end
|
end
|
||||||
-- end
|
end
|
||||||
|
|
||||||
|
local function lamp_on_rightclick(pos, node, clicker)
|
||||||
|
local mem = tubelib2.get_mem(pos)
|
||||||
|
if not mem.running then
|
||||||
|
swap_node(pos, "techage:lamp_on")
|
||||||
|
mem.running = true
|
||||||
|
M(pos):set_string("infotext", "On")
|
||||||
|
-- last command!!!
|
||||||
|
consumer.turn_power_on(pos, POWER_CONSUMPTION)
|
||||||
|
else
|
||||||
|
swap_node(pos, "techage:lamp")
|
||||||
|
mem.running = false
|
||||||
|
M(pos):set_string("infotext", "Off")
|
||||||
|
-- last command!!!
|
||||||
|
consumer.turn_power_on(pos, 0)
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
minetest.register_node("techage:lamp", {
|
minetest.register_node("techage:lamp", {
|
||||||
@ -45,21 +63,17 @@ minetest.register_node("techage:lamp", {
|
|||||||
'techage_electric_button.png',
|
'techage_electric_button.png',
|
||||||
},
|
},
|
||||||
techage = {
|
techage = {
|
||||||
turn_on = lamp_turn_on,
|
turn_on = lamp_turn_on_clbk,
|
||||||
power_consumption = techage.consumer_power_consumption,
|
read_power_consumption = consumer.read_power_consumption,
|
||||||
power_network = techage.ElectricCable,
|
power_network = Cable,
|
||||||
power_side = "L",
|
power_side = "L",
|
||||||
valid_power_dir = valid_power_dir,
|
valid_power_dir = valid_power_dir,
|
||||||
|
|
||||||
},
|
},
|
||||||
|
|
||||||
after_place_node = function(pos, placer)
|
after_place_node = consumer.after_place_node,
|
||||||
local mem = techage.consumer_after_place_node(pos, placer)
|
after_tube_update = consumer.after_tube_update,
|
||||||
mem.power_consume = POWER_CONSUME
|
after_dig_node = consumer.after_dig_node,
|
||||||
end,
|
on_rightclick = lamp_on_rightclick,
|
||||||
|
|
||||||
after_tube_update = techage.consumer_after_tube_update,
|
|
||||||
after_dig_node = techage.consumer_after_dig_node,
|
|
||||||
|
|
||||||
paramtype = "light",
|
paramtype = "light",
|
||||||
light_source = 0,
|
light_source = 0,
|
||||||
@ -76,16 +90,15 @@ minetest.register_node("techage:lamp_on", {
|
|||||||
'techage_electric_button.png',
|
'techage_electric_button.png',
|
||||||
},
|
},
|
||||||
techage = {
|
techage = {
|
||||||
turn_on = lamp_turn_on,
|
turn_on = lamp_turn_on_clbk,
|
||||||
power_consumption = techage.consumer_power_consumption,
|
read_power_consumption = consumer.read_power_consumption,
|
||||||
power_network = techage.ElectricCable,
|
power_network = Cable,
|
||||||
power_consume = POWER_CONSUME,
|
|
||||||
valid_power_dir = valid_power_dir,
|
valid_power_dir = valid_power_dir,
|
||||||
},
|
},
|
||||||
|
|
||||||
after_place_node = techage.consumer_after_place_node,
|
after_tube_update = consumer.after_tube_update,
|
||||||
after_tube_update = techage.consumer_after_tube_update,
|
after_dig_node = consumer.after_dig_node,
|
||||||
after_dig_node = techage.consumer_after_dig_node,
|
on_rightclick = lamp_on_rightclick,
|
||||||
|
|
||||||
paramtype = "light",
|
paramtype = "light",
|
||||||
light_source = LIGHT_MAX,
|
light_source = LIGHT_MAX,
|
||||||
@ -97,3 +110,54 @@ minetest.register_node("techage:lamp_on", {
|
|||||||
sounds = default.node_sound_wood_defaults(),
|
sounds = default.node_sound_wood_defaults(),
|
||||||
})
|
})
|
||||||
|
|
||||||
|
-------------------------------------------------------------------------------
|
||||||
|
-------------------------------------------------------------------------------
|
||||||
|
local function generator_turn_on_clbk(pos, in_dir, sum)
|
||||||
|
local mem = tubelib2.get_mem(pos)
|
||||||
|
if sum > 0 then
|
||||||
|
-- No automatic turn on
|
||||||
|
else
|
||||||
|
M(pos):set_string("infotext", "Err: "..sum.." / "..8)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
local function generator_on_rightclick(pos, node, clicker)
|
||||||
|
local mem = tubelib2.get_mem(pos)
|
||||||
|
if not mem.running then
|
||||||
|
generator.turn_power_on(pos, POWER_CAPACITY)
|
||||||
|
mem.running = true
|
||||||
|
M(pos):set_string("infotext", "On")
|
||||||
|
else
|
||||||
|
generator.turn_power_on(pos, 0)
|
||||||
|
mem.running = false
|
||||||
|
M(pos):set_string("infotext", "Off")
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
minetest.register_node("techage:power", {
|
||||||
|
description = "TechAge Power",
|
||||||
|
tiles = {
|
||||||
|
-- up, down, right, left, back, front
|
||||||
|
'techage_electric_button.png^techage_electric_power.png',
|
||||||
|
'techage_electric_button.png^techage_electric_power.png',
|
||||||
|
'techage_electric_button.png^techage_electric_power.png^techage_electric_plug.png',
|
||||||
|
'techage_electric_button.png^techage_electric_power.png',
|
||||||
|
'techage_electric_button.png^techage_electric_power.png',
|
||||||
|
'techage_electric_button.png^techage_electric_power.png',
|
||||||
|
},
|
||||||
|
paramtype2 = "facedir",
|
||||||
|
groups = {cracky=2, crumbly=2, choppy=2},
|
||||||
|
on_rotate = screwdriver.disallow,
|
||||||
|
is_ground_content = false,
|
||||||
|
|
||||||
|
techage = {
|
||||||
|
read_power_consumption = generator.read_power_consumption,
|
||||||
|
power_network = Cable,
|
||||||
|
},
|
||||||
|
|
||||||
|
after_place_node = generator.after_place_node,
|
||||||
|
after_tube_update = generator.after_tube_update,
|
||||||
|
after_dig_node = generator.after_dig_node,
|
||||||
|
on_rightclick = generator_on_rightclick,
|
||||||
|
})
|
||||||
|
|
||||||
|
24
init.lua
24
init.lua
@ -19,24 +19,24 @@ dofile(MP.."/basis/trowel.lua") -- hidden networks
|
|||||||
dofile(MP.."/basis/junction.lua") -- network junction box
|
dofile(MP.."/basis/junction.lua") -- network junction box
|
||||||
|
|
||||||
-- Steam Engine
|
-- Steam Engine
|
||||||
dofile(MP.."/steam_engine/drive_axle.lua")
|
--dofile(MP.."/steam_engine/drive_axle.lua")
|
||||||
dofile(MP.."/steam_engine/steam_pipe.lua")
|
--dofile(MP.."/steam_engine/steam_pipe.lua")
|
||||||
dofile(MP.."/steam_engine/firebox.lua")
|
--dofile(MP.."/steam_engine/firebox.lua")
|
||||||
dofile(MP.."/steam_engine/boiler.lua")
|
--dofile(MP.."/steam_engine/boiler.lua")
|
||||||
dofile(MP.."/steam_engine/cylinder.lua")
|
--dofile(MP.."/steam_engine/cylinder.lua")
|
||||||
--dofile(MP.."/steam_engine/flywheel.lua")
|
--dofile(MP.."/steam_engine/flywheel.lua")
|
||||||
dofile(MP.."/steam_engine/gearbox.lua")
|
--dofile(MP.."/steam_engine/gearbox.lua")
|
||||||
dofile(MP.."/steam_engine/consumer.lua")
|
--dofile(MP.."/steam_engine/consumer.lua")
|
||||||
|
|
||||||
dofile(MP.."/electric/electric_cable.lua")
|
dofile(MP.."/electric/electric_cable.lua")
|
||||||
dofile(MP.."/electric/test.lua")
|
dofile(MP.."/electric/test.lua")
|
||||||
dofile(MP.."/electric/generator.lua")
|
--dofile(MP.."/electric/generator.lua")
|
||||||
dofile(MP.."/electric/consumer.lua")
|
--dofile(MP.."/electric/consumer.lua")
|
||||||
|
|
||||||
|
|
||||||
--dofile(MP.."/fermenter/biogas_pipe.lua")
|
--dofile(MP.."/fermenter/biogas_pipe.lua")
|
||||||
dofile(MP.."/fermenter/gasflare.lua")
|
--dofile(MP.."/fermenter/gasflare.lua")
|
||||||
|
|
||||||
|
|
||||||
dofile(MP.."/nodes/test.lua")
|
--dofile(MP.."/nodes/test.lua")
|
||||||
dofile(MP.."/mechanic/perf_test.lua")
|
--dofile(MP.."/mechanic/perf_test.lua")
|
||||||
|
@ -116,10 +116,9 @@ local function water_temperature(pos, mem)
|
|||||||
end
|
end
|
||||||
|
|
||||||
local function steaming(pos, mem, temp)
|
local function steaming(pos, mem, temp)
|
||||||
print("steaming")
|
|
||||||
mem.water_level = math.max((mem.water_level or 0) - WATER_CONSUMPTION, 0)
|
mem.water_level = math.max((mem.water_level or 0) - WATER_CONSUMPTION, 0)
|
||||||
if temp >= 80 then
|
if temp >= 80 then
|
||||||
local sum = techage.calc_power_consumption(pos, mem, 8)
|
local sum = techage.calc_power_consumption(pos, mem, POWER)
|
||||||
if sum > 0 then
|
if sum > 0 then
|
||||||
State:keep_running(pos, mem, COUNTDOWN_TICKS)
|
State:keep_running(pos, mem, COUNTDOWN_TICKS)
|
||||||
else
|
else
|
||||||
@ -134,7 +133,6 @@ end
|
|||||||
local function node_timer(pos, elapsed)
|
local function node_timer(pos, elapsed)
|
||||||
local mem = tubelib2.get_mem(pos)
|
local mem = tubelib2.get_mem(pos)
|
||||||
local temp = water_temperature(pos, mem)
|
local temp = water_temperature(pos, mem)
|
||||||
print("node_timer", temp)
|
|
||||||
if State:is_active(mem) then
|
if State:is_active(mem) then
|
||||||
steaming(pos, mem, temp)
|
steaming(pos, mem, temp)
|
||||||
end
|
end
|
||||||
@ -153,6 +151,17 @@ local function on_receive_fields(pos, formname, fields, player)
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
local function valid_power_dir(pos, mem, in_dir)
|
||||||
|
return mem.power_dir == in_dir
|
||||||
|
end
|
||||||
|
|
||||||
|
local function turn_power_on(pos, in_dir, on)
|
||||||
|
local mem = tubelib2.get_mem(pos)
|
||||||
|
if State:is_active(mem) and not on then
|
||||||
|
State:fault(pos, mem)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
local function on_rightclick(pos)
|
local function on_rightclick(pos)
|
||||||
local mem = tubelib2.get_mem(pos)
|
local mem = tubelib2.get_mem(pos)
|
||||||
M(pos):set_string("formspec", formspec(State, pos, mem))
|
M(pos):set_string("formspec", formspec(State, pos, mem))
|
||||||
@ -258,6 +267,8 @@ minetest.register_node("techage:boiler2", {
|
|||||||
end
|
end
|
||||||
end,
|
end,
|
||||||
power_side = "U",
|
power_side = "U",
|
||||||
|
valid_power_dir = valid_power_dir,
|
||||||
|
turn_on = turn_power_on,
|
||||||
},
|
},
|
||||||
|
|
||||||
on_construct = function(pos)
|
on_construct = function(pos)
|
||||||
@ -283,12 +294,6 @@ minetest.register_node("techage:boiler2", {
|
|||||||
after_tube_update = techage.generator_after_tube_update,
|
after_tube_update = techage.generator_after_tube_update,
|
||||||
on_destruct = techage.generator_on_destruct,
|
on_destruct = techage.generator_on_destruct,
|
||||||
|
|
||||||
|
|
||||||
after_dig_node = function(pos, oldnode, oldmetadata, digger)
|
|
||||||
State:after_dig_node(pos, oldnode, oldmetadata, digger)
|
|
||||||
techage.generator_after_dig_node(pos, oldnode)
|
|
||||||
end,
|
|
||||||
|
|
||||||
on_metadata_inventory_put = function(pos)
|
on_metadata_inventory_put = function(pos)
|
||||||
minetest.after(0.5, move_to_water, pos)
|
minetest.after(0.5, move_to_water, pos)
|
||||||
end,
|
end,
|
||||||
|
@ -34,30 +34,33 @@ local function swap_node(pos, name)
|
|||||||
minetest.swap_node(pos, node)
|
minetest.swap_node(pos, node)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
-- called from pipe network
|
||||||
local function valid_power_dir(pos, mem, in_dir)
|
local function valid_power_dir(pos, mem, in_dir)
|
||||||
return mem.power_dir == in_dir
|
return mem.power_dir == in_dir
|
||||||
end
|
end
|
||||||
|
|
||||||
local function turn_on(pos, in_dir, on)
|
-- called from pipe network
|
||||||
local npos = techage.next_pos(pos, "R")
|
local function turn_power_on(pos, in_dir, on)
|
||||||
print("turn_on", S(pos), S(npos), on)
|
print("turn_power_on", in_dir, on)
|
||||||
local this = TP(npos)
|
local mem = tubelib2.get_mem(pos)
|
||||||
if this and this.try_to_start then
|
mem.power_supply = on
|
||||||
on = this.try_to_start(npos, on)
|
|
||||||
end
|
|
||||||
if on then
|
|
||||||
swap_node(pos, "techage:cylinder_on")
|
|
||||||
else
|
|
||||||
swap_node(pos, "techage:cylinder")
|
|
||||||
end
|
|
||||||
end
|
end
|
||||||
|
|
||||||
local function node_timer(pos, elapsed)
|
-- called from flywheel
|
||||||
|
local function start_cylinder(pos, on)
|
||||||
local mem = tubelib2.get_mem(pos)
|
local mem = tubelib2.get_mem(pos)
|
||||||
local inv = M(pos):get_inventory()
|
if on and mem.power_supply then
|
||||||
local fuellist = inv:get_list("fuel")
|
mem.power_consume = POWER_CONSUME
|
||||||
|
swap_node(pos, "techage:cylinder_on")
|
||||||
|
return true
|
||||||
|
else
|
||||||
|
mem.power_consume = 0
|
||||||
|
swap_node(pos, "techage:cylinder")
|
||||||
|
end
|
||||||
|
return false
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
||||||
minetest.register_node("techage:cylinder", {
|
minetest.register_node("techage:cylinder", {
|
||||||
description = I("TA2 Cylinder"),
|
description = I("TA2 Cylinder"),
|
||||||
tiles = {
|
tiles = {
|
||||||
@ -70,15 +73,20 @@ minetest.register_node("techage:cylinder", {
|
|||||||
"techage_filling_ta2.png^techage_cylinder.png^techage_frame_ta2.png",
|
"techage_filling_ta2.png^techage_cylinder.png^techage_frame_ta2.png",
|
||||||
},
|
},
|
||||||
techage = {
|
techage = {
|
||||||
turn_on = turn_on,
|
turn_on = turn_power_on,
|
||||||
power_consumption = techage.consumer_power_consumption,
|
power_consumption = techage.consumer_power_consumption,
|
||||||
power_network = techage.SteamPipe,
|
power_network = techage.SteamPipe,
|
||||||
power_consume = POWER_CONSUME,
|
|
||||||
power_side = 'L',
|
power_side = 'L',
|
||||||
valid_power_dir = valid_power_dir,
|
valid_power_dir = valid_power_dir,
|
||||||
|
start_cylinder = start_cylinder,
|
||||||
},
|
},
|
||||||
|
|
||||||
after_place_node = techage.consumer_after_place_node,
|
after_place_node = function(pos, placer)
|
||||||
|
local mem = techage.consumer_after_place_node(pos, placer)
|
||||||
|
mem.power_consume = 0 -- needed power to run
|
||||||
|
mem.power_supply = false -- power available?
|
||||||
|
end,
|
||||||
|
|
||||||
after_tube_update = techage.consumer_after_tube_update,
|
after_tube_update = techage.consumer_after_tube_update,
|
||||||
after_dig_node = techage.consumer_after_dig_node,
|
after_dig_node = techage.consumer_after_dig_node,
|
||||||
|
|
||||||
@ -119,15 +127,14 @@ minetest.register_node("techage:cylinder_on", {
|
|||||||
},
|
},
|
||||||
},
|
},
|
||||||
techage = {
|
techage = {
|
||||||
turn_on = turn_on,
|
turn_on = turn_power_on,
|
||||||
power_consumption = techage.consumer_power_consumption,
|
power_consumption = techage.consumer_power_consumption,
|
||||||
power_network = techage.SteamPipe,
|
power_network = techage.SteamPipe,
|
||||||
power_consume = POWER_CONSUME,
|
|
||||||
power_side = 'L',
|
power_side = 'L',
|
||||||
valid_power_dir = valid_power_dir,
|
valid_power_dir = valid_power_dir,
|
||||||
|
start_cylinder = start_cylinder,
|
||||||
},
|
},
|
||||||
|
|
||||||
after_place_node = techage.consumer_after_place_node,
|
|
||||||
after_tube_update = techage.consumer_after_tube_update,
|
after_tube_update = techage.consumer_after_tube_update,
|
||||||
after_dig_node = techage.consumer_after_dig_node,
|
after_dig_node = techage.consumer_after_dig_node,
|
||||||
|
|
||||||
|
@ -16,90 +16,115 @@
|
|||||||
local S = function(pos) if pos then return minetest.pos_to_string(pos) end end
|
local S = function(pos) if pos then return minetest.pos_to_string(pos) end end
|
||||||
local P = minetest.string_to_pos
|
local P = minetest.string_to_pos
|
||||||
local M = minetest.get_meta
|
local M = minetest.get_meta
|
||||||
|
local TP = function(pos) return (minetest.registered_nodes[minetest.get_node(pos).name] or {}).techage end
|
||||||
|
local TN = function(name) return (minetest.registered_nodes[name] or {}).techage end
|
||||||
|
|
||||||
-- Load support for intllib.
|
-- Load support for intllib.
|
||||||
local MP = minetest.get_modpath("tubelib2")
|
local MP = minetest.get_modpath("tubelib2")
|
||||||
local I,_ = dofile(MP.."/intllib.lua")
|
local I,_ = dofile(MP.."/intllib.lua")
|
||||||
|
|
||||||
|
local STANDBY_TICKS = 4
|
||||||
|
local COUNTDOWN_TICKS = 4
|
||||||
local CYCLE_TIME = 8
|
local CYCLE_TIME = 8
|
||||||
local POWER = 8
|
local POWER = 8
|
||||||
|
|
||||||
local function swap_node(pos, name)
|
local function formspec(self, pos, mem)
|
||||||
local node = minetest.get_node(pos)
|
|
||||||
if node.name == name then
|
|
||||||
return
|
|
||||||
end
|
|
||||||
node.name = name
|
|
||||||
minetest.swap_node(pos, node)
|
|
||||||
end
|
|
||||||
|
|
||||||
--local function turn_on(pos, dir, on)
|
|
||||||
-- print("jou")
|
|
||||||
-- if on then
|
|
||||||
-- swap_node(pos, "techage:flywheel_on")
|
|
||||||
-- if not minetest.get_node_timer(pos):is_started() then
|
|
||||||
-- minetest.get_node_timer(pos):start(CYCLE_TIME)
|
|
||||||
-- end
|
|
||||||
-- else
|
|
||||||
-- swap_node(pos, "techage:flywheel")
|
|
||||||
-- if minetest.get_node_timer(pos):is_started() then
|
|
||||||
-- minetest.get_node_timer(pos):stop()
|
|
||||||
-- end
|
|
||||||
-- end
|
|
||||||
--end
|
|
||||||
|
|
||||||
local function try_to_start(pos, on)
|
|
||||||
print("try_to_start", S(pos))
|
|
||||||
if on then
|
|
||||||
if techage.generator_on(pos, POWER) then
|
|
||||||
swap_node(pos, "techage:flywheel_on")
|
|
||||||
if not minetest.get_node_timer(pos):is_started() then
|
|
||||||
minetest.get_node_timer(pos):start(CYCLE_TIME)
|
|
||||||
end
|
|
||||||
return true
|
|
||||||
end
|
|
||||||
else
|
|
||||||
techage.generator_off(pos)
|
|
||||||
end
|
|
||||||
swap_node(pos, "techage:flywheel")
|
|
||||||
if minetest.get_node_timer(pos):is_started() then
|
|
||||||
minetest.get_node_timer(pos):stop()
|
|
||||||
end
|
|
||||||
return false
|
|
||||||
end
|
|
||||||
|
|
||||||
local function formspec(mem)
|
|
||||||
return "size[8,7]"..
|
return "size[8,7]"..
|
||||||
default.gui_bg..
|
default.gui_bg..
|
||||||
default.gui_bg_img..
|
default.gui_bg_img..
|
||||||
default.gui_slots..
|
default.gui_slots..
|
||||||
"image[3,0.5;1,2;"..techage.generator_formspec_level(mem)..
|
"image[6,0.5;1,2;"..techage.generator_formspec_level(mem)..
|
||||||
"button[5.5,1.2;1.8,1;update;"..I("Update").."]"..
|
"image_button[5,1;1,1;".. self:get_state_button_image(mem) ..";state_button;]"..
|
||||||
|
"button[2,1.5;2,1;update;"..I("Update").."]"..
|
||||||
"list[current_player;main;0,3;8,4;]"..
|
"list[current_player;main;0,3;8,4;]"..
|
||||||
"listring[current_name;water]"..
|
|
||||||
"listring[current_player;main]"..
|
|
||||||
default.get_hotbar_bg(0, 3)
|
default.get_hotbar_bg(0, 3)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
local function can_start(pos, mem, state)
|
||||||
|
local pos2 = techage.get_pos(pos, 'L')
|
||||||
|
if minetest.get_node(pos2).name == "techage:cylinder" and tubelib2.get_mem(pos2).power_supply then
|
||||||
|
local sum = techage.calc_power_consumption(pos, mem, POWER)
|
||||||
|
return sum > 0
|
||||||
|
end
|
||||||
|
return false
|
||||||
|
end
|
||||||
|
|
||||||
|
local function start_node(pos, mem, state)
|
||||||
|
local pos2 = techage.get_pos(pos, 'L')
|
||||||
|
local that = TP(pos2)
|
||||||
|
if that and that.start_cylinder then
|
||||||
|
that.start_cylinder(pos2, true)
|
||||||
|
techage.generator_on(pos, mem)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
local function stop_node(pos, mem, state)
|
||||||
|
techage.generator_off(pos, mem)
|
||||||
|
local pos2 = techage.get_pos(pos, 'L')
|
||||||
|
local that = TP(pos2)
|
||||||
|
if that and that.start_cylinder then
|
||||||
|
that.start_cylinder(pos2, false)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
local State = techage.NodeStates:new({
|
||||||
|
node_name_passive = "techage:flywheel",
|
||||||
|
node_name_active = "techage:flywheel_on",
|
||||||
|
cycle_time = CYCLE_TIME,
|
||||||
|
standby_ticks = STANDBY_TICKS,
|
||||||
|
formspec_func = formspec,
|
||||||
|
can_start = can_start,
|
||||||
|
start_node = start_node,
|
||||||
|
stop_node = stop_node,
|
||||||
|
})
|
||||||
|
|
||||||
|
local function distibuting(pos, mem)
|
||||||
|
local sum = techage.calc_power_consumption(pos, mem, 8)
|
||||||
|
if sum > 0 then
|
||||||
|
State:keep_running(pos, mem, COUNTDOWN_TICKS)
|
||||||
|
else
|
||||||
|
State:fault(pos, mem)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
local function node_timer(pos, elapsed)
|
||||||
|
local mem = tubelib2.get_mem(pos)
|
||||||
|
print("flywheel node_timer")
|
||||||
|
local pos2 = techage.get_pos(pos, 'L')
|
||||||
|
if minetest.get_node(pos2).name == "techage:cylinder_on" and tubelib2.get_mem(pos2).power_supply then
|
||||||
|
distibuting(pos, mem)
|
||||||
|
else
|
||||||
|
State:fault(pos, mem)
|
||||||
|
end
|
||||||
|
return State:is_active(mem)
|
||||||
|
end
|
||||||
|
|
||||||
|
local function valid_power_dir(pos, mem, in_dir)
|
||||||
|
return mem.power_dir == in_dir
|
||||||
|
end
|
||||||
|
|
||||||
|
local function turn_power_on(pos, in_dir, on)
|
||||||
|
local mem = tubelib2.get_mem(pos)
|
||||||
|
if State:is_active(mem) and not on then
|
||||||
|
State:fault(pos, mem)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
local function on_receive_fields(pos, formname, fields, player)
|
local function on_receive_fields(pos, formname, fields, player)
|
||||||
if minetest.is_protected(pos, player:get_player_name()) then
|
if minetest.is_protected(pos, player:get_player_name()) then
|
||||||
return
|
return
|
||||||
end
|
end
|
||||||
|
local mem = tubelib2.get_mem(pos)
|
||||||
|
State:state_button_event(pos, mem, fields)
|
||||||
|
|
||||||
if fields.update then
|
if fields.update then
|
||||||
local mem = tubelib2.get_mem(pos)
|
M(pos):set_string("formspec", formspec(State, pos, mem))
|
||||||
M(pos):set_string("formspec", formspec(mem))
|
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
local function on_rightclick(pos)
|
local function on_rightclick(pos)
|
||||||
local mem = tubelib2.get_mem(pos)
|
local mem = tubelib2.get_mem(pos)
|
||||||
M(pos):set_string("formspec", formspec(mem))
|
M(pos):set_string("formspec", formspec(State, pos, mem))
|
||||||
end
|
|
||||||
|
|
||||||
|
|
||||||
local function node_timer(pos, elapsed)
|
|
||||||
return try_to_start(pos, true)
|
|
||||||
end
|
end
|
||||||
|
|
||||||
minetest.register_node("techage:flywheel", {
|
minetest.register_node("techage:flywheel", {
|
||||||
@ -118,18 +143,23 @@ minetest.register_node("techage:flywheel", {
|
|||||||
power_consumption = techage.generator_power_consumption,
|
power_consumption = techage.generator_power_consumption,
|
||||||
power_consume = 0,
|
power_consume = 0,
|
||||||
animated_power_network = true,
|
animated_power_network = true,
|
||||||
--turn_on = turn_on,
|
valid_power_dir = valid_power_dir,
|
||||||
try_to_start = try_to_start,
|
turn_on = turn_power_on,
|
||||||
},
|
},
|
||||||
|
|
||||||
on_construct = function(pos)
|
after_place_node = function(pos, placer)
|
||||||
|
local mem = techage.generator_after_place_node(pos)
|
||||||
|
State:node_init(pos, mem, "")
|
||||||
on_rightclick(pos)
|
on_rightclick(pos)
|
||||||
end,
|
end,
|
||||||
|
|
||||||
after_place_node = techage.generator_after_place_node,
|
after_dig_node = function(pos, oldnode, oldmetadata, digger)
|
||||||
|
State:after_dig_node(pos, oldnode, oldmetadata, digger)
|
||||||
|
techage.generator_after_dig_node(pos, oldnode)
|
||||||
|
end,
|
||||||
|
|
||||||
after_tube_update = techage.generator_after_tube_update,
|
after_tube_update = techage.generator_after_tube_update,
|
||||||
on_destruct = techage.generator_on_destruct,
|
on_destruct = techage.generator_on_destruct,
|
||||||
after_dig_node = techage.generator_after_dig_node,
|
|
||||||
|
|
||||||
on_timer = node_timer,
|
on_timer = node_timer,
|
||||||
on_receive_fields = on_receive_fields,
|
on_receive_fields = on_receive_fields,
|
||||||
@ -185,23 +215,19 @@ minetest.register_node("techage:flywheel_on", {
|
|||||||
power_consumption = techage.generator_power_consumption,
|
power_consumption = techage.generator_power_consumption,
|
||||||
power_consume = 0,
|
power_consume = 0,
|
||||||
animated_power_network = true,
|
animated_power_network = true,
|
||||||
--turn_on = turn_on,
|
valid_power_dir = valid_power_dir,
|
||||||
try_to_start = try_to_start,
|
turn_on = turn_power_on,
|
||||||
},
|
},
|
||||||
|
|
||||||
after_place_node = techage.generator_after_place_node,
|
|
||||||
after_tube_update = techage.generator_after_tube_update,
|
after_tube_update = techage.generator_after_tube_update,
|
||||||
on_destruct = techage.generator_on_destruct,
|
|
||||||
after_dig_node = techage.generator_after_dig_node,
|
|
||||||
|
|
||||||
on_timer = node_timer,
|
on_timer = node_timer,
|
||||||
on_receive_fields = on_receive_fields,
|
on_receive_fields = on_receive_fields,
|
||||||
on_rightclick = on_rightclick,
|
on_rightclick = on_rightclick,
|
||||||
|
|
||||||
paramtype2 = "facedir",
|
paramtype2 = "facedir",
|
||||||
groups = {cracky=2, crumbly=2, choppy=2, not_in_creative_inventory=1},
|
groups = {not_in_creative_inventory=1},
|
||||||
--diggable = false,
|
diggable = false,
|
||||||
--drop = "techage:flywheel",
|
|
||||||
on_rotate = screwdriver.disallow,
|
on_rotate = screwdriver.disallow,
|
||||||
is_ground_content = false,
|
is_ground_content = false,
|
||||||
sounds = default.node_sound_wood_defaults(),
|
sounds = default.node_sound_wood_defaults(),
|
||||||
|
Loading…
Reference in New Issue
Block a user