From 867227dbfde65209abf0a37e92222490bca6190f Mon Sep 17 00:00:00 2001 From: Joachim Stolberg Date: Mon, 13 Apr 2020 22:55:49 +0200 Subject: [PATCH] ta4_chest and distributor modes enhanced, further improvements --- basic_machines/autocrafter.lua | 2 +- basic_machines/distributor.lua | 13 +- basic_machines/electronic_fab.lua | 2 +- basic_machines/gravelrinser.lua | 2 +- basic_machines/gravelsieve.lua | 2 +- basic_machines/grinder.lua | 2 +- basic_machines/quarry.lua | 2 +- icta_controller/display.lua | 181 +++++++++++++-------------- lua_controller/sensorchest.lua | 2 +- textures/techage_appl_color_top4.png | Bin 0 -> 237 bytes 10 files changed, 101 insertions(+), 107 deletions(-) create mode 100644 textures/techage_appl_color_top4.png diff --git a/basic_machines/autocrafter.lua b/basic_machines/autocrafter.lua index 3cef8b8..92d81ea 100644 --- a/basic_machines/autocrafter.lua +++ b/basic_machines/autocrafter.lua @@ -345,7 +345,7 @@ local tubing = { local meta = minetest.get_meta(pos) if meta:get_int("push_dir") == in_dir or in_dir == 5 then 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) end end, diff --git a/basic_machines/distributor.lua b/basic_machines/distributor.lua index 0d1419f..f25cf02 100644 --- a/basic_machines/distributor.lua +++ b/basic_machines/distributor.lua @@ -294,7 +294,7 @@ local function sequencing(pos, inv, crd, nvm) local num_filters = 0 -- already processed local num_pushed = 0 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 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 break end - if not techage.push_items(pos, push_dir, stack, offs) then - blocked = true - break + if techage.push_items(pos, push_dir, stack, offs) then + num_pushed = num_pushed + 1 + inv:remove_item("src", stack) + blocked = false end - num_pushed = num_pushed + 1 - inv:remove_item("src", stack) end offs = (offs % 6) + 1 num_filters = num_filters + 1 @@ -416,7 +415,7 @@ tiles.pas = { tiles.act = { -- 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, animation = { type = "vertical_frames", diff --git a/basic_machines/electronic_fab.lua b/basic_machines/electronic_fab.lua index bb62280..b97eae5 100644 --- a/basic_machines/electronic_fab.lua +++ b/basic_machines/electronic_fab.lua @@ -182,7 +182,7 @@ local tubing = { local meta = minetest.get_meta(pos) if meta:get_int("push_dir") == in_dir or in_dir == 5 then 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) end end, diff --git a/basic_machines/gravelrinser.lua b/basic_machines/gravelrinser.lua index 2e6bdb8..4915fa5 100644 --- a/basic_machines/gravelrinser.lua +++ b/basic_machines/gravelrinser.lua @@ -226,7 +226,7 @@ local tubing = { local meta = minetest.get_meta(pos) if meta:get_int("push_dir") == in_dir or in_dir == 5 then 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) end end, diff --git a/basic_machines/gravelsieve.lua b/basic_machines/gravelsieve.lua index d19003d..b878e77 100644 --- a/basic_machines/gravelsieve.lua +++ b/basic_machines/gravelsieve.lua @@ -159,7 +159,7 @@ local tubing = { local meta = minetest.get_meta(pos) if meta:get_int("push_dir") == in_dir or in_dir == 5 then 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) end end, diff --git a/basic_machines/grinder.lua b/basic_machines/grinder.lua index b9d3992..0217231 100644 --- a/basic_machines/grinder.lua +++ b/basic_machines/grinder.lua @@ -172,7 +172,7 @@ local tubing = { local meta = minetest.get_meta(pos) if meta:get_int("push_dir") == in_dir or in_dir == 5 then 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) end end, diff --git a/basic_machines/quarry.lua b/basic_machines/quarry.lua index 097cb9a..2822ef6 100644 --- a/basic_machines/quarry.lua +++ b/basic_machines/quarry.lua @@ -336,7 +336,7 @@ local tubing = { local meta = minetest.get_meta(pos) if meta:get_int("push_dir") == in_dir or in_dir == 5 then 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) end end, diff --git a/icta_controller/display.lua b/icta_controller/display.lua index 8f7bc3c..8ace0af 100644 --- a/icta_controller/display.lua +++ b/icta_controller/display.lua @@ -16,13 +16,11 @@ local NUM_ROWS = 5 local RADIUS = 6 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 meta = minetest.get_meta(pos) - local text = meta:get_string("text") or "" - text = string.gsub(text, "|", " \n") + pos = vector.round(pos) + local nvm = techage.get_nvm(pos) + nvm.text = nvm.text or {""} + local text = table.concat(nvm.text, "\n") local texture = lcdlib.make_multiline_texture( "default", text, 70, 70, NUM_ROWS, "top", "#000") @@ -31,9 +29,10 @@ local function display_update(pos, objref) end local function display_updateXL(pos, objref) - local meta = minetest.get_meta(pos) - local text = meta:get_string("text") or "" - text = string.gsub(text, "|", " \n") + pos = vector.round(pos) + local nvm = techage.get_nvm(pos) + nvm.text = nvm.text or {""} + local text = table.concat(nvm.text, "\n") local texture = lcdlib.make_multiline_texture( "default", text, 126, 70, NUM_ROWS, "top", "#000") @@ -42,19 +41,25 @@ local function display_updateXL(pos, objref) end local function on_timer(pos) - local node = minetest.get_node(pos) - -- 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 - local dir = minetest.facedir_to_dir(Param2ToFacedir[node.param2 % 6]) - local pos2 = vector.add(pos, vector.multiply(dir, RADIUS)) - for _, obj in pairs(minetest.get_objects_inside_radius(pos2, RADIUS)) do - if obj:is_player() then - lcdlib.update_entities(pos) - break + local mem = techage.get_mem(pos) + mem.ticks = mem.ticks or 0 + + if mem.ticks > 0 then + local node = minetest.get_node(pos) + -- 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 + local dir = minetest.facedir_to_dir(Param2ToFacedir[node.param2 % 6]) + local pos2 = vector.add(pos, vector.multiply(dir, RADIUS)) + for _, obj in pairs(minetest.get_objects_inside_radius(pos2, RADIUS)) do + if obj:is_player() then + lcdlib.update_entities(pos) + mem.ticks = mem.ticks - 1 + break + end end end end - return false + return true end local lcd_box = { @@ -83,9 +88,10 @@ minetest.register_node("techage:ta4_display", { local number = techage.add_node(pos, "techage:ta4_display") local meta = minetest.get_meta(pos) meta:set_string("number", number) - meta:set_string("text", "My\nTechage\nTA4\nDisplay\nNo: "..number) - meta:set_int("startscreen", 1) + local nvm = techage.get_nvm(pos) + nvm.text = {"My", "Techage","TA4", "Display", "No: "..number} lcdlib.update_entities(pos) + minetest.get_node_timer(pos):start(1) end, 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 meta = minetest.get_meta(pos) meta:set_string("number", number) - meta:set_string("text", "My\nTechage\nTA4\nDisplay\nNo: "..number) - meta:set_int("startscreen", 1) + local nvm = techage.get_nvm(pos) + nvm.text = {"My", "Techage","TA4", "Display", "No: "..number} lcdlib.update_entities(pos) + minetest.get_node_timer(pos):start(2) end, after_dig_node = function(pos) @@ -165,97 +172,85 @@ minetest.register_craft({ }, }) -local function add_line(meta, payload) - local text = meta:get_string("text") - local rows - if meta:get_int("startscreen") == 1 then - rows = {} - meta:set_int("startscreen", 0) - else - rows = string.split(text, "|") +local function add_line(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) or "oops" + + if mem.ticks == 0 then + mem.ticks = cycle_time end - while #rows >= NUM_ROWS do - table.remove(rows, 1) + + while #nvm.text >= NUM_ROWS do + table.remove(nvm.text, 1) end - table.insert(rows, payload) - text = table.concat(rows, "|") - meta:set_string("text", text) + table.insert(nvm.text, payload) end -local function write_row(meta, payload) - local text = meta:get_string("text") - if type(payload) == "table" then - local row = tonumber(payload.row) or 0 - if row > NUM_ROWS then row = NUM_ROWS end - local str = payload.str or "oops" - if row == 0 then - meta:set_string("infotext", str) - return - end - local rows - if meta:get_int("startscreen") == 1 then - rows = {} - meta:set_int("startscreen", 0) - else - rows = string.split(text, "|") - end - if #rows < NUM_ROWS then - for i = #rows, NUM_ROWS do - table.insert(rows, " ") - end - end - rows[row] = str - text = table.concat(rows, "|") - meta:set_string("text", text) +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 == 0 then + meta:set_string("infotext", str) + return + end + + while #nvm.text <= row do + table.insert(nvm.text, " ") + end + nvm.text[row] = str +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 + + nvm.text = {""} end techage.register_node({"techage:ta4_display"}, { 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 - local meta = minetest.get_meta(pos) - add_line(meta, payload) - if not timer:is_started() then - timer:start(1) - end + add_line(pos, payload, 1) elseif topic == "set" then -- overwrite the given row - local meta = minetest.get_meta(pos) - write_row(meta, payload) - if not timer:is_started() then - timer:start(1) - end + write_row(pos, payload, 1) elseif topic == "clear" then -- clear the screen - local meta = minetest.get_meta(pos) - meta:set_string("text", "") - if not timer:is_started() then - timer:start(1) - end + clear_screen(pos, 1) end end, }) techage.register_node({"techage:ta4_displayXL"}, { 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 - local meta = minetest.get_meta(pos) - add_line(meta, payload) - if not timer:is_started() then - timer:start(2) - end + add_line(pos, payload, 2) elseif topic == "set" then -- overwrite the given row - local meta = minetest.get_meta(pos) - write_row(meta, payload) - if not timer:is_started() then - timer:start(2) - end + write_row(pos, payload, 2) elseif topic == "clear" then -- clear the screen - local meta = minetest.get_meta(pos) - meta:set_string("text", "") - if not timer:is_started() then - timer:start(2) - end + clear_screen(pos, 2) end end, }) + +lcdlib.register_display_entity("techage:display_entity") +lcdlib.register_display_entity("techage:display_entityXL") + diff --git a/lua_controller/sensorchest.lua b/lua_controller/sensorchest.lua index b174b95..7f46470 100644 --- a/lua_controller/sensorchest.lua +++ b/lua_controller/sensorchest.lua @@ -141,7 +141,7 @@ minetest.register_node("techage:ta4_sensor_chest", { meta:set_string("owner", placer:get_player_name()) meta:set_string("text", "Text to be changed\nby command.") 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, on_receive_fields = function(pos, formname, fields, player) diff --git a/textures/techage_appl_color_top4.png b/textures/techage_appl_color_top4.png new file mode 100644 index 0000000000000000000000000000000000000000..10bc82b9206844a9bb604ad0a7eee11207a1f3b8 GIT binary patch literal 237 zcmeAS@N?(olHy`uVBq!ia0vp^3P9Yz!3HF=(z2z16kC$Fy9e|JTI6Tel^%7Fw`;} fxEml}af$b6lZE7&0KW{ND;PXo{an^LB{Ts5;0aEE literal 0 HcmV?d00001