path stuff

This commit is contained in:
Leijurv 2018-08-02 10:01:34 -04:00
parent a60b398b0c
commit 8c8ce9cd5e
No known key found for this signature in database
GPG Key ID: 44A3EA646EADAC6A
6 changed files with 105 additions and 15 deletions

View File

@ -0,0 +1,38 @@
package baritone.bot.behavior;
import baritone.bot.pathing.IPath;
import baritone.bot.pathing.movements.Movement;
import baritone.bot.utils.Helper;
import net.minecraft.util.Tuple;
import net.minecraft.util.math.BlockPos;
/**
* @author Brady
* @since 8/1/2018 5:38 PM
*/
public class PathExecution extends Behavior implements Helper {
private static final double MAX_DIST_FROM_PATH = 2;
private final IPath path;
public PathExecution(IPath path) {
this.path = path;
}
public void onTick() {
BlockPos playerFeet = playerFeet();
// TODO copy logic from Path in resources
if (path.isInPath(playerFeet)) {
// TODO the old Path used to keep track of the index in the path
// and only increment it when the movement said it was done, not when it detected that the player feet had
// moved into the next position
Movement movement = path.subsequentMovement(playerFeet);
//movement.tick()
} else {
Tuple<Double, BlockPos> closest = path.closestPathPos(player.posX, player.posY, player.posZ);
if (closest.getFirst() > MAX_DIST_FROM_PATH) {
// TODO how to indicate failure? Exception?
}
}
}
}

View File

@ -1,8 +0,0 @@
package baritone.bot.behavior;
/**
* @author Brady
* @since 8/1/2018 5:38 PM
*/
public class PathFinding {
}

View File

@ -1,5 +1,8 @@
package baritone.bot.pathing; package baritone.bot.pathing;
import baritone.bot.pathing.movements.Movement;
import baritone.bot.utils.Utils;
import net.minecraft.util.Tuple;
import net.minecraft.util.math.BlockPos; import net.minecraft.util.math.BlockPos;
import java.util.Collection; import java.util.Collection;
@ -7,9 +10,12 @@ import java.util.List;
public interface IPath { public interface IPath {
/** /**
* * Ordered list of movements to carry out.
* movements.get(i).getSrc() should equal positions.get(i)
* movements.get(i).getDest() should equal positions.get(i+1)
* movements.size() should equal positions.size()-1
*/ */
List<BlockPos> movements(); List<Movement> movements();
/** /**
* All positions along the way. * All positions along the way.
@ -17,6 +23,44 @@ public interface IPath {
*/ */
List<BlockPos> positions(); List<BlockPos> positions();
/**
* What's the next step
*
* @param currentPosition the current position
* @return
*/
default Movement subsequentMovement(BlockPos currentPosition) {
List<BlockPos> pos = positions();
List<Movement> moves = movements();
for (int i = 0; i < pos.size(); i++) {
if (currentPosition.equals(pos.get(i))) {
return moves.get(i);
}
}
throw new UnsupportedOperationException(currentPosition + " not in path");
}
/**
* @param currentPosition
* @return
*/
default boolean isInPath(BlockPos currentPosition) {
return positions().stream().anyMatch(pos -> currentPosition.equals(pos));
}
default Tuple<Double, BlockPos> closestPathPos(double x, double y, double z) {
double best = -1;
BlockPos bestPos = null;
for (BlockPos pos : positions()) {
double dist = Utils.distanceToCenter(pos, x, y, z);
if (dist < best || best == -1) {
best = dist;
bestPos = pos;
}
}
return new Tuple<>(best, bestPos);
}
/** /**
* Where does this path start * Where does this path start
*/ */
@ -29,12 +73,14 @@ public interface IPath {
/** /**
* For rendering purposes, what blocks should be highlighted in red * For rendering purposes, what blocks should be highlighted in red
*
* @return an unordered collection of positions * @return an unordered collection of positions
*/ */
Collection<BlockPos> getBlocksToMine(); Collection<BlockPos> getBlocksToMine();
/** /**
* For rendering purposes, what blocks should be highlighted in green * For rendering purposes, what blocks should be highlighted in green
*
* @return an unordered collection of positions * @return an unordered collection of positions
*/ */
Collection<BlockPos> getBlocksToPlace(); Collection<BlockPos> getBlocksToPlace();

View File

@ -2,10 +2,10 @@ package baritone.bot.pathing.action;
import baritone.bot.Baritone; import baritone.bot.Baritone;
import baritone.bot.behavior.Behavior; import baritone.bot.behavior.Behavior;
import baritone.bot.pathing.action.ActionState.ActionStatus;
import baritone.bot.utils.Utils; import baritone.bot.utils.Utils;
import net.minecraft.util.Tuple; import net.minecraft.util.Tuple;
import net.minecraft.util.math.BlockPos; import net.minecraft.util.math.BlockPos;
import baritone.bot.pathing.action.ActionState.ActionStatus;
public abstract class Action extends Behavior { public abstract class Action extends Behavior {
@ -29,7 +29,9 @@ public abstract class Action extends Behavior {
* *
* @return Cost * @return Cost
*/ */
public double cost() { return 0; } public double cost() {
return 0;
}
@Override @Override
public void onTick() { public void onTick() {

View File

@ -3,6 +3,7 @@ package baritone.bot.utils;
import net.minecraft.client.Minecraft; import net.minecraft.client.Minecraft;
import net.minecraft.client.entity.EntityPlayerSP; import net.minecraft.client.entity.EntityPlayerSP;
import net.minecraft.client.multiplayer.WorldClient; import net.minecraft.client.multiplayer.WorldClient;
import net.minecraft.util.math.BlockPos;
/** /**
* @author Brady * @author Brady
@ -14,4 +15,8 @@ public interface Helper {
EntityPlayerSP player = mc.player; EntityPlayerSP player = mc.player;
WorldClient world = mc.world; WorldClient world = mc.world;
default BlockPos playerFeet() {
return new BlockPos(player.posX, player.posY, player.posZ);
}
} }

View File

@ -30,4 +30,11 @@ public final class Utils {
orig.getY() + yDiff, orig.getY() + yDiff,
orig.getZ() + zDiff); orig.getZ() + zDiff);
} }
public static double distanceToCenter(BlockPos pos, double x, double y, double z) {
double xdiff = x - (pos.getX() + 0.5D);
double ydiff = y - (pos.getY() + 0.5D);
double zdiff = z - (pos.getZ() + 0.5D);
return Math.sqrt(xdiff * xdiff + ydiff * ydiff + zdiff * zdiff);
}
} }