battery added
This commit is contained in:
parent
68e21afc15
commit
18f791956b
@ -89,7 +89,6 @@ end
|
|||||||
|
|
||||||
local function determine_water_dir(pos)
|
local function determine_water_dir(pos)
|
||||||
local lvl = get_water_level(pos)
|
local lvl = get_water_level(pos)
|
||||||
print(lvl)
|
|
||||||
if lvl > get_water_level({x=pos.x+1, y=pos.y, z=pos.z}) then
|
if lvl > get_water_level({x=pos.x+1, y=pos.y, z=pos.z}) then
|
||||||
return 2
|
return 2
|
||||||
end
|
end
|
||||||
|
@ -108,7 +108,6 @@ local function on_receive_fields(pos, formname, fields, player)
|
|||||||
state:state_button_event(pos, mem, fields)
|
state:state_button_event(pos, mem, fields)
|
||||||
|
|
||||||
if fields.update then
|
if fields.update then
|
||||||
local state = tStates[mem.state_num or 2]
|
|
||||||
M(pos):set_string("formspec", formspec(state, pos, mem))
|
M(pos):set_string("formspec", formspec(state, pos, mem))
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
@ -174,7 +174,7 @@ techage.generator = {}
|
|||||||
|
|
||||||
function techage.generator.after_place_node(pos)
|
function techage.generator.after_place_node(pos)
|
||||||
local mem = tubelib2.init_mem(pos)
|
local mem = tubelib2.init_mem(pos)
|
||||||
mem.power_produce = 0
|
mem.power_capacity = 0
|
||||||
TRD(pos).power_network:after_place_node(pos)
|
TRD(pos).power_network:after_place_node(pos)
|
||||||
return mem
|
return mem
|
||||||
end
|
end
|
||||||
@ -218,10 +218,25 @@ function techage.generator.after_dig_node(pos, oldnode)
|
|||||||
end
|
end
|
||||||
|
|
||||||
function techage.generator.formspec_level(mem, sum)
|
function techage.generator.formspec_level(mem, sum)
|
||||||
local percent = ((sum or 0) * 100) / (mem.power_capacity or 1)
|
local percent = math.min(((sum or 0) * 100) / (mem.power_capacity or 1), 100)
|
||||||
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
|
||||||
|
|
||||||
|
function techage.generator.formspec_battery_capa(max_capa, current_capa)
|
||||||
|
local percent = math.min(((current_capa or 0) * 100) / (max_capa or 1), 100)
|
||||||
|
return "techage_form_level_bg.png^[lowpart:"..percent..":techage_form_level_fg.png]"
|
||||||
|
end
|
||||||
|
function techage.generator.formspec_battery_load(mem)
|
||||||
|
if mem.power_capacity ~= 0 then
|
||||||
|
if mem.charging then
|
||||||
|
return "techage_form_level_charge.png]"
|
||||||
|
elseif mem.unloading then
|
||||||
|
return "techage_form_level_unload.png]"
|
||||||
|
end
|
||||||
|
end
|
||||||
|
return "techage_form_level_off.png]"
|
||||||
|
end
|
||||||
|
|
||||||
|
|
||||||
--
|
--
|
||||||
-- Distributor functions for nodes with 6 power sides (view from the outside)
|
-- Distributor functions for nodes with 6 power sides (view from the outside)
|
||||||
|
199
coal_power_station/battery.lua
Normal file
199
coal_power_station/battery.lua
Normal file
@ -0,0 +1,199 @@
|
|||||||
|
--[[
|
||||||
|
|
||||||
|
TechAge
|
||||||
|
=======
|
||||||
|
|
||||||
|
Copyright (C) 2019 Joachim Stolberg
|
||||||
|
|
||||||
|
LGPLv2.1+
|
||||||
|
See LICENSE.txt for more information
|
||||||
|
|
||||||
|
TA3 Battery Box
|
||||||
|
|
||||||
|
]]--
|
||||||
|
|
||||||
|
-- for lazy programmers
|
||||||
|
local S = function(pos) if pos then return minetest.pos_to_string(pos) end end
|
||||||
|
local P = minetest.string_to_pos
|
||||||
|
local M = minetest.get_meta
|
||||||
|
|
||||||
|
-- Load support for intllib.
|
||||||
|
local MP = minetest.get_modpath("techage")
|
||||||
|
local I,_ = dofile(MP.."/intllib.lua")
|
||||||
|
|
||||||
|
local STANDBY_TICKS = 4
|
||||||
|
local COUNTDOWN_TICKS = 4
|
||||||
|
local CYCLE_TIME = 2
|
||||||
|
local POWER_CONSUMPTION = 10
|
||||||
|
local POWER_MAX_LOAD = 1000
|
||||||
|
|
||||||
|
local Power = techage.ElectricCable
|
||||||
|
local generator = techage.generator
|
||||||
|
|
||||||
|
-- called from pipe network
|
||||||
|
local function valid_power_dir(pos, power_dir, in_dir)
|
||||||
|
return power_dir == in_dir
|
||||||
|
end
|
||||||
|
|
||||||
|
local function formspec(self, pos, mem)
|
||||||
|
return "size[5,3]"..
|
||||||
|
default.gui_bg..
|
||||||
|
default.gui_bg_img..
|
||||||
|
default.gui_slots..
|
||||||
|
"image[0,0.5;1,2;"..generator.formspec_battery_capa(POWER_MAX_LOAD, mem.capa)..
|
||||||
|
"label[0.2,2.5;Load]"..
|
||||||
|
"button[1.1,1;1.8,1;update;"..I("Update").."]"..
|
||||||
|
"image_button[3,1;1,1;".. self:get_state_button_image(mem) ..";state_button;]"..
|
||||||
|
"image[4,0.5;1,2;"..generator.formspec_battery_load(mem)..
|
||||||
|
"label[4.2,2.5;Flow]"
|
||||||
|
end
|
||||||
|
|
||||||
|
local function turn_off(pos, mem)
|
||||||
|
generator.turn_power_on(pos, 0)
|
||||||
|
mem.charging = false
|
||||||
|
mem.unloading = false
|
||||||
|
end
|
||||||
|
|
||||||
|
local function switch_to_unloading(pos, mem)
|
||||||
|
if not mem.unloading then
|
||||||
|
mem.unloading = true
|
||||||
|
mem.charging = false
|
||||||
|
generator.turn_power_on(pos, 2 * POWER_CONSUMPTION)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
local function switch_to_charging(pos, mem)
|
||||||
|
if mem.sum > POWER_CONSUMPTION and not mem.charging then
|
||||||
|
mem.charging = true
|
||||||
|
mem.unloading = false
|
||||||
|
generator.turn_power_on(pos, -POWER_CONSUMPTION)
|
||||||
|
end
|
||||||
|
mem.delayed_call = false
|
||||||
|
end
|
||||||
|
|
||||||
|
local function start_node(pos, mem, state)
|
||||||
|
turn_off(pos, mem)
|
||||||
|
end
|
||||||
|
|
||||||
|
local function stop_node(pos, mem, state)
|
||||||
|
turn_off(pos, mem)
|
||||||
|
end
|
||||||
|
|
||||||
|
local State = techage.NodeStates:new({
|
||||||
|
node_name_passive = "techage:ta3_battery",
|
||||||
|
cycle_time = CYCLE_TIME,
|
||||||
|
standby_ticks = STANDBY_TICKS,
|
||||||
|
formspec_func = formspec,
|
||||||
|
start_node = start_node,
|
||||||
|
stop_node = stop_node,
|
||||||
|
})
|
||||||
|
|
||||||
|
local function node_timer(pos, elapsed)
|
||||||
|
local mem = tubelib2.get_mem(pos)
|
||||||
|
if State:is_active(mem) then
|
||||||
|
mem.capa = mem.capa or 0
|
||||||
|
if mem.charging then
|
||||||
|
if mem.capa < POWER_MAX_LOAD then
|
||||||
|
mem.capa = mem.capa + 1
|
||||||
|
else
|
||||||
|
turn_off(pos, mem)
|
||||||
|
end
|
||||||
|
elseif mem.unloading then
|
||||||
|
if mem.capa > 0 then
|
||||||
|
mem.capa = mem.capa - 1
|
||||||
|
else
|
||||||
|
turn_off(pos, mem)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
--print("node_timer", S(pos), mem.sum, mem.power_capacity)
|
||||||
|
return State:is_active(mem)
|
||||||
|
end
|
||||||
|
|
||||||
|
local function turn_power_on(pos, in_dir, sum)
|
||||||
|
local mem = tubelib2.get_mem(pos)
|
||||||
|
if State:is_active(mem) then
|
||||||
|
mem.capa = mem.capa or 0
|
||||||
|
mem.sum = sum
|
||||||
|
--print("turn_power_on", sum, dump(mem))
|
||||||
|
if mem.unloading then
|
||||||
|
if sum < 0 then
|
||||||
|
turn_off(pos, mem)
|
||||||
|
elseif sum > 2 * POWER_CONSUMPTION then
|
||||||
|
turn_off(pos, mem)
|
||||||
|
end
|
||||||
|
elseif mem.charging then
|
||||||
|
if sum < 0 then
|
||||||
|
turn_off(pos, mem)
|
||||||
|
end
|
||||||
|
else -- turned off
|
||||||
|
if sum > POWER_CONSUMPTION and not mem.delayed_call then
|
||||||
|
minetest.after(math.random(1.2, 5.0),
|
||||||
|
switch_to_charging, pos, mem)
|
||||||
|
mem.delayed_call = true
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
local function on_receive_fields(pos, formname, fields, player)
|
||||||
|
if minetest.is_protected(pos, player:get_player_name()) then
|
||||||
|
return
|
||||||
|
end
|
||||||
|
local mem = tubelib2.get_mem(pos)
|
||||||
|
State:state_button_event(pos, mem, fields)
|
||||||
|
|
||||||
|
if fields.update then
|
||||||
|
local mem = tubelib2.get_mem(pos)
|
||||||
|
M(pos):set_string("formspec", formspec(State, pos, mem))
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
local function on_rightclick(pos)
|
||||||
|
local mem = tubelib2.get_mem(pos)
|
||||||
|
M(pos):set_string("formspec", formspec(State, pos, mem))
|
||||||
|
end
|
||||||
|
|
||||||
|
minetest.register_node("techage:ta3_battery", {
|
||||||
|
description = "TA3 Battery",
|
||||||
|
tiles = {
|
||||||
|
-- up, down, right, left, back, front
|
||||||
|
"techage_filling_ta3.png^techage_frame_ta3_top.png",
|
||||||
|
"techage_filling_ta3.png^techage_frame_ta3.png",
|
||||||
|
"techage_filling_ta3.png^techage_frame_ta3.png^techage_appl_hole_electric.png",
|
||||||
|
"techage_filling_ta3.png^techage_frame_ta3.png^techage_appl_source.png",
|
||||||
|
"techage_filling_ta3.png^techage_frame_ta3.png^techage_appl_source.png",
|
||||||
|
"techage_filling_ta3.png^techage_frame_ta3.png^techage_appl_source.png",
|
||||||
|
},
|
||||||
|
paramtype2 = "facedir",
|
||||||
|
groups = {cracky=2, crumbly=2, choppy=2},
|
||||||
|
on_rotate = screwdriver.disallow,
|
||||||
|
is_ground_content = false,
|
||||||
|
|
||||||
|
techage = {
|
||||||
|
turn_on = turn_power_on,
|
||||||
|
read_power_consumption = generator.read_power_consumption,
|
||||||
|
power_network = Power,
|
||||||
|
power_side = "R",
|
||||||
|
},
|
||||||
|
|
||||||
|
after_place_node = function(pos, placer)
|
||||||
|
local mem = generator.after_place_node(pos)
|
||||||
|
State:node_init(pos, mem, "")
|
||||||
|
mem.charging = false
|
||||||
|
mem.unloading = false
|
||||||
|
on_rightclick(pos)
|
||||||
|
end,
|
||||||
|
|
||||||
|
after_dig_node = function(pos, oldnode, oldmetadata, digger)
|
||||||
|
State:after_dig_node(pos, oldnode, oldmetadata, digger)
|
||||||
|
generator.after_dig_node(pos, oldnode)
|
||||||
|
end,
|
||||||
|
|
||||||
|
after_tube_update = generator.after_tube_update,
|
||||||
|
on_receive_fields = on_receive_fields,
|
||||||
|
on_rightclick = on_rightclick,
|
||||||
|
on_timer = node_timer,
|
||||||
|
})
|
||||||
|
|
||||||
|
Power:add_secondary_node_names({"techage:ta3_battery"})
|
1
init.lua
1
init.lua
@ -102,6 +102,7 @@ else
|
|||||||
dofile(MP.."/coal_power_station/generator.lua")
|
dofile(MP.."/coal_power_station/generator.lua")
|
||||||
dofile(MP.."/coal_power_station/turbine.lua")
|
dofile(MP.."/coal_power_station/turbine.lua")
|
||||||
dofile(MP.."/coal_power_station/cooler.lua")
|
dofile(MP.."/coal_power_station/cooler.lua")
|
||||||
|
dofile(MP.."/coal_power_station/battery.lua")
|
||||||
|
|
||||||
|
|
||||||
--dofile(MP.."/test/generator.lua")
|
--dofile(MP.."/test/generator.lua")
|
||||||
|
123
test/battery.lua
123
test/battery.lua
@ -1,123 +0,0 @@
|
|||||||
-- for lazy programmers
|
|
||||||
local S = function(pos) if pos then return minetest.pos_to_string(pos) end end
|
|
||||||
local P = minetest.string_to_pos
|
|
||||||
local M = minetest.get_meta
|
|
||||||
|
|
||||||
-- Load support for intllib.
|
|
||||||
local MP = minetest.get_modpath("techage")
|
|
||||||
local I,_ = dofile(MP.."/intllib.lua")
|
|
||||||
|
|
||||||
local STANDBY_TICKS = 4
|
|
||||||
local COUNTDOWN_TICKS = 4
|
|
||||||
local CYCLE_TIME = 16
|
|
||||||
local POWER_CAPACITY = 12
|
|
||||||
|
|
||||||
local Axle = techage.Axle
|
|
||||||
local generator = techage.generator
|
|
||||||
|
|
||||||
local function formspec(self, pos, mem)
|
|
||||||
return "size[8,7]"..
|
|
||||||
default.gui_bg..
|
|
||||||
default.gui_bg_img..
|
|
||||||
default.gui_slots..
|
|
||||||
"image[6,0.5;1,2;"..generator.formspec_level(mem, mem.power_result)..
|
|
||||||
"image_button[5,1;1,1;".. self:get_state_button_image(mem) ..";state_button;]"..
|
|
||||||
"button[2.5,1;1.8,1;update;"..I("Update").."]"..
|
|
||||||
"list[current_player;main;0,3;8,4;]"..
|
|
||||||
default.get_hotbar_bg(0, 3)
|
|
||||||
end
|
|
||||||
|
|
||||||
local function start_node(pos, mem, state)
|
|
||||||
generator.turn_power_on(pos, POWER_CAPACITY)
|
|
||||||
end
|
|
||||||
|
|
||||||
local function stop_node(pos, mem, state)
|
|
||||||
generator.turn_power_on(pos, 0)
|
|
||||||
end
|
|
||||||
|
|
||||||
local State = techage.NodeStates:new({
|
|
||||||
node_name_passive = "techage:battery",
|
|
||||||
cycle_time = CYCLE_TIME,
|
|
||||||
standby_ticks = STANDBY_TICKS,
|
|
||||||
formspec_func = formspec,
|
|
||||||
start_node = start_node,
|
|
||||||
stop_node = stop_node,
|
|
||||||
})
|
|
||||||
|
|
||||||
|
|
||||||
local function node_timer(pos, elapsed)
|
|
||||||
local mem = tubelib2.get_mem(pos)
|
|
||||||
return State:is_active(mem)
|
|
||||||
end
|
|
||||||
|
|
||||||
local function turn_power_on(pos, in_dir, sum)
|
|
||||||
local mem = tubelib2.get_mem(pos)
|
|
||||||
-- store result for formspec
|
|
||||||
mem.power_result = sum
|
|
||||||
if State:is_active(mem) and sum <= 0 then
|
|
||||||
State:fault(pos, mem)
|
|
||||||
-- No automatic turn on
|
|
||||||
mem.power_capacity = 0
|
|
||||||
end
|
|
||||||
M(pos):set_string("formspec", formspec(State, pos, mem))
|
|
||||||
end
|
|
||||||
|
|
||||||
local function on_receive_fields(pos, formname, fields, player)
|
|
||||||
if minetest.is_protected(pos, player:get_player_name()) then
|
|
||||||
return
|
|
||||||
end
|
|
||||||
local mem = tubelib2.get_mem(pos)
|
|
||||||
State:state_button_event(pos, mem, fields)
|
|
||||||
|
|
||||||
if fields.update then
|
|
||||||
M(pos):set_string("formspec", formspec(State, pos, mem))
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
local function on_rightclick(pos)
|
|
||||||
local mem = tubelib2.get_mem(pos)
|
|
||||||
M(pos):set_string("formspec", formspec(State, pos, mem))
|
|
||||||
end
|
|
||||||
|
|
||||||
minetest.register_node("techage:battery", {
|
|
||||||
description = "TA2 Battery",
|
|
||||||
tiles = {
|
|
||||||
-- up, down, right, left, back, front
|
|
||||||
"techage_filling_ta2.png^techage_frame_ta2_top.png",
|
|
||||||
"techage_filling_ta2.png^techage_frame_ta2.png",
|
|
||||||
"techage_filling_ta2.png^techage_axle_clutch.png^techage_frame_ta2.png",
|
|
||||||
"techage_filling_ta2.png^techage_frame_ta2.png^techage_appl_electric_power.png",
|
|
||||||
"techage_filling_ta2.png^techage_frame_ta2.png^techage_appl_electric_power.png",
|
|
||||||
"techage_filling_ta2.png^techage_frame_ta2.png^techage_appl_electric_power.png",
|
|
||||||
},
|
|
||||||
paramtype2 = "facedir",
|
|
||||||
groups = {cracky=2, crumbly=2, choppy=2},
|
|
||||||
on_rotate = screwdriver.disallow,
|
|
||||||
is_ground_content = false,
|
|
||||||
|
|
||||||
techage = {
|
|
||||||
turn_on = turn_power_on,
|
|
||||||
read_power_consumption = generator.read_power_consumption,
|
|
||||||
power_network = Axle,
|
|
||||||
power_side = "R",
|
|
||||||
animated_power_network = true,
|
|
||||||
},
|
|
||||||
|
|
||||||
after_place_node = function(pos, placer)
|
|
||||||
local mem = generator.after_place_node(pos)
|
|
||||||
State:node_init(pos, mem, "")
|
|
||||||
on_rightclick(pos)
|
|
||||||
end,
|
|
||||||
|
|
||||||
after_dig_node = function(pos, oldnode, oldmetadata, digger)
|
|
||||||
State:after_dig_node(pos, oldnode, oldmetadata, digger)
|
|
||||||
generator.after_dig_node(pos, oldnode)
|
|
||||||
end,
|
|
||||||
|
|
||||||
after_tube_update = generator.after_tube_update,
|
|
||||||
on_receive_fields = on_receive_fields,
|
|
||||||
on_rightclick = on_rightclick,
|
|
||||||
on_timer = node_timer,
|
|
||||||
})
|
|
||||||
|
|
||||||
Axle:add_secondary_node_names({"techage:battery"})
|
|
@ -7,7 +7,7 @@ local M = minetest.get_meta
|
|||||||
local MP = minetest.get_modpath("techage")
|
local MP = minetest.get_modpath("techage")
|
||||||
local I,_ = dofile(MP.."/intllib.lua")
|
local I,_ = dofile(MP.."/intllib.lua")
|
||||||
|
|
||||||
local POWER_CONSUMPTION = 2
|
local POWER_CONSUMPTION = 1
|
||||||
|
|
||||||
local Power = techage.ElectricCable
|
local Power = techage.ElectricCable
|
||||||
local consumer = techage.consumer
|
local consumer = techage.consumer
|
||||||
@ -23,13 +23,13 @@ end
|
|||||||
|
|
||||||
-- called from pipe network
|
-- called from pipe network
|
||||||
local function valid_power_dir(pos, power_dir, in_dir)
|
local function valid_power_dir(pos, power_dir, in_dir)
|
||||||
print("valid_power_dir", power_dir, in_dir)
|
--print("valid_power_dir", power_dir, in_dir)
|
||||||
return true
|
return true
|
||||||
end
|
end
|
||||||
|
|
||||||
local function lamp_turn_on_clbk(pos, in_dir, sum)
|
local function lamp_turn_on_clbk(pos, in_dir, sum)
|
||||||
local mem = tubelib2.get_mem(pos)
|
local mem = tubelib2.get_mem(pos)
|
||||||
print("lamp_turn_on_clbk", sum, dump(mem))
|
--print("lamp_turn_on_clbk", sum)
|
||||||
if sum > 0 and mem.running then
|
if sum > 0 and mem.running then
|
||||||
swap_node(pos, "techage:test_lamp_on")
|
swap_node(pos, "techage:test_lamp_on")
|
||||||
else
|
else
|
||||||
@ -39,7 +39,7 @@ end
|
|||||||
|
|
||||||
local function lamp_on_rightclick(pos, node, clicker)
|
local function lamp_on_rightclick(pos, node, clicker)
|
||||||
local mem = tubelib2.get_mem(pos)
|
local mem = tubelib2.get_mem(pos)
|
||||||
print("lamp_on_rightclick", dump(mem))
|
--print("lamp_on_rightclick", dump(mem))
|
||||||
if not mem.running then
|
if not mem.running then
|
||||||
swap_node(pos, "techage:test_lamp_on")
|
swap_node(pos, "techage:test_lamp_on")
|
||||||
mem.running = true
|
mem.running = true
|
||||||
@ -74,7 +74,6 @@ minetest.register_node("techage:test_lamp", {
|
|||||||
|
|
||||||
after_place_node = function(pos, placer)
|
after_place_node = function(pos, placer)
|
||||||
local mem = consumer.after_place_node(pos, placer)
|
local mem = consumer.after_place_node(pos, placer)
|
||||||
mem.power_consumption = POWER_CONSUMPTION
|
|
||||||
end,
|
end,
|
||||||
|
|
||||||
after_tube_update = consumer.after_tube_update,
|
after_tube_update = consumer.after_tube_update,
|
||||||
|
BIN
textures/techage_form_level_charge.png
Normal file
BIN
textures/techage_form_level_charge.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 234 B |
BIN
textures/techage_form_level_charge.png.png
Normal file
BIN
textures/techage_form_level_charge.png.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 234 B |
BIN
textures/techage_form_level_off.png
Normal file
BIN
textures/techage_form_level_off.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 221 B |
BIN
textures/techage_form_level_unload.png
Normal file
BIN
textures/techage_form_level_unload.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 234 B |
Loading…
Reference in New Issue
Block a user