mirror of
https://github.com/pyrollo/digiterms.git
synced 2025-01-24 16:00:20 +01:00
Added keyboard
This commit is contained in:
parent
d80b6c2696
commit
4a5539748a
@ -18,6 +18,17 @@
|
|||||||
along with signs. If not, see <http://www.gnu.org/licenses/>.
|
along with signs. If not, see <http://www.gnu.org/licenses/>.
|
||||||
--]]
|
--]]
|
||||||
|
|
||||||
|
local player_contexts = {}
|
||||||
|
|
||||||
|
minetest.register_on_leaveplayer(function(player)
|
||||||
|
player_contexts[player:get_player_name()] = nil
|
||||||
|
end)
|
||||||
|
|
||||||
|
function digiterms.get_player_context(name)
|
||||||
|
player_contexts[name] = player_contexts[name] or {}
|
||||||
|
return player_contexts[name]
|
||||||
|
end
|
||||||
|
|
||||||
local function get_lines(pos)
|
local function get_lines(pos)
|
||||||
local lines = {}
|
local lines = {}
|
||||||
local meta = minetest.get_meta(pos)
|
local meta = minetest.get_meta(pos)
|
||||||
@ -84,9 +95,6 @@ function digiterms.push_text_on_screen(pos, text)
|
|||||||
minetest.log("warning", "[digiterms] At "..minetest.pos_to_string(pos)
|
minetest.log("warning", "[digiterms] At "..minetest.pos_to_string(pos)
|
||||||
..", digiterms:screen entity should have 'lines' and 'columns' attribures.")
|
..", digiterms:screen entity should have 'lines' and 'columns' attribures.")
|
||||||
end
|
end
|
||||||
else
|
|
||||||
minetest.log("warning", "[digiterms] Node at "..minetest.pos_to_string(pos)
|
|
||||||
.." does not have digiterms:screen entity.")
|
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
@ -152,6 +160,9 @@ function digiterms.register_monitor(
|
|||||||
minetest.register_node(nodename, superpose_table(ndef, nodedefon))
|
minetest.register_node(nodename, superpose_table(ndef, nodedefon))
|
||||||
|
|
||||||
-- Register the corresponding Off node
|
-- Register the corresponding Off node
|
||||||
|
if ndef.display_entities then
|
||||||
|
ndef.display_entities["digiterms:screen"] = nil
|
||||||
|
end
|
||||||
ndef.drop = nodename
|
ndef.drop = nodename
|
||||||
ndef.groups.not_in_creative_inventory = 1
|
ndef.groups.not_in_creative_inventory = 1
|
||||||
ndef.on_destruct = nil
|
ndef.on_destruct = nil
|
||||||
|
79
nodes.lua
79
nodes.lua
@ -61,7 +61,7 @@ digiterms.register_monitor('digiterms:lcd_monitor', {
|
|||||||
paramtype2 = "facedir",
|
paramtype2 = "facedir",
|
||||||
sunlight_propagates = false,
|
sunlight_propagates = false,
|
||||||
drawtype = "nodebox",
|
drawtype = "nodebox",
|
||||||
groups = {choppy = 1, oddly_breakable_by_hand = 1},
|
groups = {choppy = 1, oddly_breakable_by_hand = 3},
|
||||||
node_box = lcd_node_box,
|
node_box = lcd_node_box,
|
||||||
collision_box = lcd_collision_box,
|
collision_box = lcd_collision_box,
|
||||||
selection_box = lcd_collision_box,
|
selection_box = lcd_collision_box,
|
||||||
@ -91,7 +91,7 @@ digiterms.register_monitor('digiterms:cathodic_amber_monitor', {
|
|||||||
paramtype2 = "facedir",
|
paramtype2 = "facedir",
|
||||||
sunlight_propagates = false,
|
sunlight_propagates = false,
|
||||||
drawtype = "nodebox",
|
drawtype = "nodebox",
|
||||||
groups = {choppy = 1, oddly_breakable_by_hand = 1},
|
groups = {oddly_breakable_by_hand = 3},
|
||||||
node_box = cathodic_node_box,
|
node_box = cathodic_node_box,
|
||||||
collision_box = cathodic_collision_box,
|
collision_box = cathodic_collision_box,
|
||||||
selection_box = cathodic_collision_box,
|
selection_box = cathodic_collision_box,
|
||||||
@ -121,7 +121,7 @@ digiterms.register_monitor('digiterms:cathodic_green_monitor', {
|
|||||||
paramtype2 = "facedir",
|
paramtype2 = "facedir",
|
||||||
sunlight_propagates = false,
|
sunlight_propagates = false,
|
||||||
drawtype = "nodebox",
|
drawtype = "nodebox",
|
||||||
groups = {choppy = 1, oddly_breakable_by_hand = 1},
|
groups = {oddly_breakable_by_hand = 1, dig_immediate = 1},
|
||||||
node_box = cathodic_node_box,
|
node_box = cathodic_node_box,
|
||||||
collision_box = cathodic_collision_box,
|
collision_box = cathodic_collision_box,
|
||||||
selection_box = cathodic_collision_box,
|
selection_box = cathodic_collision_box,
|
||||||
@ -159,7 +159,76 @@ minetest.register_node('digiterms:beige_keyboard', {
|
|||||||
type = "fixed",
|
type = "fixed",
|
||||||
fixed = {
|
fixed = {
|
||||||
{-8/16, -8/16, -1/16, 8/16, -6/16, 7/16},
|
{-8/16, -8/16, -1/16, 8/16, -6/16, 7/16},
|
||||||
{-7/16, -12/32, 1/32, 7/16, -11/32, 11/32},
|
{-7/16, -12/32, 0, 7/16, -11/32, 6/16},
|
||||||
}
|
}
|
||||||
}
|
},
|
||||||
|
digiline =
|
||||||
|
{
|
||||||
|
receptor = {}
|
||||||
|
},
|
||||||
|
on_rightclick = function(pos, node, player, itemstack, pointed_thing)
|
||||||
|
if not minetest.is_player(player) then
|
||||||
|
return
|
||||||
|
end
|
||||||
|
local name = player:get_player_name()
|
||||||
|
local context = digiterms.get_player_context(name)
|
||||||
|
context.formname = 'digiterms:keyboard'
|
||||||
|
context.pos = pos
|
||||||
|
|
||||||
|
local owned = not minetest.is_protected(context.pos, name)
|
||||||
|
local protected = minetest.is_protected(context.pos, '')
|
||||||
|
local meta = minetest.get_meta(pos)
|
||||||
|
local channel = meta:get_string('channel')
|
||||||
|
local public = meta:get_string('public')
|
||||||
|
|
||||||
|
if owned then
|
||||||
|
local fs = "size[8,5]"..
|
||||||
|
default.gui_bg..default.gui_bg_img..default.gui_slots..
|
||||||
|
"field[1,1;3,1;channel;Chanel;"..channel.."]"..
|
||||||
|
"field[1,3;6.5,1;text;Type text:;]"..
|
||||||
|
"field_close_on_enter[text;true]button_exit[2.5,4;3,1;send;Send]"
|
||||||
|
if protected then
|
||||||
|
fs = fs.."checkbox[4,0.6;public;Public keyboard;"..public.."]"
|
||||||
|
end
|
||||||
|
minetest.show_formspec(name, context.formname, fs)
|
||||||
|
else
|
||||||
|
if public == 'true' and channel ~= '' then
|
||||||
|
minetest.show_formspec(name, context.formname, "size[8,3]"..
|
||||||
|
default.gui_bg..default.gui_bg_img..default.gui_slots..
|
||||||
|
"field[1,1;6.5,1;text;Type text:;]"..
|
||||||
|
"field_close_on_enter[text;true]button_exit[2.5,2;3,1;send;Send]")
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end,
|
||||||
})
|
})
|
||||||
|
|
||||||
|
minetest.register_on_player_receive_fields(function(player, formname, fields)
|
||||||
|
if formname ~= 'digiterms:keyboard' or not minetest.is_player(player) then
|
||||||
|
return
|
||||||
|
end
|
||||||
|
local name = player:get_player_name()
|
||||||
|
local context = digiterms.get_player_context(name)
|
||||||
|
if context.formname ~= formname then
|
||||||
|
return
|
||||||
|
end
|
||||||
|
|
||||||
|
local owned = not minetest.is_protected(context.pos, name)
|
||||||
|
local protected = minetest.is_protected(context.pos, '')
|
||||||
|
local meta = minetest.get_meta(context.pos)
|
||||||
|
if owned then
|
||||||
|
if fields.channel ~= nil and fields.channel ~= '' then
|
||||||
|
meta:set_string("channel", fields.channel)
|
||||||
|
end
|
||||||
|
if fields.public ~= nil and protected then
|
||||||
|
meta:set_string("public", fields.public)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
local channel = meta:get_string("channel")
|
||||||
|
|
||||||
|
if fields.text and channel ~= '' and
|
||||||
|
(owned or meta:get_string("public") == 'true') then
|
||||||
|
digiline:receptor_send(context.pos, digiline.rules.default, channel, fields.text)
|
||||||
|
end
|
||||||
|
return true
|
||||||
|
end)
|
||||||
|
3690
svg/keyboards.svg
3690
svg/keyboards.svg
File diff suppressed because one or more lines are too long
Before Width: | Height: | Size: 2.6 MiB After Width: | Height: | Size: 2.8 MiB |
Binary file not shown.
Before Width: | Height: | Size: 281 B After Width: | Height: | Size: 283 B |
Binary file not shown.
Before Width: | Height: | Size: 1.2 KiB After Width: | Height: | Size: 652 B |
Loading…
Reference in New Issue
Block a user