mirror of
https://github.com/sbrl/Minetest-WorldEditAdditions.git
synced 2024-11-25 16:43:05 +00:00
Implement point cloud wand
This commit is contained in:
parent
f2aa87b396
commit
78572e453e
6 changed files with 111 additions and 1 deletions
|
@ -40,3 +40,36 @@ function worldeditadditions.vector.floor(v)
|
||||||
-- Some vectors are 2d
|
-- Some vectors are 2d
|
||||||
if v.z then v.z = math.floor(v.z) end
|
if v.z then v.z = math.floor(v.z) end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
--- Determines if the target point is contained within the defined worldedit region.
|
||||||
|
-- @param pos1 Vector pos1 of the defined region.
|
||||||
|
-- @param pos2 Vector pos2 of the defined region.
|
||||||
|
-- @param target Vector The target vector to check.
|
||||||
|
-- @return boolean Whether the given target is contained within the defined worldedit region.
|
||||||
|
function worldeditadditions.vector.is_contained(pos1, pos2, target)
|
||||||
|
local pos1, pos2 = worldedit.sort_pos(pos1, pos2)
|
||||||
|
return pos1.x >= target.x
|
||||||
|
and pos1.y >= target.y
|
||||||
|
and pos1.z >= target.z
|
||||||
|
and pos2.x <= target.x
|
||||||
|
and pos2.y <= target.y
|
||||||
|
and pos2.z <= target.z
|
||||||
|
end
|
||||||
|
|
||||||
|
--- Expands the defined region to include the given point.
|
||||||
|
-- @param pos1 Vector pos1 of the defined region.
|
||||||
|
-- @param pos2 Vector pos2 of the defined region.
|
||||||
|
-- @param target Vector The target vector to include.
|
||||||
|
function worldeditadditions.vector.expand_region(pos1, pos2, target)
|
||||||
|
local pos1, pos2 = worldedit.sort_pos(pos1, pos2)
|
||||||
|
|
||||||
|
if target.x < pos1.x then pos1.x = target.x end
|
||||||
|
if target.y < pos1.y then pos1.y = target.y end
|
||||||
|
if target.z < pos1.z then pos1.z = target.z end
|
||||||
|
|
||||||
|
if target.x > pos2.x then pos2.x = target.x end
|
||||||
|
if target.y > pos2.y then pos2.y = target.y end
|
||||||
|
if target.z > pos2.z then pos2.z = target.z end
|
||||||
|
|
||||||
|
return pos1, pos2
|
||||||
|
end
|
||||||
|
|
|
@ -1 +1 @@
|
||||||
{"modelVersion":2,"piskel":{"name":"worldedit_wand","description":"","fps":0,"height":16,"width":16,"layers":["{\"name\":\"Layer 1\",\"opacity\":1,\"frameCount\":3,\"chunks\":[{\"layout\":[[0],[1],[2]],\"base64PNG\":\"\"}]}"]}}
|
{"modelVersion":2,"piskel":{"name":"worldedit_wand","description":"","fps":0,"height":16,"width":16,"layers":["{\"name\":\"Layer 1\",\"opacity\":1,\"frameCount\":4,\"chunks\":[{\"layout\":[[0],[1],[2],[3]],\"base64PNG\":\"\"}]}"]}}
|
|
@ -4,6 +4,8 @@ worldeditadditions.farwand = {
|
||||||
|
|
||||||
local modpath = minetest.get_modpath("worldeditadditions_farwand")
|
local modpath = minetest.get_modpath("worldeditadditions_farwand")
|
||||||
|
|
||||||
|
dofile(modpath.."/lib/do_raycast.lua")
|
||||||
dofile(modpath.."/lib/farwand.lua")
|
dofile(modpath.."/lib/farwand.lua")
|
||||||
|
dofile(modpath.."/lib/cloudwand.lua")
|
||||||
dofile(modpath.."/lib/chatcommand.lua")
|
dofile(modpath.."/lib/chatcommand.lua")
|
||||||
dofile(modpath.."/lib/settings.lua")
|
dofile(modpath.."/lib/settings.lua")
|
||||||
|
|
58
worldeditadditions_farwand/lib/cloudwand.lua
Normal file
58
worldeditadditions_farwand/lib/cloudwand.lua
Normal file
|
@ -0,0 +1,58 @@
|
||||||
|
local function add_point(name, pos)
|
||||||
|
if pos ~= nil then
|
||||||
|
-- print("[set_pos1]", name, "("..pos.x..", "..pos.y..", "..pos.z..")")
|
||||||
|
if not worldedit.pos1[name] then worldedit.pos1[name] = vector.new(pos) end
|
||||||
|
if not worldedit.pos2[name] then worldedit.pos2[name] = vector.new(pos) end
|
||||||
|
|
||||||
|
worldedit.marker_update(name)
|
||||||
|
|
||||||
|
local volume_before = worldedit.volume(worldedit.pos1[name], worldedit.pos2[name])
|
||||||
|
|
||||||
|
worldedit.pos1[name], worldedit.pos2[name] = worldeditadditions.vector.expand_region(worldedit.pos1[name], worldedit.pos2[name], pos)
|
||||||
|
|
||||||
|
local volume_after = worldedit.volume(worldedit.pos1[name], worldedit.pos2[name])
|
||||||
|
|
||||||
|
local volume_difference = volume_after - volume_before
|
||||||
|
|
||||||
|
worldedit.marker_update(name)
|
||||||
|
worldedit.player_notify(name, "Expanded region by "..volume_difference.." nodes")
|
||||||
|
else
|
||||||
|
worldedit.player_notify(name, "Error: Too far away (try raising your maxdist with //farwand maxdist <number>)")
|
||||||
|
-- print("[set_pos1]", name, "nil")
|
||||||
|
end
|
||||||
|
end
|
||||||
|
local function clear_points(name, pos)
|
||||||
|
worldedit.pos1[name] = nil
|
||||||
|
worldedit.pos2[name] = nil
|
||||||
|
worldedit.marker_update(name)
|
||||||
|
worldedit.set_pos[name] = nil
|
||||||
|
end
|
||||||
|
|
||||||
|
minetest.register_tool(":worldeditadditions:cloudwand", {
|
||||||
|
description = "WorldEditAdditions far-reaching point cloud wand",
|
||||||
|
inventory_image = "worldeditadditions_cloudwand.png",
|
||||||
|
|
||||||
|
on_place = function(itemstack, player, pointed_thing)
|
||||||
|
local name = player:get_player_name()
|
||||||
|
-- print("[farwand] on_place", name)
|
||||||
|
-- Right click when pointing at something
|
||||||
|
-- Pointed thing: https://rubenwardy.com/minetest_modding_book/lua_api.html#pointed_thing
|
||||||
|
clear_points(name)
|
||||||
|
end,
|
||||||
|
|
||||||
|
on_use = function(itemstack, player, pointed_thing)
|
||||||
|
local name = player:get_player_name()
|
||||||
|
-- print("[farwand] on_use", name)
|
||||||
|
local looking_pos, node_id = worldeditadditions.farwand.do_raycast(player)
|
||||||
|
add_point(name, looking_pos)
|
||||||
|
-- Left click when pointing at something or nothing
|
||||||
|
end,
|
||||||
|
|
||||||
|
on_secondary_use = function(itemstack, player, pointed_thing)
|
||||||
|
local name = player:get_player_name()
|
||||||
|
-- Right click when pointing at nothing
|
||||||
|
-- print("[farwand] on_secondary_use", name)
|
||||||
|
|
||||||
|
clear_points(name)
|
||||||
|
end
|
||||||
|
})
|
17
worldeditadditions_farwand/lib/do_raycast.lua
Normal file
17
worldeditadditions_farwand/lib/do_raycast.lua
Normal file
|
@ -0,0 +1,17 @@
|
||||||
|
|
||||||
|
--- worldeditadditions.raycast() wrapper
|
||||||
|
function worldeditadditions.farwand.do_raycast(player)
|
||||||
|
if player == nil then return nil end
|
||||||
|
local player_name = player:get_player_name()
|
||||||
|
|
||||||
|
if worldeditadditions.farwand.player_data[player_name] == nil then
|
||||||
|
worldeditadditions.farwand.player_data[player_name] = { maxdist = 1000, skip_liquid = true }
|
||||||
|
end
|
||||||
|
|
||||||
|
local looking_pos, node_id = worldeditadditions.raycast(
|
||||||
|
player,
|
||||||
|
worldeditadditions.farwand.player_data[player_name].maxdist,
|
||||||
|
worldeditadditions.farwand.player_data[player_name].skip_liquid
|
||||||
|
)
|
||||||
|
return looking_pos, node_id
|
||||||
|
end
|
Binary file not shown.
After Width: | Height: | Size: 181 B |
Loading…
Reference in a new issue