forked from mtcontrib/pipeworks
Add one way tube
This commit is contained in:
parent
ce1acebf6d
commit
3c8266d3ee
@ -14,4 +14,4 @@ enable_accelerator_tube = true
|
|||||||
enable_crossing_tube = true
|
enable_crossing_tube = true
|
||||||
enable_sand_tube = true
|
enable_sand_tube = true
|
||||||
enable_mese_sand_tube = true
|
enable_mese_sand_tube = true
|
||||||
|
enable_one_way_tube = true
|
||||||
|
BIN
textures/pipeworks_one_way_tube_input.png
Normal file
BIN
textures/pipeworks_one_way_tube_input.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 839 B |
BIN
textures/pipeworks_one_way_tube_output.png
Normal file
BIN
textures/pipeworks_one_way_tube_output.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 839 B |
BIN
textures/pipeworks_one_way_tube_side.png
Normal file
BIN
textures/pipeworks_one_way_tube_side.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 1.6 KiB |
BIN
textures/pipeworks_one_way_tube_top.png
Normal file
BIN
textures/pipeworks_one_way_tube_top.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 1.7 KiB |
79
tubes.lua
79
tubes.lua
@ -249,8 +249,6 @@ inv_texture="pipeworks_tube_inv.png"
|
|||||||
|
|
||||||
register_tube("pipeworks:tube","Pneumatic tube segment",plain_textures,noctr_textures,end_textures,short_texture,inv_texture)
|
register_tube("pipeworks:tube","Pneumatic tube segment",plain_textures,noctr_textures,end_textures,short_texture,inv_texture)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
if enable_mese_tube then
|
if enable_mese_tube then
|
||||||
|
|
||||||
mese_noctr_textures={"pipeworks_mese_tube_noctr_1.png","pipeworks_mese_tube_noctr_2.png","pipeworks_mese_tube_noctr_3.png",
|
mese_noctr_textures={"pipeworks_mese_tube_noctr_1.png","pipeworks_mese_tube_noctr_2.png","pipeworks_mese_tube_noctr_3.png",
|
||||||
@ -578,3 +576,80 @@ if enable_mese_sand_tube then
|
|||||||
end
|
end
|
||||||
})
|
})
|
||||||
end
|
end
|
||||||
|
|
||||||
|
local function facedir_to_dir(facedir)
|
||||||
|
--a table of possible dirs
|
||||||
|
return ({{x=0, y=0, z=1},
|
||||||
|
{x=1, y=0, z=0},
|
||||||
|
{x=0, y=0, z=-1},
|
||||||
|
{x=-1, y=0, z=0},
|
||||||
|
{x=0, y=-1, z=0},
|
||||||
|
{x=0, y=1, z=0}})
|
||||||
|
|
||||||
|
--indexed into by a table of correlating facedirs
|
||||||
|
[({[0]=1, 2, 3, 4,
|
||||||
|
5, 2, 6, 4,
|
||||||
|
6, 2, 5, 4,
|
||||||
|
1, 5, 3, 6,
|
||||||
|
1, 6, 3, 5,
|
||||||
|
1, 4, 3, 2})
|
||||||
|
|
||||||
|
--indexed into by the facedir in question
|
||||||
|
[facedir]]
|
||||||
|
end
|
||||||
|
|
||||||
|
local function facedir_to_right_dir(facedir)
|
||||||
|
|
||||||
|
--find the other directions
|
||||||
|
local backdir = facedir_to_dir(facedir)
|
||||||
|
local topdir = ({[0]={x=0, y=1, z=0},
|
||||||
|
{x=0, y=0, z=1},
|
||||||
|
{x=0, y=0, z=-1},
|
||||||
|
{x=1, y=0, z=0},
|
||||||
|
{x=-1, y=0, z=0},
|
||||||
|
{x=0, y=-1, z=0}})[math.floor(facedir/4)]
|
||||||
|
|
||||||
|
--return a cross product
|
||||||
|
return {x=topdir.y*backdir.z - backdir.y*topdir.z,
|
||||||
|
y=topdir.z*backdir.x - backdir.z*topdir.x,
|
||||||
|
z=topdir.x*backdir.y - backdir.x*topdir.y}
|
||||||
|
end
|
||||||
|
|
||||||
|
if enable_one_way_tube then
|
||||||
|
minetest.register_node("pipeworks:one_way_tube", {
|
||||||
|
description = "One way tube",
|
||||||
|
tiles = {"pipeworks_one_way_tube_top.png", "pipeworks_one_way_tube_top.png", "pipeworks_one_way_tube_output.png",
|
||||||
|
"pipeworks_one_way_tube_input.png", "pipeworks_one_way_tube_side.png", "pipeworks_one_way_tube_top.png"},
|
||||||
|
paramtype2 = "facedir",
|
||||||
|
drawtype = "nodebox",
|
||||||
|
node_box = {type="fixed",
|
||||||
|
fixed = {{-1/2, -9/64, -9/64, 1/2, 9/64, 9/64}}},
|
||||||
|
groups = {snappy=2,choppy=2,oddly_breakable_by_hand=2,tubedevice=1,tubedevice_receiver=1},
|
||||||
|
legacy_facedir_simple = true,
|
||||||
|
sounds = default.node_sound_wood_defaults(),
|
||||||
|
after_place_node = function(pos)
|
||||||
|
tube_scanforobjects(pos)
|
||||||
|
end,
|
||||||
|
after_dig_node = function(pos)
|
||||||
|
tube_scanforobjects(pos)
|
||||||
|
end,
|
||||||
|
tube={connect_sides={left=1, right=1},
|
||||||
|
can_go=function(pos,node,velocity,stack)
|
||||||
|
return velocity
|
||||||
|
end,
|
||||||
|
insert_object = function(pos,node,stack,direction)
|
||||||
|
item1=tube_item(pos,stack)
|
||||||
|
item1:get_luaentity().start_pos = pos
|
||||||
|
item1:setvelocity(direction)
|
||||||
|
item1:setacceleration({x=0, y=0, z=0})
|
||||||
|
return ItemStack("")
|
||||||
|
end,
|
||||||
|
can_insert=function(pos,node,stack,direction)
|
||||||
|
local dir = facedir_to_right_dir(node.param2)
|
||||||
|
if dir.x == direction.x and dir.y == direction.y and dir.z == direction.z then
|
||||||
|
return true
|
||||||
|
end
|
||||||
|
return false
|
||||||
|
end},
|
||||||
|
})
|
||||||
|
end
|
||||||
|
Loading…
Reference in New Issue
Block a user