mirror of
https://github.com/ClassiCube/ClassiCube.git
synced 2025-01-24 10:02:08 -05:00
Fix water/lava physics being more difficult than classicube. (Thanks venom983)
This commit is contained in:
parent
f5fd0c9853
commit
4e080a63c1
2 changed files with 23 additions and 7 deletions
|
@ -45,6 +45,7 @@
|
|||
<DefineConstants>TRACE;</DefineConstants>
|
||||
<BaseIntermediateOutputPath>obj\</BaseIntermediateOutputPath>
|
||||
<StartAction>Project</StartAction>
|
||||
<StartArguments>wwwf 4f34 127.0.0.1 25564</StartArguments>
|
||||
</PropertyGroup>
|
||||
<PropertyGroup Condition=" '$(Configuration)' == 'Debug_D3D' ">
|
||||
<PlatformTarget>AnyCPU</PlatformTarget>
|
||||
|
|
|
@ -134,6 +134,7 @@ namespace ClassicalSharp {
|
|||
}
|
||||
|
||||
bool useLiquidGravity = false; // used by BlockDefinitions.
|
||||
bool canLiquidJump = true;
|
||||
void UpdateVelocityYState() {
|
||||
if( flying || noClip ) {
|
||||
Velocity.Y = 0; // eliminate the effect of gravity
|
||||
|
@ -149,25 +150,39 @@ namespace ClassicalSharp {
|
|||
if( jumping ) {
|
||||
if( TouchesAnyWater() || TouchesAnyLava() ) {
|
||||
BoundingBox bounds = CollisionBounds;
|
||||
bounds.Min.Y += 1;
|
||||
bounds.Max.Y = bounds.Min.Y;
|
||||
bool feetInWater = TouchesAny( bounds, StandardLiquid );
|
||||
bool pastJumpPoint = feetInWater && (Position.Y % 1 >= 0.4);
|
||||
|
||||
bool isSolid = TouchesAny( bounds,
|
||||
b => info.CollideType[b] != BlockCollideType.WalkThrough || b == (byte)Block.Rope );
|
||||
bool pastJumpPoint = Position.Y % 1 >= 0.4;
|
||||
if( isSolid || !pastJumpPoint )
|
||||
if( !pastJumpPoint ) {
|
||||
canLiquidJump = true;
|
||||
Velocity.Y += speeding ? 0.08f : 0.04f;
|
||||
else if( (collideX || collideZ) && !isSolid && pastJumpPoint )
|
||||
Velocity.Y += 0.10f;
|
||||
} else if( pastJumpPoint ) {
|
||||
// either A) jump bob in water B) climb up solid on side
|
||||
if( canLiquidJump || (collideX || collideZ) )
|
||||
Velocity.Y += 0.10f;
|
||||
canLiquidJump = false;
|
||||
}
|
||||
} else if( useLiquidGravity ) {
|
||||
Velocity.Y += speeding ? 0.08f : 0.04f;
|
||||
canLiquidJump = false;
|
||||
} else if( TouchesAnyRope() ) {
|
||||
Velocity.Y += speeding ? 0.15f : 0.10f;
|
||||
canLiquidJump = false;
|
||||
} else if( onGround ) {
|
||||
Velocity.Y = speeding ? jumpVel * 2 : jumpVel;
|
||||
canLiquidJump = false;
|
||||
}
|
||||
} else {
|
||||
canLiquidJump = false;
|
||||
}
|
||||
}
|
||||
|
||||
bool StandardLiquid( byte block ) {
|
||||
return block == (byte)Block.Water || block == (byte)Block.StillWater ||
|
||||
block == (byte)Block.Lava || block == (byte)Block.StillLava;
|
||||
}
|
||||
|
||||
static Vector3 waterDrag = new Vector3( 0.8f, 0.8f, 0.8f ),
|
||||
lavaDrag = new Vector3( 0.5f, 0.5f, 0.5f ),
|
||||
ropeDrag = new Vector3( 0.5f, 0.85f, 0.5f ),
|
||||
|
|
Loading…
Add table
Reference in a new issue