diff --git a/code/pawn/PawnController.Wallrunning.cs b/code/pawn/PawnController.Wallrunning.cs index ffdbd72..fd4d3ef 100644 --- a/code/pawn/PawnController.Wallrunning.cs +++ b/code/pawn/PawnController.Wallrunning.cs @@ -68,6 +68,9 @@ bool CanWallrun( WallRunTrace traceWall ) if ( Wallrunning == WallRunSide.Right && traceWall.side != WallRunSide.Right ) return false; + if ( !IsWallRunning() && (Entity.Velocity * 0.5f).WithZ( 0 ).Length < 100f ) + return false; + if ( IsWallRunning() && Entity.Velocity.WithZ( 0 ).Length < 100f ) return false; diff --git a/code/pawn/PawnController.cs b/code/pawn/PawnController.cs index dedd53e..fb3683e 100644 --- a/code/pawn/PawnController.cs +++ b/code/pawn/PawnController.cs @@ -7,7 +7,7 @@ namespace RunnerVision; public partial class PawnController : EntityComponent { public int StepSize => 26; - public int GroundAngle => 100; + public int GroundAngle => 200; public int JumpSpeed => 300; public float Gravity => 800f; public float StartingSpeed => 1000f; @@ -87,7 +87,6 @@ public void Simulate( IClient cl ) UpdateMaxSpeed( moveVector ); AdjustSharpTurn( moveVector ); - UpdateMoveHelper( groundEntity ); if ( groundEntity.IsValid() ) { @@ -96,6 +95,12 @@ public void Simulate( IClient cl ) InitiateLandingOnFloor(); } + } + + UpdateMoveHelper( groundEntity ); + + if (Grounded) + { DoMovement( moveVector ); } else