1
0
mirror of https://github.com/D00Med/scifi_nodes.git synced 2025-07-15 06:20:24 +02:00

19 Commits

Author SHA1 Message Date
2fd4de11c0 Merge remote-tracking branch 'upstream/master' 2021-08-16 18:18:21 +02:00
85aa74e98b fix metal plant pot 2021-08-15 11:01:17 +02:00
5b9431ea18 add pot-lid protection-check and fix lid-toggle code 2021-08-14 19:17:20 +02:00
b88b7349a5 Merge remote-tracking branch 'upstream/master' 2021-06-20 17:30:14 +02:00
53d9659051 Exit minetest.after callback if node no longer exists 2021-06-06 10:32:50 +02:00
c30ae4b3bd Merge remote-tracking branch 'upstream/master' 2021-05-09 21:44:34 +02:00
79ba8cabc3 Fix drop of scifi_nodes:digicode_on 2021-05-02 19:11:55 +02:00
6cf45fcd43 Merge remote-tracking branch 'upstream/master' 2021-03-25 21:58:42 +01:00
1ded358e04 Merge branch 'github' 2021-03-20 13:38:15 +01:00
ecfaa4714a Fix things to avoid warnings about use_texture_alpha
And optimize textures with optipng
2021-03-20 13:33:39 +01:00
c341cb8a20 Merge remote-tracking branch 'upstream/master' 2021-01-29 17:43:56 +01:00
d66e04f9b1 Merge remote-tracking branch 'upstream/master' 2020-12-24 21:10:26 +01:00
d3d6a7bf79 Merge remote-tracking branch 'upstream/master' 2020-12-18 12:21:17 +01:00
e34fdde795 Merge remote-tracking branch 'upstream/master' 2020-12-15 23:41:17 +01:00
1993068ed1 Merge remote-tracking branch 'upstream/master' 2020-11-12 22:04:59 +01:00
436f51ab0d Merge remote-tracking branch 'upstream/master' 2020-11-10 19:59:40 +01:00
749d59a530 Merge remote-tracking branch 'upstream/master' 2020-09-13 12:28:42 +02:00
bd58dbc48b Merge remote-tracking branch 'upstream/master' 2020-07-23 11:42:19 +02:00
4eaba4f6e1 Adds loading message in the Action Log 2020-07-21 11:52:47 +02:00
7 changed files with 85 additions and 59 deletions

View File

