Spawner: Add search radius and height to manual spawn egg.

This commit is contained in:
Hector Franqui 2017-09-21 20:03:01 -04:00
parent 164e09bed5
commit 43c69ffee4
2 changed files with 24 additions and 6 deletions

View File

@ -427,7 +427,7 @@ function npc.places.scan_area_for_usable_nodes(pos1, pos2)
result.storage_type = npc.places.get_nodes_by_type(start_pos, end_pos, npc.places.nodes.STORAGE_TYPE) result.storage_type = npc.places.get_nodes_by_type(start_pos, end_pos, npc.places.nodes.STORAGE_TYPE)
result.openable_type = npc.places.get_nodes_by_type(start_pos, end_pos, npc.places.nodes.OPENABLE_TYPE) result.openable_type = npc.places.get_nodes_by_type(start_pos, end_pos, npc.places.nodes.OPENABLE_TYPE)
-- Find workplace nodes: if mg_villages:plotmarker is given a start pos, take it from there. -- Find workplace nodes: if mg_villages:plotmarker is given as start pos, take it from there.
-- If not, search for them. -- If not, search for them.
local node = minetest.get_node(pos1) local node = minetest.get_node(pos1)
if node.name == "mg_villages:plotmarker" then if node.name == "mg_villages:plotmarker" then
@ -436,7 +436,11 @@ function npc.places.scan_area_for_usable_nodes(pos1, pos2)
end end
else else
-- Just search for workplace nodes -- Just search for workplace nodes
result.workplace_type = npc.places.get_nodes_by_type(start_pos, end_pos, npc.places.nodes.WORKPLACE_TYPE) -- The search radius is increased by 2
result.workplace_type = npc.places.get_nodes_by_type(
{x=start_pos.x-20, y=start_pos.y, z=start_pos.z-20},
{x=end_pos.x+20, y=end_pos.y, z=end_pos.z+20},
npc.places.nodes.WORKPLACE_TYPE)
-- Find out building type and add it to the result -- Find out building type and add it to the result
for i = 1, #result.workplace_type do for i = 1, #result.workplace_type do
local meta = minetest.get_meta(result.workplace_type[i].node_pos) local meta = minetest.get_meta(result.workplace_type[i].node_pos)

View File

@ -693,6 +693,8 @@ minetest.register_craftitem("advanced_npc:spawn_egg", {
building_dropdown_string.. building_dropdown_string..
"label[0.1,1.45;Occupation]".. "label[0.1,1.45;Occupation]"..
occupation_dropdown_string.. occupation_dropdown_string..
"field[0.5,3;3,2;radius;Search radius;20]"..
"field[3.5,3;3,2;height;Search height;2]"..
"button_exit[2.25,6.25;2.5,0.75;exit;Spawn]" "button_exit[2.25,6.25;2.5,0.75;exit;Spawn]"
minetest.show_formspec(user:get_player_name(), "advanced_npc:spawn_egg_main", formspec) minetest.show_formspec(user:get_player_name(), "advanced_npc:spawn_egg_main", formspec)
@ -753,8 +755,19 @@ minetest.register_on_player_receive_fields(function(player, formname, fields)
-- Handle exit (spawn) button -- Handle exit (spawn) button
if fields.exit then if fields.exit then
local pos = spawner.spawn_pos[player:get_player_name()] local pos = spawner.spawn_pos[player:get_player_name()]
local start_pos = {x=pos.x-20, y=pos.y-2, z=pos.z-20 } local radius = 20
local end_pos = {x=pos.x+20, y=pos.y+2, z=pos.z+20 } local y_adj = 2
-- Set radius if present
if fields.radius then
radius = tonumber(fields.radius)
end
-- Set y adjustment if present
if fields.height then
y_adj = tonumber(fields.height)
end
-- Calculate positions
local start_pos = {x=pos.x-radius, y=pos.y-y_adj, z=pos.z-radius }
local end_pos = {x=pos.x+radius, y=pos.y+y_adj, z=pos.z+radius }
-- Scan for usable nodes -- Scan for usable nodes
local area_info = npc.spawner.scan_area_for_spawn(start_pos, end_pos, player:get_player_name()) local area_info = npc.spawner.scan_area_for_spawn(start_pos, end_pos, player:get_player_name())
@ -787,7 +800,7 @@ minetest.register_on_player_receive_fields(function(player, formname, fields)
local meta = minetest.get_meta(pos) local meta = minetest.get_meta(pos)
-- Checkbox setting -- Checkbox setting
if fields.is_surrounding then if fields.is_surrounding then
minetest.log("Saving.. "..fields.is_surrounding) --minetest.log("Saving.. "..fields.is_surrounding)
meta:set_string("surrounding_workplace", ""..fields.is_surrounding.."") meta:set_string("surrounding_workplace", ""..fields.is_surrounding.."")
end end
-- Handle reset button -- Handle reset button
@ -799,7 +812,8 @@ minetest.register_on_player_receive_fields(function(player, formname, fields)
return return
end end
-- Handle set button -- Handle set button
if pos and fields.text and fields.exit_btn then if (pos and fields.text and fields.exit_btn)
or (fields.key_enter_field and fields.key_enter_field == "building_type") then
local meta = minetest.get_meta(pos) local meta = minetest.get_meta(pos)
meta:set_string("building_type", fields.text) meta:set_string("building_type", fields.text)
meta:set_string("infotext", fields.text.." (workplace)") meta:set_string("infotext", fields.text.." (workplace)")