Fix target creation of Movement superclass
This commit is contained in:
parent
84aeca710e
commit
3c6415d486
@ -2,6 +2,7 @@ package baritone.bot.behavior.impl;
|
|||||||
|
|
||||||
import baritone.bot.utils.BlockStateInterface;
|
import baritone.bot.utils.BlockStateInterface;
|
||||||
import baritone.bot.utils.Helper;
|
import baritone.bot.utils.Helper;
|
||||||
|
import baritone.bot.utils.Rotation;
|
||||||
import baritone.bot.utils.Utils;
|
import baritone.bot.utils.Utils;
|
||||||
import net.minecraft.block.state.IBlockState;
|
import net.minecraft.block.state.IBlockState;
|
||||||
import net.minecraft.util.Tuple;
|
import net.minecraft.util.Tuple;
|
||||||
@ -34,7 +35,7 @@ public final class LookBehaviorUtils implements Helper{
|
|||||||
return new Vec3d((double) (f1 * f2), (double) f3, (double) (f * f2));
|
return new Vec3d((double) (f1 * f2), (double) f3, (double) (f * f2));
|
||||||
}
|
}
|
||||||
|
|
||||||
public static Optional<Tuple<Float, Float>> reachable(BlockPos pos) {
|
public static Optional<Rotation> reachable(BlockPos pos) {
|
||||||
Optional possibleRotation = reachableCenter(pos);
|
Optional possibleRotation = reachableCenter(pos);
|
||||||
if(possibleRotation.isPresent()) {
|
if(possibleRotation.isPresent()) {
|
||||||
return possibleRotation;
|
return possibleRotation;
|
||||||
@ -72,8 +73,8 @@ public final class LookBehaviorUtils implements Helper{
|
|||||||
* @param offset
|
* @param offset
|
||||||
* @return
|
* @return
|
||||||
*/
|
*/
|
||||||
protected static Optional<Tuple<Float, Float>> reachableRotation(BlockPos pos, Vec3d offset) {
|
protected static Optional<Rotation> reachableRotation(BlockPos pos, Vec3d offset) {
|
||||||
Tuple<Float, Float> rotation = Utils.calcRotationFromVec3d(mc.player.getPositionEyes(1.0F),
|
Rotation rotation = Utils.calcRotationFromVec3d(mc.player.getPositionEyes(1.0F),
|
||||||
offset);
|
offset);
|
||||||
RayTraceResult result = raytraceTowards(rotation);
|
RayTraceResult result = raytraceTowards(rotation);
|
||||||
if(result != null
|
if(result != null
|
||||||
@ -88,8 +89,8 @@ public final class LookBehaviorUtils implements Helper{
|
|||||||
* @param pos
|
* @param pos
|
||||||
* @return
|
* @return
|
||||||
*/
|
*/
|
||||||
protected static Optional<Tuple<Float, Float>> reachableCenter(BlockPos pos) {
|
protected static Optional<Rotation> reachableCenter(BlockPos pos) {
|
||||||
Tuple<Float, Float> rotation = Utils.calcRotationFromVec3d(mc.player.getPositionEyes(1.0F),
|
Rotation rotation = Utils.calcRotationFromVec3d(mc.player.getPositionEyes(1.0F),
|
||||||
Utils.calcCenterFromCoords(pos, mc.world));
|
Utils.calcCenterFromCoords(pos, mc.world));
|
||||||
RayTraceResult result = raytraceTowards(rotation);
|
RayTraceResult result = raytraceTowards(rotation);
|
||||||
if(result != null
|
if(result != null
|
||||||
|
@ -7,7 +7,7 @@ import baritone.bot.pathing.movement.MovementState.MovementStatus;
|
|||||||
import baritone.bot.utils.BlockStateInterface;
|
import baritone.bot.utils.BlockStateInterface;
|
||||||
import baritone.bot.utils.Helper;
|
import baritone.bot.utils.Helper;
|
||||||
import baritone.bot.utils.ToolSet;
|
import baritone.bot.utils.ToolSet;
|
||||||
import net.minecraft.util.Tuple;
|
import baritone.bot.utils.*;
|
||||||
import net.minecraft.util.math.BlockPos;
|
import net.minecraft.util.math.BlockPos;
|
||||||
import net.minecraft.util.math.Vec3d;
|
import net.minecraft.util.math.Vec3d;
|
||||||
|
|
||||||
@ -132,12 +132,11 @@ public abstract class Movement implements Helper, MovementHelper {
|
|||||||
if (state.getStatus() == MovementStatus.WAITING) {
|
if (state.getStatus() == MovementStatus.WAITING) {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
Optional<BlockPos> cruftPos;
|
for(BlockPos blockPos : positionsToBreak) {
|
||||||
for (BlockPos blockPos : positionsToBreak) {
|
if(MovementHelper.canWalkThrough(blockPos, BlockStateInterface.get(blockPos))) {
|
||||||
if (MovementHelper.canWalkThrough(blockPos, BlockStateInterface.get(blockPos))) {
|
Optional<Rotation> reachable = LookBehaviorUtils.reachable(blockPos);
|
||||||
Optional<Tuple<Float, Float>> reachable = LookBehaviorUtils.reachable(blockPos);
|
|
||||||
reachable.ifPresent(rotation -> {
|
reachable.ifPresent(rotation -> {
|
||||||
state.setTarget(new MovementState.MovementTarget())
|
state.setTarget(new MovementState.MovementTarget(Optional.empty(), reachable));
|
||||||
state.setInput(Input.CLICK_LEFT, true);
|
state.setInput(Input.CLICK_LEFT, true);
|
||||||
});
|
});
|
||||||
if (reachable.isPresent())
|
if (reachable.isPresent())
|
||||||
|
@ -39,9 +39,9 @@ public class MovementState {
|
|||||||
*/
|
*/
|
||||||
public Optional<Rotation> rotation;
|
public Optional<Rotation> rotation;
|
||||||
|
|
||||||
public MovementTarget(Vec3d position, Rotation rotation) {
|
public MovementTarget(Optional<Vec3d> position, Optional<Rotation> rotation) {
|
||||||
this.position = Optional.of(position);
|
this.position = position;
|
||||||
this.rotation = Optional.of(rotation);
|
this.rotation = rotation;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -25,11 +25,11 @@ public final class Utils {
|
|||||||
* @param dest
|
* @param dest
|
||||||
* @return Rotation Tuple {@link LookBehavior#target}
|
* @return Rotation Tuple {@link LookBehavior#target}
|
||||||
*/
|
*/
|
||||||
public static Tuple<Float, Float> calcRotationFromVec3d(Vec3d orig, Vec3d dest) {
|
public static Rotation calcRotationFromVec3d(Vec3d orig, Vec3d dest) {
|
||||||
double yaw = Math.atan2(orig.x - dest.x, -orig.z + dest.z);
|
double yaw = Math.atan2(orig.x - dest.x, -orig.z + dest.z);
|
||||||
double dist = Math.sqrt((orig.x - dest.x) * (orig.x - dest.x) + (-orig.z + dest.z) * (-orig.z + dest.z));
|
double dist = Math.sqrt((orig.x - dest.x) * (orig.x - dest.x) + (-orig.z + dest.z) * (-orig.z + dest.z));
|
||||||
double pitch = Math.atan2(orig.y - dest.y, dist);
|
double pitch = Math.atan2(orig.y - dest.y, dist);
|
||||||
return new Tuple<>((float) (yaw * 180 / Math.PI),
|
return new Rotation((float) (yaw * 180 / Math.PI),
|
||||||
(float) (pitch * 180 / Math.PI));
|
(float) (pitch * 180 / Math.PI));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user