forked from Mirrorlandia_minetest/mesecons
Experimental battery - not finished yet
This commit is contained in:
parent
aa8ad0fde9
commit
278a705cba
1
mesecons_battery/depends.txt
Normal file
1
mesecons_battery/depends.txt
Normal file
@ -0,0 +1 @@
|
|||||||
|
mesecons
|
130
mesecons_battery/init.lua
Normal file
130
mesecons_battery/init.lua
Normal file
@ -0,0 +1,130 @@
|
|||||||
|
for i = 1, 5 do
|
||||||
|
minetest.register_node("mesecons_battery:battery_charging_"..i, {
|
||||||
|
drawtype = "nodebox",
|
||||||
|
tiles = {"jeija_battery_charging.png"},
|
||||||
|
paramtype = "light",
|
||||||
|
is_ground_content = true,
|
||||||
|
walkable = true,
|
||||||
|
node_box = {
|
||||||
|
type = "fixed",
|
||||||
|
fixed = {
|
||||||
|
{-0.499, -0.499, -0.499, -0.4, 0.499, 0.499},
|
||||||
|
{ 0.499, -0.499, -0.499, 0.4, 0.499, 0.499},
|
||||||
|
{-0.499, -0.499, -0.499, 0.499, 0.499, -0.4 },
|
||||||
|
{-0.499, -0.499, 0.499, 0.499, 0.499, 0.4 },
|
||||||
|
{-0.4 , -0.5 , -0.4 , 0.4 , 1*(i/5)-0.5, 0.4}}
|
||||||
|
},
|
||||||
|
|
||||||
|
selection_box = {
|
||||||
|
type = "fixed",
|
||||||
|
fixed = {
|
||||||
|
{-0.499, -0.499, -0.499, -0.4, 0.499, 0.499},
|
||||||
|
{ 0.499, -0.499, -0.499, 0.4, 0.499, 0.499},
|
||||||
|
{-0.499, -0.499, -0.499, 0.499, 0.499, -0.4 },
|
||||||
|
{-0.499, -0.499, 0.499, 0.499, 0.499, 0.4 },
|
||||||
|
{-0.4 , -0.5 , -0.4 , 0.4 , 1*(i/5)-0.5, 0.4}}
|
||||||
|
},
|
||||||
|
groups = {dig_immediate=2},
|
||||||
|
description="Battery",
|
||||||
|
})
|
||||||
|
mesecon:add_receptor_node_off("mesecons_battery:battery_charging_"..i)
|
||||||
|
end
|
||||||
|
|
||||||
|
for i = 1, 5 do
|
||||||
|
minetest.register_node("mesecons_battery:battery_discharging_"..i, {
|
||||||
|
drawtype = "nodebox",
|
||||||
|
tiles = {"jeija_battery_discharging.png"},
|
||||||
|
paramtype = "light",
|
||||||
|
is_ground_content = true,
|
||||||
|
walkable = true,
|
||||||
|
node_box = {
|
||||||
|
type = "fixed",
|
||||||
|
fixed = {
|
||||||
|
{-0.499, -0.499, -0.499, -0.4, 0.499, 0.499},
|
||||||
|
{ 0.499, -0.499, -0.499, 0.4, 0.499, 0.499},
|
||||||
|
{-0.499, -0.499, -0.499, 0.499, 0.499, -0.4 },
|
||||||
|
{-0.499, -0.499, 0.499, 0.499, 0.499, 0.4 },
|
||||||
|
{-0.4 , -0.5 , -0.4 , 0.4 , 1*(i/5)-0.5, 0.4}}
|
||||||
|
},
|
||||||
|
|
||||||
|
selection_box = {
|
||||||
|
type = "fixed",
|
||||||
|
fixed = {
|
||||||
|
{-0.499, -0.499, -0.499, -0.4, 0.499, 0.499},
|
||||||
|
{ 0.499, -0.499, -0.499, 0.4, 0.499, 0.499},
|
||||||
|
{-0.499, -0.499, -0.499, 0.499, 0.499, -0.4 },
|
||||||
|
{-0.499, -0.499, 0.499, 0.499, 0.499, 0.4 },
|
||||||
|
{-0.4 , -0.5 , -0.4 , 0.4 , 1*(i/5)-0.5, 0.4}}
|
||||||
|
},
|
||||||
|
groups = {dig_immediate=2},
|
||||||
|
description="Battery",
|
||||||
|
})
|
||||||
|
mesecon:add_receptor_node("mesecons_battery:battery_discharging_"..i)
|
||||||
|
end
|
||||||
|
|
||||||
|
minetest.register_on_placenode(function (pos, newnode, placer)
|
||||||
|
meta = minetest.env:get_meta(pos)
|
||||||
|
meta:set_int("batterstate", 0)
|
||||||
|
meta:set_int("charging", 0)
|
||||||
|
end)
|
||||||
|
|
||||||
|
minetest.register_on_punchnode(function(pos, node, puncher)
|
||||||
|
if string.find(node.name, "mesecons_battery:battery_charging") then
|
||||||
|
local meta = minetest.env:get_meta(pos);
|
||||||
|
local batterystate = meta:get_int("batterystate")
|
||||||
|
local charging = meta:get_int("charging")
|
||||||
|
minetest.env:add_node(pos, {name=string.gsub(node.name, "charging", "discharging")})
|
||||||
|
mesecon:receptor_on(pos)
|
||||||
|
meta:set_int("batterystate", batterystate)
|
||||||
|
meta:set_int("charging", charging)
|
||||||
|
end
|
||||||
|
if string.find(node.name, "mesecons_battery:battery_discharging") then
|
||||||
|
local meta = minetest.env:get_meta(pos);
|
||||||
|
local batterystate = meta:get_int("batterystate")
|
||||||
|
local charging = meta:get_int("charging")
|
||||||
|
minetest.env:add_node(pos, {name=string.gsub(node.name, "discharging", "charging")})
|
||||||
|
mesecon:receptor_off(pos)
|
||||||
|
meta:set_int("batterystate", batterystate)
|
||||||
|
meta:set_int("charging", charging)
|
||||||
|
end
|
||||||
|
end)
|
||||||
|
|
||||||
|
minetest.register_abm({
|
||||||
|
nodenames = {"mesecons_battery:battery_charging_1", "mesecons_battery:battery_charging_2", "mesecons_battery:battery_charging_3", "mesecons_battery:battery_charging_4", "mesecons_battery:battery_charging_5"},
|
||||||
|
interval = 1,
|
||||||
|
chance = 1,
|
||||||
|
action = function(pos, node, active_object_count, active_object_count_wider)
|
||||||
|
local meta = minetest.env:get_meta(pos);
|
||||||
|
if meta:get_int("charging") == 1 then
|
||||||
|
local batterystate = meta:get_int("batterystate")
|
||||||
|
local charging = meta:get_int("charging")
|
||||||
|
local name = node.name;
|
||||||
|
if batterystate < 100 then --change battery charging state
|
||||||
|
batterystate = batterystate + 1
|
||||||
|
end
|
||||||
|
|
||||||
|
if string.find(node.name, tostring(math.ceil(batterystate/20))) == nil then
|
||||||
|
node.name = string.gsub(node.name, tostring(math.ceil(batterystate/20)-1), tostring(math.ceil(batterystate/20))) --change node for new nodebox model
|
||||||
|
end
|
||||||
|
minetest.env:add_node(pos, node)
|
||||||
|
meta:set_int("batterystate", batterystate)
|
||||||
|
meta:set_int("charging", charging)
|
||||||
|
end
|
||||||
|
end,
|
||||||
|
})
|
||||||
|
|
||||||
|
mesecon:register_on_signal_on(function(pos, node)
|
||||||
|
if string.find(node.name, "mesecons_battery:battery") then
|
||||||
|
minetest.env:get_meta(pos):set_int("charging", 1)
|
||||||
|
end
|
||||||
|
end)
|
||||||
|
|
||||||
|
mesecon:register_on_signal_off(function(pos, node)
|
||||||
|
if string.find(node.name, "mesecons_battery:battery") then
|
||||||
|
minetest.env:get_meta(pos):set_int("charging", 0)
|
||||||
|
end
|
||||||
|
end)
|
||||||
|
|
||||||
|
minetest.register_on_punchnode(function(pos, node, puncher)
|
||||||
|
print(minetest.env:get_meta(pos):get_int("batterystate"))
|
||||||
|
end)
|
Loading…
Reference in New Issue
Block a user