mirror of
https://git.minetest.land/VoxeLibre/VoxeLibre.git
synced 2024-11-19 09:31:07 +01:00
Merge pull request 'Lightning Rod Fixes' (#2838) from lightning-rod-fixes into master
Reviewed-on: https://git.minetest.land/MineClone2/MineClone2/pulls/2838 Reviewed-by: cora <cora@noreply.git.minetest.land>
This commit is contained in:
commit
468b46a920
5 changed files with 91 additions and 29 deletions
|
@ -1,34 +1,49 @@
|
||||||
local S = minetest.get_translator("mobs_mc")
|
local S = minetest.get_translator("mcl_lightning_rods")
|
||||||
|
|
||||||
|
---@type nodebox
|
||||||
local cbox = {
|
local cbox = {
|
||||||
type = "fixed",
|
type = "fixed",
|
||||||
fixed = {
|
fixed = {
|
||||||
{ 0/16, -8/16, 0/16, 2/16, 4/16, 2/16 },
|
{ -0.0625, -0.5, -0.0625, 0.0625, 0.25, 0.0625 },
|
||||||
{ 0/16, 4/16, 0/16, 3/16, 8/16, 3/16 },
|
{ -0.125, 0.25, -0.125, 0.125, 0.5, 0.125 },
|
||||||
}
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
minetest.register_node("mcl_lightning_rods:rod", {
|
local text_top = "[combine:16x16:6,6=mcl_lightning_rods_rod.png"
|
||||||
|
local text_side = "[combine:16x16:7,0=mcl_lightning_rods_rod.png:-6,0=mcl_lightning_rods_rod.png\\^[transformR270"
|
||||||
|
|
||||||
|
local text_top_active = "[combine:16x16:6,6=mcl_lightning_rods_rod.png\\^[brighten"
|
||||||
|
local text_side_active = "[combine:16x16:7,0=mcl_lightning_rods_rod.png\\^[brighten:-6,0=mcl_lightning_rods_rod.png\\^[transformR270\\^[brighten"
|
||||||
|
|
||||||
|
---@type node_definition
|
||||||
|
local rod_def = {
|
||||||
description = S("Lightning Rod"),
|
description = S("Lightning Rod"),
|
||||||
_doc_items_longdesc = S("A block that attracts lightning"),
|
_doc_items_longdesc = S("A block that attracts lightning"),
|
||||||
--inventory_image = "mcl_lightning_rods_rod_inv.png",
|
|
||||||
tiles = {
|
tiles = {
|
||||||
"mcl_lightning_rods_rod.png",
|
text_top,
|
||||||
"mcl_lightning_rods_rod.png",
|
text_top,
|
||||||
"mcl_lightning_rods_rod.png",
|
text_side,
|
||||||
"mcl_lightning_rods_rod.png",
|
text_side,
|
||||||
"mcl_lightning_rods_rod.png",
|
text_side,
|
||||||
"mcl_lightning_rods_rod.png",
|
text_side,
|
||||||
},
|
},
|
||||||
drawtype = "nodebox",
|
drawtype = "nodebox",
|
||||||
is_ground_content = false,
|
is_ground_content = false,
|
||||||
paramtype = "light",
|
paramtype = "light",
|
||||||
paramtype2 = "facedir",
|
paramtype2 = "facedir",
|
||||||
groups = {pickaxey=2,attracts_lightning=1},
|
use_texture_alpha = "opaque",
|
||||||
|
groups = { pickaxey = 2, attracts_lightning = 1 },
|
||||||
sounds = mcl_sounds.node_sound_metal_defaults(),
|
sounds = mcl_sounds.node_sound_metal_defaults(),
|
||||||
node_box = cbox,
|
node_box = cbox,
|
||||||
selection_box = cbox,
|
selection_box = cbox,
|
||||||
collision_box = cbox,
|
collision_box = cbox,
|
||||||
|
node_placement_prediction = "",
|
||||||
|
mesecons = {
|
||||||
|
receptor = {
|
||||||
|
state = mesecon.state.off,
|
||||||
|
rules = mesecon.rules.alldirs,
|
||||||
|
},
|
||||||
|
},
|
||||||
on_place = function(itemstack, placer, pointed_thing)
|
on_place = function(itemstack, placer, pointed_thing)
|
||||||
if pointed_thing.type ~= "node" then
|
if pointed_thing.type ~= "node" then
|
||||||
return itemstack
|
return itemstack
|
||||||
|
@ -40,12 +55,7 @@ minetest.register_node("mcl_lightning_rods:rod", {
|
||||||
|
|
||||||
local placer_pos = placer:get_pos()
|
local placer_pos = placer:get_pos()
|
||||||
if placer_pos then
|
if placer_pos then
|
||||||
local dir = {
|
param2 = minetest.dir_to_facedir(vector.subtract(p1, placer_pos))
|
||||||
x = p1.x - placer_pos.x,
|
|
||||||
y = p1.y - placer_pos.y,
|
|
||||||
z = p1.z - placer_pos.z
|
|
||||||
}
|
|
||||||
param2 = minetest.dir_to_facedir(dir)
|
|
||||||
end
|
end
|
||||||
|
|
||||||
if p0.y - 1 == p1.y then
|
if p0.y - 1 == p1.y then
|
||||||
|
@ -63,20 +73,66 @@ minetest.register_node("mcl_lightning_rods:rod", {
|
||||||
return minetest.item_place(itemstack, placer, pointed_thing, param2)
|
return minetest.item_place(itemstack, placer, pointed_thing, param2)
|
||||||
end,
|
end,
|
||||||
|
|
||||||
sounds = mcl_sounds.node_sound_glass_defaults(),
|
|
||||||
_mcl_blast_resistance = 0,
|
_mcl_blast_resistance = 0,
|
||||||
})
|
}
|
||||||
|
|
||||||
lightning.register_on_strike(function(pos,pos2,objects)
|
minetest.register_node("mcl_lightning_rods:rod", rod_def)
|
||||||
local lr = minetest.find_node_near(pos,128,{"group:attracts_lightning"},true)
|
|
||||||
return lr,nil
|
local rod_def_a = table.copy(rod_def)
|
||||||
|
|
||||||
|
rod_def_a.tiles = {
|
||||||
|
text_top_active,
|
||||||
|
text_top_active,
|
||||||
|
text_side_active,
|
||||||
|
text_side_active,
|
||||||
|
text_side_active,
|
||||||
|
text_side_active,
|
||||||
|
}
|
||||||
|
|
||||||
|
rod_def_a.groups.not_in_creative_inventory = 1
|
||||||
|
|
||||||
|
rod_def_a.mesecons = {
|
||||||
|
receptor = {
|
||||||
|
state = mesecon.state.on,
|
||||||
|
rules = mesecon.rules.alldirs,
|
||||||
|
},
|
||||||
|
}
|
||||||
|
|
||||||
|
rod_def_a.on_timer = function(pos, elapsed)
|
||||||
|
local node = minetest.get_node(pos)
|
||||||
|
|
||||||
|
if node.name == "mcl_lightning_rods:rod_powered" then --has not been dug
|
||||||
|
minetest.set_node(pos, { name = "mcl_lightning_rods:rod" })
|
||||||
|
mesecon.receptor_off(pos, mesecon.rules.alldirs)
|
||||||
|
end
|
||||||
|
|
||||||
|
return false
|
||||||
|
end
|
||||||
|
|
||||||
|
minetest.register_node("mcl_lightning_rods:rod_powered", rod_def_a)
|
||||||
|
|
||||||
|
|
||||||
|
lightning.register_on_strike(function(pos, pos2, objects)
|
||||||
|
local lr = minetest.find_node_near(pos, 128, { "group:attracts_lightning" }, true)
|
||||||
|
|
||||||
|
if lr then
|
||||||
|
local node = minetest.get_node(lr)
|
||||||
|
|
||||||
|
if node.name == "mcl_lightning_rods:rod" then
|
||||||
|
minetest.set_node(lr, { name = "mcl_lightning_rods:rod_powered" })
|
||||||
|
mesecon.receptor_on(lr, mesecon.rules.alldirs)
|
||||||
|
minetest.get_node_timer(lr):start(0.4)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
return lr, nil
|
||||||
end)
|
end)
|
||||||
|
|
||||||
minetest.register_craft({
|
minetest.register_craft({
|
||||||
output = "mcl_lightning_rods:rod",
|
output = "mcl_lightning_rods:rod",
|
||||||
recipe = {
|
recipe = {
|
||||||
{"", "mcl_copper:copper_ingot",""},
|
{ "", "mcl_copper:copper_ingot", "" },
|
||||||
{"", "mcl_copper:copper_ingot",""},
|
{ "", "mcl_copper:copper_ingot", "" },
|
||||||
{"", "mcl_copper:copper_ingot",""},
|
{ "", "mcl_copper:copper_ingot", "" },
|
||||||
}
|
},
|
||||||
})
|
})
|
||||||
|
|
|
@ -0,0 +1,3 @@
|
||||||
|
# textdomain: mcl_lightning_rods
|
||||||
|
Lightning Rod=Paratonnerre
|
||||||
|
A block that attracts lightning=Un bloc qui attire la foudre
|
3
mods/ITEMS/mcl_lightning_rods/locale/template.txt
Normal file
3
mods/ITEMS/mcl_lightning_rods/locale/template.txt
Normal file
|
@ -0,0 +1,3 @@
|
||||||
|
# textdomain: mcl_lightning_rods
|
||||||
|
Lightning Rod=
|
||||||
|
A block that attracts lightning=
|
|
@ -1,3 +1,3 @@
|
||||||
name = mcl_lightning_rods
|
name = mcl_lightning_rods
|
||||||
author = cora
|
author = cora
|
||||||
depends = mcl_sounds, lightning
|
depends = mcl_sounds, lightning, mesecons
|
||||||
|
|
Binary file not shown.
Before Width: | Height: | Size: 236 B After Width: | Height: | Size: 203 B |
Loading…
Reference in a new issue