forked from mtcontrib/maidroid
[ADD] Add active core writer
This commit is contained in:
parent
b614a24d23
commit
02c9771216
|
@ -15,7 +15,42 @@
|
||||||
{ 0.375, 0.1875, 0.0625, 0.4375, 0.375, 0.125},
|
{ 0.375, 0.1875, 0.0625, 0.4375, 0.375, 0.125},
|
||||||
{ -0.375, -0.5, -0.375, 0.375, -0.25, 0.375},
|
{ -0.375, -0.5, -0.375, 0.375, -0.25, 0.375},
|
||||||
},
|
},
|
||||||
};
|
}
|
||||||
|
|
||||||
|
function can_dig(pos, player)
|
||||||
|
local meta = minetest.get_meta(pos)
|
||||||
|
local inventory = meta:get_inventory()
|
||||||
|
return (
|
||||||
|
inventory:is_empty("core") and
|
||||||
|
inventory:is_empty("fuel") and
|
||||||
|
inventory:is_empty("dye")
|
||||||
|
)
|
||||||
|
end;
|
||||||
|
|
||||||
|
function allow_metadata_inventory_put(pos, listname, index, stack, player)
|
||||||
|
local meta = minetest.get_meta(pos)
|
||||||
|
local inventory = meta:get_inventory()
|
||||||
|
local itemname = stack:get_name()
|
||||||
|
|
||||||
|
if (listname == "fuel" and itemname == "default:coal_lump") then
|
||||||
|
return stack:get_count()
|
||||||
|
elseif listname == "dye" and minetest.get_item_group(itemname, "dye") > 0 then
|
||||||
|
return stack:get_count()
|
||||||
|
else if listname == "core" and maidroid.is_core(itemname then
|
||||||
|
return stack:get_count()
|
||||||
|
end
|
||||||
|
return 0
|
||||||
|
end
|
||||||
|
|
||||||
|
function allow_metadata_inventory_move(pos, from_list, from_index, to_list, to_index, count, player)
|
||||||
|
local meta = minetest.get_meta(pos)
|
||||||
|
local inventory = meta:get_inventory()
|
||||||
|
local stack = inventory:get_stack(from_list, from_index)
|
||||||
|
|
||||||
|
return allow_metadata_inventory_put(pos, listname, to_index, stack, player)
|
||||||
|
end
|
||||||
|
|
||||||
|
--------------------------------------------------------------------
|
||||||
|
|
||||||
(function() -- register a definition of an inactive core writer.
|
(function() -- register a definition of an inactive core writer.
|
||||||
local tiles = {
|
local tiles = {
|
||||||
|
@ -45,29 +80,6 @@
|
||||||
|
|
||||||
end
|
end
|
||||||
|
|
||||||
function allow_metadata_inventory_put(pos, listname, index, stack, player)
|
|
||||||
local meta = minetest.get_meta(pos)
|
|
||||||
local inventory = meta:get_inventory()
|
|
||||||
local itemname = stack:get_name()
|
|
||||||
|
|
||||||
if (listname == "fuel" and itemname == "default:coal_lump") then
|
|
||||||
return stack:get_count()
|
|
||||||
elseif listname == "dye" and minetest.get_item_group(itemname, "dye") > 0 then
|
|
||||||
return stack:get_count()
|
|
||||||
else if listname == "core" and maidroid.is_core(itemname then
|
|
||||||
return stack:get_count()
|
|
||||||
end
|
|
||||||
return 0
|
|
||||||
end
|
|
||||||
|
|
||||||
function allow_metadata_inventory_move(pos, from_list, from_index, to_list, to_index, count, player)
|
|
||||||
local meta = minetest.get_meta(pos)
|
|
||||||
local inventory = meta:get_inventory()
|
|
||||||
local stack = inventory:get_stack(from_list, from_index)
|
|
||||||
|
|
||||||
return allow_metadata_inventory_put(pos, listname, to_index, stack, player)
|
|
||||||
end
|
|
||||||
|
|
||||||
function allow_metadata_inventory_take(pos, listname, index, stack, player)
|
function allow_metadata_inventory_take(pos, listname, index, stack, player)
|
||||||
return stack:get_count() -- maybe add more.
|
return stack:get_count() -- maybe add more.
|
||||||
end
|
end
|
||||||
|
@ -91,8 +103,46 @@
|
||||||
})
|
})
|
||||||
end) ();
|
end) ();
|
||||||
|
|
||||||
(function () -- register a definition of an active core writer.
|
--------------------------------------------------------------------
|
||||||
|
|
||||||
|
(function () -- register a definition of an active core writer.
|
||||||
|
local tiles = {
|
||||||
|
"maidroid_tool_core_writer_top.png",
|
||||||
|
"maidroid_tool_core_writer_bottom.png",
|
||||||
|
"maidroid_tool_core_writer_right.png",
|
||||||
|
"maidroid_tool_core_writer_right.png^[transformFX",
|
||||||
|
"maidroid_tool_core_writer_front.png^[transformFX",
|
||||||
|
{
|
||||||
|
backface_culling = false,
|
||||||
|
image = "maidroid_tool_core_writer_front_active.png",
|
||||||
|
|
||||||
|
animation = {
|
||||||
|
type = "vertical_frames",
|
||||||
|
aspect_w = 16,
|
||||||
|
aspect_h = 16,
|
||||||
|
length = 1.5,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
}
|
||||||
|
|
||||||
|
function allow_metadata_inventory_take(pos, listname, index, stack, player)
|
||||||
|
return stack:get_count() -- maybe add more.
|
||||||
|
end
|
||||||
|
|
||||||
|
minetest.register_node("maidroid_tool:core_writer_active", {
|
||||||
|
drawtype = "nodebox",
|
||||||
|
paramtype = "light",
|
||||||
|
paramtype2 = "facedir",
|
||||||
|
groups = {cracky = 2},
|
||||||
|
is_ground_content = false,
|
||||||
|
sounds = default.node_sound_stone_defaults(),
|
||||||
|
node_box = node_box,
|
||||||
|
tiles = tiles,
|
||||||
|
can_dig = can_dig,
|
||||||
|
allow_metadata_inventory_put = allow_metadata_inventory_put,
|
||||||
|
allow_metadata_inventory_move = allow_metadata_inventory_move,
|
||||||
|
allow_metadata_inventory_take = allow_metadata_inventory_take,
|
||||||
|
})
|
||||||
end) ();
|
end) ();
|
||||||
end) ();
|
end) ();
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue
Block a user