add a few new shapes to the table saw: (#67)

* 1/16 slab, L-shaped (two sides)
* 1/16 slab, corner-shaped (three sides)
* 1/16 slab, U-shaped (three sides)
This commit is contained in:
Vanessa Ezekowitz 2017-02-21 16:58:40 -05:00 committed by Hugo Locurcio
parent 6f033c1695
commit 0569ff9683
2 changed files with 47 additions and 10 deletions

View File

@ -26,9 +26,9 @@ circular_saw.cost_in_microblocks = {
1, 1, 1, 1, 1, 1, 1, 2, 1, 1, 1, 1, 1, 1, 1, 2,
2, 3, 2, 4, 2, 4, 5, 6, 2, 3, 2, 4, 2, 4, 5, 6,
7, 1, 1, 2, 4, 6, 7, 8, 7, 1, 1, 2, 4, 6, 7, 8,
3, 1, 1, 2, 4, 4, 2, 6, 1, 2, 2, 3, 1, 1, 2, 4,
7, 3, 7, 7, 4, 8, 3, 2, 4, 2, 6, 7, 3, 7, 7, 4,
6, 2, 1, 3, 4, 8, 3, 2, 6, 2, 1, 3, 4
} }
circular_saw.names = { circular_saw.names = {
@ -40,6 +40,7 @@ circular_saw.names = {
{"panel", "_4"}, {"panel", "_4"},
{"micro", ""}, {"micro", ""},
{"panel", ""}, {"panel", ""},
{"micro", "_12"}, {"micro", "_12"},
{"panel", "_12"}, {"panel", "_12"},
{"micro", "_14"}, {"micro", "_14"},
@ -48,6 +49,7 @@ circular_saw.names = {
{"panel", "_15"}, {"panel", "_15"},
{"stair", "_outer"}, {"stair", "_outer"},
{"stair", ""}, {"stair", ""},
{"stair", "_inner"}, {"stair", "_inner"},
{"slab", "_1"}, {"slab", "_1"},
{"slab", "_2"}, {"slab", "_2"},
@ -56,11 +58,16 @@ circular_saw.names = {
{"slab", "_three_quarter"}, {"slab", "_three_quarter"},
{"slab", "_14"}, {"slab", "_14"},
{"slab", "_15"}, {"slab", "_15"},
{"slab", "_two_sides"},
{"slab", "_three_sides"},
{"slab", "_three_sides_u"},
{"stair", "_half"}, {"stair", "_half"},
{"stair", "_alt_1"}, {"stair", "_alt_1"},
{"stair", "_alt_2"}, {"stair", "_alt_2"},
{"stair", "_alt_4"}, {"stair", "_alt_4"},
{"stair", "_alt"}, {"stair", "_alt"},
{"slope", ""}, {"slope", ""},
{"slope", "_half"}, {"slope", "_half"},
{"slope", "_half_raised"}, {"slope", "_half_raised"},
@ -69,6 +76,7 @@ circular_saw.names = {
{"slope", "_inner_half_raised"}, {"slope", "_inner_half_raised"},
{"slope", "_inner_cut"}, {"slope", "_inner_cut"},
{"slope", "_inner_cut_half"}, {"slope", "_inner_cut_half"},
{"slope", "_inner_cut_half_raised"}, {"slope", "_inner_cut_half_raised"},
{"slope", "_outer"}, {"slope", "_outer"},
{"slope", "_outer_half"}, {"slope", "_outer_half"},

View File

@ -28,6 +28,20 @@ local slabs_defs = {
["_2"] = 2, ["_2"] = 2,
["_14"] = 14, ["_14"] = 14,
["_15"] = 15, ["_15"] = 15,
["_two_sides"] = {
{ -0.5, -0.5, -0.5, 0.5, -7/16, 7/16 },
{ -0.5, -0.5, 7/16, 0.5, 0.5, 0.5 }
},
["_three_sides"] = {
{ -7/16, -0.5, -0.5, 0.5, -7/16, 7/16 },
{ -7/16, -0.5, 7/16, 0.5, 0.5, 0.5 },
{ -0.5, -0.5, -0.5, -7/16, 0.5, 0.5 }
},
["_three_sides_u"] = {
{ -0.5, -0.5, -0.5, 0.5, 0.5, -7/16 },
{ -0.5, -0.5, -7/16, 0.5, -7/16, 7/16 },
{ -0.5, -0.5, 7/16, 0.5, 0.5, 0.5 }
}
} }
function stairsplus:register_slab_alias(modname_old, subname_old, modname_new, subname_new) function stairsplus:register_slab_alias(modname_old, subname_old, modname_new, subname_new)
@ -47,21 +61,36 @@ end
function stairsplus:register_slab(modname, subname, recipeitem, fields) function stairsplus:register_slab(modname, subname, recipeitem, fields)
local defs = stairsplus.copytable(slabs_defs) local defs = stairsplus.copytable(slabs_defs)
local desc_base = S("%s Slab"):format(fields.description) local desc_base = S("%s Slab"):format(fields.description)
for alternate, num in pairs(defs) do for alternate, shape in pairs(defs) do
local def = {
local def = {}
if type(shape) ~= "table" then
def = {
node_box = { node_box = {
type = "fixed", type = "fixed",
fixed = {-0.5, -0.5, -0.5, 0.5, (num/16)-0.5, 0.5}, fixed = {-0.5, -0.5, -0.5, 0.5, (shape/16)-0.5, 0.5},
},
description = ("%s (%d/16)"):format(desc_base, shape)
} }
else
def = {
node_box = {
type = "fixed",
fixed = shape,
},
description = desc_base
} }
end
for k, v in pairs(fields) do for k, v in pairs(fields) do
def[k] = v def[k] = v
end end
def.drawtype = "nodebox" def.drawtype = "nodebox"
def.paramtype = "light" def.paramtype = "light"
def.paramtype2 = def.paramtype2 or "facedir" def.paramtype2 = def.paramtype2 or "facedir"
def.on_place = minetest.rotate_node def.on_place = minetest.rotate_node
def.description = ("%s (%d/16)"):format(desc_base, num)
def.groups = stairsplus:prepare_groups(fields.groups) def.groups = stairsplus:prepare_groups(fields.groups)
if fields.drop and not (type(fields.drop) == "table") then if fields.drop and not (type(fields.drop) == "table") then
def.drop = modname.. ":slab_" .. fields.drop .. alternate def.drop = modname.. ":slab_" .. fields.drop .. alternate