mirror of
https://github.com/NoCheatPlus/NoCheatPlus.git
synced 2025-01-15 20:11:55 +01:00
Only allow a reduced max movement speed in water
This commit is contained in:
parent
81b4d7160e
commit
7945496e79
@ -53,6 +53,7 @@ public class MovingCheck extends Check {
|
|||||||
|
|
||||||
private final static double stepWidth = 0.6D;
|
private final static double stepWidth = 0.6D;
|
||||||
private final static double sneakStepWidth = 0.25D;
|
private final static double sneakStepWidth = 0.25D;
|
||||||
|
private final static double swimStepWidth = 0.4D;
|
||||||
|
|
||||||
private int ticksBeforeSummary = 100;
|
private int ticksBeforeSummary = 100;
|
||||||
|
|
||||||
@ -120,36 +121,16 @@ public class MovingCheck extends Check {
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
final boolean canFakeSneak = allowFakeSneak || plugin.hasPermission(player, PermissionData.PERMISSION_FAKESNEAK);
|
|
||||||
|
|
||||||
/**** Horizontal movement check START ****/
|
/**** Horizontal movement check START ****/
|
||||||
|
|
||||||
int violationLevelSneaking = -1;
|
final int onGroundFrom = playerIsOnGround(from, 0.0D);
|
||||||
|
|
||||||
if(!canFakeSneak && player.isSneaking()) {
|
int sn = getSneakingViolationLevel(combined, data, player);
|
||||||
violationLevelSneaking = limitCheck(combined - (data.horizFreedom + sneakStepWidth));
|
int sw = getSwimmingViolationLevel(combined, data, onGroundFrom == MovingData.LIQUID);
|
||||||
if(violationLevelSneaking >= 0) {
|
int s = limitCheck(combined - (data.horizFreedom + stepWidth));
|
||||||
if(combined >= data.sneakingLastDistance)
|
|
||||||
data.sneakingFreedomCounter -= 2;
|
|
||||||
else
|
|
||||||
{
|
|
||||||
violationLevelSneaking = -1;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
data.sneakingLastDistance = combined;
|
// The maximum of the three values
|
||||||
}
|
int violationLevelHorizontal = sn > sw && sn > s ? sn : (sw > s ? sw : s);
|
||||||
|
|
||||||
if(violationLevelSneaking >= 0 && data.sneakingFreedomCounter > 0) {
|
|
||||||
violationLevelSneaking = -1;
|
|
||||||
}
|
|
||||||
else if(violationLevelSneaking < 0 && data.sneakingFreedomCounter < 10){
|
|
||||||
data.sneakingFreedomCounter += 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
int violationLevelHorizontal = limitCheck(combined - (data.horizFreedom + stepWidth));
|
|
||||||
|
|
||||||
violationLevelHorizontal = violationLevelHorizontal > violationLevelSneaking ? violationLevelHorizontal : violationLevelSneaking;
|
|
||||||
|
|
||||||
// Reduce horiz moving freedom with each event
|
// Reduce horiz moving freedom with each event
|
||||||
data.horizFreedom *= 0.9;
|
data.horizFreedom *= 0.9;
|
||||||
@ -163,8 +144,6 @@ public class MovingCheck extends Check {
|
|||||||
// The location we'd use as a new setback if there are no violations
|
// The location we'd use as a new setback if there are no violations
|
||||||
Location newSetBack = null;
|
Location newSetBack = null;
|
||||||
|
|
||||||
final int onGroundFrom = playerIsOnGround(from, 0.0D);
|
|
||||||
|
|
||||||
double limit = calculateVerticalLimit(data, onGroundFrom);
|
double limit = calculateVerticalLimit(data, onGroundFrom);
|
||||||
|
|
||||||
// Handle 4 distinct cases: Walk, Jump, Land, Fly
|
// Handle 4 distinct cases: Walk, Jump, Land, Fly
|
||||||
@ -254,6 +233,67 @@ public class MovingCheck extends Check {
|
|||||||
statisticTotalEvents++;
|
statisticTotalEvents++;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
private int getSneakingViolationLevel(final double combined, final MovingData data, final Player player) {
|
||||||
|
|
||||||
|
final boolean canFakeSneak = allowFakeSneak || plugin.hasPermission(player, PermissionData.PERMISSION_FAKESNEAK);
|
||||||
|
int violationLevelSneaking = -1;
|
||||||
|
|
||||||
|
if(!canFakeSneak) {
|
||||||
|
if(player.isSneaking()) {
|
||||||
|
violationLevelSneaking = limitCheck(combined - (data.horizFreedom + sneakStepWidth));
|
||||||
|
if(violationLevelSneaking >= 0) {
|
||||||
|
if(combined >= data.sneakingLastDistance * 0.9)
|
||||||
|
data.sneakingFreedomCounter -= 2;
|
||||||
|
else
|
||||||
|
{
|
||||||
|
violationLevelSneaking = -1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
data.sneakingLastDistance = combined;
|
||||||
|
}
|
||||||
|
|
||||||
|
if(violationLevelSneaking >= 0 && data.sneakingFreedomCounter > 0) {
|
||||||
|
violationLevelSneaking = -1;
|
||||||
|
}
|
||||||
|
else if(violationLevelSneaking < 0 && data.sneakingFreedomCounter < 10){
|
||||||
|
data.sneakingFreedomCounter += 1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return violationLevelSneaking;
|
||||||
|
}
|
||||||
|
|
||||||
|
private int getSwimmingViolationLevel( final double combined, final MovingData data, final boolean isSwimming) {
|
||||||
|
|
||||||
|
int violationLevelSwimming = -1;
|
||||||
|
final double limit = data.horizFreedom + swimStepWidth;
|
||||||
|
|
||||||
|
if(isSwimming) {
|
||||||
|
violationLevelSwimming = limitCheck(combined - limit);
|
||||||
|
if(violationLevelSwimming >= 0) {
|
||||||
|
if(combined >= data.swimmingLastDistance * 0.9)
|
||||||
|
data.swimmingFreedomCounter -= 2;
|
||||||
|
else
|
||||||
|
{
|
||||||
|
violationLevelSwimming = -1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
data.swimmingLastDistance = combined;
|
||||||
|
}
|
||||||
|
|
||||||
|
if(violationLevelSwimming >= 0 && data.swimmingFreedomCounter > 0) {
|
||||||
|
violationLevelSwimming = -1;
|
||||||
|
}
|
||||||
|
else if(violationLevelSwimming < 0 && data.swimmingFreedomCounter < 10){
|
||||||
|
data.swimmingFreedomCounter += 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
return violationLevelSwimming;
|
||||||
|
}
|
||||||
|
|
||||||
private double calculateVerticalLimit(final MovingData data, final int onGroundFrom) {
|
private double calculateVerticalLimit(final MovingData data, final int onGroundFrom) {
|
||||||
|
|
||||||
// A halfway lag-resistant method of allowing vertical acceleration without allowing blatant cheating
|
// A halfway lag-resistant method of allowing vertical acceleration without allowing blatant cheating
|
||||||
@ -524,7 +564,7 @@ public class MovingCheck extends Check {
|
|||||||
// check in what kind of block the player is standing "in"
|
// check in what kind of block the player is standing "in"
|
||||||
result = types[w.getBlockTypeIdAt(lowerX, Y, lowerZ)] | types[w.getBlockTypeIdAt(upperX, Y, lowerZ)] |
|
result = types[w.getBlockTypeIdAt(lowerX, Y, lowerZ)] | types[w.getBlockTypeIdAt(upperX, Y, lowerZ)] |
|
||||||
types[w.getBlockTypeIdAt(lowerX, Y, higherZ)] | types[w.getBlockTypeIdAt(upperX, Y, higherZ)];
|
types[w.getBlockTypeIdAt(lowerX, Y, higherZ)] | types[w.getBlockTypeIdAt(upperX, Y, higherZ)];
|
||||||
|
|
||||||
if((result & MovingData.SOLID) != 0) {
|
if((result & MovingData.SOLID) != 0) {
|
||||||
// return standing
|
// return standing
|
||||||
return MovingData.SOLID;
|
return MovingData.SOLID;
|
||||||
@ -542,6 +582,11 @@ public class MovingCheck extends Check {
|
|||||||
// return standing
|
// return standing
|
||||||
return MovingData.SOLID;
|
return MovingData.SOLID;
|
||||||
}
|
}
|
||||||
|
// TODO : REMOVE THIS
|
||||||
|
else if((result & MovingData.LIQUID) != 0) {
|
||||||
|
// return swimming
|
||||||
|
return MovingData.LIQUID;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
// check if his head is "stuck" in an block
|
// check if his head is "stuck" in an block
|
||||||
|
@ -25,7 +25,9 @@ public class MovingData {
|
|||||||
public Level highestLogLevel = null;
|
public Level highestLogLevel = null;
|
||||||
public double maxYVelocity = 0.0D;
|
public double maxYVelocity = 0.0D;
|
||||||
public int sneakingFreedomCounter = 10;
|
public int sneakingFreedomCounter = 10;
|
||||||
|
public int swimmingFreedomCounter = 10;
|
||||||
public double sneakingLastDistance = 0.0D;
|
public double sneakingLastDistance = 0.0D;
|
||||||
|
public double swimmingLastDistance = 0.0D;
|
||||||
|
|
||||||
public int worldChanged = 0;
|
public int worldChanged = 0;
|
||||||
public boolean respawned = false;
|
public boolean respawned = false;
|
||||||
@ -36,6 +38,8 @@ public class MovingData {
|
|||||||
|
|
||||||
public Location teleportInitializedByMe = null;
|
public Location teleportInitializedByMe = null;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
// Block types that may need to be treated specially
|
// Block types that may need to be treated specially
|
||||||
public static final int NONSOLID = 0; // 0x00000000
|
public static final int NONSOLID = 0; // 0x00000000
|
||||||
public static final int SOLID = 1; // 0x00000001
|
public static final int SOLID = 1; // 0x00000001
|
||||||
|
Loading…
Reference in New Issue
Block a user