Improve command interface
This commit is contained in:
parent
bf5c5bb919
commit
a62f883d36
@ -457,6 +457,7 @@ function techage.beduino_send_cmnd(src, number, topic, payload)
|
|||||||
if ninfo and ninfo.name and ninfo.pos then
|
if ninfo and ninfo.name and ninfo.pos then
|
||||||
local ndef = NodeDef[ninfo.name]
|
local ndef = NodeDef[ninfo.name]
|
||||||
if ndef and ndef.on_beduino_receive_cmnd then
|
if ndef and ndef.on_beduino_receive_cmnd then
|
||||||
|
techage_counting_hit()
|
||||||
return ndef.on_beduino_receive_cmnd(ninfo.pos, src, topic, payload or {})
|
return ndef.on_beduino_receive_cmnd(ninfo.pos, src, topic, payload or {})
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
@ -469,6 +470,7 @@ function techage.beduino_request_data(src, number, topic, payload)
|
|||||||
if ninfo and ninfo.name and ninfo.pos then
|
if ninfo and ninfo.name and ninfo.pos then
|
||||||
local ndef = NodeDef[ninfo.name]
|
local ndef = NodeDef[ninfo.name]
|
||||||
if ndef and ndef.on_beduino_request_data then
|
if ndef and ndef.on_beduino_request_data then
|
||||||
|
techage_counting_hit()
|
||||||
return ndef.on_beduino_request_data(ninfo.pos, src, topic, payload or {})
|
return ndef.on_beduino_request_data(ninfo.pos, src, topic, payload or {})
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
@ -87,7 +87,7 @@ local WRENCH_MENU4 = {
|
|||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
local function switch_on(pos)
|
local function switch_on(pos, no_sound)
|
||||||
local cycle_time = M(pos):get_int("cycle_time")
|
local cycle_time = M(pos):get_int("cycle_time")
|
||||||
local name = techage.get_node_lvm(pos).name
|
local name = techage.get_node_lvm(pos).name
|
||||||
if name == "techage:ta3_button_off" then
|
if name == "techage:ta3_button_off" then
|
||||||
@ -96,14 +96,16 @@ local function switch_on(pos)
|
|||||||
logic.swap_node(pos, "techage:ta4_button_on")
|
logic.swap_node(pos, "techage:ta4_button_on")
|
||||||
end
|
end
|
||||||
logic.send_cmnd(pos, "command", "on", cycle_time)
|
logic.send_cmnd(pos, "command", "on", cycle_time)
|
||||||
minetest.sound_play("techage_button", {
|
if not no_sound then
|
||||||
pos = pos,
|
minetest.sound_play("techage_button", {
|
||||||
gain = 0.5,
|
pos = pos,
|
||||||
max_hear_distance = 5,
|
gain = 0.5,
|
||||||
})
|
max_hear_distance = 5,
|
||||||
|
})
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
local function switch_off(pos, is_button)
|
local function switch_off(pos, no_sound)
|
||||||
local name = techage.get_node_lvm(pos).name
|
local name = techage.get_node_lvm(pos).name
|
||||||
if name == "techage:ta3_button_on" then
|
if name == "techage:ta3_button_on" then
|
||||||
logic.swap_node(pos, "techage:ta3_button_off")
|
logic.swap_node(pos, "techage:ta3_button_off")
|
||||||
@ -115,7 +117,7 @@ local function switch_off(pos, is_button)
|
|||||||
(not meta:contains("command") or meta:get_string("command") == "on") then
|
(not meta:contains("command") or meta:get_string("command") == "on") then
|
||||||
logic.send_off(pos, M(pos))
|
logic.send_off(pos, M(pos))
|
||||||
end
|
end
|
||||||
if not is_button then
|
if not no_sound then
|
||||||
minetest.sound_play("techage_button", {
|
minetest.sound_play("techage_button", {
|
||||||
pos = pos,
|
pos = pos,
|
||||||
gain = 0.5,
|
gain = 0.5,
|
||||||
@ -425,13 +427,54 @@ minetest.register_craft({
|
|||||||
},
|
},
|
||||||
})
|
})
|
||||||
|
|
||||||
techage.register_node({"techage:ta3_button_off", "techage:ta3_button_on"}, {})
|
techage.register_node({"techage:ta3_button_off", "techage:ta3_button_on"}, {
|
||||||
|
on_recv_message = function(pos, src, topic, payload)
|
||||||
|
if topic == "on" then
|
||||||
|
switch_on(pos, true)
|
||||||
|
return true
|
||||||
|
elseif topic == "off" then
|
||||||
|
switch_off(pos, true)
|
||||||
|
return true
|
||||||
|
elseif topic == "state" then
|
||||||
|
local name = techage.get_node_lvm(pos).name
|
||||||
|
return name == "techage:ta3_button_on" and "on" or "off"
|
||||||
|
else
|
||||||
|
return "unsupported"
|
||||||
|
end
|
||||||
|
end,
|
||||||
|
on_beduino_receive_cmnd = function(pos, src, topic, payload)
|
||||||
|
if topic == 1 and payload[1] == 1 then
|
||||||
|
switch_on(pos, true)
|
||||||
|
return 0
|
||||||
|
elseif topic == 1 and payload[1] == 0 then
|
||||||
|
switch_off(pos, true)
|
||||||
|
return 0
|
||||||
|
else
|
||||||
|
return 2
|
||||||
|
end
|
||||||
|
end,
|
||||||
|
on_beduino_request_data = function(pos, src, topic, payload)
|
||||||
|
if topic == 131 then -- State
|
||||||
|
local name = techage.get_node_lvm(pos).name
|
||||||
|
return 0, name == "techage:ta3_button_on" and {1} or {0}
|
||||||
|
else
|
||||||
|
return 2, ""
|
||||||
|
end
|
||||||
|
end,
|
||||||
|
}
|
||||||
|
)
|
||||||
|
|
||||||
techage.register_node({
|
techage.register_node({
|
||||||
"techage:ta4_button_off", "techage:ta4_button_on",
|
"techage:ta4_button_off", "techage:ta4_button_on",
|
||||||
}, {
|
}, {
|
||||||
on_recv_message = function(pos, src, topic, payload)
|
on_recv_message = function(pos, src, topic, payload)
|
||||||
if topic == "state" then
|
if topic == "on" then
|
||||||
|
switch_on(pos, true)
|
||||||
|
return true
|
||||||
|
elseif topic == "off" then
|
||||||
|
switch_off(pos, true)
|
||||||
|
return true
|
||||||
|
elseif topic == "state" then
|
||||||
local name = techage.get_node_lvm(pos).name
|
local name = techage.get_node_lvm(pos).name
|
||||||
return name == "techage:ta4_button_on" and "on" or "off"
|
return name == "techage:ta4_button_on" and "on" or "off"
|
||||||
elseif topic == "name" then
|
elseif topic == "name" then
|
||||||
@ -444,6 +487,17 @@ techage.register_node({
|
|||||||
return "unsupported"
|
return "unsupported"
|
||||||
end
|
end
|
||||||
end,
|
end,
|
||||||
|
on_beduino_receive_cmnd = function(pos, src, topic, payload)
|
||||||
|
if topic == 1 and payload[1] == 1 then
|
||||||
|
switch_on(pos, true)
|
||||||
|
return 0
|
||||||
|
elseif topic == 1 and payload[1] == 0 then
|
||||||
|
switch_off(pos, true)
|
||||||
|
return 0
|
||||||
|
else
|
||||||
|
return 2
|
||||||
|
end
|
||||||
|
end,
|
||||||
on_beduino_request_data = function(pos, src, topic, payload)
|
on_beduino_request_data = function(pos, src, topic, payload)
|
||||||
if topic == 131 then -- State
|
if topic == 131 then -- State
|
||||||
local name = techage.get_node_lvm(pos).name
|
local name = techage.get_node_lvm(pos).name
|
||||||
|
@ -244,7 +244,49 @@ minetest.register_node("techage:ta4_button_2x", {
|
|||||||
sounds = default.node_sound_glass_defaults(),
|
sounds = default.node_sound_glass_defaults(),
|
||||||
})
|
})
|
||||||
|
|
||||||
techage.register_node({"techage:ta4_button_2x"}, {})
|
techage.register_node({"techage:ta4_button_2x"}, {
|
||||||
|
on_recv_message = function(pos, src, topic, payload)
|
||||||
|
local num = math.max(tonumber(payload) or 0, 1)
|
||||||
|
if topic == "on" then
|
||||||
|
switch_on(pos, num)
|
||||||
|
send_cmnd(pos, num)
|
||||||
|
return true
|
||||||
|
elseif topic == "off" then
|
||||||
|
switch_off(pos, num)
|
||||||
|
return true
|
||||||
|
elseif topic == "state" then
|
||||||
|
local nvm = techage.get_nvm(pos)
|
||||||
|
nvm.button = nvm.button or {}
|
||||||
|
return nvm.button[num] == true
|
||||||
|
else
|
||||||
|
return "unsupported"
|
||||||
|
end
|
||||||
|
end,
|
||||||
|
on_beduino_receive_cmnd = function(pos, src, topic, payload)
|
||||||
|
local num = math.max(payload[1], 1)
|
||||||
|
if topic == 23 and payload[2] == 1 then
|
||||||
|
switch_on(pos, num)
|
||||||
|
send_cmnd(pos, num)
|
||||||
|
return 0
|
||||||
|
elseif topic == 23 and payload[2] == 0 then
|
||||||
|
switch_off(pos, num)
|
||||||
|
return 0
|
||||||
|
else
|
||||||
|
return 2
|
||||||
|
end
|
||||||
|
end,
|
||||||
|
on_beduino_request_data = function(pos, src, topic, payload)
|
||||||
|
if topic == 152 then -- State
|
||||||
|
local num = math.max(payload[1], 1)
|
||||||
|
local nvm = techage.get_nvm(pos)
|
||||||
|
nvm.button = nvm.button or {}
|
||||||
|
return 0, nvm.button[num] and {1} or {0}
|
||||||
|
else
|
||||||
|
return 2, ""
|
||||||
|
end
|
||||||
|
end,
|
||||||
|
}
|
||||||
|
)
|
||||||
|
|
||||||
minetest.register_craft({
|
minetest.register_craft({
|
||||||
output = "techage:ta4_button_2x",
|
output = "techage:ta4_button_2x",
|
||||||
|
Loading…
Reference in New Issue
Block a user