Added normal fences
parent
de71cfccfb
commit
c98b783e09
|
@ -46,3 +46,18 @@ function set_node_instead_air(pos, node)
|
|||
minetest.env:set_node(pos, node)
|
||||
end
|
||||
end
|
||||
|
||||
function merge(lhs, rhs)
|
||||
local merged_table = {}
|
||||
for _, v in ipairs(lhs) do
|
||||
table.insert(merged_table, v)
|
||||
end
|
||||
for _, v in ipairs(rhs) do
|
||||
table.insert(merged_table, v)
|
||||
end
|
||||
return merged_table
|
||||
end
|
||||
|
||||
function rshift(x, by)
|
||||
return math.floor(x / 2 ^ by)
|
||||
end
|
|
@ -0,0 +1,2 @@
|
|||
core
|
||||
trees
|
|
@ -0,0 +1,106 @@
|
|||
local directions = {
|
||||
{x = 1, y = 0, z = 0},
|
||||
{x = 0, y = 0, z = 1},
|
||||
{x = -1, y = 0, z = 0},
|
||||
{x = 0, y = 0, z = -1},
|
||||
}
|
||||
|
||||
local function update_fence(pos)
|
||||
if minetest.get_node_group(minetest.env:get_node(pos).name, "fence") ~= 1 then
|
||||
return
|
||||
end
|
||||
local sum = 0
|
||||
for i = 1, 4 do
|
||||
local node = minetest.env:get_node({x = pos.x + directions[i].x, y = pos.y + directions[i].y, z = pos.z + directions[i].z})
|
||||
if minetest.registered_nodes[node.name].walkable ~= false then
|
||||
sum = sum + 2 ^ (i - 1)
|
||||
end
|
||||
end
|
||||
local material = realtest.registered_trees_list[minetest.get_node_group(minetest.env:get_node(pos).name, "material")]:remove_modname_prefix()
|
||||
minetest.env:add_node(pos, {name = "fences:"..material.."_fence_"..sum})
|
||||
end
|
||||
|
||||
local function update_nearby(pos)
|
||||
for i = 1,4 do
|
||||
update_fence({x = pos.x + directions[i].x, y = pos.y + directions[i].y, z = pos.z + directions[i].z})
|
||||
end
|
||||
end
|
||||
|
||||
local blocks = {
|
||||
{{0, 0.25, -0.06, 0.5, 0.4, 0.06}, {0, -0.15, -0.06, 0.5, 0, 0.06}},
|
||||
{{-0.06, 0.25, 0, 0.06, 0.4, 0.5}, {-0.06, -0.15, 0, 0.06, 0, 0.5}},
|
||||
{{-0.5, 0.25, -0.06, 0, 0.4, 0.06}, {-0.5, -0.15, -0.06, 0, 0, 0.06}},
|
||||
{{-0.06, 0.25, -0.5, 0.06, 0.4, 0}, {-0.06, -0.15, -0.5, 0.06, 0, 0}}
|
||||
}
|
||||
|
||||
local limiters = {
|
||||
{{0, 1.0, -0.1, 0.5, 1.0, -0.0999}, {0, 1.0, 0.0999, 0.5, 1.0, 0.1}},
|
||||
{{-0.1, 1.0, 0, -0.0999, 1.0, 0.5}, {0.0999, 1.0, 0, 0.1, 1.0, 0.5}},
|
||||
{{-0.5, 1.0, -0.1, 0, 1.0, -0.0999}, {-0.5, 1.0, 0.0999, 0, 1.0, 0.1}},
|
||||
{{-0.1, 1.0, -0.5, -0.0999, 1.0, 0}, {0.0999, 1.0, -0.5, 0.1, 1.0, 0}},
|
||||
}
|
||||
|
||||
local base = {-0.1, -0.5, -0.1, 0.1, 0.5, 0.1}
|
||||
|
||||
for j, tree_name in ipairs(realtest.registered_trees_list) do
|
||||
local tree = realtest.registered_trees[tree_name]
|
||||
for i = 0, 15 do
|
||||
local take = {base}
|
||||
local take_with_limits = {base}
|
||||
for j = 1, 4 do
|
||||
if rshift(i, j - 1) % 2 == 1 then
|
||||
take = merge(take, blocks[j])
|
||||
take_with_limits = merge(take_with_limits, merge(blocks[j], limiters[j]))
|
||||
end
|
||||
end
|
||||
|
||||
minetest.register_node("fences:"..tree.name:remove_modname_prefix().."_fence_"..i, {
|
||||
drawtype = "nodebox",
|
||||
tile_images = {tree.textures.planks},
|
||||
paramtype = "light",
|
||||
groups = {snappy=2,choppy=2,oddly_breakable_by_hand=2,drop_on_dig=1,fence=1,material=j},
|
||||
sunlight_propagates = true,
|
||||
drop = "fences:"..tree.name:remove_modname_prefix().."_fence",
|
||||
node_box = {
|
||||
type = "fixed",
|
||||
fixed = take_with_limits
|
||||
},
|
||||
selection_box = {
|
||||
type = "fixed",
|
||||
fixed = take
|
||||
},
|
||||
sounds = default.node_sound_wood_defaults(),
|
||||
})
|
||||
end
|
||||
|
||||
minetest.register_node("fences:"..tree.name:remove_modname_prefix().."_fence", {
|
||||
description = tree.description.." Fence",
|
||||
drawtype = "nodebox",
|
||||
tile_images = {tree.textures.planks},
|
||||
paramtype = "light",
|
||||
groups = {snappy=2,coppy=2,oddly_breakable_by_hand=2,drop_on_dig=1,fence=1,material=j},
|
||||
sunlight_propagates = true,
|
||||
node_box = {
|
||||
type = "fixed",
|
||||
fixed = {-0.1, -0.5, -0.1, 0.1, 0.5, 0.1}
|
||||
},
|
||||
selection_box = {
|
||||
type = "fixed",
|
||||
fixed = {-0.1, -0.5, -0.1, 0.1, 0.5, 0.1}
|
||||
},
|
||||
on_construct = update_fence
|
||||
})
|
||||
|
||||
minetest.register_alias(tree.name.."_fence","fences:"..tree.name:remove_modname_prefix().."_fence")
|
||||
|
||||
minetest.register_craft({
|
||||
output = "fences:"..tree.name:remove_modname_prefix().."_fence 2",
|
||||
recipe = {
|
||||
{tree.name.."_plank", tree.name.."_plank", tree.name.."_plank"},
|
||||
{tree.name.."_plank", tree.name.."_plank", tree.name.."_plank"}
|
||||
}
|
||||
})
|
||||
end
|
||||
|
||||
minetest.register_on_placenode(update_nearby)
|
||||
minetest.register_on_dignode(update_nearby)
|
|
@ -190,20 +190,6 @@ function realtest.register_tree(name, TreeDef)
|
|||
end,
|
||||
})
|
||||
|
||||
minetest.register_node(tree.name.."_fence", {
|
||||
description = tree.description.." Fence",
|
||||
drawtype = "fencelike",
|
||||
tiles = {tree.textures.planks},
|
||||
paramtype = "light",
|
||||
is_ground_content = true,
|
||||
selection_box = {
|
||||
type = "fixed",
|
||||
fixed = {-1/7, -1/2, -1/7, 1/7, 1/2, 1/7},
|
||||
},
|
||||
groups = {snappy=1,choppy=2,oddly_breakable_by_hand=2,flammable=2},
|
||||
sounds = default.node_sound_wood_defaults(),
|
||||
})
|
||||
|
||||
minetest.register_node(tree.name.."_stair", {
|
||||
description = tree.description.." Stair",
|
||||
drawtype = "nodebox",
|
||||
|
@ -469,14 +455,6 @@ function realtest.register_tree(name, TreeDef)
|
|||
},
|
||||
})
|
||||
|
||||
minetest.register_craft({
|
||||
output = tree.name.."_fence 2",
|
||||
recipe = {
|
||||
{tree.name.."_plank", tree.name.."_plank", tree.name.."_plank"},
|
||||
{tree.name.."_plank", tree.name.."_plank", tree.name.."_plank"},
|
||||
}
|
||||
})
|
||||
|
||||
minetest.register_craft({
|
||||
output = "default:sign_wall",
|
||||
recipe = {
|
||||
|
|
Loading…
Reference in New Issue