mirror of
https://github.com/minetest-mods/technic.git
synced 2024-12-25 02:10:30 +01:00
add custom collision and selection box handling to CNC machine
also clean up formatting of surrounding code
This commit is contained in:
parent
7e92fe0a46
commit
ec73a8508f
@ -13,119 +13,248 @@ technic.cnc = {}
|
|||||||
technic.cnc.programs = {
|
technic.cnc.programs = {
|
||||||
{ suffix = "technic_cnc_stick",
|
{ suffix = "technic_cnc_stick",
|
||||||
model = {-0.15, -0.5, -0.15, 0.15, 0.5, 0.15},
|
model = {-0.15, -0.5, -0.15, 0.15, 0.5, 0.15},
|
||||||
desc = S("Stick")},
|
desc = S("Stick")
|
||||||
|
},
|
||||||
|
|
||||||
{ suffix = "technic_cnc_element_end_double",
|
{ suffix = "technic_cnc_element_end_double",
|
||||||
model = {-0.3, -0.5, -0.3, 0.3, 0.5, 0.5},
|
model = {-0.3, -0.5, -0.3, 0.3, 0.5, 0.5},
|
||||||
desc = S("Element End Double")},
|
desc = S("Element End Double")
|
||||||
|
},
|
||||||
|
|
||||||
{ suffix = "technic_cnc_element_cross_double",
|
{ suffix = "technic_cnc_element_cross_double",
|
||||||
model = {
|
model = {
|
||||||
{0.3, -0.5, -0.3, 0.5, 0.5, 0.3},
|
{0.3, -0.5, -0.3, 0.5, 0.5, 0.3},
|
||||||
{-0.3, -0.5, -0.5, 0.3, 0.5, 0.5},
|
{-0.3, -0.5, -0.5, 0.3, 0.5, 0.5},
|
||||||
{-0.5, -0.5, -0.3, -0.3, 0.5, 0.3}},
|
{-0.5, -0.5, -0.3, -0.3, 0.5, 0.3}},
|
||||||
desc = S("Element Cross Double")},
|
desc = S("Element Cross Double")
|
||||||
|
},
|
||||||
|
|
||||||
{ suffix = "technic_cnc_element_t_double",
|
{ suffix = "technic_cnc_element_t_double",
|
||||||
model = {
|
model = {
|
||||||
{-0.3, -0.5, -0.5, 0.3, 0.5, 0.3},
|
{-0.3, -0.5, -0.5, 0.3, 0.5, 0.3},
|
||||||
{-0.5, -0.5, -0.3, -0.3, 0.5, 0.3},
|
{-0.5, -0.5, -0.3, -0.3, 0.5, 0.3},
|
||||||
{0.3, -0.5, -0.3, 0.5, 0.5, 0.3}},
|
{0.3, -0.5, -0.3, 0.5, 0.5, 0.3}},
|
||||||
desc = S("Element T Double")},
|
desc = S("Element T Double")
|
||||||
|
},
|
||||||
|
|
||||||
{ suffix = "technic_cnc_element_edge_double",
|
{ suffix = "technic_cnc_element_edge_double",
|
||||||
model = {
|
model = {
|
||||||
{-0.3, -0.5, -0.5, 0.3, 0.5, 0.3},
|
{-0.3, -0.5, -0.5, 0.3, 0.5, 0.3},
|
||||||
{-0.5, -0.5, -0.3, -0.3, 0.5, 0.3}},
|
{-0.5, -0.5, -0.3, -0.3, 0.5, 0.3}},
|
||||||
desc = S("Element Edge Double")},
|
desc = S("Element Edge Double")
|
||||||
|
},
|
||||||
|
|
||||||
{ suffix = "technic_cnc_element_straight_double",
|
{ suffix = "technic_cnc_element_straight_double",
|
||||||
model = {-0.3, -0.5, -0.5, 0.3, 0.5, 0.5},
|
model = {-0.3, -0.5, -0.5, 0.3, 0.5, 0.5},
|
||||||
desc = S("Element Straight Double")},
|
desc = S("Element Straight Double")
|
||||||
|
},
|
||||||
|
|
||||||
{ suffix = "technic_cnc_element_end",
|
{ suffix = "technic_cnc_element_end",
|
||||||
model = {-0.3, -0.5, -0.3, 0.3, 0, 0.5},
|
model = {-0.3, -0.5, -0.3, 0.3, 0, 0.5},
|
||||||
desc = S("Element End")},
|
desc = S("Element End")
|
||||||
|
},
|
||||||
|
|
||||||
{ suffix = "technic_cnc_element_cross",
|
{ suffix = "technic_cnc_element_cross",
|
||||||
model = {
|
model = {
|
||||||
{0.3, -0.5, -0.3, 0.5, 0, 0.3},
|
{0.3, -0.5, -0.3, 0.5, 0, 0.3},
|
||||||
{-0.3, -0.5, -0.5, 0.3, 0, 0.5},
|
{-0.3, -0.5, -0.5, 0.3, 0, 0.5},
|
||||||
{-0.5, -0.5, -0.3, -0.3, 0, 0.3}},
|
{-0.5, -0.5, -0.3, -0.3, 0, 0.3}},
|
||||||
desc = S("Element Cross")},
|
desc = S("Element Cross")
|
||||||
|
},
|
||||||
|
|
||||||
{ suffix = "technic_cnc_element_t",
|
{ suffix = "technic_cnc_element_t",
|
||||||
model = {
|
model = {
|
||||||
{-0.3, -0.5, -0.5, 0.3, 0, 0.3},
|
{-0.3, -0.5, -0.5, 0.3, 0, 0.3},
|
||||||
{-0.5, -0.5, -0.3, -0.3, 0, 0.3},
|
{-0.5, -0.5, -0.3, -0.3, 0, 0.3},
|
||||||
{0.3, -0.5, -0.3, 0.5, 0, 0.3}},
|
{0.3, -0.5, -0.3, 0.5, 0, 0.3}},
|
||||||
desc = S("Element T")},
|
desc = S("Element T")
|
||||||
|
},
|
||||||
|
|
||||||
{ suffix = "technic_cnc_element_edge",
|
{ suffix = "technic_cnc_element_edge",
|
||||||
model = {
|
model = {
|
||||||
{-0.3, -0.5, -0.5, 0.3, 0, 0.3},
|
{-0.3, -0.5, -0.5, 0.3, 0, 0.3},
|
||||||
{-0.5, -0.5, -0.3, -0.3, 0, 0.3}},
|
{-0.5, -0.5, -0.3, -0.3, 0, 0.3}},
|
||||||
desc = S("Element Edge")},
|
desc = S("Element Edge")
|
||||||
|
},
|
||||||
|
|
||||||
{ suffix = "technic_cnc_element_straight",
|
{ suffix = "technic_cnc_element_straight",
|
||||||
model = {-0.3, -0.5, -0.5, 0.3, 0, 0.5},
|
model = {-0.3, -0.5, -0.5, 0.3, 0, 0.5},
|
||||||
desc = S("Element Straight")},
|
desc = S("Element Straight")
|
||||||
|
},
|
||||||
|
|
||||||
{ suffix = "technic_cnc_sphere",
|
{ suffix = "technic_cnc_sphere",
|
||||||
model = "technic_oblatesphere.obj",
|
model = "technic_oblatesphere.obj",
|
||||||
desc = S("Oblate Sphere")},
|
desc = S("Oblate Sphere"),
|
||||||
|
cbox = {
|
||||||
|
type = "fixed",
|
||||||
|
fixed = {
|
||||||
|
{ -6/16, 4/16, -6/16, 6/16, 8/16, 6/16 },
|
||||||
|
{ -8/16, -4/16, -8/16, 8/16, 4/16, 8/16 },
|
||||||
|
{ -6/16, -8/16, -6/16, 6/16, -4/16, 6/16 }
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
{ suffix = "technic_cnc_cylinder_horizontal",
|
{ suffix = "technic_cnc_cylinder_horizontal",
|
||||||
model = "technic_cylinder_horizontal.obj",
|
model = "technic_cylinder_horizontal.obj",
|
||||||
desc = S("Horizontal Cylinder")},
|
desc = S("Horizontal Cylinder")
|
||||||
|
},
|
||||||
|
|
||||||
{ suffix = "technic_cnc_cylinder",
|
{ suffix = "technic_cnc_cylinder",
|
||||||
model = "technic_cylinder.obj",
|
model = "technic_cylinder.obj",
|
||||||
desc = S("Cylinder")},
|
desc = S("Cylinder")
|
||||||
|
},
|
||||||
|
|
||||||
{ suffix = "technic_cnc_twocurvededge",
|
{ suffix = "technic_cnc_twocurvededge",
|
||||||
model = "technic_two_curved_edge.obj",
|
model = "technic_two_curved_edge.obj",
|
||||||
desc = S("Two Curved Edge/Corner Block")},
|
desc = S("Two Curved Edge/Corner Block")
|
||||||
|
},
|
||||||
|
|
||||||
{ suffix = "technic_cnc_onecurvededge",
|
{ suffix = "technic_cnc_onecurvededge",
|
||||||
model = "technic_one_curved_edge.obj",
|
model = "technic_one_curved_edge.obj",
|
||||||
desc = S("One Curved Edge Block")},
|
desc = S("One Curved Edge Block")
|
||||||
|
},
|
||||||
|
|
||||||
{ suffix = "technic_cnc_spike",
|
{ suffix = "technic_cnc_spike",
|
||||||
model = "technic_pyramid_spike.obj",
|
model = "technic_pyramid_spike.obj",
|
||||||
desc = S("Spike")},
|
desc = S("Spike"),
|
||||||
|
cbox = {
|
||||||
|
type = "fixed",
|
||||||
|
fixed = {
|
||||||
|
{ -2/16, 4/16, -2/16, 2/16, 8/16, 2/16 },
|
||||||
|
{ -4/16, 0, -4/16, 4/16, 4/16, 4/16 },
|
||||||
|
{ -6/16, -4/16, -6/16, 6/16, 0, 6/16 },
|
||||||
|
{ -8/16, -8/16, -8/16, 8/16, -4/16, 8/16 }
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
{ suffix = "technic_cnc_pyramid",
|
{ suffix = "technic_cnc_pyramid",
|
||||||
model = "technic_pyramid.obj",
|
model = "technic_pyramid.obj",
|
||||||
desc = S("Pyramid")},
|
desc = S("Pyramid"),
|
||||||
|
cbox = {
|
||||||
|
type = "fixed",
|
||||||
|
fixed = {
|
||||||
|
{ -2/16, -2/16, -2/16, 2/16, 0, 2/16 },
|
||||||
|
{ -4/16, -4/16, -4/16, 4/16, -2/16, 4/16 },
|
||||||
|
{ -6/16, -6/16, -6/16, 6/16, -4/16, 6/16 },
|
||||||
|
{ -8/16, -8/16, -8/16, 8/16, -6/16, 8/16 }
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
{ suffix = "technic_cnc_slope_inner_edge_upsdown",
|
{ suffix = "technic_cnc_slope_inner_edge_upsdown",
|
||||||
model = "technic_innercorner_upsdown.obj",
|
model = "technic_innercorner_upsdown.obj",
|
||||||
desc = S("Slope Upside Down Inner Edge/Corner")},
|
desc = S("Slope Upside Down Inner Edge/Corner"),
|
||||||
|
sbox = {
|
||||||
|
type = "fixed",
|
||||||
|
fixed = { -0.5, -0.5, -0.5, 0.5, 0.5, 0.5 }
|
||||||
|
},
|
||||||
|
cbox = {
|
||||||
|
type = "fixed",
|
||||||
|
fixed = {
|
||||||
|
{ 0.25, -0.25, -0.5, 0.5, -0.5, 0.5 },
|
||||||
|
{ -0.5, -0.25, 0.25, 0.5, -0.5, 0.5 },
|
||||||
|
{ 0, 0, -0.5, 0.5, -0.25, 0.5 },
|
||||||
|
{ -0.5, 0, 0, 0.5, -0.25, 0.5 },
|
||||||
|
{ -0.25, 0.25, -0.5, 0.5, 0, -0.25 },
|
||||||
|
{ -0.5, 0.25, -0.25, 0.5, 0, 0.5 },
|
||||||
|
{ -0.5, 0.5, -0.5, 0.5, 0.25, 0.5 }
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
{ suffix = "technic_cnc_slope_edge_upsdown",
|
{ suffix = "technic_cnc_slope_edge_upsdown",
|
||||||
model = "technic_outercorner_upsdown.obj",
|
model = "technic_outercorner_upsdown.obj",
|
||||||
desc = S("Slope Upside Down Outer Edge/Corner")},
|
desc = S("Slope Upside Down Outer Edge/Corner"),
|
||||||
|
cbox = {
|
||||||
|
type = "fixed",
|
||||||
|
fixed = {
|
||||||
|
{ -8/16, 8/16, -8/16, 8/16, 4/16, 8/16 },
|
||||||
|
{ -4/16, 4/16, -4/16, 8/16, 0, 8/16 },
|
||||||
|
{ 0, 0, 0, 8/16, -4/16, 8/16 },
|
||||||
|
{ 4/16, -4/16, 4/16, 8/16, -8/16, 8/16 }
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
{ suffix = "technic_cnc_slope_inner_edge",
|
{ suffix = "technic_cnc_slope_inner_edge",
|
||||||
model = "technic_innercorner.obj",
|
model = "technic_innercorner.obj",
|
||||||
desc = S("Slope Inner Edge/Corner")},
|
desc = S("Slope Inner Edge/Corner"),
|
||||||
|
sbox = {
|
||||||
|
type = "fixed",
|
||||||
|
fixed = { -0.5, -0.5, -0.5, 0.5, 0.5, 0.5 }
|
||||||
|
},
|
||||||
|
cbox = {
|
||||||
|
type = "fixed",
|
||||||
|
fixed = {
|
||||||
|
{ -0.5, -0.5, -0.5, 0.5, -0.25, 0.5 },
|
||||||
|
{ -0.5, -0.25, -0.25, 0.5, 0, 0.5 },
|
||||||
|
{ -0.25, -0.25, -0.5, 0.5, 0, -0.25 },
|
||||||
|
{ -0.5, 0, 0, 0.5, 0.25, 0.5 },
|
||||||
|
{ 0, 0, -0.5, 0.5, 0.25, 0.5 },
|
||||||
|
{ -0.5, 0.25, 0.25, 0.5, 0.5, 0.5 },
|
||||||
|
{ 0.25, 0.25, -0.5, 0.5, 0.5, 0.5 }
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
{ suffix = "technic_cnc_slope_edge",
|
{ suffix = "technic_cnc_slope_edge",
|
||||||
model = "technic_outercorner.obj",
|
model = "technic_outercorner.obj",
|
||||||
desc = S("Slope Outer Edge/Corner")},
|
desc = S("Slope Outer Edge/Corner"),
|
||||||
|
cbox = {
|
||||||
|
type = "fixed",
|
||||||
|
fixed = {
|
||||||
|
{ 4/16, 4/16, 4/16, 8/16, 8/16, 8/16 },
|
||||||
|
{ 0, 0, 0, 8/16, 4/16, 8/16 },
|
||||||
|
{ -4/16, -4/16, -4/16, 8/16, 0, 8/16 },
|
||||||
|
{ -8/16, -8/16, -8/16, 8/16, -4/16, 8/16 }
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
{ suffix = "technic_cnc_slope_upsdown",
|
{ suffix = "technic_cnc_slope_upsdown",
|
||||||
model = "technic_slope_upsdown.obj",
|
model = "technic_slope_upsdown.obj",
|
||||||
desc = S("Slope Upside Down")},
|
desc = S("Slope Upside Down"),
|
||||||
|
cbox = {
|
||||||
|
type = "fixed",
|
||||||
|
fixed = {
|
||||||
|
{ -8/16, 8/16, -8/16, 8/16, 4/16, 8/16 },
|
||||||
|
{ -8/16, 4/16, -4/16, 8/16, 0, 8/16 },
|
||||||
|
{ -8/16, 0, 0, 8/16, -4/16, 8/16 },
|
||||||
|
{ -8/16, -4/16, 4/16, 8/16, -8/16, 8/16 }
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
{ suffix = "technic_cnc_slope_lying",
|
{ suffix = "technic_cnc_slope_lying",
|
||||||
model = "technic_slope_horizontal.obj",
|
model = "technic_slope_horizontal.obj",
|
||||||
desc = S("Slope Lying")},
|
desc = S("Slope Lying"),
|
||||||
|
cbox = {
|
||||||
|
type = "fixed",
|
||||||
|
fixed = {
|
||||||
|
{ 4/16, -8/16, 4/16, 8/16, 8/16, 8/16 },
|
||||||
|
{ 0, -8/16, 0, 4/16, 8/16, 8/16 },
|
||||||
|
{ -4/16, -8/16, -4/16, 0, 8/16, 8/16 },
|
||||||
|
{ -8/16, -8/16, -8/16, -4/16, 8/16, 8/16 }
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
{ suffix = "technic_cnc_slope",
|
{ suffix = "technic_cnc_slope",
|
||||||
model = "technic_slope.obj",
|
model = "technic_slope.obj",
|
||||||
desc = S("Slope")},
|
desc = S("Slope"),
|
||||||
|
cbox = {
|
||||||
|
type = "fixed",
|
||||||
|
fixed = {
|
||||||
|
{ -8/16, 4/16, 4/16, 8/16, 8/16, 8/16 },
|
||||||
|
{ -8/16, 0, 0, 8/16, 4/16, 8/16 },
|
||||||
|
{ -8/16, -4/16, -4/16, 8/16, 0, 8/16 },
|
||||||
|
{ -8/16, -8/16, -8/16, 8/16, -4/16, 8/16 }
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
-- Allow disabling certain programs for some node. Default is allowing all types for all nodes
|
-- Allow disabling certain programs for some node. Default is allowing all types for all nodes
|
||||||
@ -139,7 +268,7 @@ technic.cnc.programs_disable = {
|
|||||||
}
|
}
|
||||||
|
|
||||||
-- Generic function for registering all the different node types
|
-- Generic function for registering all the different node types
|
||||||
function technic.cnc.register_program(recipeitem, suffix, model, groups, images, description)
|
function technic.cnc.register_program(recipeitem, suffix, model, groups, images, description, cbox, sbox)
|
||||||
|
|
||||||
local dtype
|
local dtype
|
||||||
local nodeboxdef
|
local nodeboxdef
|
||||||
@ -156,6 +285,8 @@ function technic.cnc.register_program(recipeitem, suffix, model, groups, images,
|
|||||||
meshdef = model
|
meshdef = model
|
||||||
end
|
end
|
||||||
|
|
||||||
|
if cbox and not sbox then sbox = cbox end
|
||||||
|
|
||||||
minetest.register_node(":"..recipeitem.."_"..suffix, {
|
minetest.register_node(":"..recipeitem.."_"..suffix, {
|
||||||
description = description,
|
description = description,
|
||||||
drawtype = dtype,
|
drawtype = dtype,
|
||||||
@ -166,6 +297,8 @@ function technic.cnc.register_program(recipeitem, suffix, model, groups, images,
|
|||||||
paramtype2 = "facedir",
|
paramtype2 = "facedir",
|
||||||
walkable = true,
|
walkable = true,
|
||||||
groups = groups,
|
groups = groups,
|
||||||
|
selection_box = sbox,
|
||||||
|
collision_box = cbox
|
||||||
})
|
})
|
||||||
end
|
end
|
||||||
|
|
||||||
@ -183,7 +316,8 @@ function technic.cnc.register_all(recipeitem, groups, images, description)
|
|||||||
end
|
end
|
||||||
-- Create the node if it passes the test
|
-- Create the node if it passes the test
|
||||||
if do_register then
|
if do_register then
|
||||||
technic.cnc.register_program(recipeitem, data.suffix, data.model, groups, images, description.." "..data.desc)
|
technic.cnc.register_program(recipeitem, data.suffix, data.model,
|
||||||
|
groups, images, description.." "..data.desc, data.cbox, data.sbox)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
Loading…
Reference in New Issue
Block a user