Spawner: Add search radius and height to manual spawn egg.
This commit is contained in:
parent
164e09bed5
commit
43c69ffee4
@ -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)
|
||||||
|
22
spawner.lua
22
spawner.lua
@ -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)")
|
||||||
|
Loading…
Reference in New Issue
Block a user