mirror of
https://github.com/Uberi/Minetest-WorldEdit.git
synced 2025-10-16 07:35:27 +02:00
Move and refactor cuboid functions
This commit is contained in:
@@ -32,7 +32,6 @@ load_module(path .. "/visualization.lua")
|
|||||||
load_module(path .. "/serialization.lua")
|
load_module(path .. "/serialization.lua")
|
||||||
load_module(path .. "/code.lua")
|
load_module(path .. "/code.lua")
|
||||||
load_module(path .. "/compatibility.lua")
|
load_module(path .. "/compatibility.lua")
|
||||||
load_module(path .. "/cuboid.lua")
|
|
||||||
|
|
||||||
|
|
||||||
if minetest.settings:get_bool("log_mods") then
|
if minetest.settings:get_bool("log_mods") then
|
||||||
|
@@ -1,114 +1,21 @@
|
|||||||
-- FIXME: worldedit.pos1/2 is a concept of worldedit_commands only, so these functions here
|
|
||||||
-- are actually misplaced.
|
|
||||||
|
|
||||||
-- Expands or contracts the cuboid in all axes by amount (positive or negative)
|
|
||||||
worldedit.cuboid_volumetric_expand = function(name, amount)
|
|
||||||
local pos1 = worldedit.pos1[name]
|
|
||||||
local pos2 = worldedit.pos2[name]
|
|
||||||
|
|
||||||
if pos1 == nil or pos2 == nil then
|
|
||||||
return false, "Undefined cuboid"
|
|
||||||
end
|
|
||||||
|
|
||||||
local delta1 = vector.new()
|
|
||||||
local delta2 = vector.new()
|
|
||||||
local delta_dir1
|
|
||||||
local delta_dir2
|
|
||||||
|
|
||||||
delta1 = vector.add(delta1, amount)
|
|
||||||
delta2 = vector.add(delta2, amount)
|
|
||||||
delta_dir1, delta_dir2 = worldedit.get_expansion_directions(pos1, pos2)
|
|
||||||
delta1 = vector.multiply(delta1, delta_dir1)
|
|
||||||
delta2 = vector.multiply(delta2, delta_dir2)
|
|
||||||
worldedit.pos1[name] = vector.add(pos1, delta1)
|
|
||||||
worldedit.pos2[name] = vector.add(pos2, delta2)
|
|
||||||
|
|
||||||
return true
|
|
||||||
end
|
|
||||||
|
|
||||||
|
|
||||||
-- Expands or contracts the cuboid in a single axis by amount (positive or negative)
|
|
||||||
worldedit.cuboid_linear_expand = function(name, axis, direction, amount)
|
|
||||||
local pos1 = worldedit.pos1[name]
|
|
||||||
local pos2 = worldedit.pos2[name]
|
|
||||||
|
|
||||||
if pos1 == nil or pos2 == nil then
|
|
||||||
return false, "undefined cuboid"
|
|
||||||
end
|
|
||||||
|
|
||||||
if direction ~= 1 and direction ~= -1 then
|
|
||||||
return false, "invalid marker"
|
|
||||||
end
|
|
||||||
|
|
||||||
local marker = worldedit.marker_get_closest_to_axis(name, axis, direction)
|
|
||||||
local deltavect = vector.new()
|
|
||||||
|
|
||||||
if axis == 'x' then
|
|
||||||
deltavect.x = amount * direction
|
|
||||||
elseif axis == 'y' then
|
|
||||||
deltavect.y = amount * direction
|
|
||||||
elseif axis == 'z' then
|
|
||||||
deltavect.z = amount * direction
|
|
||||||
else
|
|
||||||
return false, "invalid axis"
|
|
||||||
end
|
|
||||||
|
|
||||||
worldedit.marker_move(name, marker, deltavect)
|
|
||||||
return true
|
|
||||||
end
|
|
||||||
|
|
||||||
|
|
||||||
-- Shifts the cuboid by '+-amount' in axis 'axis'
|
|
||||||
worldedit.cuboid_shift = function(name, axis, amount)
|
|
||||||
local pos1 = worldedit.pos1[name]
|
|
||||||
local pos2 = worldedit.pos2[name]
|
|
||||||
|
|
||||||
if pos1 == nil or pos2 == nil then
|
|
||||||
return false, "undefined cuboid"
|
|
||||||
end
|
|
||||||
|
|
||||||
assert(not rawequal(pos1, pos2)) -- vectors must not alias
|
|
||||||
|
|
||||||
if axis == 'x' then
|
|
||||||
worldedit.pos1[name].x = pos1.x + amount
|
|
||||||
worldedit.pos2[name].x = pos2.x + amount
|
|
||||||
elseif axis == 'y' then
|
|
||||||
worldedit.pos1[name].y = pos1.y + amount
|
|
||||||
worldedit.pos2[name].y = pos2.y + amount
|
|
||||||
elseif axis == 'z' then
|
|
||||||
worldedit.pos1[name].z = pos1.z + amount
|
|
||||||
worldedit.pos2[name].z = pos2.z + amount
|
|
||||||
else
|
|
||||||
return false, "invalid axis"
|
|
||||||
end
|
|
||||||
|
|
||||||
return true
|
|
||||||
end
|
|
||||||
|
|
||||||
|
|
||||||
-- Moves the location of a single marker by adding deltavector
|
-- Moves the location of a single marker by adding deltavector
|
||||||
worldedit.marker_move = function(name, marker, deltavector)
|
local function marker_move(name, marker, deltavector)
|
||||||
if marker ~= 1 and marker ~= 2 then
|
|
||||||
return false
|
|
||||||
end
|
|
||||||
|
|
||||||
if marker == 1 then
|
if marker == 1 then
|
||||||
local pos = worldedit.pos1[name]
|
local pos = worldedit.pos1[name]
|
||||||
worldedit.pos1[name] = vector.add(deltavector, pos)
|
worldedit.pos1[name] = vector.add(deltavector, pos)
|
||||||
else
|
elseif marker == 2 then
|
||||||
local pos = worldedit.pos2[name]
|
local pos = worldedit.pos2[name]
|
||||||
worldedit.pos2[name] = vector.add(deltavector, pos)
|
worldedit.pos2[name] = vector.add(deltavector, pos)
|
||||||
|
else
|
||||||
|
assert(false)
|
||||||
end
|
end
|
||||||
|
|
||||||
return true
|
return true
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
||||||
-- Returns two vectors with the directions for volumetric expansion
|
-- Returns two vectors with the directions for volumetric expansion
|
||||||
worldedit.get_expansion_directions = function(mark1, mark2)
|
local function get_expansion_directions(mark1, mark2)
|
||||||
if mark1 == nil or mark2 == nil then
|
assert(mark1 and mark2)
|
||||||
return
|
|
||||||
end
|
|
||||||
local dir1 = vector.new()
|
local dir1 = vector.new()
|
||||||
local dir2 = vector.new()
|
local dir2 = vector.new()
|
||||||
|
|
||||||
@@ -137,55 +44,109 @@ worldedit.get_expansion_directions = function(mark1, mark2)
|
|||||||
end
|
end
|
||||||
|
|
||||||
|
|
||||||
-- Return the marker that is closest to the player
|
-- Returns the closest marker to the specified axis and direction
|
||||||
worldedit.marker_get_closest_to_player = function(name)
|
local function marker_get_closest_to_axis(name, axis, direction)
|
||||||
local player = assert(minetest.get_player_by_name(name))
|
assert(direction == 1 or direction == -1)
|
||||||
local playerpos = player:get_pos()
|
local pos1 = worldedit.pos1[name]
|
||||||
local dist1 = vector.distance(playerpos, worldedit.pos1[name])
|
local pos2 = worldedit.pos2[name]
|
||||||
local dist2 = vector.distance(playerpos, worldedit.pos2[name])
|
|
||||||
|
|
||||||
if dist1 < dist2 then
|
if axis == "x" then
|
||||||
return 1
|
if pos1.x * direction > pos2.x * direction then
|
||||||
|
return 1
|
||||||
|
else
|
||||||
|
return 2
|
||||||
|
end
|
||||||
|
elseif axis == "y" then
|
||||||
|
if pos1.y * direction > pos2.y * direction then
|
||||||
|
return 1
|
||||||
|
else
|
||||||
|
return 2
|
||||||
|
end
|
||||||
|
elseif axis == "z" then
|
||||||
|
if pos1.z * direction > pos2.z * direction then
|
||||||
|
return 1
|
||||||
|
else
|
||||||
|
return 2
|
||||||
|
end
|
||||||
else
|
else
|
||||||
return 2
|
assert(false)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
||||||
-- Returns the closest marker to the specified axis and direction
|
-- Expands or contracts the cuboid in all axes by amount (positive or negative)
|
||||||
worldedit.marker_get_closest_to_axis = function(name, axis, direction)
|
worldedit.cuboid_volumetric_expand = function(name, amount)
|
||||||
local pos1 = vector.new()
|
local pos1 = worldedit.pos1[name]
|
||||||
local pos2 = vector.new()
|
local pos2 = worldedit.pos2[name]
|
||||||
|
|
||||||
|
if pos1 == nil or pos2 == nil then
|
||||||
|
return false, "Undefined cuboid"
|
||||||
|
end
|
||||||
|
|
||||||
|
local delta1 = vector.new(amount, amount, amount)
|
||||||
|
local delta2 = vector.new(amount, amount, amount)
|
||||||
|
local delta_dir1, delta_dir2 = get_expansion_directions(pos1, pos2)
|
||||||
|
delta1 = vector.multiply(delta1, delta_dir1)
|
||||||
|
delta2 = vector.multiply(delta2, delta_dir2)
|
||||||
|
worldedit.pos1[name] = vector.add(pos1, delta1)
|
||||||
|
worldedit.pos2[name] = vector.add(pos2, delta2)
|
||||||
|
|
||||||
|
return true
|
||||||
|
end
|
||||||
|
|
||||||
|
|
||||||
|
-- Expands or contracts the cuboid in a single axis by amount (positive or negative)
|
||||||
|
worldedit.cuboid_linear_expand = function(name, axis, direction, amount)
|
||||||
|
local pos1 = worldedit.pos1[name]
|
||||||
|
local pos2 = worldedit.pos2[name]
|
||||||
|
|
||||||
|
if pos1 == nil or pos2 == nil then
|
||||||
|
return false, "undefined cuboid"
|
||||||
|
end
|
||||||
|
|
||||||
if direction ~= 1 and direction ~= -1 then
|
if direction ~= 1 and direction ~= -1 then
|
||||||
return nil
|
return false, "invalid marker"
|
||||||
end
|
end
|
||||||
|
|
||||||
if axis == 'x' then
|
local marker = marker_get_closest_to_axis(name, axis, direction)
|
||||||
pos1.x = worldedit.pos1[name].x * direction
|
local deltavect = vector.new()
|
||||||
pos2.x = worldedit.pos2[name].x * direction
|
|
||||||
if pos1.x > pos2.x then
|
if axis == "x" then
|
||||||
return 1
|
deltavect.x = amount * direction
|
||||||
else
|
elseif axis == "y" then
|
||||||
return 2
|
deltavect.y = amount * direction
|
||||||
end
|
elseif axis == "z" then
|
||||||
elseif axis == 'y' then
|
deltavect.z = amount * direction
|
||||||
pos1.y = worldedit.pos1[name].y * direction
|
|
||||||
pos2.y = worldedit.pos2[name].y * direction
|
|
||||||
if pos1.y > pos2.y then
|
|
||||||
return 1
|
|
||||||
else
|
|
||||||
return 2
|
|
||||||
end
|
|
||||||
elseif axis == 'z' then
|
|
||||||
pos1.z = worldedit.pos1[name].z * direction
|
|
||||||
pos2.z = worldedit.pos2[name].z * direction
|
|
||||||
if pos1.z > pos2.z then
|
|
||||||
return 1
|
|
||||||
else
|
|
||||||
return 2
|
|
||||||
end
|
|
||||||
else
|
else
|
||||||
return nil
|
return false, "invalid axis"
|
||||||
end
|
end
|
||||||
|
|
||||||
|
marker_move(name, marker, deltavect)
|
||||||
|
return true
|
||||||
|
end
|
||||||
|
|
||||||
|
|
||||||
|
-- Shifts the cuboid by '+-amount' in axis 'axis'
|
||||||
|
worldedit.cuboid_shift = function(name, axis, amount)
|
||||||
|
local pos1 = worldedit.pos1[name]
|
||||||
|
local pos2 = worldedit.pos2[name]
|
||||||
|
|
||||||
|
if pos1 == nil or pos2 == nil then
|
||||||
|
return false, "undefined cuboid"
|
||||||
|
end
|
||||||
|
|
||||||
|
local delta = vector.new()
|
||||||
|
if axis == "x" then
|
||||||
|
delta.x = amount
|
||||||
|
elseif axis == "y" then
|
||||||
|
delta.y = amount
|
||||||
|
elseif axis == "z" then
|
||||||
|
delta.z = amount
|
||||||
|
else
|
||||||
|
return false, "invalid axis"
|
||||||
|
end
|
||||||
|
|
||||||
|
worldedit.pos1[name] = vector.add(pos1, delta)
|
||||||
|
worldedit.pos2[name] = vector.add(pos2, delta)
|
||||||
|
return true
|
||||||
end
|
end
|
@@ -395,8 +395,8 @@ worldedit.register_command("reset", {
|
|||||||
do
|
do
|
||||||
local modpath = minetest.get_modpath("worldedit_commands")
|
local modpath = minetest.get_modpath("worldedit_commands")
|
||||||
for _, name in ipairs({
|
for _, name in ipairs({
|
||||||
"code", "cuboid", "manipulations", "marker", "nodename", "primitives",
|
"code", "cuboid_funcs", "cuboid", "manipulations", "marker", "nodename",
|
||||||
"region", "schematics", "transform", "wand"
|
"primitives", "region", "schematics", "transform", "wand"
|
||||||
}) do
|
}) do
|
||||||
dofile(modpath .. "/" .. name .. ".lua")
|
dofile(modpath .. "/" .. name .. ".lua")
|
||||||
end
|
end
|
||||||
|
Reference in New Issue
Block a user