summaryrefslogtreecommitdiff
path: root/signs/nodes.lua
diff options
context:
space:
mode:
authorPierre-Yves Rollo <dev@pyrollo.com>2017-08-26 14:12:38 +0200
committerPierre-Yves Rollo <dev@pyrollo.com>2017-08-26 14:12:38 +0200
commitc179f44ba481c73158fa72d658cbd9fed046dcdd (patch)
tree48513ec25683841fad77f51a48ce91f0f47deaf9 /signs/nodes.lua
parentd59c475162da02695a85ebd92a44e53129aa8be3 (diff)
Release 2017-08-26
Diffstat (limited to 'signs/nodes.lua')
-rw-r--r--signs/nodes.lua112
1 files changed, 43 insertions, 69 deletions
diff --git a/signs/nodes.lua b/signs/nodes.lua
index abd63a0..6146d50 100644
--- a/signs/nodes.lua
+++ b/signs/nodes.lua
@@ -22,17 +22,20 @@ local S = signs.intllib
local F = function(...) return minetest.formspec_escape(S(...)) end
-- Poster specific formspec
-local function on_rightclick_poster(pos, node, player)
+local function on_rightclick_poster(pos, node, player, itemstack, pointed_thing)
local formspec
local meta = minetest.get_meta(pos)
+
if not minetest.is_protected(pos, player:get_player_name()) then
formspec =
"size[6.5,7.5]"..
- "field[0.5,0.7;6,1;display_text;"..F("Title")..";"..minetest.formspec_escape(meta:get_string("display_text")).."]"..
- "textarea[0.5,1.7;6,6;text;"..F("Text")..";"..minetest.formspec_escape(meta:get_string("text")).."]"..
+ "field[0.5,0.7;6,1;display_text;"..F("Title")..";"..
+ minetest.formspec_escape(meta:get_string("display_text")).."]"..
+ "textarea[0.5,1.7;6,6;text;"..F("Text")..";"..
+ minetest.formspec_escape(meta:get_string("text")).."]"..
"button_exit[2,7;2,1;ok;"..F("Write").."]"
minetest.show_formspec(player:get_player_name(),
- "signs:poster@"..minetest.pos_to_string(pos),
+ node.name.."@"..minetest.pos_to_string(pos),
formspec)
else
formspec = "size[8,9]"..
@@ -45,14 +48,14 @@ local function on_rightclick_poster(pos, node, player)
"",
formspec)
end
-
+ return itemstack
end
-- Poster specific on_receive_fields callback
local function on_receive_fields_poster(pos, formname, fields, player)
local meta = minetest.get_meta(pos)
if not minetest.is_protected(pos, player:get_player_name()) then
- if fields and fields.ok then
+ if fields and (fields.ok or fields.key_enter) then
meta:set_string("display_text", fields.display_text)
meta:set_string("text", fields.text)
meta:set_string("infotext", "\""..fields.display_text
@@ -67,66 +70,55 @@ display_lib.register_display_entity("signs:text")
-- Sign models and registration
local models = {
- wooden_right={
- depth=1/16,
+ wooden_right_sign = {
+ depth = 1/16,
width = 14/16,
height = 7/16,
entity_fields = {
- size = { x = 12/16, y = 5/16 },
+ right = -3/32,
+ size = { x = 12/16, y = 6/16 },
resolution = { x = 112, y = 64 },
maxlines = 2,
color="#000",
},
node_fields = {
- description=S("Wooden direction sign"),
- tiles={"signs_wooden_direction.png"},
- inventory_image="signs_wooden_inventory.png",
- on_place=signs.on_place_direction,
- on_rightclick = signs.on_right_click_direction,
+ description = S("Wooden direction sign"),
+ tiles = { "signs_wooden_direction.png" },
+ inventory_image = "signs_wooden_inventory.png",
+ signs_other_dir = 'signs:wooden_left_sign',
+ on_place = signs.on_place_direction,
drawtype = "mesh",
mesh = "signs_dir_right.obj",
- selection_box = { type="wallmounted",
- wall_side = {-0.5, -7/32, -7/16, -7/16, 7/32, 0.5},
- wall_bottom = {-0.5, -0.5, -0.5, 0.5, -7/16, 0.5},
- wall_top = {-0.5, 0.5, -0.5, 0.5, 7/16, 0.5}},
- collision_box = { type="wallmounted",
- wall_side = {-0.5, -7/32, -7/16, -7/16, 7/32, 0.5},
- wall_bottom = {-0.5, -0.5, -0.5, 0.5, -7/16, 0.5},
- wall_top = {-0.5, 0.5, -0.5, 0.5, 7/16, 0.5}},
+ selection_box = { type="fixed", fixed = {-0.5, -7/32, 0.5, 7/16, 7/32, 7/16}},
+ collision_box = { type="fixed", fixed = {-0,5, -7/32, 0.5, 7/16, 7/32, 7/16}},
},
},
- wooden_left={
+ wooden_left_sign = {
depth = 1/16,
width = 14/16,
height = 7/16,
entity_fields = {
- size = { x = 12/16, y = 5/16 },
+ right = 3/32,
+ size = { x = 12/16, y = 6/16 },
resolution = { x = 112, y = 64 },
maxlines = 2,
- color="#000",
+ color = "#000",
},
node_fields = {
- description=S("Wooden direction sign"),
- tiles={"signs_wooden_direction.png"},
- inventory_image="signs_wooden_inventory.png",
- on_place=signs.on_place_direction,
- on_rightclick = signs.on_right_click_direction,
+ description = S("Wooden direction sign"),
+ tiles = { "signs_wooden_direction.png" },
+ inventory_image = "signs_wooden_inventory.png",
+ signs_other_dir = 'signs:wooden_right_sign',
drawtype = "mesh",
mesh = "signs_dir_left.obj",
- selection_box = { type="wallmounted",
- wall_side = {-0.5, -7/32, -0.5, -7/16, 7/32, 7/16},
- wall_bottom = {-0.5, -0.5, -0.5, 0.5, -7/16, 0.5},
- wall_top = {-0.5, 0.5, -0.5, 0.5, 7/16, 0.5}},
- collision_box = { type="wallmounted",
- wall_side = {-0.5, -7/32, -0.5, -7/16, 7/32, 7/16},
- wall_bottom = {-0.5, -0.5, -0.5, 0.5, -7/16, 0.5},
- wall_top = {-0.5, 0.5, -0.5, 0.5, 7/16, 0.5}},
- groups={not_in_creative_inventory=1},
- drop="signs:wooden_right",
+ selection_box = { type="fixed", fixed = {-7/16, -7/32, 0.5, 0.5, 7/32, 7/16}},
+ collision_box = { type="fixed", fixed = {-7/16, -7/32, 0.5, 0.5, 7/32, 7/16}},
+ groups = { not_in_creative_inventory = 1 },
+ drop = "signs:wooden_right_sign",
},
},
- poster={
- depth=1/32,
+ paper_poster = {
+ depth = 1/32,
width = 26/32,
height = 30/32,
entity_fields = {
@@ -136,39 +128,21 @@ local models = {
valign="top",
},
node_fields = {
- description=S("Poster"),
- tiles={"signs_poster.png"},
- inventory_image="signs_poster_inventory.png",
- on_construct=display_lib.on_construct,
- on_rightclick=on_rightclick_poster,
- on_receive_fields=on_receive_fields_poster,
+ description = S("Poster"),
+ tiles = { "signs_poster_sides.png", "signs_poster_sides.png",
+ "signs_poster_sides.png", "signs_poster_sides.png",
+ "signs_poster_sides.png", "signs_poster.png" },
+ inventory_image = "signs_poster_inventory.png",
+ on_construct = display_lib.on_construct,
+ on_rightclick = on_rightclick_poster,
+ on_receive_fields = on_receive_fields_poster,
},
},
}
+-- Node registration
for name, model in pairs(models)
do
signs.register_sign("signs", name, model)
end
-if minetest.get_modpath("homedecor") then
- print ("["..minetest.get_current_modname().."] homedecor mod is present, not overriding default:sign.")
-else
--- Override default sign
- signs.register_sign(":default", "sign_wall", {
- depth = 1/16,
- width = 14/16,
- height = 10/16,
- entity_fields = {
- size = { x = 12/16, y = 8/16 },
- resolution = { x = 144, y = 64 },
- maxlines = 3,
- color="#000",
- },
- node_fields = {
- description="Sign",
- tiles={"signs_default.png"},
- inventory_image="signs_default_inventory.png",
- },
- })
-end