ta4_chest and distributor modes enhanced, further improvements

This commit is contained in:
Joachim Stolberg 2020-04-13 22:55:49 +02:00
parent ea4765ce46
commit 867227dbfd
10 changed files with 101 additions and 107 deletions

View File

@ -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,

View File

@ -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",

View File

@ -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,

View File

@ -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,

View File

@ -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,

View File

@ -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,

View File

@ -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,

View File

@ -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
end mem.ticks = cycle_time
while #rows >= NUM_ROWS do
table.remove(rows, 1)
end
table.insert(rows, payload)
text = table.concat(rows, "|")
meta:set_string("text", text)
end end
local function write_row(meta, payload) while #nvm.text >= NUM_ROWS do
local text = meta:get_string("text") table.remove(nvm.text, 1)
if type(payload) == "table" then end
local row = tonumber(payload.row) or 0 table.insert(nvm.text, payload)
end
local function write_row(pos, payload, cycle_time)
local nvm = techage.get_nvm(pos)
local mem = techage.get_mem(pos)
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
table.insert(rows, " ")
end end
local function clear_screen(pos, cycle_time)
local nvm = techage.get_nvm(pos)
local mem = techage.get_mem(pos)
mem.ticks = mem.ticks or 0
if mem.ticks == 0 then
mem.ticks = cycle_time
end end
rows[row] = str
text = table.concat(rows, "|") nvm.text = {""}
meta:set_string("text", text)
end
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")

View File

@ -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)

Binary file not shown.

After

Width:  |  Height:  |  Size: 237 B