forked from Mirrorlandia_minetest/mesecons
Code improvement, Bugfix for solar panel
This commit is contained in:
parent
2b1f0d1338
commit
55bdf5441f
@ -53,7 +53,6 @@ nodenames = {"mesecons_hydroturbine:hydro_turbine_off"},
|
|||||||
action = function(pos, node, active_object_count, active_object_count_wider)
|
action = function(pos, node, active_object_count, active_object_count_wider)
|
||||||
local waterpos={x=pos.x, y=pos.y+1, z=pos.z}
|
local waterpos={x=pos.x, y=pos.y+1, z=pos.z}
|
||||||
if minetest.env:get_node(waterpos).name=="default:water_flowing" then
|
if minetest.env:get_node(waterpos).name=="default:water_flowing" then
|
||||||
--minetest.env:remove_node(pos)
|
|
||||||
minetest.env:add_node(pos, {name="mesecons_hydroturbine:hydro_turbine_on"})
|
minetest.env:add_node(pos, {name="mesecons_hydroturbine:hydro_turbine_on"})
|
||||||
nodeupdate(pos)
|
nodeupdate(pos)
|
||||||
mesecon:receptor_on(pos)
|
mesecon:receptor_on(pos)
|
||||||
@ -68,7 +67,6 @@ nodenames = {"mesecons_hydroturbine:hydro_turbine_on"},
|
|||||||
action = function(pos, node, active_object_count, active_object_count_wider)
|
action = function(pos, node, active_object_count, active_object_count_wider)
|
||||||
local waterpos={x=pos.x, y=pos.y+1, z=pos.z}
|
local waterpos={x=pos.x, y=pos.y+1, z=pos.z}
|
||||||
if minetest.env:get_node(waterpos).name~="default:water_flowing" then
|
if minetest.env:get_node(waterpos).name~="default:water_flowing" then
|
||||||
--minetest.env:remove_node(pos)
|
|
||||||
minetest.env:add_node(pos, {name="mesecons_hydroturbine:hydro_turbine_off"})
|
minetest.env:add_node(pos, {name="mesecons_hydroturbine:hydro_turbine_off"})
|
||||||
nodeupdate(pos)
|
nodeupdate(pos)
|
||||||
mesecon:receptor_off(pos)
|
mesecon:receptor_off(pos)
|
||||||
|
@ -1,5 +1,32 @@
|
|||||||
-- Solar Panel
|
-- Solar Panel
|
||||||
minetest.register_node("mesecons_solarpanel:solar_panel", {
|
minetest.register_node("mesecons_solarpanel:solar_panel_on", {
|
||||||
|
drawtype = "nodebox",
|
||||||
|
tiles = { "jeija_solar_panel.png", },
|
||||||
|
inventory_image = "jeija_solar_panel.png",
|
||||||
|
wield_image = "jeija_solar_panel.png",
|
||||||
|
paramtype = "light",
|
||||||
|
paramtype2 = "wallmounted",
|
||||||
|
walkable = false,
|
||||||
|
is_ground_content = true,
|
||||||
|
node_box = {
|
||||||
|
type = "wallmounted",
|
||||||
|
wall_bottom = { -7/16, -8/16, -7/16, 7/16, -7/16, 7/16 },
|
||||||
|
wall_top = { -7/16, 7/16, -7/16, 7/16, 8/16, 7/16 },
|
||||||
|
wall_side = { -8/16, -7/16, -7/16, -7/16, 7/16, 7/16 },
|
||||||
|
},
|
||||||
|
selection_box = {
|
||||||
|
type = "wallmounted",
|
||||||
|
wall_bottom = { -7/16, -8/16, -7/16, 7/16, -7/16, 7/16 },
|
||||||
|
wall_top = { -7/16, 7/16, -7/16, 7/16, 8/16, 7/16 },
|
||||||
|
wall_side = { -8/16, -7/16, -7/16, -7/16, 7/16, 7/16 },
|
||||||
|
},
|
||||||
|
drop = "mesecons_solarpanel:solar_panel_off",
|
||||||
|
groups = {dig_immediate=3, mesecon = 2, not_in_creative_inventory = 1},
|
||||||
|
description="Solar Panel",
|
||||||
|
})
|
||||||
|
|
||||||
|
-- Solar Panel
|
||||||
|
minetest.register_node("mesecons_solarpanel:solar_panel_off", {
|
||||||
drawtype = "nodebox",
|
drawtype = "nodebox",
|
||||||
tiles = { "jeija_solar_panel.png", },
|
tiles = { "jeija_solar_panel.png", },
|
||||||
inventory_image = "jeija_solar_panel.png",
|
inventory_image = "jeija_solar_panel.png",
|
||||||
@ -20,13 +47,12 @@ minetest.register_node("mesecons_solarpanel:solar_panel", {
|
|||||||
wall_top = { -7/16, 7/16, -7/16, 7/16, 8/16, 7/16 },
|
wall_top = { -7/16, 7/16, -7/16, 7/16, 8/16, 7/16 },
|
||||||
wall_side = { -8/16, -7/16, -7/16, -7/16, 7/16, 7/16 },
|
wall_side = { -8/16, -7/16, -7/16, -7/16, 7/16, 7/16 },
|
||||||
},
|
},
|
||||||
furnace_burntime = 5,
|
|
||||||
groups = {dig_immediate=3, mesecon = 2},
|
groups = {dig_immediate=3, mesecon = 2},
|
||||||
description="Solar Panel",
|
description="Solar Panel",
|
||||||
})
|
})
|
||||||
|
|
||||||
minetest.register_craft({
|
minetest.register_craft({
|
||||||
output = '"mesecons_solarpanel:solar_panel" 1',
|
output = '"mesecons_solarpanel:solar_panel_off" 1',
|
||||||
recipe = {
|
recipe = {
|
||||||
{'"mesecons_materials:silicon"', '"mesecons_materials:silicon"'},
|
{'"mesecons_materials:silicon"', '"mesecons_materials:silicon"'},
|
||||||
{'"mesecons_materials:silicon"', '"mesecons_materials:silicon"'},
|
{'"mesecons_materials:silicon"', '"mesecons_materials:silicon"'},
|
||||||
@ -34,16 +60,32 @@ minetest.register_craft({
|
|||||||
})
|
})
|
||||||
|
|
||||||
minetest.register_abm(
|
minetest.register_abm(
|
||||||
{nodenames = {"mesecons_solarpanel:solar_panel"},
|
{nodenames = {"mesecons_solarpanel:solar_panel_off"},
|
||||||
interval = 0.1,
|
interval = 1,
|
||||||
chance = 1,
|
chance = 1,
|
||||||
action = function(pos, node, active_object_count, active_object_count_wider)
|
action = function(pos, node, active_object_count, active_object_count_wider)
|
||||||
local light = minetest.env:get_node_light(pos, nil)
|
local light = minetest.env:get_node_light(pos, nil)
|
||||||
if light == nil then light = 0 end
|
|
||||||
if light >= 12 then
|
if light >= 12 then
|
||||||
|
minetest.env:set_node(pos, {name="mesecons_solarpanel:solar_panel_on", param2=node.param2})
|
||||||
mesecon:receptor_on(pos)
|
mesecon:receptor_on(pos)
|
||||||
else
|
end
|
||||||
|
end,
|
||||||
|
})
|
||||||
|
|
||||||
|
minetest.register_abm(
|
||||||
|
{nodenames = {"mesecons_solarpanel:solar_panel_on"},
|
||||||
|
interval = 1,
|
||||||
|
chance = 1,
|
||||||
|
action = function(pos, node, active_object_count, active_object_count_wider)
|
||||||
|
local light = minetest.env:get_node_light(pos, nil)
|
||||||
|
|
||||||
|
if light < 12 then
|
||||||
|
minetest.env:set_node(pos, {name="mesecons_solarpanel:solar_panel_off", param2=node.param2})
|
||||||
mesecon:receptor_off(pos)
|
mesecon:receptor_off(pos)
|
||||||
end
|
end
|
||||||
end,
|
end,
|
||||||
})
|
})
|
||||||
|
|
||||||
|
mesecon:add_receptor_node("mesecons_solarpanel:solar_panel_on")
|
||||||
|
mesecon:add_receptor_node_off("mesecons_solarpanel:solar_panel_off")
|
||||||
|
Loading…
Reference in New Issue
Block a user