@ -1099,6 +1099,22 @@ minetest.register_craft({
}
})
-- wet metal plant pot from dry metal plant pot
minetest.register_craft({
output = "scifi_nodes:pot2",
recipe = {
{"scifi_nodes:pot", "bucket:bucket_water"}
},
replacements = {{"bucket:bucket_water", "bucket:bucket_empty"}}
})
-- dry metal plant pot from wet metal plant pot
minetest.register_craft({
type = "cooking",
output = "scifi_nodes:pot",
recipe = "scifi_nodes:pot2",
})
-- 6 itemholder from 2 dented metal block and 1 plastic
minetest.register_craft({
output = "scifi_nodes:itemholder 6",

View File

@ -122,7 +122,7 @@ minetest.register_node("scifi_nodes:digicode_on", {
paramtype2 = "wallmounted",
light_source = 5,
groups = {cracky=1, oddly_breakable_by_hand=1, not_in_creative_inventory=1, mesecon_needs_receiver = 1},
drop = {items = {"scifi_nodes:digicode_off"}},
drop = "scifi_nodes:digicode_off",
mesecons = {
receptor = {
state = (has_mesecons and mesecon.state.on)

View File

@ -22,3 +22,4 @@ dofile(MP.."/digicode.lua")
dofile(MP.."/models.lua")
dofile(MP.."/octagon_panes.lua")
dofile(MP.."/crafts.lua")
minetest.log("action", "[scifi_nodes] loaded.")

View File

@ -324,13 +324,8 @@ minetest.register_node("scifi_nodes:gloshroom", {
})
minetest.register_node("scifi_nodes:pot_lid", {
description = "plant pot lid(place above plant)",
description = "Plant Pot Lid",
tiles = {
"scifi_nodes_glass2.png",
"scifi_nodes_glass2.png",
"scifi_nodes_glass2.png",
"scifi_nodes_glass2.png",
"scifi_nodes_glass2.png",
"scifi_nodes_glass2.png"
},
inventory_image = "scifi_nodes_pod_inv.png",
@ -338,36 +333,55 @@ minetest.register_node("scifi_nodes:pot_lid", {
use_texture_alpha = "blend",
drawtype = "nodebox",
paramtype = "light",
groups = {cracky=1, not_in_creative_inventory=1},
groups = {not_in_creative_inventory = 1},
sunlight_propagates = true,
diggable = false,
drop = "",
selection_box = {
type = "fixed",
fixed = {0, 0, 0, 0, 0, 0}
},
collision_box = {
type = "fixed",
fixed = {-0.5, -1.5, -0.5, 0.5, -0.5, 0.5}
fixed = {-0.5, -1.5, -0.5, 0.5, -0.25, 0.5}
},
node_box = {
type = "fixed",
fixed = {
{-0.1875, -0.5625, -0.1875, 0.1875, -0.5, 0.1875}, -- NodeBox13
{-0.25, -0.625, -0.25, 0.25, -0.5625, 0.25}, -- NodeBox14
{-0.3125, -0.6875, -0.3125, 0.3125, -0.625, 0.3125}, -- NodeBox15
{-0.375, -0.75, -0.375, 0.375, -0.6875, 0.375}, -- NodeBox16
{-0.4375, -0.75, 0.375, 0.4375, -1.5, 0.4375}, -- NodeBox17
{-0.4375, -0.75, -0.4375, 0.4375, -1.5, -0.375}, -- NodeBox18
{0.375, -0.75, -0.4375, 0.4375, -1.5, 0.4375}, -- NodeBox19
{-0.4375, -0.75, -0.4375, -0.375, -1.5, 0.4375}, -- NodeBox20
{-0.4375, -1.5, -0.4375, 0.4375, -0.5, -0.375},
{-0.4375, -1.5, 0.375, 0.4375, -0.5, 0.4375},
{-0.4375, -1.5, -0.375, -0.375, -0.5, 0.375},
{0.375, -1.5, -0.375, 0.4375, -0.5, 0.375},
{-0.375, -0.5, -0.375, 0.375, -0.4375, 0.375},
{-0.3125, -0.4375, -0.3125, 0.3125, -0.375, 0.3125},
{-0.25, -0.375, -0.25, 0.25, -0.3125, 0.25},
{-0.1875, -0.3125, -0.1875, 0.1875, -0.25, 0.1875}
}
},
sounds = default.node_sound_glass_defaults()
})
local function toggle_lid(pos, node, player, itemstack)
if not player or minetest.is_protected(pos, player:get_player_name()) then
return
end
local lid_pos = {x = pos.x, y = pos.y+2 , z = pos.z}
local lid_node = minetest.get_node(lid_pos)
if lid_node.name == "scifi_nodes:pot_lid" then
minetest.set_node(lid_pos, {name = "air"})
elseif lid_node.name == "air" then
minetest.set_node(lid_pos, {name = "scifi_nodes:pot_lid"})
end
end
local function remove_lid(pos)
local lid_pos = {x = pos.x, y = pos.y+2 , z = pos.z}
local lid_node = minetest.get_node(lid_pos)
if lid_node.name == "scifi_nodes:pot_lid" then
minetest.set_node(lid_pos, {name = "air"})
end
end
minetest.register_node("scifi_nodes:pot", {
description = "metal plant pot (right click for lid, shift+rightclick to plant)",
description = "Metal Plant Pot (right-click for lid, sneak + right-click to plant)",
tiles = {
"scifi_nodes_pot.png",
"default_dirt.png^scifi_nodes_pot.png",
"scifi_nodes_greybolts.png",
"scifi_nodes_greybolts.png",
"scifi_nodes_greybolts.png",
@ -376,34 +390,30 @@ minetest.register_node("scifi_nodes:pot", {
},
drawtype = "nodebox",
paramtype = "light",
groups = {cracky=1, soil=1, sand=1},
groups = {cracky = 1, soil = 1, sand = 1},
selection_box = {
type = "fixed",
fixed = {-0.5, -0.5, -0.5, 0.5, 0.5, 0.5}
},
node_box = {
type = "fixed",
fixed = {
{-0.5, -0.25, -0.5, 0.5, 0.5, 0.5}, -- NodeBox1
{0.1875, -0.5, 0.1875, 0.5, -0.25, 0.5}, -- NodeBox2
{-0.5, -0.5, -0.5, -0.1875, -0.25, -0.1875}, -- NodeBox3
{-0.5, -0.5, 0.1875, -0.1875, -0.25, 0.5}, -- NodeBox4
{0.1875, -0.5, -0.5, 0.5, -0.25, -0.1875}, -- NodeBox5
{-0.5, -0.25, -0.5, 0.5, 0.5, 0.5},
{0.1875, -0.5, 0.1875, 0.5, -0.25, 0.5},
{-0.5, -0.5, -0.5, -0.1875, -0.25, -0.1875},
{-0.5, -0.5, 0.1875, -0.1875, -0.25, 0.5},
{0.1875, -0.5, -0.5, 0.5, -0.25, -0.1875}
}
},
on_rightclick = function(pos, node, clicker, item, _)
local lid_node = minetest.get_node({x=pos.x, y=pos.y+2, z=pos.z})
if lid_node.name == "scifi_nodes:pot_lid" then
minetest.set_node({x=pos.x, y=pos.y+2, z=pos.z}, {name="air", param2=lid_node.param2})
elseif lid_node.name ~= "scifi_nodes:pot_lid" and node.name == "air" then
minetest.set_node({x=pos.x, y=pos.y+2, z=pos.z}, {name="scifi_nodes:pot_lid", param2=lid_node.param2})
end
end,
on_destruct = function(pos, node, _)
minetest.remove_node({x=pos.x, y=pos.y+2, z=pos.z})
end
on_rightclick = toggle_lid,
on_destruct = remove_lid,
sounds = default.node_sound_metal_defaults(),
})
minetest.register_node("scifi_nodes:pot2", {
description = "metal wet plant pot(right click for lid, shift+rightclick to plant)",
description = "Metal Plant Pot Wet (right-click for lid, sneak + right-click to plant)",
tiles = {
"scifi_nodes_pot.png^[colorize:black:100",
"default_dirt.png^scifi_nodes_pot2.png",
"scifi_nodes_greybolts.png",
"scifi_nodes_greybolts.png",
"scifi_nodes_greybolts.png",
@ -412,28 +422,24 @@ minetest.register_node("scifi_nodes:pot2", {
},
drawtype = "nodebox",
paramtype = "light",
groups = {cracky=1, soil=3, wet=1},
groups = {cracky = 1, soil = 3, wet = 1},
selection_box = {
type = "fixed",
fixed = {-0.5, -0.5, -0.5, 0.5, 0.5, 0.5}
},
node_box = {
type = "fixed",
fixed = {
{-0.5, -0.25, -0.5, 0.5, 0.5, 0.5}, -- NodeBox1
{0.1875, -0.5, 0.1875, 0.5, -0.25, 0.5}, -- NodeBox2
{-0.5, -0.5, -0.5, -0.1875, -0.25, -0.1875}, -- NodeBox3
{-0.5, -0.5, 0.1875, -0.1875, -0.25, 0.5}, -- NodeBox4
{0.1875, -0.5, -0.5, 0.5, -0.25, -0.1875}, -- NodeBox5
{-0.5, -0.25, -0.5, 0.5, 0.5, 0.5},
{0.1875, -0.5, 0.1875, 0.5, -0.25, 0.5},
{-0.5, -0.5, -0.5, -0.1875, -0.25, -0.1875},
{-0.5, -0.5, 0.1875, -0.1875, -0.25, 0.5},
{0.1875, -0.5, -0.5, 0.5, -0.25, -0.1875}
}
},
on_rightclick = function(pos, node, clicker, item, _)
local lid_node = minetest.get_node({x=pos.x, y=pos.y+2, z=pos.z})
if lid_node.name == "scifi_nodes:pot_lid" then
minetest.set_node({x=pos.x, y=pos.y+2, z=pos.z}, {name="air", param2=lid_node.param2})
elseif lid_node.name ~= "scifi_nodes:pot_lid" and node.name == "air" then
minetest.set_node({x=pos.x, y=pos.y+2, z=pos.z}, {name="scifi_nodes:pot_lid", param2=lid_node.param2})
end
end,
on_destruct = function(pos, node, _)
minetest.remove_node({x=pos.x, y=pos.y+2, z=pos.z})
end
on_rightclick = toggle_lid,
on_destruct = remove_lid,
sounds = default.node_sound_metal_defaults(),
})
minetest.register_node("scifi_nodes:lightbar", {

View File

@ -22,6 +22,8 @@ local function activate_palm_scanner(pos, node, player)
-- check protection
minetest.after(2, function()
if minetest.get_node(pos).name ~= node.name then return end
if minetest.is_protected(pos, name or "") then
-- clicker has no access to area
minetest.chat_send_player(name, "Access denied !")
@ -36,6 +38,7 @@ local function activate_palm_scanner(pos, node, player)
-- reset state
minetest.after(1, function()
if minetest.get_node(pos).name ~= node.name then return end
node.name = "scifi_nodes:palm_scanner_off"
minetest.swap_node(pos, node)
mesecon.receptor_off(pos, scifi_nodes.get_switch_rules(node.param2))

Binary file not shown.

Before

Width:  |  Height:  |  Size: 193 B

After

Width:  |  Height:  |  Size: 124 B

Binary file not shown.

After

Width:  |  Height:  |  Size: 124 B