Merge pull request #2664 from ZacSharp/buildSelectedSchematic
Add setting to only build selected part of schematica schematic
This commit is contained in:
commit
fccac8ed74
@ -847,6 +847,11 @@ public final class Settings {
|
|||||||
*/
|
*/
|
||||||
public final Setting<Boolean> skipFailedLayers = new Setting<>(false);
|
public final Setting<Boolean> skipFailedLayers = new Setting<>(false);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Only build the selected part of schematics
|
||||||
|
*/
|
||||||
|
public final Setting<Boolean> buildOnlySelection = new Setting<>(false);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* How far to move before repeating the build. 0 to disable repeating on a certain axis, 0,0,0 to disable entirely
|
* How far to move before repeating the build. 0 to disable repeating on a certain axis, 0,0,0 to disable entirely
|
||||||
*/
|
*/
|
||||||
|
@ -43,6 +43,7 @@ import baritone.utils.BlockStateInterface;
|
|||||||
import baritone.utils.NotificationHelper;
|
import baritone.utils.NotificationHelper;
|
||||||
import baritone.utils.PathingCommandContext;
|
import baritone.utils.PathingCommandContext;
|
||||||
import baritone.utils.schematic.MapArtSchematic;
|
import baritone.utils.schematic.MapArtSchematic;
|
||||||
|
import baritone.utils.schematic.SelectionSchematic;
|
||||||
import baritone.utils.schematic.SchematicSystem;
|
import baritone.utils.schematic.SchematicSystem;
|
||||||
import baritone.utils.schematic.schematica.SchematicaHelper;
|
import baritone.utils.schematic.schematica.SchematicaHelper;
|
||||||
import it.unimi.dsi.fastutil.longs.LongOpenHashSet;
|
import it.unimi.dsi.fastutil.longs.LongOpenHashSet;
|
||||||
@ -140,6 +141,11 @@ public final class BuilderProcess extends BaritoneProcessHelper implements IBuil
|
|||||||
parsed = new MapArtSchematic((IStaticSchematic) parsed);
|
parsed = new MapArtSchematic((IStaticSchematic) parsed);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (Baritone.settings().buildOnlySelection.value) {
|
||||||
|
parsed = new SelectionSchematic(parsed, origin, baritone.getSelectionManager().getSelections());
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
build(name, parsed, origin);
|
build(name, parsed, origin);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
@ -150,10 +156,15 @@ public final class BuilderProcess extends BaritoneProcessHelper implements IBuil
|
|||||||
Optional<Tuple<IStaticSchematic, BlockPos>> schematic = SchematicaHelper.getOpenSchematic();
|
Optional<Tuple<IStaticSchematic, BlockPos>> schematic = SchematicaHelper.getOpenSchematic();
|
||||||
if (schematic.isPresent()) {
|
if (schematic.isPresent()) {
|
||||||
IStaticSchematic s = schematic.get().getFirst();
|
IStaticSchematic s = schematic.get().getFirst();
|
||||||
|
BlockPos origin = schematic.get().getSecond();
|
||||||
|
ISchematic schem = Baritone.settings().mapArtMode.value ? new MapArtSchematic(s) : s;
|
||||||
|
if (Baritone.settings().buildOnlySelection.value) {
|
||||||
|
schem = new SelectionSchematic(schem, origin, baritone.getSelectionManager().getSelections());
|
||||||
|
}
|
||||||
this.build(
|
this.build(
|
||||||
schematic.get().getFirst().toString(),
|
schematic.get().getFirst().toString(),
|
||||||
Baritone.settings().mapArtMode.value ? new MapArtSchematic(s) : s,
|
schem,
|
||||||
schematic.get().getSecond()
|
origin
|
||||||
);
|
);
|
||||||
} else {
|
} else {
|
||||||
logDirect("No schematic currently open");
|
logDirect("No schematic currently open");
|
||||||
|
@ -0,0 +1,53 @@
|
|||||||
|
/*
|
||||||
|
* This file is part of Baritone.
|
||||||
|
*
|
||||||
|
* Baritone is free software: you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU Lesser General Public License as published by
|
||||||
|
* the Free Software Foundation, either version 3 of the License, or
|
||||||
|
* (at your option) any later version.
|
||||||
|
*
|
||||||
|
* Baritone is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU Lesser General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU Lesser General Public License
|
||||||
|
* along with Baritone. If not, see <https://www.gnu.org/licenses/>.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package baritone.utils.schematic;
|
||||||
|
|
||||||
|
import baritone.api.schematic.ISchematic;
|
||||||
|
import baritone.api.schematic.MaskSchematic;
|
||||||
|
import baritone.api.selection.ISelection;
|
||||||
|
import net.minecraft.block.state.IBlockState;
|
||||||
|
import net.minecraft.util.EnumFacing;
|
||||||
|
import net.minecraft.util.math.Vec3i;
|
||||||
|
|
||||||
|
import java.util.stream.Stream;
|
||||||
|
|
||||||
|
public class SelectionSchematic extends MaskSchematic {
|
||||||
|
|
||||||
|
private final ISelection[] selections;
|
||||||
|
|
||||||
|
public SelectionSchematic(ISchematic schematic, Vec3i origin, ISelection[] selections) {
|
||||||
|
super(schematic);
|
||||||
|
this.selections = Stream.of(selections).map(
|
||||||
|
sel -> sel
|
||||||
|
.shift(EnumFacing.WEST, origin.getX())
|
||||||
|
.shift(EnumFacing.DOWN, origin.getY())
|
||||||
|
.shift(EnumFacing.NORTH, origin.getZ()))
|
||||||
|
.toArray(ISelection[]::new);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected boolean partOfMask(int x, int y, int z, IBlockState currentState) {
|
||||||
|
for (ISelection selection : selections) {
|
||||||
|
if (x >= selection.min().x && y >= selection.min().y && z >= selection.min().z
|
||||||
|
&& x <= selection.max().x && y <= selection.max().y && z <= selection.max().z) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
Loading…
x
Reference in New Issue
Block a user