Put back collision boxes on cauldrons
This commit is contained in:
parent
d08db7dda3
commit
2d455515a3
81
cooking.lua
81
cooking.lua
@ -1,41 +1,6 @@
|
|||||||
minetest.register_alias("xdecor:cauldron", "xdecor:cauldron_empty")
|
minetest.register_alias("xdecor:cauldron", "xdecor:cauldron_empty")
|
||||||
|
|
||||||
xdecor.register("cauldron_empty", {
|
local cauldron_cbox = {
|
||||||
description = "Cauldron",
|
|
||||||
groups = {cracky=2, oddly_breakable_by_hand=1},
|
|
||||||
on_rotate = screwdriver.rotate_simple,
|
|
||||||
tiles = {"xdecor_cauldron_top_empty.png", "xdecor_cauldron_sides.png"},
|
|
||||||
infotext = "Empty Cauldron",
|
|
||||||
on_rightclick = function(pos, node, clicker, itemstack, _)
|
|
||||||
local wield_item = clicker:get_wielded_item():get_name()
|
|
||||||
if wield_item == "bucket:bucket_water" or
|
|
||||||
wield_item == "bucket:bucket_river_water" then
|
|
||||||
minetest.set_node(pos, {name="xdecor:cauldron_idle", param2=node.param2})
|
|
||||||
itemstack:replace("bucket:bucket_empty")
|
|
||||||
end
|
|
||||||
end
|
|
||||||
})
|
|
||||||
|
|
||||||
xdecor.register("cauldron_idle", {
|
|
||||||
groups = {cracky=2, oddly_breakable_by_hand=1, not_in_creative_inventory=1},
|
|
||||||
on_rotate = screwdriver.rotate_simple,
|
|
||||||
tiles = {"xdecor_cauldron_top_idle.png", "xdecor_cauldron_sides.png"},
|
|
||||||
drop = "xdecor:cauldron_empty",
|
|
||||||
infotext = "Cauldron (idle)",
|
|
||||||
})
|
|
||||||
|
|
||||||
xdecor.register("cauldron_boiling_water", {
|
|
||||||
groups = {cracky=2, oddly_breakable_by_hand=1, not_in_creative_inventory=1},
|
|
||||||
on_rotate = screwdriver.rotate_simple,
|
|
||||||
drop = "xdecor:cauldron_empty",
|
|
||||||
infotext = "Drop foods inside to make a soup",
|
|
||||||
damage_per_second = 2,
|
|
||||||
tiles = {
|
|
||||||
{ name = "xdecor_cauldron_top_anim_boiling_water.png",
|
|
||||||
animation = {type="vertical_frames", length=3.0} },
|
|
||||||
"xdecor_cauldron_sides.png"
|
|
||||||
},
|
|
||||||
collision_box = {
|
|
||||||
type = "fixed",
|
type = "fixed",
|
||||||
fixed = {
|
fixed = {
|
||||||
{-0.5, -0.5, -0.5, 0.5, 0.5, -0.5},
|
{-0.5, -0.5, -0.5, 0.5, 0.5, -0.5},
|
||||||
@ -45,19 +10,59 @@ xdecor.register("cauldron_boiling_water", {
|
|||||||
{-0.5, -0.5, -0.5, 0.5, 0, 0.5}
|
{-0.5, -0.5, -0.5, 0.5, 0, 0.5}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
xdecor.register("cauldron_empty", {
|
||||||
|
description = "Cauldron",
|
||||||
|
groups = {cracky=2, oddly_breakable_by_hand=1},
|
||||||
|
on_rotate = screwdriver.rotate_simple,
|
||||||
|
tiles = {"xdecor_cauldron_top_empty.png", "xdecor_cauldron_sides.png"},
|
||||||
|
infotext = "Cauldron (empty)",
|
||||||
|
on_rightclick = function(pos, node, clicker, itemstack, _)
|
||||||
|
local wield_item = clicker:get_wielded_item():get_name()
|
||||||
|
if wield_item == "bucket:bucket_water" or
|
||||||
|
wield_item == "bucket:bucket_river_water" then
|
||||||
|
minetest.set_node(pos, {name="xdecor:cauldron_idle", param2=node.param2})
|
||||||
|
itemstack:replace("bucket:bucket_empty")
|
||||||
|
end
|
||||||
|
end,
|
||||||
|
collision_box = cauldron_cbox
|
||||||
|
})
|
||||||
|
|
||||||
|
xdecor.register("cauldron_idle", {
|
||||||
|
groups = {cracky=2, oddly_breakable_by_hand=1, not_in_creative_inventory=1},
|
||||||
|
on_rotate = screwdriver.rotate_simple,
|
||||||
|
tiles = {"xdecor_cauldron_top_idle.png", "xdecor_cauldron_sides.png"},
|
||||||
|
drop = "xdecor:cauldron_empty",
|
||||||
|
infotext = "Cauldron (idle)",
|
||||||
|
collision_box = cauldron_cbox
|
||||||
|
})
|
||||||
|
|
||||||
|
xdecor.register("cauldron_boiling_water", {
|
||||||
|
groups = {cracky=2, oddly_breakable_by_hand=1, not_in_creative_inventory=1},
|
||||||
|
on_rotate = screwdriver.rotate_simple,
|
||||||
|
drop = "xdecor:cauldron_empty",
|
||||||
|
infotext = "Cauldron (active) - Drop foods inside to make a soup",
|
||||||
|
damage_per_second = 2,
|
||||||
|
tiles = {
|
||||||
|
{ name = "xdecor_cauldron_top_anim_boiling_water.png",
|
||||||
|
animation = {type="vertical_frames", length=3.0} },
|
||||||
|
"xdecor_cauldron_sides.png"
|
||||||
|
},
|
||||||
|
collision_box = cauldron_cbox
|
||||||
})
|
})
|
||||||
|
|
||||||
xdecor.register("cauldron_soup", {
|
xdecor.register("cauldron_soup", {
|
||||||
groups = {cracky=2, oddly_breakable_by_hand=1, not_in_creative_inventory=1},
|
groups = {cracky=2, oddly_breakable_by_hand=1, not_in_creative_inventory=1},
|
||||||
on_rotate = screwdriver.rotate_simple,
|
on_rotate = screwdriver.rotate_simple,
|
||||||
drop = "xdecor:cauldron_empty",
|
drop = "xdecor:cauldron_empty",
|
||||||
infotext = "The soup is ready, use a bowl to eat it",
|
infotext = "Cauldron (active) - Use a bowl to eat the soup",
|
||||||
damage_per_second = 2,
|
damage_per_second = 2,
|
||||||
tiles = {
|
tiles = {
|
||||||
{ name = "xdecor_cauldron_top_anim_soup.png",
|
{ name = "xdecor_cauldron_top_anim_soup.png",
|
||||||
animation = {type="vertical_frames", length=3.0} },
|
animation = {type="vertical_frames", length=3.0} },
|
||||||
"xdecor_cauldron_sides.png"
|
"xdecor_cauldron_sides.png"
|
||||||
},
|
},
|
||||||
|
collision_box = cauldron_cbox,
|
||||||
on_rightclick = function(pos, node, clicker, itemstack, _)
|
on_rightclick = function(pos, node, clicker, itemstack, _)
|
||||||
local inv = clicker:get_inventory()
|
local inv = clicker:get_inventory()
|
||||||
if clicker:get_wielded_item():get_name() == "xdecor:bowl" then
|
if clicker:get_wielded_item():get_name() == "xdecor:bowl" then
|
||||||
@ -91,7 +96,7 @@ minetest.register_abm({
|
|||||||
action = function(pos, node, _, _)
|
action = function(pos, node, _, _)
|
||||||
local objs = nil
|
local objs = nil
|
||||||
local ingredients = {}
|
local ingredients = {}
|
||||||
objs = minetest.get_objects_inside_radius(pos, .5)
|
objs = minetest.get_objects_inside_radius(pos, 0.5)
|
||||||
if not objs then return end
|
if not objs then return end
|
||||||
|
|
||||||
for _, obj in pairs(objs) do
|
for _, obj in pairs(objs) do
|
||||||
|
@ -35,7 +35,7 @@ minetest.register_entity("xdecor:f_item", {
|
|||||||
|
|
||||||
local remove_item = function(pos, node)
|
local remove_item = function(pos, node)
|
||||||
local objs = nil
|
local objs = nil
|
||||||
objs = minetest.get_objects_inside_radius(pos, .5)
|
objs = minetest.get_objects_inside_radius(pos, 0.5)
|
||||||
if not objs then return end
|
if not objs then return end
|
||||||
|
|
||||||
for _, obj in pairs(objs) do
|
for _, obj in pairs(objs) do
|
||||||
|
Loading…
Reference in New Issue
Block a user