mirror of
https://github.com/NoCheatPlus/NoCheatPlus.git
synced 2025-01-18 21:41:21 +01:00
Tweak NoFall.
For maximum and minimum y also consider player.getLocation(). For the most normal cases it does not matter, but it can matter.
This commit is contained in:
parent
b531091e7f
commit
dd74accab8
@ -87,14 +87,18 @@ public class NoFall extends Check {
|
|||||||
* the to
|
* the to
|
||||||
*/
|
*/
|
||||||
public void check(final Player player, final PlayerLocation from, final PlayerLocation to, final MovingData data, final MovingConfig cc) {
|
public void check(final Player player, final PlayerLocation from, final PlayerLocation to, final MovingData data, final MovingConfig cc) {
|
||||||
|
|
||||||
// Reset the on ground properties only if necessary.
|
final double fromY = from.getY();
|
||||||
if (from.getY() > to.getY()){
|
final double toY = to.getY();
|
||||||
if (from.getyOnGround() != cc.noFallyOnGround && from.getY() - from.getBlockY() < cc.noFallyOnGround)
|
final double yDiff = toY - fromY;
|
||||||
from.setyOnGround(cc.noFallyOnGround);
|
|
||||||
if (to.getyOnGround() != cc.noFallyOnGround && to.getY() - to.getBlockY() < cc.noFallyOnGround)
|
// Adapt yOnGround if necessary (sf uses another setting).
|
||||||
to.setyOnGround(cc.noFallyOnGround);
|
if (yDiff < 0) {
|
||||||
}
|
// In fact this is somewhat heuristic, but it seems to work well.
|
||||||
|
// Missing on-ground seems to happen with running down pyramids rather.
|
||||||
|
if (from.getyOnGround() != cc.noFallyOnGround && fromY - from.getBlockY() < cc.noFallyOnGround) from.setyOnGround(cc.noFallyOnGround);
|
||||||
|
if (to.getyOnGround() != cc.noFallyOnGround && toY - to.getBlockY() < cc.noFallyOnGround) to.setyOnGround(cc.noFallyOnGround);
|
||||||
|
}
|
||||||
|
|
||||||
// TODO: Distinguish water depth vs. fall distance!
|
// TODO: Distinguish water depth vs. fall distance!
|
||||||
|
|
||||||
@ -105,18 +109,21 @@ public class NoFall extends Check {
|
|||||||
|
|
||||||
final EntityPlayer mcPlayer = ((CraftPlayer) player).getHandle();
|
final EntityPlayer mcPlayer = ((CraftPlayer) player).getHandle();
|
||||||
|
|
||||||
final double yDiff = to.getY() - from.getY();
|
|
||||||
// TODO: early returns (...)
|
// TODO: early returns (...)
|
||||||
|
|
||||||
|
final double pY = player.getLocation().getY();
|
||||||
|
final double minY = Math.min(fromY, Math.min(toY, pY));
|
||||||
|
|
||||||
if (fromReset){
|
if (fromReset){
|
||||||
// Just reset.
|
// Just reset.
|
||||||
data.clearNoFallData();
|
data.clearNoFallData();
|
||||||
}
|
}
|
||||||
else if (fromOnGround || data.noFallAssumeGround){
|
else if (fromOnGround || data.noFallAssumeGround){
|
||||||
// Check if to deal damage (fall back damage check).
|
// Check if to deal damage (fall back damage check).
|
||||||
if (cc.noFallDealDamage) handleOnGround(mcPlayer, data, from.getY(), cc);
|
if (cc.noFallDealDamage) handleOnGround(mcPlayer, data, minY, cc);
|
||||||
else{
|
else{
|
||||||
mcPlayer.fallDistance = Math.max(mcPlayer.fallDistance, Math.max(data.noFallFallDistance, (float) (data.noFallMaxY - from.getY())));
|
mcPlayer.fallDistance = Math.max(mcPlayer.fallDistance, Math.max(data.noFallFallDistance, (float) (data.noFallMaxY - minY)));
|
||||||
data.clearNoFallData();
|
data.clearNoFallData();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -127,9 +134,9 @@ public class NoFall extends Check {
|
|||||||
else if (toOnGround){
|
else if (toOnGround){
|
||||||
// Check if to deal damage.
|
// Check if to deal damage.
|
||||||
if (yDiff < 0) data.noFallFallDistance -= yDiff;
|
if (yDiff < 0) data.noFallFallDistance -= yDiff;
|
||||||
if (cc.noFallDealDamage) handleOnGround(mcPlayer, data, to.getY(), cc);
|
if (cc.noFallDealDamage) handleOnGround(mcPlayer, data, minY, cc);
|
||||||
else{
|
else{
|
||||||
mcPlayer.fallDistance = Math.max(mcPlayer.fallDistance, Math.max(data.noFallFallDistance, (float) (data.noFallMaxY - to.getY())));
|
mcPlayer.fallDistance = Math.max(mcPlayer.fallDistance, Math.max(data.noFallFallDistance, (float) (data.noFallMaxY - minY)));
|
||||||
data.clearNoFallData();
|
data.clearNoFallData();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -138,7 +145,8 @@ public class NoFall extends Check {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Set reference y for nofall (always).
|
// Set reference y for nofall (always).
|
||||||
data.noFallMaxY = Math.max(Math.max(from.getY(), to.getY()), data.noFallMaxY);
|
// TODO: Consider setting this before handleOnGround (at least for resetTo).
|
||||||
|
data.noFallMaxY = Math.max(Math.max(fromY, Math.max(toY, pY)), data.noFallMaxY);
|
||||||
|
|
||||||
// TODO: fall distance might be behind (!)
|
// TODO: fall distance might be behind (!)
|
||||||
// TODO: should be the data.noFallMaxY be counted in ?
|
// TODO: should be the data.noFallMaxY be counted in ?
|
||||||
|
Loading…
Reference in New Issue
Block a user