forked from minetest-mods/technic
Change chainsaw cutting algorithm back to old one
The new algorithm caused horizontal sections of trees to be left, with the sections above and below them removed.
This commit is contained in:
parent
16302cffce
commit
ec069aa43e
@ -148,37 +148,52 @@ local function handle_drops(drops)
|
|||||||
end
|
end
|
||||||
|
|
||||||
--- Iterator over positions to try to saw around a sawed node.
|
--- Iterator over positions to try to saw around a sawed node.
|
||||||
-- This returns nodes in a 3x2x3 area. It does not return lower (y) positions
|
-- This returns positions in a 3x1x3 area around the position, plus the
|
||||||
-- to prevent the chainsaw from cutting down nodes below the cutting position.
|
-- position above it. This does not return the bottom position to prevent
|
||||||
|
-- the chainsaw from cutting down nodes below the cutting position.
|
||||||
-- @param pos Sawing position.
|
-- @param pos Sawing position.
|
||||||
local function iterSawTries(pos)
|
local function iterSawTries(pos)
|
||||||
-- Copy position to prevent mangling it
|
-- Copy position to prevent mangling it
|
||||||
local pos = vector.new(pos)
|
local pos = vector.new(pos)
|
||||||
-- Shift the position down on the x and z axes
|
local i = 0
|
||||||
pos.x, pos.z = pos.x - 1, pos.z - 1
|
|
||||||
-- Save our starting position for reseting it later
|
|
||||||
local startx, startz = pos.x, pos.z
|
|
||||||
-- We will move out by one in every direction except -y
|
|
||||||
local endx, endy, endz = pos.x + 2, pos.y + 1, pos.z + 2
|
|
||||||
-- Adjust for initial increment
|
|
||||||
pos.x = pos.x - 1
|
|
||||||
|
|
||||||
return function()
|
return function()
|
||||||
if pos.x < endx then
|
i = i + 1
|
||||||
|
-- Given a (top view) area like so (where 5 is the starting position):
|
||||||
|
-- X -->
|
||||||
|
-- Z 123
|
||||||
|
-- | 456
|
||||||
|
-- V 789
|
||||||
|
-- This will return positions 1, 4, 7, 2, 8 (skip 5), 3, 6, 9,
|
||||||
|
-- and the position above 5.
|
||||||
|
if i == 1 then
|
||||||
|
-- Move to starting position
|
||||||
|
pos.x = pos.x - 1
|
||||||
|
pos.z = pos.z - 1
|
||||||
|
elseif i == 4 or i == 7 then
|
||||||
|
-- Move to next X and back to start of Z when we reach
|
||||||
|
-- the end of a Z line.
|
||||||
pos.x = pos.x + 1
|
pos.x = pos.x + 1
|
||||||
else
|
pos.z = pos.z - 2
|
||||||
pos.x = startx
|
elseif i == 5 then
|
||||||
if pos.z < endz then
|
-- Skip the middle position (we've already run on it)
|
||||||
|
-- and double-increment the counter.
|
||||||
|
pos.z = pos.z + 2
|
||||||
|
i = i + 1
|
||||||
|
elseif i <= 9 then
|
||||||
|
-- Go to next Z.
|
||||||
pos.z = pos.z + 1
|
pos.z = pos.z + 1
|
||||||
else
|
elseif i == 10 then
|
||||||
pos.z = startz
|
-- Move back to center and up.
|
||||||
if pos.y < endy then
|
-- The Y+ position must be last so that we don't dig
|
||||||
|
-- straight upward and not come down (since the Y-
|
||||||
|
-- position isn't checked).
|
||||||
|
pos.x = pos.x - 1
|
||||||
|
pos.z = pos.z - 1
|
||||||
pos.y = pos.y + 1
|
pos.y = pos.y + 1
|
||||||
else
|
else
|
||||||
return nil
|
return nil
|
||||||
end
|
end
|
||||||
end
|
|
||||||
end
|
|
||||||
return pos
|
return pos
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
@ -195,7 +210,7 @@ local function recursive_dig(pos, remaining_charge)
|
|||||||
return remaining_charge
|
return remaining_charge
|
||||||
end
|
end
|
||||||
|
|
||||||
-- wood found - cut it
|
-- Wood found - cut it
|
||||||
handle_drops(minetest.get_node_drops(node.name, ""))
|
handle_drops(minetest.get_node_drops(node.name, ""))
|
||||||
minetest.remove_node(pos)
|
minetest.remove_node(pos)
|
||||||
remaining_charge = remaining_charge - chainsaw_charge_per_node
|
remaining_charge = remaining_charge - chainsaw_charge_per_node
|
||||||
|
Loading…
Reference in New Issue
Block a user