Add flip-flop

This commit is contained in:
Joachim Stolberg 2023-06-09 16:31:22 +02:00
parent 9210bce637
commit d6be0812c4
14 changed files with 186 additions and 7 deletions

View File

@ -311,4 +311,4 @@ end
function techage.dropdown_index(sChoices, selected_value) function techage.dropdown_index(sChoices, selected_value)
local l = sChoices:split(",") local l = sChoices:split(",")
return index(l, selected_value) or 1 return index(l, selected_value) or 1
end end

View File

@ -127,6 +127,7 @@ techage.Items = {
ta3_motor = "techage:ta3_motor_off", ta3_motor = "techage:ta3_motor_off",
ta3_injector = "techage:ta3_injector_pas", ta3_injector = "techage:ta3_injector_pas",
ta3_command_converter = "techage:ta3_command_converter_off", ta3_command_converter = "techage:ta3_command_converter_off",
ta3_flipflop = "techage:ta3_flipflop_off",
---------------------------- ----------------------------
techage_ta4 = "techage_ta4.png", techage_ta4 = "techage_ta4.png",
techage_ta4c = "techage_ta4c.png", techage_ta4c = "techage_ta4c.png",

View File

@ -108,6 +108,7 @@ techage.manual_DE.aTitel = {
"2,Logik-/Schalt-Blöcke", "2,Logik-/Schalt-Blöcke",
"3,TA3 Taster/Schalter / Button/Switch", "3,TA3 Taster/Schalter / Button/Switch",
"3,TA3 Kommando Konverter / Command Converter", "3,TA3 Kommando Konverter / Command Converter",
"3,TA3 Flipflop / Flip-Flop",
"3,TA3 Logikblock / Logic Block", "3,TA3 Logikblock / Logic Block",
"3,TA3 Wiederholer / Repeater", "3,TA3 Wiederholer / Repeater",
"3,TA3 Sequenzer / Sequencer", "3,TA3 Sequenzer / Sequencer",
@ -1067,6 +1068,12 @@ techage.manual_DE.aText = {
"\n".. "\n"..
"\n".. "\n"..
"\n", "\n",
"Das TA3 Flipflop wechselt seinen Zustand mit jedem empfangenen 'on' Kommando. Empfangene 'off' Kommandos werden ignortiert. Damit werden abhängig vom Zustandswechsel abwechselnd 'on' / 'off' Kommandos gesendet. Die Nummer des Zielblockes bzw. die Nummern der Zielblöcke müssen eingegeben werden. Die Nummern können auch mit Hilfe des Techage Programmers programmiert werden.\n"..
"\n"..
"Damit lassen sich bspw. Lampen mit Hilfe von Tastern ein- und wieder ausschalten.\n"..
"\n"..
"\n"..
"\n",
"Den TA3 Logikblock kann man so programmieren\\, dass ein oder mehrere Eingangskommandos zu einem Ausgangskommando verknüpft und gesendet werden. Dieser Block kann daher diverse Logik-Elemente wie AND\\, OR\\, NOT\\, XOR usw. ersetzen.\n".. "Den TA3 Logikblock kann man so programmieren\\, dass ein oder mehrere Eingangskommandos zu einem Ausgangskommando verknüpft und gesendet werden. Dieser Block kann daher diverse Logik-Elemente wie AND\\, OR\\, NOT\\, XOR usw. ersetzen.\n"..
"Eingangkommandos für den Logikblock sind 'on'/'off' Kommandos.\n".. "Eingangkommandos für den Logikblock sind 'on'/'off' Kommandos.\n"..
"Eingangskommandos werden über die Nummer referenziert\\, also bspw. '1234' für das Kommando vom Sender mit der Nummer 1234.\n".. "Eingangskommandos werden über die Nummer referenziert\\, also bspw. '1234' für das Kommando vom Sender mit der Nummer 1234.\n"..
@ -2312,6 +2319,7 @@ techage.manual_DE.aItemName = {
"ta3_logic", "ta3_logic",
"ta3_button", "ta3_button",
"ta3_command_converter", "ta3_command_converter",
"ta3_flipflop",
"ta3_logic", "ta3_logic",
"ta3_repeater", "ta3_repeater",
"ta3_sequencer", "ta3_sequencer",
@ -2605,6 +2613,7 @@ techage.manual_DE.aPlanTable = {
"", "",
"", "",
"", "",
"",
"ta4_windturbine", "ta4_windturbine",
"", "",
"", "",

View File

@ -109,6 +109,7 @@ techage.manual_EN.aTitel = {
"2,Logic / Switching Blocks", "2,Logic / Switching Blocks",
"3,TA3 Button / Switch", "3,TA3 Button / Switch",
"3,TA3 Command Converter", "3,TA3 Command Converter",
"3,TA3 Flip-Flop",
"3,TA3 Logic Block", "3,TA3 Logic Block",
"3,TA3 Repeater", "3,TA3 Repeater",
"3,TA3 Sequencer", "3,TA3 Sequencer",
@ -1075,6 +1076,12 @@ techage.manual_EN.aText = {
"\n".. "\n"..
"\n".. "\n"..
"\n", "\n",
"The TA3 flip-flop changes its state with each received 'on' command. Received 'off' commands are ignored. Depending on the status change\\, 'on' / 'off' commands are sent alternately. The number of the target block or the numbers of the target blocks must be entered. The numbers can also be programmed using the Techage programmer.\n"..
"\n"..
"For example\\, lamps can be switched on and off with the help of buttons.\n"..
"\n"..
"\n"..
"\n",
"The TA3 logic block can be programmed in such a way that one or more input commands are linked to one output command and sent. This block can therefore replace various logic elements such as AND\\, OR\\, NOT\\, XOR etc. \n".. "The TA3 logic block can be programmed in such a way that one or more input commands are linked to one output command and sent. This block can therefore replace various logic elements such as AND\\, OR\\, NOT\\, XOR etc. \n"..
"Input commands for the logic block are 'on' /'off' commands.\n".. "Input commands for the logic block are 'on' /'off' commands.\n"..
"Input commands are referenced via the number\\, e.g. '1234' for the command from the sender with the number 1234. \n".. "Input commands are referenced via the number\\, e.g. '1234' for the command from the sender with the number 1234. \n"..
@ -2323,6 +2330,7 @@ techage.manual_EN.aItemName = {
"ta3_logic", "ta3_logic",
"ta3_button", "ta3_button",
"ta3_command_converter", "ta3_command_converter",
"ta3_flipflop",
"ta3_logic", "ta3_logic",
"ta3_repeater", "ta3_repeater",
"ta3_sequencer", "ta3_sequencer",
@ -2618,6 +2626,7 @@ techage.manual_EN.aPlanTable = {
"", "",
"", "",
"", "",
"",
"ta4_windturbine", "ta4_windturbine",
"", "",
"", "",

View File

@ -52,7 +52,6 @@ techage.NodeDef = {} -- node registration info
techage.max_num_forceload_blocks = tonumber(minetest.settings:get("techage_max_num_forceload_blocks")) or 24 techage.max_num_forceload_blocks = tonumber(minetest.settings:get("techage_max_num_forceload_blocks")) or 24
techage.basalt_stone_enabled = minetest.settings:get_bool("techage_basalt_stone_enabled") ~= false
techage.ore_rarity = tonumber(minetest.settings:get("techage_ore_rarity")) or 1 techage.ore_rarity = tonumber(minetest.settings:get("techage_ore_rarity")) or 1
techage.modified_recipes_enabled = minetest.settings:get_bool("techage_modified_recipes_enabled") ~= false techage.modified_recipes_enabled = minetest.settings:get_bool("techage_modified_recipes_enabled") ~= false
techage.collider_min_depth = tonumber(minetest.settings:get("techage_collider_min_depth")) or -28 techage.collider_min_depth = tonumber(minetest.settings:get("techage_collider_min_depth")) or -28
@ -292,6 +291,7 @@ dofile(MP.."/logic/light_detector.lua")
dofile(MP.."/logic/player_detector.lua") dofile(MP.."/logic/player_detector.lua")
dofile(MP.."/logic/gaze_sensor.lua") dofile(MP.."/logic/gaze_sensor.lua")
dofile(MP.."/logic/command_converter.lua") dofile(MP.."/logic/command_converter.lua")
dofile(MP.."/logic/flipflop.lua")
dofile(MP.."/logic/mba_detector.lua") dofile(MP.."/logic/mba_detector.lua")
dofile(MP.."/logic/cart_detector.lua") dofile(MP.."/logic/cart_detector.lua")
dofile(MP.."/logic/charge_detector.lua") dofile(MP.."/logic/charge_detector.lua")

View File

@ -179,4 +179,4 @@ techage.register_node({
end end
end, end,
} }
) )

147
logic/flipflop.lua Normal file
View File

@ -0,0 +1,147 @@
--[[
TechAge
=======
Copyright (C) 2017-2023 Joachim Stolberg
AGPL v3
See LICENSE.txt for more information
TA3 Flip-flop
]]--
-- for lazy programmers
local M = minetest.get_meta
local S = techage.S
local DESCR = S("TA3 Flip-Flop")
local logic = techage.logic
local function switch_on(pos)
logic.swap_node(pos, "techage:ta3_flipflop_on")
logic.send_on(pos, M(pos))
end
local function switch_off(pos)
logic.swap_node(pos, "techage:ta3_flipflop_off")
logic.send_off(pos, M(pos))
end
local function formspec(meta)
local numbers = meta:get_string("numbers") or ""
return "formspec_version[4]size[10,3.5]"..
"box[0.2,0.2;9.6,0.6;#c6e8ff]" ..
"label[0.4,0.5;" .. minetest.colorize( "#000000", DESCR) .. "]" ..
"field[1.0,1.5;8,0.6;numbers;" .. S("Insert destination node number(s)") .. ";" .. numbers .. "]" ..
"button_exit[3.5,2.7;3,0.6;exit;" .. S("Save") .. "]"
end
local function techage_set_numbers(pos, numbers, player_name)
local meta = M(pos)
local res = logic.set_numbers(pos, numbers, player_name, DESCR)
meta:set_string("formspec", formspec(meta))
return true --res
end
local function after_dig_node(pos, oldnode, oldmetadata, digger)
techage.remove_node(pos, oldnode, oldmetadata)
techage.del_mem(pos)
end
local function on_receive_fields(pos, formname, fields, player)
if minetest.is_protected(pos, player:get_player_name()) then
return
end
local meta = minetest.get_meta(pos)
if fields.exit and fields.exit ~= "" then
if techage.check_numbers(fields.numbers, player:get_player_name()) then
meta:set_string("numbers", fields.numbers)
logic.infotext(M(pos), DESCR)
end
meta:set_string("formspec", formspec(meta))
elseif fields.exit == "close" then
meta:set_string("formspec", formspec(meta))
end
end
minetest.register_node("techage:ta3_flipflop_off", {
description = DESCR,
tiles = {
-- up, down, right, left, back, front
"techage_filling_ta3.png^techage_frame_ta3_top.png",
"techage_filling_ta3.png^techage_frame_ta3_top.png",
"techage_filling_ta3.png^techage_frame_ta3.png^techage_appl_flipflop.png",
},
after_place_node = function(pos, placer)
local meta = M(pos)
logic.after_place_node(pos, placer, "techage:ta3_flipflop_off", DESCR)
logic.infotext(meta, DESCR)
meta:set_string("formspec", formspec(meta))
end,
on_timer = function (pos, elapsed)
switch_on(pos)
end,
on_receive_fields = on_receive_fields,
techage_set_numbers = techage_set_numbers,
after_dig_node = after_dig_node,
paramtype2 = "facedir",
groups = {choppy=2, cracky=2, crumbly=2},
is_ground_content = false,
sounds = default.node_sound_wood_defaults(),
})
minetest.register_node("techage:ta3_flipflop_on", {
description = DESCR,
tiles = {
-- up, down, right, left, back, front
"techage_filling_ta3.png^techage_frame_ta3_top.png",
"techage_filling_ta3.png^techage_frame_ta3_top.png",
"techage_filling_ta3.png^techage_frame_ta3.png^techage_appl_flipflop_on.png",
},
on_timer = function (pos, elapsed)
switch_off(pos)
end,
on_receive_fields = on_receive_fields,
techage_set_numbers = techage_set_numbers,
after_dig_node = after_dig_node,
paramtype2 = "facedir",
groups = {choppy=2, cracky=2, crumbly=2, not_in_creative_inventory=1},
is_ground_content = false,
sounds = default.node_sound_wood_defaults(),
drop = "techage:ta3_flipflop_off"
})
minetest.register_craft({
output = "techage:ta3_flipflop_off",
recipe = {
{"", "group:wood", ""},
{"default:mese_crystal_fragment", "default:steel_ingot", "techage:vacuum_tube"},
{"", "group:wood", ""},
},
})
techage.register_node({
"techage:ta3_flipflop_off", "techage:ta3_flipflop_on"
}, {
on_recv_message = function(pos, src, topic, payload)
if topic == "on" then
minetest.get_node_timer(pos):start(0.1)
return true
elseif topic == "off" then
return true
else
return "unsupported"
end
end,
}
)

View File

@ -544,6 +544,14 @@ Die Nummern können auch mit Hilfe des Techage Programmers programmiert werden.
[ta3_command_converter|image] [ta3_command_converter|image]
### TA3 Flipflop / Flip-Flop
Das TA3 Flipflop wechselt seinen Zustand mit jedem empfangenen `on` Kommando. Empfangene `off` Kommandos werden ignortiert. Damit werden abhängig vom Zustandswechsel abwechselnd `on` / `off` Kommandos gesendet. Die Nummer des Zielblockes bzw. die Nummern der Zielblöcke müssen eingegeben werden. Die Nummern können auch mit Hilfe des Techage Programmers programmiert werden.
Damit lassen sich bspw. Lampen mit Hilfe von Tastern ein- und wieder ausschalten.
[ta3_flipflop|image]
### TA3 Logikblock / Logic Block ### TA3 Logikblock / Logic Block
Den TA3 Logikblock kann man so programmieren, dass ein oder mehrere Eingangskommandos zu einem Ausgangskommando verknüpft und gesendet werden. Dieser Block kann daher diverse Logik-Elemente wie AND, OR, NOT, XOR usw. ersetzen. Den TA3 Logikblock kann man so programmieren, dass ein oder mehrere Eingangskommandos zu einem Ausgangskommando verknüpft und gesendet werden. Dieser Block kann daher diverse Logik-Elemente wie AND, OR, NOT, XOR usw. ersetzen.

View File

@ -537,7 +537,6 @@ Note: With the programmer, block numbers can be easily collected and configured.
[ta3_button|image] [ta3_button|image]
### TA3 Command Converter ### TA3 Command Converter
With the TA3 command converter, `on` / `off` commands can be converted into other commands, and forwarding can be prevented or delayed. With the TA3 command converter, `on` / `off` commands can be converted into other commands, and forwarding can be prevented or delayed.
@ -547,6 +546,13 @@ The numbers can also be programmed using the Techage programmer.
[ta3_command_converter|image] [ta3_command_converter|image]
### TA3 Flip-Flop
The TA3 flip-flop changes its state with each received `on` command. Received `off` commands are ignored. Depending on the status change, `on` / `off` commands are sent alternately. The number of the target block or the numbers of the target blocks must be entered. The numbers can also be programmed using the Techage programmer.
For example, lamps can be switched on and off with the help of buttons.
[ta3_flipflop|image]
### TA3 Logic Block ### TA3 Logic Block

View File

@ -107,6 +107,7 @@
- [Logik-/Schalt-Blöcke](./manual_ta3_DE.md#logik-schalt-blöcke) - [Logik-/Schalt-Blöcke](./manual_ta3_DE.md#logik-schalt-blöcke)
- [TA3 Taster/Schalter / Button/Switch](./manual_ta3_DE.md#ta3-tasterschalter--buttonswitch) - [TA3 Taster/Schalter / Button/Switch](./manual_ta3_DE.md#ta3-tasterschalter--buttonswitch)
- [TA3 Kommando Konverter / Command Converter](./manual_ta3_DE.md#ta3-kommando-konverter--command-converter) - [TA3 Kommando Konverter / Command Converter](./manual_ta3_DE.md#ta3-kommando-konverter--command-converter)
- [TA3 Flipflop / Flip-Flop](./manual_ta3_DE.md#ta3-flipflop--flip-flop)
- [TA3 Logikblock / Logic Block](./manual_ta3_DE.md#ta3-logikblock--logic-block) - [TA3 Logikblock / Logic Block](./manual_ta3_DE.md#ta3-logikblock--logic-block)
- [TA3 Wiederholer / Repeater](./manual_ta3_DE.md#ta3-wiederholer--repeater) - [TA3 Wiederholer / Repeater](./manual_ta3_DE.md#ta3-wiederholer--repeater)
- [TA3 Sequenzer / Sequencer](./manual_ta3_DE.md#ta3-sequenzer--sequencer) - [TA3 Sequenzer / Sequencer](./manual_ta3_DE.md#ta3-sequenzer--sequencer)

View File

@ -108,6 +108,7 @@
- [Logic / Switching Blocks](./manual_ta3_EN.md#logic--switching-blocks) - [Logic / Switching Blocks](./manual_ta3_EN.md#logic--switching-blocks)
- [TA3 Button / Switch](./manual_ta3_EN.md#ta3-button--switch) - [TA3 Button / Switch](./manual_ta3_EN.md#ta3-button--switch)
- [TA3 Command Converter](./manual_ta3_EN.md#ta3-command-converter) - [TA3 Command Converter](./manual_ta3_EN.md#ta3-command-converter)
- [TA3 Flip-Flop](./manual_ta3_EN.md#ta3-flip-flop)
- [TA3 Logic Block](./manual_ta3_EN.md#ta3-logic-block) - [TA3 Logic Block](./manual_ta3_EN.md#ta3-logic-block)
- [TA3 Repeater](./manual_ta3_EN.md#ta3-repeater) - [TA3 Repeater](./manual_ta3_EN.md#ta3-repeater)
- [TA3 Sequencer](./manual_ta3_EN.md#ta3-sequencer) - [TA3 Sequencer](./manual_ta3_EN.md#ta3-sequencer)

View File

@ -1,9 +1,6 @@
# Maximim number of Forceload Blocks per player (default 20) # Maximim number of Forceload Blocks per player (default 20)
techage_max_num_forceload_blocks (Max. number of Forceload Blocks) int 20 techage_max_num_forceload_blocks (Max. number of Forceload Blocks) int 20
# Enable Basalt Stone (and disable ore generation via cobble generator)
techage_basalt_stone_enabled (Basalt Stone enabled) bool false
# Rarity factor to find ores when sieving with the Gravel Sieve # Rarity factor to find ores when sieving with the Gravel Sieve
# 1.0 is according to the mapgen generator # 1.0 is according to the mapgen generator
# 2.0 means half as many ores as result # 2.0 means half as many ores as result

Binary file not shown.

After

Width:  |  Height:  |  Size: 126 B

Binary file not shown.

After

Width:  |  Height:  |  Size: 126 B