akku box added

This commit is contained in:
Joachim Stolberg 2019-05-13 23:36:42 +02:00
parent 57980442d3
commit 779a31de04
7 changed files with 61 additions and 14 deletions

View File

@ -50,6 +50,10 @@ function techage.get_pos(pos, side)
return tubelib2.get_pos(pos, dir) return tubelib2.get_pos(pos, dir)
end end
function techage.percent(max_val, curr_val)
return math.min(math.ceil(((curr_val or 0) * 100.0) / (max_val or 1.0)), 100)
end
-- Both nodes are from the same power network type? -- Both nodes are from the same power network type?
local function matching_nodes(pos, peer_pos) local function matching_nodes(pos, peer_pos)
local tube_type1 = pos and TRD(pos) and TRD(pos).power_network.tube_type local tube_type1 = pos and TRD(pos) and TRD(pos).power_network.tube_type
@ -218,12 +222,12 @@ 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 = math.min(((sum or 0) * 100) / (mem.power_capacity or 1), 100) local percent = techage.percent(mem.power_capacity, sum)
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) function techage.generator.formspec_battery_capa(max_capa, current_capa)
local percent = math.min(((current_capa or 0) * 100) / (max_capa or 1), 100) local percent = techage.percent(max_capa, current_capa)
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_load(mem) function techage.generator.formspec_battery_load(mem)

View File

