diff --git a/init.lua b/init.lua index 3a36f3f..8b06c3d 100644 --- a/init.lua +++ b/init.lua @@ -356,9 +356,9 @@ travelnet.on_receive_fields = function(pos, formname, fields, player) end - -- check if the box has at the other end has been removed + -- check if the box has at the other end has been removed. local node2 = minetest.env:get_node( target_pos ); - if( node2 ~= nil and node2.name ~= 'ignore' and node2.name ~= 'travelnet:travelnet' ) then + if( node2 ~= nil and node2.name ~= 'ignore' and node2.name ~= 'travelnet:travelnet' and node2.name ~= 'travelnet:elevator') then -- provide information necessary to identify the removed box local oldmetadata = { fields = { owner = owner_name, @@ -464,9 +464,8 @@ minetest.register_node("travelnet:travelnet", { "default_clay.png", -- view from top "default_clay.png", -- view from bottom - "travelnet_travelnet_side.png", -- side - "travelnet_travelnet_side.png", -- side - + "travelnet_travelnet_side.png", -- left side + "travelnet_travelnet_side.png", -- right side "travelnet_travelnet_back.png", -- front view "travelnet_travelnet_front.png", -- backward view }, @@ -560,4 +559,151 @@ minetest.register_craft({ -- upon server start, read the savefile travelnet.restore_data(); +minetest.register_node("travelnet:elevator", { + description = "Travelnet Elevator Bottom", + drawtype = "nodebox", + sunlight_propagates = true, + paramtype = 'light', + paramtype2 = "facedir", + + selection_box = { + type = "fixed", + fixed = { -0.5, -0.5, -0.5, 0.5, 1.5, 0.5 } + }, + + node_box = { + type = "fixed", + fixed = { + + { 0.48, -0.5,-0.5, 0.5, 0.5, 0.5}, + {-0.5 , -0.5, 0.48, 0.48, 0.5, 0.5}, + {-0.5, -0.5,-0.5 ,-0.48, 0.5, 0.5}, + + --groundplate to stand on + { -0.5,-0.5,-0.5,0.5,-0.48, 0.5}, + }, + }, + + + tiles = { + + "travelnet_elevator_inside_floor.png", -- view from top + "default_stone.png", -- view from bottom + "travelnet_elevator_inside_bottom.png", -- left side + "travelnet_elevator_inside_bottom.png", -- right side + "travelnet_elevator_inside_bottom.png", -- front view + "travelnet_elevator_inside_bottom.png", -- backward view + }, + inventory_image = "travelnet_inv.png", + + groups = {choppy=2,dig_immediate=2,attached_node=1}, + + light_source = 10, + + after_place_node = function(pos, placer, itemstack) + local meta = minetest.env:get_meta(pos); + meta:set_string("infotext", "Travelnet Elevator (unconfigured)"); + meta:set_string("station_name", ""); + meta:set_string("station_network",""); + meta:set_string("owner", placer:get_player_name() ); + -- request initinal data + meta:set_string("formspec", + "size[12,10]".. + "field[0.3,5.6;6,0.7;station_name;Name of this station:;]".. + "field[0.3,6.6;6,0.7;station_network;Assign to Network:;]".. + "field[0.3,7.6;6,0.7;owner_name;(optional) owned by:;]".. + "button_exit[6.3,6.2;1.7,0.7;station_set;Store]" ); + end, + + on_receive_fields = travelnet.on_receive_fields, + on_punch = function(pos, node, puncher) + travelnet.update_formspec(pos, puncher:get_player_name()) + end, + + after_dig_node = function(pos, oldnode, oldmetadata, digger) + travelnet.remove_box( pos, oldnode, oldmetadata, digger ) + end, + + -- taken from VanessaEs homedecor fridge + on_place = function(itemstack, placer, pointed_thing) + local pos = pointed_thing.above; + if( minetest.env:get_node({x=pos.x, y=pos.y+1, z=pos.z}).name ~= "air" ) then + minetest.chat_send_player( placer:get_player_name(), 'Not enough vertical space to place the travelnet box!' ) + return; + end + local p = {x=pos.x, y=pos.y+1, z=pos.z} + local p2 = minetest.dir_to_facedir(placer:get_look_dir()) + minetest.env:add_node(p, {name="travelnet:elevator_top", paramtype2="facedir", param2=p2}) + return minetest.item_place(itemstack, placer, pointed_thing); + end, + + on_destruct = function(pos) + local p = {x=pos.x, y=pos.y+1, z=pos.z} + minetest.env:remove_node(p) + end +}) + +minetest.register_node("travelnet:elevator_top", { + description = "Travelnet Elevator Top", + + drawtype = "nodebox", + sunlight_propagates = true, + paramtype = 'light', + paramtype2 = "facedir", + + selection_box = { + type = "fixed", + fixed = { 0, 0, 0, 0, 0, 0 } +-- fixed = { -0.5, -0.5, -0.5, 0.5, 0.5, 0.5 } + }, + + node_box = { + type = "fixed", + fixed = { + + { 0.48, -0.5,-0.5, 0.5, 0.5, 0.5}, + {-0.5 , -0.5, 0.48, 0.48, 0.5, 0.5}, + {-0.5, -0.5,-0.5 ,-0.48, 0.5, 0.5}, + + --top ceiling + { -0.5, 0.48,-0.5,0.5, 0.5, 0.5}, + }, + }, + + + tiles = { + + "default_stone.png", -- view from top + "travelnet_elevator_inside_ceiling.png", -- view from bottom + "travelnet_elevator_inside_top_control.png", -- left side + "travelnet_elevator_inside_top.png", -- right side + "travelnet_elevator_inside_top.png", -- front view + "travelnet_elevator_inside_top.png", -- backward view + }, + inventory_image = "travelnet_inv.png", + + light_source = 10, + + groups = {choppy=2,dig_immediate=2,attached_node=1}, +}) + +if( minetest.get_modpath("technic") ~= nil ) then + minetest.register_craft({ + output = "travelnet:elevator", + recipe = { + {"default:steel_ingot", "technic:motor", "default:steel_ingot", }, + {"default:steel_ingot", "technic:control_logic_unit", "default:steel_ingot", }, + {"default:steel_ingot", "moreores:copper_ingot", "default:steel_ingot", } + } + }) +else + minetest.register_craft({ + output = "travelnet:elevator", + recipe = { + {"default:steel_ingot", "default_sandstone", "default:steel_ingot", }, + {"default:steel_ingot", "default_sandstone", "default:steel_ingot", }, + {"default:mese_crystal_fragment", "default:mese_crystal_fragment", "default:mese_crystal_fragment", } + } + }) +end diff --git a/textures/travelnet_elevator_inside_bottom.png b/textures/travelnet_elevator_inside_bottom.png new file mode 100644 index 0000000..920496e Binary files /dev/null and b/textures/travelnet_elevator_inside_bottom.png differ diff --git a/textures/travelnet_elevator_inside_ceiling.png b/textures/travelnet_elevator_inside_ceiling.png new file mode 100644 index 0000000..12dfb8c Binary files /dev/null and b/textures/travelnet_elevator_inside_ceiling.png differ diff --git a/textures/travelnet_elevator_inside_floor.png b/textures/travelnet_elevator_inside_floor.png new file mode 100644 index 0000000..7c4a731 Binary files /dev/null and b/textures/travelnet_elevator_inside_floor.png differ diff --git a/textures/travelnet_elevator_inside_top.png b/textures/travelnet_elevator_inside_top.png new file mode 100644 index 0000000..a29cfa1 Binary files /dev/null and b/textures/travelnet_elevator_inside_top.png differ diff --git a/textures/travelnet_elevator_inside_top_control.png b/textures/travelnet_elevator_inside_top_control.png new file mode 100644 index 0000000..ed92b3a Binary files /dev/null and b/textures/travelnet_elevator_inside_top_control.png differ diff --git a/textures512/travelnet_elevator_inside_bottom.png b/textures512/travelnet_elevator_inside_bottom.png new file mode 100644 index 0000000..2ffb79d Binary files /dev/null and b/textures512/travelnet_elevator_inside_bottom.png differ diff --git a/textures512/travelnet_elevator_inside_ceiling.png b/textures512/travelnet_elevator_inside_ceiling.png new file mode 100644 index 0000000..14f96c6 Binary files /dev/null and b/textures512/travelnet_elevator_inside_ceiling.png differ diff --git a/textures512/travelnet_elevator_inside_floor.png b/textures512/travelnet_elevator_inside_floor.png new file mode 100644 index 0000000..4de5ddd Binary files /dev/null and b/textures512/travelnet_elevator_inside_floor.png differ diff --git a/textures512/travelnet_elevator_inside_top.png b/textures512/travelnet_elevator_inside_top.png new file mode 100644 index 0000000..b1ff3a2 Binary files /dev/null and b/textures512/travelnet_elevator_inside_top.png differ diff --git a/textures512/travelnet_elevator_inside_top_control.png b/textures512/travelnet_elevator_inside_top_control.png new file mode 100644 index 0000000..00519b4 Binary files /dev/null and b/textures512/travelnet_elevator_inside_top_control.png differ