diff options
Diffstat (limited to 'src/main/java/gregtech/api/util')
-rw-r--r-- | src/main/java/gregtech/api/util/GT_Utility.java | 19 |
1 files changed, 11 insertions, 8 deletions
diff --git a/src/main/java/gregtech/api/util/GT_Utility.java b/src/main/java/gregtech/api/util/GT_Utility.java index 62c4498927..1e88d0b75d 100644 --- a/src/main/java/gregtech/api/util/GT_Utility.java +++ b/src/main/java/gregtech/api/util/GT_Utility.java @@ -4965,18 +4965,21 @@ public class GT_Utility { return 0; } - public static MovingObjectPosition getPlayerLookingTarget() { - // Basically copied from waila, thanks Caedis for such challenge - Minecraft mc = Minecraft.getMinecraft(); - EntityLivingBase viewpoint = mc.renderViewEntity; - if (viewpoint == null) return null; - - float reachDistance = mc.playerController.getBlockReachDistance(); - Vec3 posVec = viewpoint.getPosition(0); + public static MovingObjectPosition getPlayerLookingTarget(EntityPlayer viewpoint) { + double reachDistance = viewpoint instanceof EntityPlayerMP mp ? mp.theItemInWorldManager.getBlockReachDistance() + : getClientReachDistance(); + Vec3 posVec = Vec3.createVectorHelper( + viewpoint.posX, + viewpoint.posY + (viewpoint.getEyeHeight() - viewpoint.getDefaultEyeHeight()), + viewpoint.posZ); Vec3 lookVec = viewpoint.getLook(0); Vec3 modifiedPosVec = posVec .addVector(lookVec.xCoord * reachDistance, lookVec.yCoord * reachDistance, lookVec.zCoord * reachDistance); return viewpoint.worldObj.rayTraceBlocks(posVec, modifiedPosVec); } + + public static float getClientReachDistance() { + return Minecraft.getMinecraft().playerController.getBlockReachDistance(); + } } |