Jumping
This commit is contained in:
parent
8ce13c35a7
commit
676700ecfa
@ -1001,6 +1001,8 @@ MonoBehaviour:
|
||||
m_EditorClassIdentifier:
|
||||
maxSpeed: 10
|
||||
maxAcceleration: 10
|
||||
jumpHeight: 2
|
||||
maxAirJumps: 1
|
||||
--- !u!54 &1695436951
|
||||
Rigidbody:
|
||||
m_ObjectHideFlags: 0
|
||||
|
@ -6,11 +6,22 @@ public class MovingSphere : MonoBehaviour
|
||||
private float maxSpeed = 10f;
|
||||
|
||||
[SerializeField, Range(0f, 100f)]
|
||||
private float maxAcceleration = 10f;
|
||||
private float maxAcceleration = 10f, maxAirAcceleration = 1f;
|
||||
|
||||
[SerializeField, Range(0f, 10f)]
|
||||
float jumpHeight = 2f;
|
||||
|
||||
[SerializeField, Range(0, 5)]
|
||||
int maxAirJumps = 0;
|
||||
|
||||
private Rigidbody body;
|
||||
|
||||
private Vector3 desiredVelocity;
|
||||
private Vector3 desiredVelocity = new Vector3(0f, 0f, 0f);
|
||||
private bool desiredJump = false;
|
||||
|
||||
private bool onGround;
|
||||
private int jumpPhase;
|
||||
private Vector3 velocity;
|
||||
|
||||
private void Awake()
|
||||
{
|
||||
@ -24,14 +35,70 @@ public class MovingSphere : MonoBehaviour
|
||||
playerInput.y = Input.GetAxis("Vertical");
|
||||
playerInput = Vector2.ClampMagnitude(playerInput, 1f);
|
||||
desiredVelocity = new Vector3(playerInput.x, 0f, playerInput.y) * maxSpeed;
|
||||
|
||||
desiredJump |= Input.GetButtonDown("Jump");
|
||||
}
|
||||
|
||||
private void FixedUpdate()
|
||||
{
|
||||
var velocity = body.velocity;
|
||||
float maxSpeedChange = maxAcceleration * Time.deltaTime;
|
||||
UpdateState();
|
||||
|
||||
float acceleration = onGround ? maxAcceleration : maxAirAcceleration;
|
||||
float maxSpeedChange = acceleration * Time.deltaTime;
|
||||
velocity.x = Mathf.MoveTowards(velocity.x, desiredVelocity.x, maxSpeedChange);
|
||||
velocity.z = Mathf.MoveTowards(velocity.z, desiredVelocity.z, maxSpeedChange);
|
||||
body.velocity = velocity;
|
||||
|
||||
if (desiredJump)
|
||||
{
|
||||
desiredJump = false;
|
||||
Jump();
|
||||
}
|
||||
|
||||
body.velocity = velocity;
|
||||
|
||||
onGround = false;
|
||||
}
|
||||
|
||||
private void UpdateState()
|
||||
{
|
||||
velocity = body.velocity;
|
||||
if (onGround)
|
||||
{
|
||||
jumpPhase = 0;
|
||||
}
|
||||
}
|
||||
|
||||
private void OnCollisionEnter(Collision collision)
|
||||
{
|
||||
EvaluateCollision(collision);
|
||||
}
|
||||
|
||||
private void OnCollisionStay(Collision collision)
|
||||
{
|
||||
EvaluateCollision(collision);
|
||||
}
|
||||
|
||||
private void EvaluateCollision(Collision collision)
|
||||
{
|
||||
for (int i = 0; i < collision.contactCount; i++)
|
||||
{
|
||||
var normal = collision.GetContact(i).normal;
|
||||
onGround |= normal.y >= 0.9f;
|
||||
}
|
||||
}
|
||||
|
||||
private void Jump()
|
||||
{
|
||||
if (onGround || jumpPhase < maxAirJumps)
|
||||
{
|
||||
jumpPhase++;
|
||||
float jumpSpeed = Mathf.Sqrt(-2f * Physics.gravity.y * jumpHeight);
|
||||
if (velocity.y > 0f)
|
||||
{
|
||||
jumpSpeed = Mathf.Max(jumpSpeed - velocity.y, 0f);
|
||||
}
|
||||
velocity.y += jumpSpeed;
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
|
Reference in New Issue
Block a user