Fix core writer, etc...

This commit is contained in:
tacigar 2016-12-17 12:12:20 +09:00
parent fa92b56652
commit f7c363f953
4 changed files with 61 additions and 38 deletions

View File

@ -277,7 +277,7 @@ end
-- maidroid.register_egg registers a definition of a new egg.
function maidroid.register_egg(egg_name, def)
maidroid.register_eggs[egg_name] = def
maidroid.registered_eggs[egg_name] = def
minetest.register_craftitem(egg_name, {
description = def.description,
@ -547,8 +547,8 @@ function maidroid.register_maidroid(product_name, def)
})
-- register maidroid egg.
maidroid.register_egg(production_name .. "_egg", {
description = production_name .. " egg",
maidroid.register_egg(product_name .. "_egg", {
description = product_name .. " egg",
inventory_image = def.egg_image,
product_name = product_name,
})

View File

@ -8,9 +8,10 @@ maidroid_tool.shared = {}
-- maidroid_tool.shared.generate_writer is a shared
-- function called for registering egg writer and core writer.
function maidroid_tool.register_writer(nodename, options)
local formspecs = options.formspecs
local description = options.description
local formspec = options.formspec
local tiles = options.tiles
local nodebox = options.nodebox
local node_box = options.node_box
local selection_box = options.selection_box
local duration = options.duration
local on_activate = options.on_activate
@ -52,7 +53,7 @@ function maidroid_tool.register_writer(nodename, options)
-- if time is positive, this node is active.
if time >= 0 then
if time <= max_time then
if time <= duration then
meta:set_float("time", time + 1)
meta:set_string("formspec", formspec.active(time))
else
@ -100,15 +101,15 @@ function maidroid_tool.register_writer(nodename, options)
if (listname == "fuel" and itemname == "default:coal_lump") then
return stack:get_count()
elseif listname == "dye" and dye_core_map[itemname] ~= nil then
elseif listname == "dye" and dye_item_map[itemname] ~= nil then
return stack:get_count()
elseif listname == "main" and is_mainitem(itemname) then
elseif listname == "main" and itemname == empty_itemname then
return stack:get_count()
end
return 0
end
-- allow_metadata_inventory_move is a common callback for the core writer.
-- allow_metadata_inventory_move is a common callback for the node.
local 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()
@ -116,10 +117,10 @@ function maidroid_tool.register_writer(nodename, options)
return allow_metadata_inventory_put(pos, listname, to_index, stack, player)
end
do -- register a definition of an inactive core writer.
do -- register a definition of an inactive node.
local function on_construct(pos)
local meta = minetest.get_meta(pos)
meta:set_string("formspec", formspec_inactive)
meta:set_string("formspec", formspec.inactive)
meta:set_string("output", "")
meta:set_string("time", -1)
@ -161,8 +162,8 @@ function maidroid_tool.register_writer(nodename, options)
return stack:get_count() -- maybe add more.
end
minetest.register_node("maidroid_tool:core_writer", {
description = "maidroid tool : core writer",
minetest.register_node(nodename, {
description = description,
drawtype = "nodebox",
paramtype = "light",
paramtype2 = "facedir",
@ -185,15 +186,15 @@ function maidroid_tool.register_writer(nodename, options)
end -- end register inactive node.
do -- register a definition of an active core writer.
do -- register a definition of an active node.
local function allow_metadata_inventory_take(pos, listname, index, stack, player)
if listname == "core" then
if listname == "main" then
return 0
end
return stack:get_count()
end
minetest.register_node("maidroid_tool:core_writer_active", {
minetest.register_node(nodename .. "_active", {
drawtype = "nodebox",
paramtype = "light",
paramtype2 = "facedir",

View File

@ -5,11 +5,11 @@
do -- register core writer
local dye_core_map = {
local dye_item_map = {
["dye:red"] = "maidroid_core:basic",
}
local nodebox = {
local node_box = {
type = "fixed",
fixed = {
{-0.4375, -0.25, -0.4375, 0.4375, 0.1875, 0.4375},
@ -34,7 +34,7 @@ do -- register core writer
.. default.gui_bg_img
.. default.gui_slots
.. "label[3.75,0;Core]"
.. "list[current_name;core;3.5,0.5;1,1;]"
.. "list[current_name;main;3.5,0.5;1,1;]"
.. "label[2.75,2;Coal]"
.. "list[current_name;fuel;2.5,2.5;1,1;]"
.. "label[4.75,2;Dye]"
@ -57,7 +57,7 @@ do -- register core writer
.. default.gui_bg_img
.. default.gui_slots
.. "label[3.75,0;Core]"
.. "list[current_name;core;3.5,0.5;1,1;]"
.. "list[current_name;main;3.5,0.5;1,1;]"
.. "label[2.75,2;Coal]"
.. "list[current_name;fuel;2.5,2.5;1,1;]"
.. "label[4.75,2;Dye]"
@ -110,7 +110,7 @@ do -- register core writer
length = 1.5,
},
},
}
},
}
-- get_nearest_core_entity returns the nearest core entity.
@ -136,7 +136,7 @@ do -- register core writer
local function on_metadata_inventory_put_to_main(pos)
local entity_position = {
x = pos.x, y = pos.y + 0.65, z = pos.z
x = pos.x, y = pos.y + 0.65, z = pos.z,
}
minetest.add_entity(entity_position, "maidroid_tool:core_entity")
end
@ -147,19 +147,19 @@ do -- register core writer
end
maidroid_tool.register_writer("maidroid_tool:core_writer", {
description = "maidroid tool : core writer",
formspec = formspec,
tiles = tiles,
nodebox = nodebox,
node_box = node_box,
selection_box = selection_box,
duration = 40,
on_activate = on_activate,
on_deactivate = on_deactivate,
empty_itemname = "maidroid_core:empty",
dye_item_map = dye_item_map,
is_mainitem = maidroid.is_core,
on_metadata_inventory_put_to_main = on_metadata_inventory_put_to_main,
on_metadata_inventory_take_from_main = on_metadata_inventory_take_from_main,
}
})
end
@ -195,23 +195,45 @@ do
local function on_activate(self, staticdata)
self.object:set_properties{textures = {"maidroid_tool:core_node"}}
print(staticdata)
if staticdata ~= "" then
local data = minetest.deserialize(staticdata)
self.is_rotating = data["is_rotating"]
if self.is_rotating then
self:start_rotate()
end
end
end
local function start_rotate(self)
self.object:set_properties{automatic_rotate = 1}
self.is_rotating = true
end
local function stop_rotate(self)
self.object:set_properties{automatic_rotate = 0}
self.is_rotating = false
end
local function get_staticdata(self)
local data = {
["is_rotating"] = self.is_rotating,
}
return minetest.serialize(data)
end
minetest.register_entity("maidroid_tool:core_entity", {
physical = false,
visual = "wielditem",
visual_size = {x = 0.5, y = 0.5},
collisionbox = {0, 0, 0, 0, 0, 0},
on_activate = on_activate,
start_rotate = start_rotate,
stop_rotate = stop_rotate,
physical = false,
visual = "wielditem",
visual_size = {x = 0.5, y = 0.5},
collisionbox = {0, 0, 0, 0, 0, 0},
on_activate = on_activate,
start_rotate = start_rotate,
stop_rotate = stop_rotate,
get_staticdata = get_staticdata,
is_rotating = false,
})
end

View File

@ -54,15 +54,15 @@ local formspec = { -- want to change.
local tiles = {
["active"] = {
"default:stone",
"default_stone.png",
},
["inactive"] = {
"default:stone",
"default_stone.png",
},
}
local nodebox = {
local node_box = {
type = "fixed",
fixed = {
{ -0.5, -0.375, -0.4375, 0.5, 0.3125, 0.4375},
@ -82,12 +82,12 @@ local selection_box = {
}
maidroid_tool.register_writer("maidroid_tool:egg_writer", {
description = "maidroid tool : egg writer",
formspec = formspec,
tiles = tiles,
nodebox = nodebox,
node_box = node_box,
selection_box = selection_box,
duration = 30,
empty_itemname = "maidroid:empty_egg",
dye_item_map = dye_item_map,
is_mainitem = maidroid.is_egg,
}
})