mirror of
https://github.com/NoCheatPlus/NoCheatPlus.git
synced 2025-01-28 02:11:22 +01:00
Sharpen maximum jump distance.
This commit is contained in:
parent
eb4c537e65
commit
5a76b22ef6
@ -261,7 +261,7 @@ public class SurvivalFly extends Check {
|
|||||||
// else vAllowedDistance = climbSpeed;
|
// else vAllowedDistance = climbSpeed;
|
||||||
// vDistanceAboveLimit = Math.abs(yDistance) - vAllowedDistance;
|
// vDistanceAboveLimit = Math.abs(yDistance) - vAllowedDistance;
|
||||||
// if (vDistanceAboveLimit > 0) tags.add("vclimb");
|
// if (vDistanceAboveLimit > 0) tags.add("vclimb");
|
||||||
final double jumpHeight = 1.45 + (data.jumpAmplifier > 0 ? (0.5 + data.jumpAmplifier - 1.0) : 0.0);
|
final double jumpHeight = 1.35 + (data.jumpAmplifier > 0 ? (0.6 + data.jumpAmplifier - 1.0) : 0.0);
|
||||||
// TODO: ladders are ground !
|
// TODO: ladders are ground !
|
||||||
if (yDistance > climbSpeed && !from.isOnGround(jumpHeight, 0D, 0D, BlockProperties.F_CLIMBABLE)){
|
if (yDistance > climbSpeed && !from.isOnGround(jumpHeight, 0D, 0D, BlockProperties.F_CLIMBABLE)){
|
||||||
// Ignore ladders. TODO: Check for false positives...
|
// Ignore ladders. TODO: Check for false positives...
|
||||||
@ -319,14 +319,14 @@ public class SurvivalFly extends Check {
|
|||||||
else{
|
else{
|
||||||
// Check traveled y-distance, orientation is air + jumping + velocity (as far as it gets).
|
// Check traveled y-distance, orientation is air + jumping + velocity (as far as it gets).
|
||||||
// TODO: Can it be easily transformed to a more accurate max. absolute height?
|
// TODO: Can it be easily transformed to a more accurate max. absolute height?
|
||||||
vAllowedDistance = (!(fromOnGround || data.noFallAssumeGround) && !toOnGround ? 1.45D : 1.35D) + data.verticalFreedom;
|
vAllowedDistance = 1.35D + data.verticalFreedom;
|
||||||
int maxJumpPhase;
|
int maxJumpPhase;
|
||||||
if (data.mediumLiftOff == MediumLiftOff.LIMIT_JUMP){
|
if (data.mediumLiftOff == MediumLiftOff.LIMIT_JUMP){
|
||||||
maxJumpPhase = 3;
|
maxJumpPhase = 3;
|
||||||
if (data.sfJumpPhase > 0) tags.add("limitjump");
|
if (data.sfJumpPhase > 0) tags.add("limitjump");
|
||||||
}
|
}
|
||||||
else if (data.jumpAmplifier > 0){
|
else if (data.jumpAmplifier > 0){
|
||||||
vAllowedDistance += 0.5 + data.jumpAmplifier - 1.0;
|
vAllowedDistance += 0.6 + data.jumpAmplifier - 1.0;
|
||||||
maxJumpPhase = (int) (9 + (data.jumpAmplifier - 1.0) * 6);
|
maxJumpPhase = (int) (9 + (data.jumpAmplifier - 1.0) * 6);
|
||||||
}
|
}
|
||||||
else maxJumpPhase = 6;
|
else maxJumpPhase = 6;
|
||||||
@ -594,8 +594,7 @@ public class SurvivalFly extends Check {
|
|||||||
|
|
||||||
if (yDistance >= 0){
|
if (yDistance >= 0){
|
||||||
// Half block step up.
|
// Half block step up.
|
||||||
if (yDistance <= 0.5 && hDistance < 0.5 && to.isOnGround()){
|
if (yDistance <= 0.5 && hDistance < 0.5 && setBackYDistance <= 1.3 + 0.1 * data.jumpAmplifier && to.isOnGround()){
|
||||||
// TODO: Also confine concerning hDist !
|
|
||||||
if (data.sfLastYDist < 0 || from.isOnGround(0.5 - Math.abs(yDistance))){
|
if (data.sfLastYDist < 0 || from.isOnGround(0.5 - Math.abs(yDistance))){
|
||||||
return applyWorkaround(player, from, true, data);
|
return applyWorkaround(player, from, true, data);
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user