From b6a823386b0bbc82475e6321087ae7ca9507edee Mon Sep 17 00:00:00 2001 From: BlockMen Date: Fri, 23 Aug 2013 10:58:29 +0200 Subject: [PATCH] Update to 1.2.6 --- README.txt | 8 +++-- init.lua | 55 +++++++++++++++----------------- textures/door_glass_a.png | Bin 0 -> 978 bytes textures/door_glass_b.png | Bin 0 -> 978 bytes textures/door_glass_side.png | Bin 0 -> 109 bytes textures/door_trapdoor_side.png | Bin 0 -> 276 bytes 6 files changed, 31 insertions(+), 32 deletions(-) create mode 100644 textures/door_glass_a.png create mode 100644 textures/door_glass_b.png create mode 100644 textures/door_glass_side.png create mode 100644 textures/door_trapdoor_side.png diff --git a/README.txt b/README.txt index db6ed00..a1b676a 100644 --- a/README.txt +++ b/README.txt @@ -1,6 +1,6 @@ Minetest 0.4 mod: doors ======================= -version: 1.2.4 +version: 1.2.6 License of source code: ----------------------- @@ -24,9 +24,13 @@ following Textures created by Fernando Zapata (CC BY-SA 3.0): following Textures created by BlockMen (WTFPL): door_glass.png + door_glass_a.png + door_glass_b.png + door_glass_side.png door_trapdoor.png + door_trapdoor_side.png -All other textures created by PilzAdam (WTFPL) +All other textures (created by PilzAdam): WTFPL License of sounds diff --git a/init.lua b/init.lua index 7d57c2c..19408e1 100644 --- a/init.lua +++ b/init.lua @@ -16,13 +16,15 @@ doors = {} -- only_placer_can_open: if true only the player who placed the door can -- open it -local function is_right(pos, clicker) - local r1 = minetest.env:get_node({x=pos.x+1, y=pos.y, z=pos.z}) - local r2 = minetest.env:get_node({x=pos.x, y=pos.y, z=pos.z+1}) +local function is_right(pos) + local r1 = minetest.env:get_node({x=pos.x-1, y=pos.y, z=pos.z}) + local r2 = minetest.env:get_node({x=pos.x, y=pos.y, z=pos.z-1}) if string.find(r1.name, "door_") or string.find(r2.name, "door_") then - return true - else - return false + if string.find(r1.name, "_1") or string.find(r2.name, "_1") then + return true + else + return false + end end end @@ -133,6 +135,19 @@ function doors:register_door(name, def) meta = minetest.env:get_meta(pos):to_table() minetest.env:set_node(pos, {name=replace, param2=p2}) minetest.env:get_meta(pos):from_table(meta) + + local snd_1 = "_close" + local snd_2 = "_open" + if params[1] == 3 then + snd_1 = "_open" + snd_2 = "_close" + end + + if is_right(pos) then + minetest.sound_play("door"..snd_1, {pos = pos, gain = 0.3, max_hear_distance = 10}) + else + minetest.sound_play("door"..snd_2, {pos = pos, gain = 0.3, max_hear_distance = 10}) + end end local function check_player_priv(pos, player) @@ -168,11 +183,6 @@ function doors:register_door(name, def) on_rightclick = function(pos, node, clicker) if check_player_priv(pos, clicker) then on_rightclick(pos, 1, name.."_t_1", name.."_b_2", name.."_t_2", {1,2,3,0}) - if is_right(pos, clicker) then - minetest.sound_play("door_close", {pos = pos, gain = 0.3, max_hear_distance = 10}) - else - minetest.sound_play("door_open", {pos = pos, gain = 0.3, max_hear_distance = 10}) - end end end, @@ -203,11 +213,6 @@ function doors:register_door(name, def) on_rightclick = function(pos, node, clicker) if check_player_priv(pos, clicker) then on_rightclick(pos, -1, name.."_b_1", name.."_t_2", name.."_b_2", {1,2,3,0}) - if is_right(pos, clicker) then - minetest.sound_play("door_close", {pos = pos, gain = 0.3, max_hear_distance = 10}) - else - minetest.sound_play("door_open", {pos = pos, gain = 0.3, max_hear_distance = 10}) - end end end, @@ -238,11 +243,6 @@ function doors:register_door(name, def) on_rightclick = function(pos, node, clicker) if check_player_priv(pos, clicker) then on_rightclick(pos, 1, name.."_t_2", name.."_b_1", name.."_t_1", {3,0,1,2}) - if is_right(pos, clicker) then - minetest.sound_play("door_open", {pos = pos, gain = 0.3, max_hear_distance = 10}) - else - minetest.sound_play("door_close", {pos = pos, gain = 0.3, max_hear_distance = 10}) - end end end, @@ -273,11 +273,6 @@ function doors:register_door(name, def) on_rightclick = function(pos, node, clicker) if check_player_priv(pos, clicker) then on_rightclick(pos, -1, name.."_b_2", name.."_t_1", name.."_b_1", {3,0,1,2}) - if is_right(pos, clicker) then - minetest.sound_play("door_open", {pos = pos, gain = 0.3, max_hear_distance = 10}) - else - minetest.sound_play("door_close", {pos = pos, gain = 0.3, max_hear_distance = 10}) - end end end, @@ -325,8 +320,8 @@ doors:register_door("doors:door_glass", { description = "Glass Door", inventory_image = "door_glass.png", groups = {snappy=1,cracky=1,oddly_breakable_by_hand=2,door=1}, - tiles_bottom = {"default_glass.png", "door_grey.png"}, - tiles_top = {"default_glass.png", "door_grey.png"}, + tiles_bottom = {"door_glass_b.png", "door_glass_side.png"}, + tiles_top = {"door_glass_a.png", "door_glass_side.png"}, }) minetest.register_craft({ @@ -379,7 +374,7 @@ minetest.register_node("doors:trapdoor", { description = "Trapdoor", inventory_image = "door_trapdoor.png", drawtype = "nodebox", - tiles = {"door_trapdoor.png", "door_trapdoor.png", "default_wood.png", "default_wood.png", "default_wood.png", "default_wood.png"}, + tiles = {"door_trapdoor.png", "door_trapdoor.png", "default_trapdoor_side.png", "default_trapdoor_side.png", "default_trapdoor_side.png", "default_trapdoor_side.png"}, paramtype = "light", paramtype2 = "facedir", groups = {snappy=1,choppy=2,oddly_breakable_by_hand=2,flammable=2,door=1}, @@ -404,7 +399,7 @@ minetest.register_node("doors:trapdoor", { minetest.register_node("doors:trapdoor_open", { drawtype = "nodebox", - tiles = {"default_wood.png", "default_wood.png", "default_wood.png", "default_wood.png", "door_trapdoor.png", "door_trapdoor.png"}, + tiles = {"door_trapdoor_side.png", "door_trapdoor_side.png", "door_trapdoor_side.png", "door_trapdoor_side.png", "door_trapdoor.png", "door_trapdoor.png"}, paramtype = "light", paramtype2 = "facedir", pointable = true, diff --git a/textures/door_glass_a.png b/textures/door_glass_a.png new file mode 100644 index 0000000000000000000000000000000000000000..ade0196fe64e00c80496c9bfc914645d5b472bd2 GIT binary patch literal 978 zcmeAS@N?(olHy`uVBq!ia0vp^0wB!63?wyl`GbKJV{wqX6T`Z5GA|hzm>B|mLR^7@ z%a)v6w&dK(WhYlGJF{xV*~N>mELwDR$>J+(*WTK?_3n-x_jc{Nf8fC5BS#(|JNER< znHLu?zPf(>&7C{%?%)6L@Zra&Pd~kW{q^I=pI^WJ{{H>fj~{=2{rdao&%b~F{sRpk z1*0J_m_r~WI*bSCKE{$DzhDN3XE)M7oFs2|7lsa2Sq~tGv%n*=n1O*?2!t6g-L3lr z6l5>)^mS#w&CM^YBGzz7?t<8 literal 0 HcmV?d00001 diff --git a/textures/door_glass_b.png b/textures/door_glass_b.png new file mode 100644 index 0000000000000000000000000000000000000000..ade0196fe64e00c80496c9bfc914645d5b472bd2 GIT binary patch literal 978 zcmeAS@N?(olHy`uVBq!ia0vp^0wB!63?wyl`GbKJV{wqX6T`Z5GA|hzm>B|mLR^7@ z%a)v6w&dK(WhYlGJF{xV*~N>mELwDR$>J+(*WTK?_3n-x_jc{Nf8fC5BS#(|JNER< znHLu?zPf(>&7C{%?%)6L@Zra&Pd~kW{q^I=pI^WJ{{H>fj~{=2{rdao&%b~F{sRpk z1*0J_m_r~WI*bSCKE{$DzhDN3XE)M7oFs2|7lsa2Sq~tGv%n*=n1O*?2!t6g-L3lr z6l5>)^mS#w&CM^YBGzz7?t<8 literal 0 HcmV?d00001 diff --git a/textures/door_glass_side.png b/textures/door_glass_side.png new file mode 100644 index 0000000000000000000000000000000000000000..aa01458c3718fac08003a3042338fc9a85f60118 GIT binary patch literal 109 zcmeAS@N?(olHy`uVBq!ia0vp^j3CUx1SBVv2j2ryoCO|{#S9GG!XV7ZFl&wkP>{XE z)7O>#4mY0whv9BE$tge~9#0p?5RU7~5nD0@8JI6HK4)I>tPm*9;OXk;vd$@?2>=4k B7Uuu} literal 0 HcmV?d00001 diff --git a/textures/door_trapdoor_side.png b/textures/door_trapdoor_side.png new file mode 100644 index 0000000000000000000000000000000000000000..f81ff3d6ad0535b65687f9471ae49fb8203edd49 GIT binary patch literal 276 zcmeAS@N?(olHy`uVBq!ia0vp^0wB!61SBU+%rFB|jKx9jP7LeL$-D$|*pj^6T^Rm@ z;DWu&Cj&(|3p^r=85sBugD~Uq{1qucLG}_)Usv`!%rbmN;uESQ_5+2cc)B=-Xq<1I zWXsiHz|(ral%-r>!D7eGT|2C*IS-y(UE!px`%>9cyT&==Uwl{YyQ!tGShoFCZ7i0b z@;pkU)0>T*v*GzJs^swjfmq6w;b>)WZ44PAyUz((t!P2U&So2jR za_5GLb2OE&>P0cT{cGEo$?~K0_Gty1f*EtHe>^T;A@PTMKi~dnDciWN=jPw$Ja@|g Px{txr)z4*}Q$iB}=rCg7 literal 0 HcmV?d00001