1
0
Fork 0
MineClone2_For_PRs/mods/ITEMS/mcl_walls/init.lua

240 lines
5.8 KiB
Lua
Raw Normal View History

mcl_walls = {}
2015-06-29 19:55:56 +02:00
local function rshift(x, by)
2015-07-04 15:32:26 +02:00
return math.floor(x / 2 ^ by)
2015-06-29 19:55:56 +02:00
end
local directions = {
2015-07-04 15:32:26 +02:00
{x = 1, y = 0, z = 0},
{x = 0, y = 0, z = 1},
{x = -1, y = 0, z = 0},
{x = 0, y = 0, z = -1},
{x = 0, y = -1, z = 0},
2015-06-29 19:55:56 +02:00
}
2015-07-04 15:32:26 +02:00
local function update_wall(pos)
local thisnode = minetest.get_node(pos)
2015-07-04 15:32:26 +02:00
2017-01-27 18:15:36 +01:00
if minetest.get_item_group(thisnode.name, "wall") == 0 then
2015-06-29 19:55:56 +02:00
return
end
2015-07-04 15:32:26 +02:00
-- Get the node's base name, including the underscore since we will need it
2017-01-27 18:15:36 +01:00
local colonpos = thisnode.name:find(":")
local underscorepos
local itemname, basename, modname
2017-01-27 18:15:36 +01:00
if colonpos ~= nil then
itemname = thisnode.name:sub(colonpos+1)
modname = thisnode.name:sub(1, colonpos-1)
2017-01-27 18:15:36 +01:00
end
underscorepos = itemname:find("_")
if underscorepos == nil then -- New wall
2015-07-04 15:32:26 +02:00
basename = thisnode.name .. "_"
else -- Already placed wall
basename = modname .. ":" .. itemname:sub(1, underscorepos)
2015-07-04 15:32:26 +02:00
end
local sum = 0
-- Neighbouring walkable nodes
for i = 1, 4 do
local dir = directions[i]
local node = minetest.get_node({x = pos.x + dir.x, y = pos.y + dir.y, z = pos.z + dir.z})
2015-07-04 15:32:26 +02:00
if minetest.registered_nodes[node.name].walkable then
sum = sum + 2 ^ (i - 1)
end
end
-- Torches or walkable nodes above the wall
local upnode = minetest.get_node({x = pos.x, y = pos.y+1, z = pos.z})
2015-07-04 15:32:26 +02:00
if sum == 5 or sum == 10 then
2017-02-10 14:41:36 +01:00
if minetest.registered_nodes[upnode.name].walkable or upnode.name == "mcl_torches:floor" then
2015-07-04 15:32:26 +02:00
sum = sum + 11
end
end
2015-06-29 19:55:56 +02:00
2015-07-04 15:32:26 +02:00
--[[if sum == 0 then
sum = 15
end]]
minetest.add_node(pos, {name = basename..sum})
2015-06-29 19:55:56 +02:00
end
2017-01-24 02:31:49 +01:00
local function update_wall_global(pos)
2015-07-04 15:32:26 +02:00
for i = 1,5 do
local dir = directions[i]
update_wall({x = pos.x + dir.x, y = pos.y + dir.y, z = pos.z + dir.z})
end
2015-06-29 19:55:56 +02:00
end
local half_blocks = {
{4/16, -0.5, -3/16, 0.5, 5/16, 3/16},
{-3/16, -0.5, 4/16, 3/16, 5/16, 0.5},
{-0.5, -0.5, -3/16, -4/16, 5/16, 3/16},
{-3/16, -0.5, -0.5, 3/16, 5/16, -4/16}
}
local pillar = {-4/16, -0.5, -4/16, 4/16, 0.5, 4/16}
local full_blocks = {
{-0.5, -0.5, -3/16, 0.5, 5/16, 3/16},
{-3/16, -0.5, -0.5, 3/16, 5/16, 0.5}
}
2017-01-27 18:15:36 +01:00
--[[ Adds a new wall type.
2017-02-21 17:14:15 +01:00
* nodename: Itemstring of base node to add. Must not contain an underscore
* description: Item description (tooltip), visible to user
2017-02-17 20:52:19 +01:00
* tiles: Wall textures table
2017-02-21 17:32:48 +01:00
* inventory_image: Inventory image (optional)
2017-02-21 17:14:15 +01:00
* groups: Base group memberships (optional, default is {cracky=3})
2017-02-21 17:20:58 +01:00
* sounds: Sound table (optional, default is stone)
2017-02-21 17:14:15 +01:00
]]
2017-02-21 17:32:48 +01:00
function mcl_walls.register_wall(nodename, description, tiles, inventory_image, groups, sounds)
2017-02-21 17:14:15 +01:00
local base_groups = groups
if not base_groups then
base_groups = {cracky=3}
end
base_groups.wall = 1
internal_groups = table.copy(base_groups)
internal_groups.not_in_creative_inventory = 1
main_node_groups = table.copy(base_groups)
main_node_groups.deco_block = 1
2017-02-21 17:20:58 +01:00
if not sounds then
sounds = mcl_sounds.node_sound_stone_defaults()
end
2015-07-04 15:32:26 +02:00
for i = 0, 15 do
local need = {}
local need_pillar = false
for j = 1, 4 do
if rshift(i, j - 1) % 2 == 1 then
need[j] = true
end
end
local take = {}
if need[1] == true and need[3] == true then
need[1] = nil
need[3] = nil
table.insert(take, full_blocks[1])
end
if need[2] == true and need[4] == true then
need[2] = nil
need[4] = nil
table.insert(take, full_blocks[2])
end
for k in pairs(need) do
table.insert(take, half_blocks[k])
need_pillar = true
end
if i == 15 or i == 0 then need_pillar = true end
if need_pillar then table.insert(take, pillar) end
minetest.register_node(nodename.."_"..i, {
collision_box = {
type = 'fixed',
2017-01-17 02:10:29 +01:00
fixed = {-4/16, -0.5, -4/16, 4/16, 1, 4/16}
2015-07-04 15:32:26 +02:00
},
drawtype = "nodebox",
is_ground_content = false,
2017-02-17 20:52:19 +01:00
tiles = tiles,
2015-07-04 15:32:26 +02:00
paramtype = "light",
2017-02-21 17:14:15 +01:00
groups = internal_groups,
2015-07-04 15:32:26 +02:00
drop = nodename,
node_box = {
type = "fixed",
fixed = take
},
2017-02-21 17:20:58 +01:00
sounds = sounds,
2015-07-04 15:32:26 +02:00
})
end
2015-06-29 19:55:56 +02:00
2015-07-04 15:32:26 +02:00
minetest.register_node(nodename.."_16", {
drawtype = "nodebox",
collision_box = {
type = 'fixed',
2017-01-17 02:10:29 +01:00
fixed = {-4/16, -0.5, -4/16, 4/16, 1, 4/16}
2015-07-04 15:32:26 +02:00
},
2017-02-17 20:52:19 +01:00
tiles = tiles,
2015-07-04 15:32:26 +02:00
paramtype = "light",
is_ground_content = false,
2017-02-21 17:14:15 +01:00
groups = internal_groups,
2015-07-04 15:32:26 +02:00
drop = nodename,
node_box = {
type = "fixed",
fixed = {pillar, full_blocks[1]}
},
2017-02-21 17:20:58 +01:00
sounds = sounds,
2015-07-04 15:32:26 +02:00
})
2015-06-29 19:55:56 +02:00
2015-07-04 15:32:26 +02:00
minetest.register_node(nodename.."_21", {
drawtype = "nodebox",
collision_box = {
type = 'fixed',
2017-01-17 02:10:29 +01:00
fixed = {-4/16, -0.5, -4/16, 4/16, 1, 4/16}
2015-07-04 15:32:26 +02:00
},
2017-02-17 20:52:19 +01:00
tiles = tiles,
2015-07-04 15:32:26 +02:00
paramtype = "light",
is_ground_content = false,
2017-02-21 17:14:15 +01:00
groups = internal_groups,
2015-07-04 15:32:26 +02:00
drop = nodename,
node_box = {
type = "fixed",
fixed = {pillar, full_blocks[2]}
},
2017-02-21 17:20:58 +01:00
sounds = sounds,
2015-07-04 15:32:26 +02:00
})
-- Inventory item
minetest.register_node(nodename, {
2017-02-21 17:14:15 +01:00
description = description,
2015-07-04 15:32:26 +02:00
paramtype = "light",
is_ground_content = false,
2017-02-21 17:14:15 +01:00
groups = main_node_groups,
2017-02-17 20:52:19 +01:00
tiles = tiles,
2017-02-21 17:32:48 +01:00
inventory_image = inventory_image,
2015-07-04 15:32:26 +02:00
stack_max = 64,
drawtype = "nodebox",
node_box = {
type = "fixed",
fixed = pillar
},
2015-06-29 19:55:56 +02:00
collision_box = {
2015-07-04 15:32:26 +02:00
type = 'fixed',
2017-01-17 02:10:29 +01:00
fixed = {-4/16, -0.5, -4/16, 4/16, 1, 4/16}
2015-06-29 19:55:56 +02:00
},
2015-07-04 15:32:26 +02:00
collisionbox = {-0.2, 0, -0.2, 0.2, 1.4, 0.2},
2017-01-17 02:08:41 +01:00
on_construct = update_wall,
2017-02-21 17:20:58 +01:00
sounds = sounds,
2015-07-04 15:32:26 +02:00
})
2015-06-29 19:55:56 +02:00
end
2015-07-04 15:32:26 +02:00
-- Cobblestone wall
2015-06-29 19:55:56 +02:00
2017-02-17 20:52:19 +01:00
mcl_walls.register_wall("mcl_walls:cobble", "Cobblestone Wall", {"default_cobble.png"}, "mcl_walls_cobble.png")
2015-06-29 19:55:56 +02:00
minetest.register_craft({
2017-01-27 18:15:36 +01:00
output = 'mcl_walls:cobble 6',
2015-06-29 19:55:56 +02:00
recipe = {
2017-01-31 23:32:56 +01:00
{'mcl_core:cobble', 'mcl_core:cobble', 'mcl_core:cobble'},
{'mcl_core:cobble', 'mcl_core:cobble', 'mcl_core:cobble'}
2015-06-29 19:55:56 +02:00
}
})
2015-07-04 15:32:26 +02:00
-- Mossy wall
2015-06-29 19:55:56 +02:00
2017-02-17 20:52:19 +01:00
mcl_walls.register_wall("mcl_walls:mossycobble", "Mossy Cobblestone Wall", {"default_mossycobble.png"}, "mcl_walls_mossycobble.png")
2015-06-29 19:55:56 +02:00
minetest.register_craft({
2017-01-27 18:15:36 +01:00
output = 'mcl_walls:mossycobble 6',
2015-06-29 19:55:56 +02:00
recipe = {
2017-01-31 23:32:56 +01:00
{'mcl_core:mossycobble', 'mcl_core:mossycobble', 'mcl_core:mossycobble'},
{'mcl_core:mossycobble', 'mcl_core:mossycobble', 'mcl_core:mossycobble'}
2015-06-29 19:55:56 +02:00
}
})
minetest.register_on_placenode(update_wall_global)
minetest.register_on_dignode(update_wall_global)