From 81abbed3eb4a5a745c96efe8179d0cc3accff299 Mon Sep 17 00:00:00 2001 From: webdesigner97 Date: Sun, 13 Oct 2013 12:33:14 +0200 Subject: Changed drawtype to nodebox --- roadsigns/signs.lua | 24 +++++++++++++++++++++--- 1 file changed, 21 insertions(+), 3 deletions(-) (limited to 'roadsigns/signs.lua') diff --git a/roadsigns/signs.lua b/roadsigns/signs.lua index a73b294..0a3ecf4 100644 --- a/roadsigns/signs.lua +++ b/roadsigns/signs.lua @@ -5,7 +5,13 @@ if streets.extendedBy.bucket == true and streets.extendedBy.wool then inventory_image = "streets_sign_lava.png", wield_image = "streets_sign_lava.png", groups = {snappy = 1,attached_node = 1}, - drawtype = "signlike", + drawtype = "nodebox", + node_box = { + type = "wallmounted", + fixed = { + {-0.4,-0.5,-0.4,0.4,-0.4,0.4} + } + }, paramtype = "light", paramtype2 = "wallmounted", walkable = false, @@ -33,7 +39,13 @@ if streets.extendedBy.bucket == true and streets.extendedBy.wool then inventory_image = "streets_sign_water.png", wield_image = "streets_sign_water.png", groups = {snappy = 1,attached_node = 1}, - drawtype = "signlike", + drawtype = "nodebox", + node_box = { + type = "wallmounted", + fixed = { + {-0.4,-0.5,-0.4,0.4,-0.4,0.4} + } + }, paramtype = "light", paramtype2 = "wallmounted", walkable = false, @@ -61,7 +73,13 @@ if streets.extendedBy.bucket == true and streets.extendedBy.wool then inventory_image = "streets_sign_construction.png", wield_image = "streets_sign_construction.png", groups = {snappy = 1,attached_node = 1}, - drawtype = "signlike", + drawtype = "nodebox", + node_box = { + type = "wallmounted", + fixed = { + {-0.4,-0.5,-0.4,0.4,-0.4,0.4} + } + }, paramtype = "light", paramtype2 = "wallmounted", walkable = false, -- cgit v1.2.3 From 52b2ae9334403d49103f38d6007f643b52a131f6 Mon Sep 17 00:00:00 2001 From: webdesigner97 Date: Mon, 14 Oct 2013 12:02:09 +0200 Subject: Signs available in creative mode --- roadsigns/signs.lua | 182 ++++++++++++++++++++++++++-------------------------- 1 file changed, 90 insertions(+), 92 deletions(-) (limited to 'roadsigns/signs.lua') diff --git a/roadsigns/signs.lua b/roadsigns/signs.lua index 0a3ecf4..9010691 100644 --- a/roadsigns/signs.lua +++ b/roadsigns/signs.lua @@ -1,99 +1,97 @@ -if streets.extendedBy.bucket == true and streets.extendedBy.wool then - minetest.register_node(":streets:sign_lava",{ - description = "Warning sign (lava)", - tiles = {"streets_sign_lava.png"}, - inventory_image = "streets_sign_lava.png", - wield_image = "streets_sign_lava.png", - groups = {snappy = 1,attached_node = 1}, - drawtype = "nodebox", - node_box = { - type = "wallmounted", - fixed = { - {-0.4,-0.5,-0.4,0.4,-0.4,0.4} - } - }, - paramtype = "light", - paramtype2 = "wallmounted", - walkable = false, - sunlight_propagates = true, - selection_box = { - type = "wallmounted" +minetest.register_node(":streets:sign_lava",{ + description = "Warning sign (lava)", + tiles = {"streets_sign_lava.png"}, + inventory_image = "streets_sign_lava.png", + wield_image = "streets_sign_lava.png", + groups = {snappy = 1,attached_node = 1}, + drawtype = "nodebox", + node_box = { + type = "wallmounted", + fixed = { + {-0.4,-0.5,-0.4,0.4,-0.4,0.4} } - }) - - minetest.register_craft({ - output = "streets:sign_lava 2", - recipe = { - {"wool:red","wool:red","wool:red"}, - {"wool:red","bucket:bucket_lava","wool:red"}, - {"wool:red","wool:red","wool:red"} - }, - replacements = { - {"bucket:bucket_lava", "bucket:bucket_empty"} + }, + paramtype = "light", + paramtype2 = "wallmounted", + walkable = false, + sunlight_propagates = true, + selection_box = { + type = "wallmounted" } - }) +}) + +minetest.register_craft({ + output = "streets:sign_lava 2", + recipe = { + {"wool:red","wool:red","wool:red"}, + {"wool:red","bucket:bucket_lava","wool:red"}, + {"wool:red","wool:red","wool:red"} + }, + replacements = { + {"bucket:bucket_lava", "bucket:bucket_empty"} + } +}) - minetest.register_node(":streets:sign_water",{ - description = "Warning sign (water)", - tiles = {"streets_sign_water.png"}, - inventory_image = "streets_sign_water.png", - wield_image = "streets_sign_water.png", - groups = {snappy = 1,attached_node = 1}, - drawtype = "nodebox", - node_box = { - type = "wallmounted", - fixed = { - {-0.4,-0.5,-0.4,0.4,-0.4,0.4} - } - }, - paramtype = "light", - paramtype2 = "wallmounted", - walkable = false, - sunlight_propagates = true, - selection_box = { - type = "wallmounted" +minetest.register_node(":streets:sign_water",{ + description = "Warning sign (water)", + tiles = {"streets_sign_water.png"}, + inventory_image = "streets_sign_water.png", + wield_image = "streets_sign_water.png", + groups = {snappy = 1,attached_node = 1}, + drawtype = "nodebox", + node_box = { + type = "wallmounted", + fixed = { + {-0.4,-0.5,-0.4,0.4,-0.4,0.4} } - }) + }, + paramtype = "light", + paramtype2 = "wallmounted", + walkable = false, + sunlight_propagates = true, + selection_box = { + type = "wallmounted" + } +}) - minetest.register_craft({ - output = "streets:sign_water 2", - recipe = { - {"wool:red","wool:red","wool:red"}, - {"wool:red","bucket:bucket_water","wool:red"}, - {"wool:red","wool:red","wool:red"} - }, - replacements = { - {"bucket:bucket_water", "bucket:bucket_empty"} - } - }) +minetest.register_craft({ + output = "streets:sign_water 2", + recipe = { + {"wool:red","wool:red","wool:red"}, + {"wool:red","bucket:bucket_water","wool:red"}, + {"wool:red","wool:red","wool:red"} + }, + replacements = { + {"bucket:bucket_water", "bucket:bucket_empty"} + } +}) - minetest.register_node(":streets:sign_construction",{ - description = "Warning sign (Construction area)", - tiles = {"streets_sign_construction.png"}, - inventory_image = "streets_sign_construction.png", - wield_image = "streets_sign_construction.png", - groups = {snappy = 1,attached_node = 1}, - drawtype = "nodebox", - node_box = { - type = "wallmounted", - fixed = { - {-0.4,-0.5,-0.4,0.4,-0.4,0.4} - } - }, - paramtype = "light", - paramtype2 = "wallmounted", - walkable = false, - sunlight_propagates = true, - selection_box = { - type = "wallmounted" - } - }) - minetest.register_craft({ - output = "streets:sign_construction 2", - recipe = { - {"wool:red","wool:red","wool:red"}, - {"wool:red","default:shovel_steel","wool:red"}, - {"wool:red","wool:red","wool:red"} +minetest.register_node(":streets:sign_construction",{ + description = "Warning sign (Construction area)", + tiles = {"streets_sign_construction.png"}, + inventory_image = "streets_sign_construction.png", + wield_image = "streets_sign_construction.png", + groups = {snappy = 1,attached_node = 1}, + drawtype = "nodebox", + node_box = { + type = "wallmounted", + fixed = { + {-0.4,-0.5,-0.4,0.4,-0.4,0.4} } - }) -end \ No newline at end of file + }, + paramtype = "light", + paramtype2 = "wallmounted", + walkable = false, + sunlight_propagates = true, + selection_box = { + type = "wallmounted" + } +}) +minetest.register_craft({ + output = "streets:sign_construction 2", + recipe = { + {"wool:red","wool:red","wool:red"}, + {"wool:red","default:shovel_steel","wool:red"}, + {"wool:red","wool:red","wool:red"} + } +}) \ No newline at end of file -- cgit v1.2.3 From 761e23f88221f74c89299105d0a9920205ebba33 Mon Sep 17 00:00:00 2001 From: webdesigner97 Date: Mon, 14 Oct 2013 19:30:49 +0200 Subject: Removed craft recipes --- roadsigns/signs.lua | 32 -------------------------------- 1 file changed, 32 deletions(-) (limited to 'roadsigns/signs.lua') diff --git a/roadsigns/signs.lua b/roadsigns/signs.lua index 9010691..70959cd 100644 --- a/roadsigns/signs.lua +++ b/roadsigns/signs.lua @@ -19,18 +19,6 @@ minetest.register_node(":streets:sign_lava",{ type = "wallmounted" } }) - -minetest.register_craft({ - output = "streets:sign_lava 2", - recipe = { - {"wool:red","wool:red","wool:red"}, - {"wool:red","bucket:bucket_lava","wool:red"}, - {"wool:red","wool:red","wool:red"} - }, - replacements = { - {"bucket:bucket_lava", "bucket:bucket_empty"} - } -}) minetest.register_node(":streets:sign_water",{ description = "Warning sign (water)", @@ -54,18 +42,6 @@ minetest.register_node(":streets:sign_water",{ } }) -minetest.register_craft({ - output = "streets:sign_water 2", - recipe = { - {"wool:red","wool:red","wool:red"}, - {"wool:red","bucket:bucket_water","wool:red"}, - {"wool:red","wool:red","wool:red"} - }, - replacements = { - {"bucket:bucket_water", "bucket:bucket_empty"} - } -}) - minetest.register_node(":streets:sign_construction",{ description = "Warning sign (Construction area)", tiles = {"streets_sign_construction.png"}, @@ -86,12 +62,4 @@ minetest.register_node(":streets:sign_construction",{ selection_box = { type = "wallmounted" } -}) -minetest.register_craft({ - output = "streets:sign_construction 2", - recipe = { - {"wool:red","wool:red","wool:red"}, - {"wool:red","default:shovel_steel","wool:red"}, - {"wool:red","wool:red","wool:red"} - } }) \ No newline at end of file -- cgit v1.2.3 From 3646ecaa4b0062bc7a24fb9960e85dd719e69aaf Mon Sep 17 00:00:00 2001 From: webdesigner97 Date: Tue, 15 Oct 2013 10:32:37 +0200 Subject: Display recipe and validate input --- roadsigns/signs.lua | 33 +++++++++++++++++++++++++++++++++ roadsigns/workshop.lua | 45 +++++++++++++++++++++++++++++++++++++++++++-- 2 files changed, 76 insertions(+), 2 deletions(-) (limited to 'roadsigns/signs.lua') diff --git a/roadsigns/signs.lua b/roadsigns/signs.lua index 70959cd..0b01ff5 100644 --- a/roadsigns/signs.lua +++ b/roadsigns/signs.lua @@ -1,3 +1,30 @@ +minetest.register_node(":streets:sign_blank",{ + description = "Emtpy sign", + tiles = {"streets_sign_back.png"}, + inventory_image = "streets_sign_back.png", + wield_image = "streets_sign_back.png", + groups = {snappy = 1,attached_node = 1}, + drawtype = "nodebox", + node_box = { + type = "wallmounted", + fixed = { + {-0.4,-0.5,-0.4,0.4,-0.4,0.4} + } + }, + paramtype = "light", + paramtype2 = "wallmounted", + walkable = false, + sunlight_propagates = true, + selection_box = { + type = "wallmounted" + }, + streets = { + signworkshop = { + recipe = {"default:steel_ingot","","",""}, + time = 5 + } + } +}) minetest.register_node(":streets:sign_lava",{ description = "Warning sign (lava)", tiles = {"streets_sign_lava.png"}, @@ -17,7 +44,13 @@ minetest.register_node(":streets:sign_lava",{ sunlight_propagates = true, selection_box = { type = "wallmounted" + }, + streets = { + signworkshop = { + recipe = {"streets:sign_blank","bucket:bucket_lava","",""}, + time = 7 } + } }) minetest.register_node(":streets:sign_water",{ diff --git a/roadsigns/workshop.lua b/roadsigns/workshop.lua index 939c570..283d2b4 100644 --- a/roadsigns/workshop.lua +++ b/roadsigns/workshop.lua @@ -28,6 +28,11 @@ minetest.register_node(":streets:signworkshop",{ inv:set_size("streets:signworkshop_input",4*1) inv:set_size("streets:signworkshop_select",1*1) inv:set_size("streets:signworkshop_output",1*1) + -- Fill + inv:add_item("streets:signworkshop_list","streets:sign_blank") + inv:add_item("streets:signworkshop_list","streets:sign_lava") + inv:add_item("streets:signworkshop_list","streets:sign_water") + inv:add_item("streets:signworkshop_list","streets:sign_construction") end, allow_metadata_inventory_put = function(pos, listname, index, stack, player) if listname ~= "streets:signworkshop_input" then @@ -37,8 +42,22 @@ minetest.register_node(":streets:signworkshop",{ end end, allow_metadata_inventory_move = function(pos, from_list, from_index, to_list, to_index, count, player) + -- Move items inside input slots if to_list == "streets:signworkshop_input" and from_list == "streets:signworkshop_input" then return 1 + -- List -> selection + elseif from_list == "streets:signworkshop_list" and to_list == "streets:signworkshop_select" then + local inv = minetest.get_meta(pos):get_inventory() + local selected = inv:get_stack("streets:signworkshop_list",from_index):to_table() + local need = minetest.registered_nodes[selected.name].streets.signworkshop.recipe + inv:set_list("streets:signworkshop_recipe",{need[1],need[2],need[3],need[4]}) + return 1 + -- selection -> list + elseif from_list == "streets:signworkshop_select" and to_list == "streets:signworkshop_list" then + local inv = minetest.get_meta(pos):get_inventory() + inv:set_list("streets:signworkshop_recipe",{"","","",""}) + return 1 + -- Every other case else return 0 end @@ -53,8 +72,30 @@ minetest.register_node(":streets:signworkshop",{ on_receive_fields = function(pos, formname, fields, sender) local inv = minetest.get_inventory({type = "node", pos = pos}) -- - if inv:is_emtpy("streets:signworkshop_input") ~= true then - + if inv:is_empty("streets:signworkshop_input") ~= true and inv:is_empty("streets:signworkshop_select") ~= true then + local selection = inv:get_stack("streets:signworkshop_select",1):get_name() + local def = minetest.registered_nodes[selection].streets.signworkshop + local need = inv:get_list("streets:signworkshop_recipe") + local has = inv:get_list("streets:signworkshop_input") + need[1] = need[1]:to_table() + need[2] = need[2]:to_table() + need[3] = need[3]:to_table() + need[4] = need[4]:to_table() + has[1] = has[1]:to_table() + has[2] = has[2]:to_table() + has[3] = has[3]:to_table() + has[4] = has[4]:to_table() + if need[1] == nil then need[1] = { name = "" } end + if need[2] == nil then need[2] = { name = "" } end + if need[3] == nil then need[3] = { name = "" } end + if need[4] == nil then need[4] = { name = "" } end + if has[1] == nil then has[1] = { name = "" } end + if has[2] == nil then has[2] = { name = "" } end + if has[3] == nil then has[3] = { name = "" } end + if has[4] == nil then has[4] = { name = "" } end + if need[1].name == has[1].name and need[2].name == has[2].name and need[3].name == has[3].name and need[4].name == has[4].name then + minetest.chat_send_all("yay") + end end end }) \ No newline at end of file -- cgit v1.2.3 From fe7607750f24d1ee8daa38d648fc39e056ef6779 Mon Sep 17 00:00:00 2001 From: webdesigner97 Date: Wed, 16 Oct 2013 09:59:39 +0200 Subject: Finished code --- roadsigns/signs.lua | 16 ++++++++++++++-- roadsigns/workshop.lua | 9 +++++---- 2 files changed, 19 insertions(+), 6 deletions(-) (limited to 'roadsigns/signs.lua') diff --git a/roadsigns/signs.lua b/roadsigns/signs.lua index 0b01ff5..0992adf 100644 --- a/roadsigns/signs.lua +++ b/roadsigns/signs.lua @@ -21,7 +21,7 @@ minetest.register_node(":streets:sign_blank",{ streets = { signworkshop = { recipe = {"default:steel_ingot","","",""}, - time = 5 + time = 3 } } }) @@ -48,7 +48,7 @@ minetest.register_node(":streets:sign_lava",{ streets = { signworkshop = { recipe = {"streets:sign_blank","bucket:bucket_lava","",""}, - time = 7 + time = 5 } } }) @@ -72,6 +72,12 @@ minetest.register_node(":streets:sign_water",{ sunlight_propagates = true, selection_box = { type = "wallmounted" + }, + streets = { + signworkshop = { + recipe = {"streets:sign_blank","bucket:bucket_water","",""}, + time = 5 + } } }) @@ -94,5 +100,11 @@ minetest.register_node(":streets:sign_construction",{ sunlight_propagates = true, selection_box = { type = "wallmounted" + }, + streets = { + signworkshop = { + recipe = {"streets:sign_blank","default:dirt","",""}, + time = 5 + } } }) \ No newline at end of file diff --git a/roadsigns/workshop.lua b/roadsigns/workshop.lua index 5ee1af5..e5dc0d6 100644 --- a/roadsigns/workshop.lua +++ b/roadsigns/workshop.lua @@ -31,14 +31,15 @@ local forms = { "list[context;streets:signworkshop_select;6,1;1,1]", "label[5.8,2.5;Output:]", "list[context;streets:signworkshop_output;6,3;1,1]", - "list[current_player;main;2,6;8,4]", - "label[8,4;Please wait...]", + "list[current_player;main;2,6;8,4]" + -- } } minetest.register_node(":streets:signworkshop",{ description = "Sign workshop", - tiles = {}, + tiles = {"streets_signworkshop_top.png","streets_signworkshop_bottom.png","streets_signworkshop_side.png","streets_signworkshop_side.png","streets_signworkshop_side.png","streets_signworkshop_front.png"}, groups = {cracky = 1, level = 2}, + paramtype2 = "facedir", after_place_node = function(pos) minetest.get_meta(pos):set_string("formspec",table.concat(forms.inactive)) local meta = minetest.get_meta(pos) @@ -120,7 +121,7 @@ minetest.register_node(":streets:signworkshop",{ if need[1].name == has[1].name and need[2].name == has[2].name and need[3].name == has[3].name and need[4].name == has[4].name then meta:set_string("infotext","Sign workshop working") meta:set_string("idle","n") - meta:set_string("formspec",table.concat(forms.active)) + meta:set_string("formspec",table.concat(forms.active) .. "label[8,4;Please wait " .. def.time .. " seconds...]") -- Clear input inv:set_list("streets:signworkshop_input",{"","","",""}) minetest.after(def.time,function() -- cgit v1.2.3