ta4_chest and distributor modes enhanced, further improvements
This commit is contained in:
parent
ea4765ce46
commit
867227dbfd
@ -345,7 +345,7 @@ local tubing = {
|
|||||||
local meta = minetest.get_meta(pos)
|
local meta = minetest.get_meta(pos)
|
||||||
if meta:get_int("push_dir") == in_dir or in_dir == 5 then
|
if meta:get_int("push_dir") == in_dir or in_dir == 5 then
|
||||||
local inv = M(pos):get_inventory()
|
local inv = M(pos):get_inventory()
|
||||||
CRD(pos).State:start_if_standby(pos)
|
--CRD(pos).State:start_if_standby(pos) -- would need power!
|
||||||
return techage.put_items(inv, "src", stack, idx)
|
return techage.put_items(inv, "src", stack, idx)
|
||||||
end
|
end
|
||||||
end,
|
end,
|
||||||
|
@ -294,7 +294,7 @@ local function sequencing(pos, inv, crd, nvm)
|
|||||||
local num_filters = 0 -- already processed
|
local num_filters = 0 -- already processed
|
||||||
local num_pushed = 0
|
local num_pushed = 0
|
||||||
local push_dir = open_ports[1] or 1
|
local push_dir = open_ports[1] or 1
|
||||||
local blocked = false
|
local blocked = true
|
||||||
|
|
||||||
while num_pushed < crd.num_items and num_filters < 7 do
|
while num_pushed < crd.num_items and num_filters < 7 do
|
||||||
local stack = filter_items[offs] and ItemStack(filter_items[offs])
|
local stack = filter_items[offs] and ItemStack(filter_items[offs])
|
||||||
@ -302,12 +302,11 @@ local function sequencing(pos, inv, crd, nvm)
|
|||||||
if not inv:contains_item("src", stack) then
|
if not inv:contains_item("src", stack) then
|
||||||
break
|
break
|
||||||
end
|
end
|
||||||
if not techage.push_items(pos, push_dir, stack, offs) then
|
if techage.push_items(pos, push_dir, stack, offs) then
|
||||||
blocked = true
|
|
||||||
break
|
|
||||||
end
|
|
||||||
num_pushed = num_pushed + 1
|
num_pushed = num_pushed + 1
|
||||||
inv:remove_item("src", stack)
|
inv:remove_item("src", stack)
|
||||||
|
blocked = false
|
||||||
|
end
|
||||||
end
|
end
|
||||||
offs = (offs % 6) + 1
|
offs = (offs % 6) + 1
|
||||||
num_filters = num_filters + 1
|
num_filters = num_filters + 1
|
||||||
@ -416,7 +415,7 @@ tiles.pas = {
|
|||||||
tiles.act = {
|
tiles.act = {
|
||||||
-- up, down, right, left, back, front
|
-- up, down, right, left, back, front
|
||||||
{
|
{
|
||||||
image = "techage_filling4_ta#.png^techage_appl_distri4.png^techage_frame4_ta#_top.png",
|
image = "techage_filling4_ta#.png^techage_appl_distri4.png^techage_frame4_ta#_top.png^techage_appl_color_top4.png",
|
||||||
backface_culling = false,
|
backface_culling = false,
|
||||||
animation = {
|
animation = {
|
||||||
type = "vertical_frames",
|
type = "vertical_frames",
|
||||||
|
@ -182,7 +182,7 @@ local tubing = {
|
|||||||
local meta = minetest.get_meta(pos)
|
local meta = minetest.get_meta(pos)
|
||||||
if meta:get_int("push_dir") == in_dir or in_dir == 5 then
|
if meta:get_int("push_dir") == in_dir or in_dir == 5 then
|
||||||
local inv = M(pos):get_inventory()
|
local inv = M(pos):get_inventory()
|
||||||
CRD(pos).State:start_if_standby(pos)
|
--CRD(pos).State:start_if_standby(pos) -- would need power!
|
||||||
return techage.put_items(inv, "src", stack, idx)
|
return techage.put_items(inv, "src", stack, idx)
|
||||||
end
|
end
|
||||||
end,
|
end,
|
||||||
|
@ -226,7 +226,7 @@ local tubing = {
|
|||||||
local meta = minetest.get_meta(pos)
|
local meta = minetest.get_meta(pos)
|
||||||
if meta:get_int("push_dir") == in_dir or in_dir == 5 then
|
if meta:get_int("push_dir") == in_dir or in_dir == 5 then
|
||||||
local inv = M(pos):get_inventory()
|
local inv = M(pos):get_inventory()
|
||||||
CRD(pos).State:start_if_standby(pos)
|
-- CRD(pos).State:start_if_standby(pos) -- would need power!
|
||||||
return techage.put_items(inv, "src", stack)
|
return techage.put_items(inv, "src", stack)
|
||||||
end
|
end
|
||||||
end,
|
end,
|
||||||
|
@ -159,7 +159,7 @@ local tubing = {
|
|||||||
local meta = minetest.get_meta(pos)
|
local meta = minetest.get_meta(pos)
|
||||||
if meta:get_int("push_dir") == in_dir or in_dir == 5 then
|
if meta:get_int("push_dir") == in_dir or in_dir == 5 then
|
||||||
local inv = M(pos):get_inventory()
|
local inv = M(pos):get_inventory()
|
||||||
CRD(pos).State:start_if_standby(pos)
|
--CRD(pos).State:start_if_standby(pos) -- would need power!
|
||||||
return techage.put_items(inv, "src", stack)
|
return techage.put_items(inv, "src", stack)
|
||||||
end
|
end
|
||||||
end,
|
end,
|
||||||
|
@ -172,7 +172,7 @@ local tubing = {
|
|||||||
local meta = minetest.get_meta(pos)
|
local meta = minetest.get_meta(pos)
|
||||||
if meta:get_int("push_dir") == in_dir or in_dir == 5 then
|
if meta:get_int("push_dir") == in_dir or in_dir == 5 then
|
||||||
local inv = M(pos):get_inventory()
|
local inv = M(pos):get_inventory()
|
||||||
CRD(pos).State:start_if_standby(pos)
|
--CRD(pos).State:start_if_standby(pos) -- would need power!
|
||||||
return techage.put_items(inv, "src", stack)
|
return techage.put_items(inv, "src", stack)
|
||||||
end
|
end
|
||||||
end,
|
end,
|
||||||
|
@ -336,7 +336,7 @@ local tubing = {
|
|||||||
local meta = minetest.get_meta(pos)
|
local meta = minetest.get_meta(pos)
|
||||||
if meta:get_int("push_dir") == in_dir or in_dir == 5 then
|
if meta:get_int("push_dir") == in_dir or in_dir == 5 then
|
||||||
local inv = M(pos):get_inventory()
|
local inv = M(pos):get_inventory()
|
||||||
CRD(pos).State:start_if_standby(pos)
|
--CRD(pos).State:start_if_standby(pos) -- would need power!
|
||||||
return techage.put_items(inv, "main", stack)
|
return techage.put_items(inv, "main", stack)
|
||||||
end
|
end
|
||||||
end,
|
end,
|
||||||
|
@ -16,13 +16,11 @@ local NUM_ROWS = 5
|
|||||||
local RADIUS = 6
|
local RADIUS = 6
|
||||||
local Param2ToFacedir = {[0] = 0, 0, 3, 1, 2, 0}
|
local Param2ToFacedir = {[0] = 0, 0, 3, 1, 2, 0}
|
||||||
|
|
||||||
lcdlib.register_display_entity("techage:display_entity")
|
|
||||||
lcdlib.register_display_entity("techage:display_entityXL")
|
|
||||||
|
|
||||||
local function display_update(pos, objref)
|
local function display_update(pos, objref)
|
||||||
local meta = minetest.get_meta(pos)
|
pos = vector.round(pos)
|
||||||
local text = meta:get_string("text") or ""
|
local nvm = techage.get_nvm(pos)
|
||||||
text = string.gsub(text, "|", " \n")
|
nvm.text = nvm.text or {""}
|
||||||
|
local text = table.concat(nvm.text, "\n")
|
||||||
local texture = lcdlib.make_multiline_texture(
|
local texture = lcdlib.make_multiline_texture(
|
||||||
"default", text,
|
"default", text,
|
||||||
70, 70, NUM_ROWS, "top", "#000")
|
70, 70, NUM_ROWS, "top", "#000")
|
||||||
@ -31,9 +29,10 @@ local function display_update(pos, objref)
|
|||||||
end
|
end
|
||||||
|
|
||||||
local function display_updateXL(pos, objref)
|
local function display_updateXL(pos, objref)
|
||||||
local meta = minetest.get_meta(pos)
|
pos = vector.round(pos)
|
||||||
local text = meta:get_string("text") or ""
|
local nvm = techage.get_nvm(pos)
|
||||||
text = string.gsub(text, "|", " \n")
|
nvm.text = nvm.text or {""}
|
||||||
|
local text = table.concat(nvm.text, "\n")
|
||||||
local texture = lcdlib.make_multiline_texture(
|
local texture = lcdlib.make_multiline_texture(
|
||||||
"default", text,
|
"default", text,
|
||||||
126, 70, NUM_ROWS, "top", "#000")
|
126, 70, NUM_ROWS, "top", "#000")
|
||||||
@ -42,6 +41,10 @@ local function display_updateXL(pos, objref)
|
|||||||
end
|
end
|
||||||
|
|
||||||
local function on_timer(pos)
|
local function on_timer(pos)
|
||||||
|
local mem = techage.get_mem(pos)
|
||||||
|
mem.ticks = mem.ticks or 0
|
||||||
|
|
||||||
|
if mem.ticks > 0 then
|
||||||
local node = minetest.get_node(pos)
|
local node = minetest.get_node(pos)
|
||||||
-- check if display is loaded and a player in front of the display
|
-- check if display is loaded and a player in front of the display
|
||||||
if node.name == "techage:ta4_display" or node.name == "techage:ta4_displayXL" then
|
if node.name == "techage:ta4_display" or node.name == "techage:ta4_displayXL" then
|
||||||
@ -50,11 +53,13 @@ local function on_timer(pos)
|
|||||||
for _, obj in pairs(minetest.get_objects_inside_radius(pos2, RADIUS)) do
|
for _, obj in pairs(minetest.get_objects_inside_radius(pos2, RADIUS)) do
|
||||||
if obj:is_player() then
|
if obj:is_player() then
|
||||||
lcdlib.update_entities(pos)
|
lcdlib.update_entities(pos)
|
||||||
|
mem.ticks = mem.ticks - 1
|
||||||
break
|
break
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
return false
|
end
|
||||||
|
return true
|
||||||
end
|
end
|
||||||
|
|
||||||
local lcd_box = {
|
local lcd_box = {
|
||||||
@ -83,9 +88,10 @@ minetest.register_node("techage:ta4_display", {
|
|||||||
local number = techage.add_node(pos, "techage:ta4_display")
|
local number = techage.add_node(pos, "techage:ta4_display")
|
||||||
local meta = minetest.get_meta(pos)
|
local meta = minetest.get_meta(pos)
|
||||||
meta:set_string("number", number)
|
meta:set_string("number", number)
|
||||||
meta:set_string("text", "My\nTechage\nTA4\nDisplay\nNo: "..number)
|
local nvm = techage.get_nvm(pos)
|
||||||
meta:set_int("startscreen", 1)
|
nvm.text = {"My", "Techage","TA4", "Display", "No: "..number}
|
||||||
lcdlib.update_entities(pos)
|
lcdlib.update_entities(pos)
|
||||||
|
minetest.get_node_timer(pos):start(1)
|
||||||
end,
|
end,
|
||||||
|
|
||||||
after_dig_node = function(pos)
|
after_dig_node = function(pos)
|
||||||
@ -128,9 +134,10 @@ minetest.register_node("techage:ta4_displayXL", {
|
|||||||
local number = techage.add_node(pos, "techage:ta4_displayXL")
|
local number = techage.add_node(pos, "techage:ta4_displayXL")
|
||||||
local meta = minetest.get_meta(pos)
|
local meta = minetest.get_meta(pos)
|
||||||
meta:set_string("number", number)
|
meta:set_string("number", number)
|
||||||
meta:set_string("text", "My\nTechage\nTA4\nDisplay\nNo: "..number)
|
local nvm = techage.get_nvm(pos)
|
||||||
meta:set_int("startscreen", 1)
|
nvm.text = {"My", "Techage","TA4", "Display", "No: "..number}
|
||||||
lcdlib.update_entities(pos)
|
lcdlib.update_entities(pos)
|
||||||
|
minetest.get_node_timer(pos):start(2)
|
||||||
end,
|
end,
|
||||||
|
|
||||||
after_dig_node = function(pos)
|
after_dig_node = function(pos)
|
||||||
@ -165,97 +172,85 @@ minetest.register_craft({
|
|||||||
},
|
},
|
||||||
})
|
})
|
||||||
|
|
||||||
local function add_line(meta, payload)
|
local function add_line(pos, payload, cycle_time)
|
||||||
local text = meta:get_string("text")
|
local nvm = techage.get_nvm(pos)
|
||||||
local rows
|
local mem = techage.get_mem(pos)
|
||||||
if meta:get_int("startscreen") == 1 then
|
nvm.text = nvm.text or {""}
|
||||||
rows = {}
|
mem.ticks = mem.ticks or 0
|
||||||
meta:set_int("startscreen", 0)
|
local str = tostring(payload) or "oops"
|
||||||
else
|
|
||||||
rows = string.split(text, "|")
|
if mem.ticks == 0 then
|
||||||
|
mem.ticks = cycle_time
|
||||||
end
|
end
|
||||||
while #rows >= NUM_ROWS do
|
|
||||||
table.remove(rows, 1)
|
while #nvm.text >= NUM_ROWS do
|
||||||
|
table.remove(nvm.text, 1)
|
||||||
end
|
end
|
||||||
table.insert(rows, payload)
|
table.insert(nvm.text, payload)
|
||||||
text = table.concat(rows, "|")
|
|
||||||
meta:set_string("text", text)
|
|
||||||
end
|
end
|
||||||
|
|
||||||
local function write_row(meta, payload)
|
local function write_row(pos, payload, cycle_time)
|
||||||
local text = meta:get_string("text")
|
local nvm = techage.get_nvm(pos)
|
||||||
if type(payload) == "table" then
|
local mem = techage.get_mem(pos)
|
||||||
local row = tonumber(payload.row) or 0
|
nvm.text = nvm.text or {""}
|
||||||
|
mem.ticks = mem.ticks or 0
|
||||||
|
local str = tostring(payload.str) or "oops"
|
||||||
|
local row = tonumber(payload.row) or 1
|
||||||
|
|
||||||
|
if mem.ticks == 0 then
|
||||||
|
mem.ticks = cycle_time
|
||||||
|
end
|
||||||
|
|
||||||
|
if row < 0 then row = 1 end
|
||||||
if row > NUM_ROWS then row = NUM_ROWS end
|
if row > NUM_ROWS then row = NUM_ROWS end
|
||||||
local str = payload.str or "oops"
|
|
||||||
if row == 0 then
|
if row == 0 then
|
||||||
meta:set_string("infotext", str)
|
meta:set_string("infotext", str)
|
||||||
return
|
return
|
||||||
end
|
end
|
||||||
local rows
|
|
||||||
if meta:get_int("startscreen") == 1 then
|
while #nvm.text <= row do
|
||||||
rows = {}
|
table.insert(nvm.text, " ")
|
||||||
meta:set_int("startscreen", 0)
|
|
||||||
else
|
|
||||||
rows = string.split(text, "|")
|
|
||||||
end
|
end
|
||||||
if #rows < NUM_ROWS then
|
nvm.text[row] = str
|
||||||
for i = #rows, NUM_ROWS do
|
end
|
||||||
table.insert(rows, " ")
|
|
||||||
end
|
local function clear_screen(pos, cycle_time)
|
||||||
end
|
local nvm = techage.get_nvm(pos)
|
||||||
rows[row] = str
|
local mem = techage.get_mem(pos)
|
||||||
text = table.concat(rows, "|")
|
mem.ticks = mem.ticks or 0
|
||||||
meta:set_string("text", text)
|
|
||||||
|
if mem.ticks == 0 then
|
||||||
|
mem.ticks = cycle_time
|
||||||
end
|
end
|
||||||
|
|
||||||
|
nvm.text = {""}
|
||||||
end
|
end
|
||||||
|
|
||||||
techage.register_node({"techage:ta4_display"}, {
|
techage.register_node({"techage:ta4_display"}, {
|
||||||
on_recv_message = function(pos, src, topic, payload)
|
on_recv_message = function(pos, src, topic, payload)
|
||||||
local timer = minetest.get_node_timer(pos)
|
|
||||||
if topic == "add" then -- add one line and scroll if necessary
|
if topic == "add" then -- add one line and scroll if necessary
|
||||||
local meta = minetest.get_meta(pos)
|
add_line(pos, payload, 1)
|
||||||
add_line(meta, payload)
|
|
||||||
if not timer:is_started() then
|
|
||||||
timer:start(1)
|
|
||||||
end
|
|
||||||
elseif topic == "set" then -- overwrite the given row
|
elseif topic == "set" then -- overwrite the given row
|
||||||
local meta = minetest.get_meta(pos)
|
write_row(pos, payload, 1)
|
||||||
write_row(meta, payload)
|
|
||||||
if not timer:is_started() then
|
|
||||||
timer:start(1)
|
|
||||||
end
|
|
||||||
elseif topic == "clear" then -- clear the screen
|
elseif topic == "clear" then -- clear the screen
|
||||||
local meta = minetest.get_meta(pos)
|
clear_screen(pos, 1)
|
||||||
meta:set_string("text", "")
|
|
||||||
if not timer:is_started() then
|
|
||||||
timer:start(1)
|
|
||||||
end
|
|
||||||
end
|
end
|
||||||
end,
|
end,
|
||||||
})
|
})
|
||||||
|
|
||||||
techage.register_node({"techage:ta4_displayXL"}, {
|
techage.register_node({"techage:ta4_displayXL"}, {
|
||||||
on_recv_message = function(pos, src, topic, payload)
|
on_recv_message = function(pos, src, topic, payload)
|
||||||
local timer = minetest.get_node_timer(pos)
|
|
||||||
if topic == "add" then -- add one line and scroll if necessary
|
if topic == "add" then -- add one line and scroll if necessary
|
||||||
local meta = minetest.get_meta(pos)
|
add_line(pos, payload, 2)
|
||||||
add_line(meta, payload)
|
|
||||||
if not timer:is_started() then
|
|
||||||
timer:start(2)
|
|
||||||
end
|
|
||||||
elseif topic == "set" then -- overwrite the given row
|
elseif topic == "set" then -- overwrite the given row
|
||||||
local meta = minetest.get_meta(pos)
|
write_row(pos, payload, 2)
|
||||||
write_row(meta, payload)
|
|
||||||
if not timer:is_started() then
|
|
||||||
timer:start(2)
|
|
||||||
end
|
|
||||||
elseif topic == "clear" then -- clear the screen
|
elseif topic == "clear" then -- clear the screen
|
||||||
local meta = minetest.get_meta(pos)
|
clear_screen(pos, 2)
|
||||||
meta:set_string("text", "")
|
|
||||||
if not timer:is_started() then
|
|
||||||
timer:start(2)
|
|
||||||
end
|
|
||||||
end
|
end
|
||||||
end,
|
end,
|
||||||
})
|
})
|
||||||
|
|
||||||
|
lcdlib.register_display_entity("techage:display_entity")
|
||||||
|
lcdlib.register_display_entity("techage:display_entityXL")
|
||||||
|
|
||||||
|
@ -141,7 +141,7 @@ minetest.register_node("techage:ta4_sensor_chest", {
|
|||||||
meta:set_string("owner", placer:get_player_name())
|
meta:set_string("owner", placer:get_player_name())
|
||||||
meta:set_string("text", "Text to be changed\nby command.")
|
meta:set_string("text", "Text to be changed\nby command.")
|
||||||
meta:set_string("formspec", formspec1())
|
meta:set_string("formspec", formspec1())
|
||||||
meta:set_string("infotext", S("TA4 Sensor Chest").." "..number)
|
meta:set_string("infotext", S("TA4 Sensor Chest").." "..number..": "..S("not connected"))
|
||||||
end,
|
end,
|
||||||
|
|
||||||
on_receive_fields = function(pos, formname, fields, player)
|
on_receive_fields = function(pos, formname, fields, player)
|
||||||
|
BIN
textures/techage_appl_color_top4.png
Normal file
BIN
textures/techage_appl_color_top4.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 237 B |
Loading…
Reference in New Issue
Block a user