diff options
author | cheapie <no-email-for-you@example.com> | 2024-04-27 00:47:59 -0500 |
---|---|---|
committer | cheapie <no-email-for-you@example.com> | 2024-04-27 00:47:59 -0500 |
commit | d376cbf90e59105955e6d02cc62f32ba4ae33cff (patch) | |
tree | 35359ce744094a4233d5845c3fadeb05f82bec43 /decorations.lua | |
parent | 97e3dfb5eb40acc1c77048169b1f7b17448459ab (diff) | |
download | celevator-d376cbf90e59105955e6d02cc62f32ba4ae33cff.tar celevator-d376cbf90e59105955e6d02cc62f32ba4ae33cff.tar.gz celevator-d376cbf90e59105955e6d02cc62f32ba4ae33cff.tar.bz2 celevator-d376cbf90e59105955e6d02cc62f32ba4ae33cff.tar.xz celevator-d376cbf90e59105955e6d02cc62f32ba4ae33cff.zip |
Add decorative buffers in two styles
Diffstat (limited to 'decorations.lua')
-rw-r--r-- | decorations.lua | 117 |
1 files changed, 117 insertions, 0 deletions
diff --git a/decorations.lua b/decorations.lua new file mode 100644 index 0000000..abf2a50 --- /dev/null +++ b/decorations.lua @@ -0,0 +1,117 @@ +minetest.register_node("celevator:buffer_rubber",{ + description = "Elevator Elastomeric Buffer", + groups = { + choppy = 1, + bouncy = 60, + }, + paramtype = "light", + tiles = { + "celevator_buffer_rubber_top.png", + "celevator_cabinet_sides.png", + "celevator_buffer_rubber_sides.png", + }, + drawtype = "nodebox", + node_box = { + type = "fixed", + fixed = { + {-0.2,-0.5,-0.2,0.2,-0.45,0.2}, + {-0.0625,-0.43,-0.0625,0.0625,0.1875,0.0625}, + {-0.125,0.1875,-0.125,-0.0625,0.35,0.125}, + {0.0625,0.1875,-0.125,0.125,0.35,0.125}, + {-0.0625,0.1875,-0.125,0.0625,0.35,-0.0625,}, + {-0.0625,0.1875,0.0625,0.0625,0.35,0.125,}, + {-0.125,-0.45,-0.125,0.125,-0.43,0.125}, + }, + }, + selection_box = { + type = "fixed", + fixed = { + {-0.25,-0.5,-0.25,0.25,-0.4,0.25}, + {-0.15,-0.4,-0.15,0.15,0.4,0.15}, + }, + }, + collision_box = { + type = "fixed", + fixed = { + {-0.25,-0.5,-0.25,0.25,-0.4,0.25}, + {-0.15,-0.4,-0.15,0.15,0.4,0.15}, + }, + }, +}) + +minetest.register_node("celevator:buffer_oil",{ + description = "Elevator Oil-Filled Buffer", + groups = { + choppy = 1, + }, + paramtype = "light", + tiles = { + "celevator_buffer_oil_lower_top.png", + "celevator_cabinet_sides.png", + "celevator_buffer_oil_lower_sides.png", + }, + drawtype = "nodebox", + node_box = { + type = "fixed", + fixed = { + {-0.2,-0.5,-0.2,0.2,-0.4375,0.2}, + {-0.094,-0.4375,-0.094,0.094,0.5,0.094}, + }, + }, + selection_box = { + type = "fixed", + fixed = { + {-0.25,-0.5,-0.25,0.25,1.35,0.25}, + }, + }, + after_place_node = function(pos,placer) + local node = minetest.get_node(pos) + local toppos = {x=pos.x,y=pos.y + 1,z=pos.z} + local topnode = minetest.get_node(toppos) + local placername = placer:get_player_name() + if topnode.name ~= "air" then + if placer:is_player() then + minetest.chat_send_player(placername,"Can't place buffer - no room for the top half!") + end + minetest.set_node(pos,{name="air"}) + return true + end + if minetest.is_protected(toppos,placername) and not minetest.check_player_privs(placername,{protection_bypass=true}) then + if placer:is_player() then + minetest.chat_send_player(placername,"Can't place buffer - top half is protected!") + minetest.record_protection_violation(toppos,placername) + end + minetest.set_node(pos,{name="air"}) + return true + end + node.name = "celevator:buffer_oil_top" + minetest.set_node(toppos,node) + end, + on_destruct = function(pos) + pos.y = pos.y + 1 + local topnode = minetest.get_node(pos) + if topnode.name == "celevator:buffer_oil_top" then + minetest.set_node(pos,{name="air"}) + end + end, +}) + +minetest.register_node("celevator:buffer_oil_top",{ + description = "Elevator Oil-Filled Buffer (top half - you hacker you!)", + groups = { + choppy = 1, + not_in_creative_inventory = 1, + }, + drop = "", + paramtype = "light", + tiles = { + "celevator_buffer_oil_upper.png", + }, + drawtype = "nodebox", + node_box = { + type = "fixed", + fixed = { + {-0.063,-0.5,-0.063,0.063,0.3,0.063}, + }, + }, +}) |