mirror of
https://github.com/minetest-mods/technic.git
synced 2025-01-20 11:31:27 +01:00
Some fixes to sonic screwdriver and gold chests
This commit is contained in:
parent
50bf1039b8
commit
14506c477a
165
gold_chest.lua
165
gold_chest.lua
@ -1,5 +1,4 @@
|
|||||||
local chest_mark_colors = {
|
local chest_mark_colors = {
|
||||||
'', -- regular chest, without color bar
|
|
||||||
'_black',
|
'_black',
|
||||||
'_blue',
|
'_blue',
|
||||||
'_brown',
|
'_brown',
|
||||||
@ -52,15 +51,76 @@ minetest.register_craftitem("technic:gold_locked_chest", {
|
|||||||
stack_max = 99,
|
stack_max = 99,
|
||||||
})
|
})
|
||||||
|
|
||||||
|
minetest.register_node("technic:gold_chest", {
|
||||||
|
description = "Gold Chest",
|
||||||
|
tiles = {"technic_gold_chest_top.png", "technic_gold_chest_top.png", "technic_gold_chest_side.png",
|
||||||
|
"technic_gold_chest_side.png", "technic_gold_chest_side.png", "technic_gold_chest_front.png"},
|
||||||
|
paramtype2 = "facedir",
|
||||||
|
groups = {snappy=2,choppy=2,oddly_breakable_by_hand=2},
|
||||||
|
legacy_facedir_simple = true,
|
||||||
|
sounds = default.node_sound_wood_defaults(),
|
||||||
|
on_construct = function(pos)
|
||||||
|
local meta = minetest.env:get_meta(pos)
|
||||||
|
meta:set_string("formspec",
|
||||||
|
"invsize[12,9;]"..
|
||||||
|
"list[current_name;main;0,0;12,4;]"..
|
||||||
|
"list[current_player;main;0,5;8,4;]")
|
||||||
|
meta:set_string("infotext", "Gold Chest")
|
||||||
|
local inv = meta:get_inventory()
|
||||||
|
inv:set_size("main", 12*4)
|
||||||
|
end,
|
||||||
|
|
||||||
|
can_dig = function(pos,player)
|
||||||
|
local meta = minetest.env:get_meta(pos);
|
||||||
|
local inv = meta:get_inventory()
|
||||||
|
return inv:is_empty("main")
|
||||||
|
end,
|
||||||
|
|
||||||
|
on_punch = function (pos, node, puncher)
|
||||||
|
chest_punched (pos,node,puncher);
|
||||||
|
end,
|
||||||
|
|
||||||
|
on_receive_fields = function(pos, formname, fields, sender)
|
||||||
|
local meta = minetest.env:get_meta(pos);
|
||||||
|
fields.text = fields.text or ""
|
||||||
|
meta:set_string("text", fields.text)
|
||||||
|
meta:set_string("infotext", '"'..fields.text..'"')
|
||||||
|
|
||||||
|
meta:set_string("formspec",
|
||||||
|
"invsize[12,9;]"..
|
||||||
|
"list[current_name;main;0,0;12,4;]"..
|
||||||
|
"list[current_player;main;0,5;8,4;]")
|
||||||
|
end,
|
||||||
|
|
||||||
|
on_metadata_inventory_move = function(pos, from_list, from_index,
|
||||||
|
to_list, to_index, count, player)
|
||||||
|
minetest.log("action", player:get_player_name()..
|
||||||
|
" moves stuff in chest at "..minetest.pos_to_string(pos))
|
||||||
|
return minetest.node_metadata_inventory_move_allow_all(
|
||||||
|
pos, from_list, from_index, to_list, to_index, count, player)
|
||||||
|
end,
|
||||||
|
on_metadata_inventory_offer = function(pos, listname, index, stack, player)
|
||||||
|
minetest.log("action", player:get_player_name()..
|
||||||
|
" moves stuff to chest at "..minetest.pos_to_string(pos))
|
||||||
|
return minetest.node_metadata_inventory_offer_allow_all(
|
||||||
|
pos, listname, index, stack, player)
|
||||||
|
end,
|
||||||
|
on_metadata_inventory_take = function(pos, listname, index, stack, player)
|
||||||
|
minetest.log("action", player:get_player_name()..
|
||||||
|
" takes stuff from chest at "..minetest.pos_to_string(pos))
|
||||||
|
end,
|
||||||
|
})
|
||||||
|
|
||||||
for i, state in ipairs(chest_mark_colors) do
|
for i, state in ipairs(chest_mark_colors) do
|
||||||
minetest.register_node("technic:gold_chest".. state, {
|
minetest.register_node("technic:gold_chest".. state, {
|
||||||
description = "Gold Chest",
|
description = "Gold Chest",
|
||||||
tiles = {"technic_gold_chest_top.png", "technic_gold_chest_top.png", "technic_gold_chest_side.png",
|
tiles = {"technic_gold_chest_top.png", "technic_gold_chest_top.png", "technic_gold_chest_side.png",
|
||||||
"technic_gold_chest_side.png", "technic_gold_chest_side.png", "technic_gold_chest_front"..state..".png"},
|
"technic_gold_chest_side.png", "technic_gold_chest_side.png", "technic_gold_chest_front"..state..".png"},
|
||||||
paramtype2 = "facedir",
|
paramtype2 = "facedir",
|
||||||
groups = {snappy=2,choppy=2,oddly_breakable_by_hand=2},
|
groups = {snappy=2,choppy=2,oddly_breakable_by_hand=2, not_in_creative_inventory=1},
|
||||||
legacy_facedir_simple = true,
|
legacy_facedir_simple = true,
|
||||||
sounds = default.node_sound_wood_defaults(),
|
sounds = default.node_sound_wood_defaults(),
|
||||||
|
drop = "technic:gold_chest",
|
||||||
on_construct = function(pos)
|
on_construct = function(pos)
|
||||||
local meta = minetest.env:get_meta(pos)
|
local meta = minetest.env:get_meta(pos)
|
||||||
meta:set_string("formspec",
|
meta:set_string("formspec",
|
||||||
@ -122,13 +182,112 @@ local function has_locked_chest_privilege(meta, player)
|
|||||||
return true
|
return true
|
||||||
end
|
end
|
||||||
|
|
||||||
|
minetest.register_node("technic:gold_locked_chest", {
|
||||||
|
description = "Gold Locked Chest",
|
||||||
|
tiles = {"technic_gold_chest_top.png", "technic_gold_chest_top.png", "technic_gold_chest_side.png",
|
||||||
|
"technic_gold_chest_side.png", "technic_gold_chest_side.png", "technic_gold_chest_locked.png"},
|
||||||
|
paramtype2 = "facedir",
|
||||||
|
drop = "technic:gold_chest",
|
||||||
|
groups = {snappy=2,choppy=2,oddly_breakable_by_hand=2},
|
||||||
|
legacy_facedir_simple = true,
|
||||||
|
sounds = default.node_sound_wood_defaults(),
|
||||||
|
after_place_node = function(pos, placer)
|
||||||
|
local meta = minetest.env:get_meta(pos)
|
||||||
|
meta:set_string("owner", placer:get_player_name() or "")
|
||||||
|
meta:set_string("infotext", "Gold Locked Chest (owned by "..
|
||||||
|
meta:get_string("owner")..")")
|
||||||
|
end,
|
||||||
|
on_construct = function(pos)
|
||||||
|
local meta = minetest.env:get_meta(pos)
|
||||||
|
meta:set_string("formspec",
|
||||||
|
"invsize[12,9;]"..
|
||||||
|
"list[current_name;main;0,0;12,4;]"..
|
||||||
|
"list[current_player;main;0,5;8,4;]")
|
||||||
|
meta:set_string("infotext", "Gold Locked Chest")
|
||||||
|
meta:set_string("owner", "")
|
||||||
|
local inv = meta:get_inventory()
|
||||||
|
inv:set_size("main", 12*4)
|
||||||
|
end,
|
||||||
|
can_dig = function(pos,player)
|
||||||
|
local meta = minetest.env:get_meta(pos);
|
||||||
|
local inv = meta:get_inventory()
|
||||||
|
return inv:is_empty("main")
|
||||||
|
end,
|
||||||
|
|
||||||
|
on_punch = function (pos, node, puncher)
|
||||||
|
local meta = minetest.env:get_meta(pos);
|
||||||
|
if (has_locked_chest_privilege(meta, puncher)) then
|
||||||
|
locked_chest_punched (pos,node,puncher);
|
||||||
|
end
|
||||||
|
end,
|
||||||
|
|
||||||
|
on_receive_fields = function(pos, formname, fields, sender)
|
||||||
|
local meta = minetest.env:get_meta(pos);
|
||||||
|
fields.text = fields.text or ""
|
||||||
|
meta:set_string("text", fields.text)
|
||||||
|
meta:set_string("infotext", '"'..fields.text..'"')
|
||||||
|
|
||||||
|
meta:set_string("formspec",
|
||||||
|
"invsize[12,9;]"..
|
||||||
|
"list[current_name;main;0,0;12,4;]"..
|
||||||
|
"list[current_player;main;0,5;8,4;]")
|
||||||
|
end,
|
||||||
|
|
||||||
|
allow_metadata_inventory_move = function(pos, from_list, from_index, to_list, to_index, count, player)
|
||||||
|
local meta = minetest.env:get_meta(pos)
|
||||||
|
if not has_locked_chest_privilege(meta, player) then
|
||||||
|
minetest.log("action", player:get_player_name()..
|
||||||
|
" tried to access a locked chest belonging to "..
|
||||||
|
meta:get_string("owner").." at "..
|
||||||
|
minetest.pos_to_string(pos))
|
||||||
|
return 0
|
||||||
|
end
|
||||||
|
return count
|
||||||
|
end,
|
||||||
|
allow_metadata_inventory_put = function(pos, listname, index, stack, player)
|
||||||
|
local meta = minetest.env:get_meta(pos)
|
||||||
|
if not has_locked_chest_privilege(meta, player) then
|
||||||
|
minetest.log("action", player:get_player_name()..
|
||||||
|
" tried to access a locked chest belonging to "..
|
||||||
|
meta:get_string("owner").." at "..
|
||||||
|
minetest.pos_to_string(pos))
|
||||||
|
return 0
|
||||||
|
end
|
||||||
|
return stack:get_count()
|
||||||
|
end,
|
||||||
|
allow_metadata_inventory_take = function(pos, listname, index, stack, player)
|
||||||
|
local meta = minetest.env:get_meta(pos)
|
||||||
|
if not has_locked_chest_privilege(meta, player) then
|
||||||
|
minetest.log("action", player:get_player_name()..
|
||||||
|
" tried to access a locked chest belonging to "..
|
||||||
|
meta:get_string("owner").." at "..
|
||||||
|
minetest.pos_to_string(pos))
|
||||||
|
return 0
|
||||||
|
end
|
||||||
|
return stack:get_count()
|
||||||
|
end,
|
||||||
|
on_metadata_inventory_move = function(pos, from_list, from_index, to_list, to_index, count, player)
|
||||||
|
minetest.log("action", player:get_player_name()..
|
||||||
|
" moves stuff in locked chest at "..minetest.pos_to_string(pos))
|
||||||
|
end,
|
||||||
|
on_metadata_inventory_put = function(pos, listname, index, stack, player)
|
||||||
|
minetest.log("action", player:get_player_name()..
|
||||||
|
" moves stuff to locked chest at "..minetest.pos_to_string(pos))
|
||||||
|
end,
|
||||||
|
on_metadata_inventory_take = function(pos, listname, index, stack, player)
|
||||||
|
minetest.log("action", player:get_player_name()..
|
||||||
|
" takes stuff from locked chest at "..minetest.pos_to_string(pos))
|
||||||
|
end,
|
||||||
|
})
|
||||||
|
|
||||||
for i, state in ipairs(chest_mark_colors) do
|
for i, state in ipairs(chest_mark_colors) do
|
||||||
minetest.register_node("technic:gold_locked_chest".. state, {
|
minetest.register_node("technic:gold_locked_chest".. state, {
|
||||||
description = "Gold Locked Chest",
|
description = "Gold Locked Chest",
|
||||||
tiles = {"technic_gold_chest_top.png", "technic_gold_chest_top.png", "technic_gold_chest_side.png",
|
tiles = {"technic_gold_chest_top.png", "technic_gold_chest_top.png", "technic_gold_chest_side.png",
|
||||||
"technic_gold_chest_side.png", "technic_gold_chest_side.png", "technic_gold_chest_locked"..state..".png"},
|
"technic_gold_chest_side.png", "technic_gold_chest_side.png", "technic_gold_chest_locked"..state..".png"},
|
||||||
paramtype2 = "facedir",
|
paramtype2 = "facedir",
|
||||||
groups = {snappy=2,choppy=2,oddly_breakable_by_hand=2},
|
drop = "technic:gold_chest",
|
||||||
|
groups = {snappy=2,choppy=2,oddly_breakable_by_hand=2, not_in_creative_inventory=1},
|
||||||
legacy_facedir_simple = true,
|
legacy_facedir_simple = true,
|
||||||
sounds = default.node_sound_wood_defaults(),
|
sounds = default.node_sound_wood_defaults(),
|
||||||
after_place_node = function(pos, placer)
|
after_place_node = function(pos, placer)
|
||||||
|
@ -15,7 +15,7 @@ sonic_screwdriver_max_charge=15000
|
|||||||
if charge ==0 then charge =65535 end
|
if charge ==0 then charge =65535 end
|
||||||
charge=get_RE_item_load(charge,sonic_screwdriver_max_charge)
|
charge=get_RE_item_load(charge,sonic_screwdriver_max_charge)
|
||||||
if charge-100>0 then
|
if charge-100>0 then
|
||||||
minetest.sound_play("technic_sonic_screwdriver", {pos = pos, gain = 1.0, max_hear_distance = 10,})
|
minetest.sound_play("technic_sonic_screwdriver", {pos = pos, gain = 0.5, max_hear_distance = 10,})
|
||||||
local n = node.param2
|
local n = node.param2
|
||||||
n = n+1
|
n = n+1
|
||||||
if n == 4 then n = 0 end
|
if n == 4 then n = 0 end
|
||||||
@ -40,8 +40,8 @@ sonic_screwdriver_max_charge=15000
|
|||||||
minetest.register_craft({
|
minetest.register_craft({
|
||||||
output = "technic:sonic_screwdriver",
|
output = "technic:sonic_screwdriver",
|
||||||
recipe = {
|
recipe = {
|
||||||
{"technic:green_energy_crystal"},
|
{"technic:diamond"},
|
||||||
{"technic:stainless_steel_ingot"},
|
{"technic:battery"},
|
||||||
{"technic:stainless_steel_ingot"}
|
{"technic:stainless_steel_ingot"}
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
Binary file not shown.
Before Width: | Height: | Size: 2.0 KiB After Width: | Height: | Size: 2.0 KiB |
Loading…
Reference in New Issue
Block a user