akku box added
This commit is contained in:
parent
57980442d3
commit
779a31de04
@ -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)
|
||||||
|
@ -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"},
|
||||||
|
},
|
||||||
|
})
|
2
init.lua
2
init.lua
@ -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")
|
||||||
|
@ -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({
|
||||||
|
@ -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 = {},
|
||||||
|
BIN
textures/techage_baborium_ingot.png
Normal file
BIN
textures/techage_baborium_ingot.png
Normal file
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 |
Loading…
Reference in New Issue
Block a user