mirror of
https://github.com/Uberi/Minetest-WorldEdit.git
synced 2025-01-13 11:30:29 +01:00
Reimplement inset/outset to make use of new marker functions
This commit is contained in:
parent
6cf8b92434
commit
ae29a9f064
@ -2,56 +2,48 @@ minetest.register_chatcommand(
|
|||||||
"/outset",
|
"/outset",
|
||||||
{
|
{
|
||||||
params = "<amount> [h|v]",
|
params = "<amount> [h|v]",
|
||||||
description = "expand the selection",
|
description = "outset the selection",
|
||||||
privs = {worldedit=true},
|
privs = {worldedit=true},
|
||||||
func = function(name, param)
|
func = function(name, param)
|
||||||
local find, _, amount, dir = param:find("^(%d+)[%s+]?([hv]?)$")
|
local find, _, amount, dir = param:find("^(%d+)[%s+]?([hv]?)$")
|
||||||
local message
|
|
||||||
|
|
||||||
if find == nil then
|
if find == nil then
|
||||||
worldedit.player_notify(name, "invalid usage: " .. param)
|
return false, "invalid usage: " .. param
|
||||||
return
|
|
||||||
end
|
end
|
||||||
|
|
||||||
if worldedit.pos1[name] == nil or worldedit.pos2[name] == nil then
|
local pos1 = worldedit.pos1[name]
|
||||||
message = "Undefined region. Region must be defined beforehand."
|
local pos2 = worldedit.pos2[name]
|
||||||
|
|
||||||
|
if pos1 == nil or pos2 == nil then
|
||||||
|
return false, "Undefined region. Region must be defined beforehand."
|
||||||
|
end
|
||||||
|
|
||||||
|
local dirs = worldedit.get_outset_directions(pos1, pos2)
|
||||||
|
|
||||||
|
if dir == 'h' then
|
||||||
|
worldedit.move_marker(name, 1, 'x', amount * dirs.x1)
|
||||||
|
worldedit.move_marker(name, 1, 'z', amount * dirs.z1)
|
||||||
|
|
||||||
|
worldedit.move_marker(name, 2, 'x', amount * dirs.x2)
|
||||||
|
worldedit.move_marker(name, 2, 'z', amount * dirs.z2)
|
||||||
|
message = "area outset by " .. amount .. " blocks horizontally"
|
||||||
|
elseif dir == 'v' then
|
||||||
|
worldedit.move_marker(name, 1, 'y', amount * dirs.y1)
|
||||||
|
worldedit.move_marker(name, 2, 'y', amount * dirs.y2)
|
||||||
|
message = "area outset by " .. amount .. " blocks vertically"
|
||||||
else
|
else
|
||||||
amount = tonumber(amount)
|
worldedit.move_marker(name, 1, 'x', amount * dirs.x1)
|
||||||
local curpos1 = worldedit.pos1[name]
|
worldedit.move_marker(name, 1, 'y', amount * dirs.y1)
|
||||||
local curpos2 = worldedit.pos2[name]
|
worldedit.move_marker(name, 1, 'z', amount * dirs.z1)
|
||||||
|
|
||||||
local dirs = worldedit.get_outset_directions(curpos1, curpos2)
|
worldedit.move_marker(name, 2, 'x', amount * dirs.x2)
|
||||||
|
worldedit.move_marker(name, 2, 'y', amount * dirs.y2)
|
||||||
if dir == 'h' then
|
worldedit.move_marker(name, 2, 'z', amount * dirs.z2)
|
||||||
worldedit.pos1[name].x = curpos1.x + (amount * dirs.x1)
|
message = "area outset by " .. amount .. " blocks in all axes"
|
||||||
worldedit.pos1[name].z = curpos1.z + (amount * dirs.z1)
|
|
||||||
|
|
||||||
worldedit.pos2[name].x = curpos2.x + (amount * dirs.x2)
|
|
||||||
worldedit.pos2[name].z = curpos2.z + (amount * dirs.z2)
|
|
||||||
|
|
||||||
message = "area expanded by " .. amount .. " blocks horizontally"
|
|
||||||
elseif dir == 'v' then
|
|
||||||
worldedit.pos1[name].y = curpos1.y + (amount * dirs.y1)
|
|
||||||
worldedit.pos2[name].y = curpos2.y + (amount * dirs.y2)
|
|
||||||
|
|
||||||
message = "area expanded by " .. amount .. " blocks vertically"
|
|
||||||
else
|
|
||||||
worldedit.pos1[name].x = curpos1.x + (amount * dirs.x1)
|
|
||||||
worldedit.pos1[name].z = curpos1.z + (amount * dirs.z1)
|
|
||||||
worldedit.pos1[name].y = curpos1.y + (amount * dirs.y1)
|
|
||||||
|
|
||||||
worldedit.pos2[name].x = curpos2.x + (amount * dirs.x2)
|
|
||||||
worldedit.pos2[name].z = curpos2.z + (amount * dirs.z2)
|
|
||||||
worldedit.pos2[name].y = curpos2.y + (amount * dirs.y2)
|
|
||||||
|
|
||||||
message = "area expanded by " .. amount .. " blocks in all axes"
|
|
||||||
end
|
|
||||||
|
|
||||||
worldedit.mark_pos1(name)
|
|
||||||
worldedit.mark_pos2(name)
|
|
||||||
end
|
end
|
||||||
|
|
||||||
worldedit.player_notify(name, message)
|
worldedit.update_markers(name)
|
||||||
|
return true, message
|
||||||
end,
|
end,
|
||||||
}
|
}
|
||||||
)
|
)
|
||||||
@ -60,56 +52,49 @@ minetest.register_chatcommand(
|
|||||||
"/inset",
|
"/inset",
|
||||||
{
|
{
|
||||||
params = "<amount> [h|v]",
|
params = "<amount> [h|v]",
|
||||||
description = "contract",
|
description = "inset the selection",
|
||||||
privs = {worldedit=true},
|
privs = {worldedit=true},
|
||||||
func = function(name, param)
|
func = function(name, param)
|
||||||
local find, _, amount, dir = param:find("^(%d+)[%s+]?([hv]?)$")
|
local find, _, amount, dir = param:find("^(%d+)[%s+]?([hv]?)$")
|
||||||
local message = ""
|
|
||||||
|
|
||||||
if find == nil then
|
if find == nil then
|
||||||
worldedit.player_notify(name, "invalid usage: " .. param)
|
return false, "invalid usage: " .. param
|
||||||
return
|
|
||||||
end
|
end
|
||||||
|
|
||||||
if worldedit.pos1[name] == nil or worldedit.pos2[name] == nil then
|
local pos1 = worldedit.pos1[name]
|
||||||
message = "Undefined region. Region must be defined beforehand."
|
local pos2 = worldedit.pos2[name]
|
||||||
|
|
||||||
|
if pos1 == nil or pos2 == nil then
|
||||||
|
return false, "Undefined region. Region must be defined beforehand."
|
||||||
|
end
|
||||||
|
|
||||||
|
local dirs = worldedit.get_outset_directions(pos1, pos2)
|
||||||
|
amount = -amount
|
||||||
|
|
||||||
|
if dir == 'h' then
|
||||||
|
worldedit.move_marker(name, 1, 'x', amount * dirs.x1)
|
||||||
|
worldedit.move_marker(name, 1, 'z', amount * dirs.z1)
|
||||||
|
|
||||||
|
worldedit.move_marker(name, 2, 'x', amount * dirs.x2)
|
||||||
|
worldedit.move_marker(name, 2, 'z', amount * dirs.z2)
|
||||||
|
message = "area inset by " .. amount .. " blocks horizontally"
|
||||||
|
elseif dir == 'v' then
|
||||||
|
worldedit.move_marker(name, 1, 'y', amount * dirs.y1)
|
||||||
|
worldedit.move_marker(name, 2, 'y', amount * dirs.y2)
|
||||||
|
message = "area inset by " .. amount .. " blocks vertically"
|
||||||
else
|
else
|
||||||
amount = tonumber(amount)
|
worldedit.move_marker(name, 1, 'x', amount * dirs.x1)
|
||||||
local curpos1 = worldedit.pos1[name]
|
worldedit.move_marker(name, 1, 'y', amount * dirs.y1)
|
||||||
local curpos2 = worldedit.pos2[name]
|
worldedit.move_marker(name, 1, 'z', amount * dirs.z1)
|
||||||
|
|
||||||
local dirs = worldedit.get_outset_directions(curpos1, curpos2)
|
worldedit.move_marker(name, 2, 'x', amount * dirs.x2)
|
||||||
|
worldedit.move_marker(name, 2, 'y', amount * dirs.y2)
|
||||||
if dir == 'h' then
|
worldedit.move_marker(name, 2, 'z', amount * dirs.z2)
|
||||||
worldedit.pos1[name].x = curpos1.x - (amount * dirs.x1)
|
message = "area inset by " .. amount .. " blocks in all axes"
|
||||||
worldedit.pos1[name].z = curpos1.z - (amount * dirs.z1)
|
|
||||||
|
|
||||||
worldedit.pos2[name].x = curpos2.x - (amount * dirs.x2)
|
|
||||||
worldedit.pos2[name].z = curpos2.z - (amount * dirs.z2)
|
|
||||||
|
|
||||||
message = "area contracted by " .. amount .. " blocks horizontally"
|
|
||||||
elseif dir == 'v' then
|
|
||||||
worldedit.pos1[name].y = curpos1.y - (amount * dirs.y1)
|
|
||||||
worldedit.pos2[name].y = curpos2.y - (amount * dirs.y2)
|
|
||||||
|
|
||||||
message = "area contracted by " .. amount .. " blocks vertically"
|
|
||||||
else
|
|
||||||
worldedit.pos1[name].x = curpos1.x - (amount * dirs.x1)
|
|
||||||
worldedit.pos1[name].z = curpos1.z - (amount * dirs.z1)
|
|
||||||
worldedit.pos1[name].y = curpos1.y - (amount * dirs.y1)
|
|
||||||
|
|
||||||
worldedit.pos2[name].x = curpos2.x - (amount * dirs.x2)
|
|
||||||
worldedit.pos2[name].z = curpos2.z - (amount * dirs.z2)
|
|
||||||
worldedit.pos2[name].y = curpos2.y - (amount * dirs.y2)
|
|
||||||
|
|
||||||
message = "area contracted by " .. amount .. " blocks in all axes"
|
|
||||||
end
|
|
||||||
|
|
||||||
worldedit.mark_pos1(name)
|
|
||||||
worldedit.mark_pos2(name)
|
|
||||||
end
|
end
|
||||||
|
|
||||||
worldedit.player_notify(name, message)
|
worldedit.update_markers(name)
|
||||||
|
return true, message
|
||||||
end,
|
end,
|
||||||
}
|
}
|
||||||
)
|
)
|
||||||
@ -389,7 +374,7 @@ worldedit.move_marker = function(name, marker, axis, amount)
|
|||||||
elseif axis == 'z' then
|
elseif axis == 'z' then
|
||||||
worldedit.pos1[name].z = pos1.z + amount
|
worldedit.pos1[name].z = pos1.z + amount
|
||||||
else
|
else
|
||||||
minetest.debug("worldedit: Invalid axis in move_marker. Value was: " .. axis)
|
minetest.debug("worldedit: Invalid axis in move_marker.")
|
||||||
end
|
end
|
||||||
elseif marker == 2 then
|
elseif marker == 2 then
|
||||||
if axis == 'x' then
|
if axis == 'x' then
|
||||||
@ -399,7 +384,7 @@ worldedit.move_marker = function(name, marker, axis, amount)
|
|||||||
elseif axis == 'z' then
|
elseif axis == 'z' then
|
||||||
worldedit.pos2[name].z = pos2.z + amount
|
worldedit.pos2[name].z = pos2.z + amount
|
||||||
else
|
else
|
||||||
minetest.debug("worldedit: Invalid axis in move_marker. Value was: " .. axis)
|
minetest.debug("worldedit: Invalid axis in move_marker.")
|
||||||
end
|
end
|
||||||
else
|
else
|
||||||
minetest.debug("Bad marker id at worldedit.move_marker")
|
minetest.debug("Bad marker id at worldedit.move_marker")
|
||||||
|
Loading…
Reference in New Issue
Block a user