diff options
author | Pierre-Yves Rollo <dev@pyrollo.com> | 2017-08-26 14:12:38 +0200 |
---|---|---|
committer | Pierre-Yves Rollo <dev@pyrollo.com> | 2017-08-26 14:12:38 +0200 |
commit | c179f44ba481c73158fa72d658cbd9fed046dcdd (patch) | |
tree | 48513ec25683841fad77f51a48ce91f0f47deaf9 /display_lib | |
parent | d59c475162da02695a85ebd92a44e53129aa8be3 (diff) | |
download | display_modpack-c179f44ba481c73158fa72d658cbd9fed046dcdd.tar.gz display_modpack-c179f44ba481c73158fa72d658cbd9fed046dcdd.tar.bz2 display_modpack-c179f44ba481c73158fa72d658cbd9fed046dcdd.zip |
Release 2017-08-26
Diffstat (limited to 'display_lib')
-rw-r--r-- | display_lib/README.md | 5 | ||||
-rw-r--r-- | display_lib/copyright.txt | 2 | ||||
-rw-r--r-- | display_lib/init.lua | 29 |
3 files changed, 22 insertions, 14 deletions
diff --git a/display_lib/README.md b/display_lib/README.md index d7372d7..3f8571a 100644 --- a/display_lib/README.md +++ b/display_lib/README.md @@ -8,4 +8,7 @@ This library's purpose is to ease creation of nodes with one or more displays on **License**: LPGL -**API**: See API.md document please. +**API**: See [API.md](https://github.com/pyrollo/display_modpack/blob/master/display_lib/API.md) document please. + +For more information, see the [forum topic](https://forum.minetest.net/viewtopic.php?f=11&t=13563) at the Minetest forums. + diff --git a/display_lib/copyright.txt b/display_lib/copyright.txt new file mode 100644 index 0000000..5d4adad --- /dev/null +++ b/display_lib/copyright.txt @@ -0,0 +1,2 @@ +Code by Pierre-Yves Rollo (pyrollo) + diff --git a/display_lib/init.lua b/display_lib/init.lua index 63ce99c..4416928 100644 --- a/display_lib/init.lua +++ b/display_lib/init.lua @@ -114,7 +114,6 @@ local function place_entities(pos) local depth = clip_pos_prop(props.depth) local height = clip_pos_prop(props.height) local right = clip_pos_prop(props.right) - if not objrefs[entity_name] then objrefs[entity_name] = minetest.add_entity(pos, entity_name) end @@ -158,26 +157,30 @@ end --- On_place callback for display_lib items. Does nothing more than preventing item --- from being placed on ceiling or ground function display_lib.on_place(itemstack, placer, pointed_thing) - local ndef = minetest.registered_nodes[itemstack.name] + local ndef = itemstack:get_definition() local above = pointed_thing.above local under = pointed_thing.under local dir = {x = under.x - above.x, y = under.y - above.y, z = under.z - above.z} - if ndef and ndef.paramtype2 == "wallmounted" then - local wdir = minetest.dir_to_wallmounted(dir) + if ndef then + if ndef.paramtype2 == "wallmounted" then - if wdir == 0 or wdir == 1 then - dir = placer:get_look_dir() - dir.y = 0 - wdir = minetest.dir_to_wallmounted(dir) - end + local wdir = minetest.dir_to_wallmounted(dir) - return minetest.item_place(itemstack, placer, pointed_thing, wdir) - else - return minetest.item_place(itemstack, placer, pointed_thing) + if wdir == 0 or wdir == 1 then + dir = placer:get_look_dir() + dir.y = 0 + wdir = minetest.dir_to_wallmounted(dir) + end + + return minetest.item_place(itemstack, placer, pointed_thing, wdir) + else + return minetest.item_place(itemstack, placer, pointed_thing, minetest.dir_to_facedir(dir)) + end end + end --- On_construct callback for display_lib items. Creates entities and update them. @@ -196,7 +199,7 @@ end -- On_rotate (screwdriver) callback for display_lib items. Prevents axis rotation and reorients entities. function display_lib.on_rotate(pos, node, user, mode, new_param2) - if mode ~= screwdriver.ROTATE_FACE then return false end + if mode ~= 1 then return false end local values = get_values(node) |