@ -8,7 +8,7 @@
LGPLv2.1+ LGPLv2.1+
See LICENSE.txt for more information See LICENSE.txt for more information
TA3 Battery Box TA3 Akku Box
]]-- ]]--
@ -25,7 +25,7 @@ local STANDBY_TICKS = 4
local COUNTDOWN_TICKS = 4 local COUNTDOWN_TICKS = 4
local CYCLE_TIME = 2 local CYCLE_TIME = 2
local POWER_CONSUMPTION = 10 local POWER_CONSUMPTION = 10
local POWER_MAX_LOAD = 1000 local POWER_MAX_LOAD = 300
local Power = techage.ElectricCable local Power = techage.ElectricCable
local generator = techage.generator local generator = techage.generator
@ -80,7 +80,7 @@ local function stop_node(pos, mem, state)
end end
local State = techage.NodeStates:new({ local State = techage.NodeStates:new({
node_name_passive = "techage:ta3_battery", node_name_passive = "techage:ta3_akku",
cycle_time = CYCLE_TIME, cycle_time = CYCLE_TIME,
standby_ticks = STANDBY_TICKS, standby_ticks = STANDBY_TICKS,
formspec_func = formspec, formspec_func = formspec,
@ -100,13 +100,12 @@ local function node_timer(pos, elapsed)
end end
elseif mem.unloading then elseif mem.unloading then
if mem.capa > 0 then if mem.capa > 0 then
mem.capa = mem.capa - 1 mem.capa = mem.capa - 2
else else
turn_off(pos, mem) turn_off(pos, mem)
end end
end end
end end
--print("node_timer", S(pos), mem.sum, mem.power_capacity)
return State:is_active(mem) return State:is_active(mem)
end end
@ -115,7 +114,6 @@ local function turn_power_on(pos, in_dir, sum)
if State:is_active(mem) then if State:is_active(mem) then
mem.capa = mem.capa or 0 mem.capa = mem.capa or 0
mem.sum = sum mem.sum = sum
--print("turn_power_on", sum, dump(mem))
if mem.unloading then if mem.unloading then
if sum < 0 then if sum < 0 then
turn_off(pos, mem) turn_off(pos, mem)
@ -154,8 +152,29 @@ 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:ta3_battery", { local function get_capa(itemstack)
description = "TA3 Battery", local meta = itemstack:get_meta()
if meta then
return meta:get_int("capa")
end
return 0
end
local function set_capa(pos, oldnode, digger, capa)
local node = ItemStack(oldnode.name)
local meta = node:get_meta()
meta:set_int("capa", capa or 0)
local text = I("TA3 Akku Box").." ("..techage.percent(POWER_MAX_LOAD, capa).." %)"
meta:set_string("description", text)
local inv = minetest.get_inventory({type="player", name=digger:get_player_name()})
local left_over = inv:add_item("main", node)
if left_over:get_count() > 0 then
minetest.add_item(pos, node)
end
end
minetest.register_node("techage:ta3_akku", {
description = I("TA3 Akku Box"),
tiles = { tiles = {
-- up, down, right, left, back, front -- up, down, right, left, back, front
"techage_filling_ta3.png^techage_frame_ta3_top.png", "techage_filling_ta3.png^techage_frame_ta3_top.png",
@ -169,6 +188,7 @@ minetest.register_node("techage:ta3_battery", {
groups = {cracky=2, crumbly=2, choppy=2}, groups = {cracky=2, crumbly=2, choppy=2},
on_rotate = screwdriver.disallow, on_rotate = screwdriver.disallow,
is_ground_content = false, is_ground_content = false,
sounds = default.node_sound_wood_defaults(),
techage = { techage = {
turn_on = turn_power_on, turn_on = turn_power_on,
@ -177,17 +197,20 @@ minetest.register_node("techage:ta3_battery", {
power_side = "R", power_side = "R",
}, },
after_place_node = function(pos, placer) after_place_node = function(pos, placer, itemstack)
local mem = generator.after_place_node(pos) local mem = generator.after_place_node(pos)
State:node_init(pos, mem, "") State:node_init(pos, mem, "")
mem.charging = false mem.charging = false
mem.unloading = false mem.unloading = false
mem.capa = get_capa(itemstack)
on_rightclick(pos) on_rightclick(pos)
end, end,
after_dig_node = function(pos, oldnode, oldmetadata, digger) after_dig_node = function(pos, oldnode, oldmetadata, digger)
local mem = tubelib2.get_mem(pos)
State:after_dig_node(pos, oldnode, oldmetadata, digger) State:after_dig_node(pos, oldnode, oldmetadata, digger)
generator.after_dig_node(pos, oldnode) generator.after_dig_node(pos, oldnode)
set_capa(pos, oldnode, digger, mem.capa)
end, end,
after_tube_update = generator.after_tube_update, after_tube_update = generator.after_tube_update,
@ -196,4 +219,19 @@ minetest.register_node("techage:ta3_battery", {
on_timer = node_timer, on_timer = node_timer,
}) })
Power:add_secondary_node_names({"techage:ta3_battery"}) Power:add_secondary_node_names({"techage:ta3_akku"})
techage.register_help_page(I("TA3 Akku Box"),
I([[Used to store electrical energy.
Charged in about 10 min,
provides energy for 5 min.]]), "techage:ta3_akku")
minetest.register_craft({
output = "techage:ta3_akku",
recipe = {
{"default:tin_ingot", "default:tin_ingot", "default:wood"},
{"default:copper_ingot", "default:copper_ingot", "techage:electric_cableS"},
{"techage:iron_ingot", "techage:iron_ingot", "default:wood"},
},
})

View File

@ -102,7 +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.."/coal_power_station/akkubox.lua")
--dofile(MP.."/test/generator.lua") --dofile(MP.."/test/generator.lua")

View File

@ -25,6 +25,11 @@ minetest.register_craftitem("techage:baborium_lump", {
inventory_image = "techage_baborium_lump.png", inventory_image = "techage_baborium_lump.png",
}) })
minetest.register_craftitem("techage:baborium_ingot", {
description = "Baborium Ingot",
inventory_image = "techage_baborium_ingot.png",
})
minetest.register_ore({ minetest.register_ore({

View File

@ -25,7 +25,7 @@ local Cable = tubelib2.Tube:new({
dirs_to_check = {1,2,3,4,5,6}, dirs_to_check = {1,2,3,4,5,6},
max_tube_length = 1000, max_tube_length = 1000,
show_infotext = false, show_infotext = false,
force_to_use_tubes = true, --force_to_use_tubes = true,
tube_type = "electric_cable", tube_type = "electric_cable",
primary_node_names = {"techage:electric_cableS", "techage:electric_cableA"}, primary_node_names = {"techage:electric_cableS", "techage:electric_cableA"},
secondary_node_names = {}, secondary_node_names = {},

Binary file not shown.

After

Width:  |  Height:  |  Size: 248 B

Binary file not shown.

Before

Width:  |  Height:  |  Size: 485 B

After

Width:  |  Height:  |  Size: 249 B