Add jumping
This commit is contained in:
parent
326ba481f8
commit
c7a4bf7e81
@ -1057,9 +1057,10 @@ size = Vector3(87.9724, 96.1174, 91.8458)
|
||||
transform = Transform3D(1, 0, 0, 0, 1, 0, 0, 0, 1, 0.0415039, 58.3319, 0.0198975)
|
||||
size = Vector3(43.3174, 26.5295, 43.4319)
|
||||
|
||||
[node name="Player" type="CharacterBody3D" parent="."]
|
||||
[node name="Player" type="CharacterBody3D" parent="." node_paths=PackedStringArray("Eye")]
|
||||
transform = Transform3D(1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 4.51124, 0)
|
||||
script = ExtResource("10_87t4r")
|
||||
Eye = NodePath("PlayerEyeCamera")
|
||||
|
||||
[node name="PlayerEyeCamera" type="Camera3D" parent="Player"]
|
||||
transform = Transform3D(1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 1.7, 0)
|
||||
|
@ -7,33 +7,48 @@ namespace Gmtk24 {
|
||||
[Export]
|
||||
public float SprintMultiplier = 1.5f;
|
||||
[Export]
|
||||
public float JumpVelocity = 10;
|
||||
[Export]
|
||||
public float JumpBufferLengthSeconds = 0.2f;
|
||||
[Export]
|
||||
public Node3D Eye;
|
||||
|
||||
private float CurrentYaw = 0;
|
||||
private float CurrentPitch = 0;
|
||||
private float JumpBufferTime = 0;
|
||||
|
||||
public override void _Ready() {
|
||||
// Input.MouseMode = Input.MouseModeEnum.Captured;
|
||||
Input.MouseMode = Input.MouseModeEnum.Captured;
|
||||
}
|
||||
|
||||
public override void _Input(InputEvent @event) {
|
||||
public override void _UnhandledInput(InputEvent @event) {
|
||||
if (@event is InputEventMouseMotion ev && Input.MouseMode == Input.MouseModeEnum.Captured) {
|
||||
var cameraSensitivityX = 3f; // FIXME: use camera sensitivity and invert settings
|
||||
var cameraSensitivityY = 3f; // FIXME: use camera sensitivity and invert settings
|
||||
Eye.RotateY(ev.Relative.X * 0.01f * cameraSensitivityX);
|
||||
CurrentPitch += ev.Relative.Y * 0.01f * cameraSensitivityY;
|
||||
var cameraSensitivityX = 2f; // FIXME: use camera sensitivity and invert settings
|
||||
var cameraSensitivityY = 2f; // FIXME: use camera sensitivity and invert settings
|
||||
var mouseMultiplier = 0.0003f;
|
||||
CurrentYaw -= ev.Relative.X * mouseMultiplier * cameraSensitivityX;
|
||||
CurrentPitch -= ev.Relative.Y * mouseMultiplier * cameraSensitivityY;
|
||||
GetViewport().SetInputAsHandled();
|
||||
}
|
||||
}
|
||||
|
||||
public override void _Process(double delta) {
|
||||
var yawInput = Input.GetActionStrength("look_left") - Input.GetActionStrength("look_right");
|
||||
var pitchInput = Input.GetActionStrength("look_up") - Input.GetActionStrength("look_down");
|
||||
var cameraSensitivityX = 3f; // FIXME: use camera sensitivity and invert settings
|
||||
var cameraSensitivityY = 3f; // FIXME: use camera sensitivity and invert settings
|
||||
Eye.RotateY(yawInput * cameraSensitivityX * (float)delta);
|
||||
var cameraSensitivityX = 2f; // FIXME: use camera sensitivity and invert settings
|
||||
var cameraSensitivityY = 2f; // FIXME: use camera sensitivity and invert settings
|
||||
CurrentYaw += yawInput * cameraSensitivityX * (float)delta;
|
||||
if (Eye != null) {
|
||||
CurrentPitch += pitchInput * cameraSensitivityY * (float)delta;
|
||||
CurrentPitch = Mathf.Clamp(CurrentPitch, -Mathf.Pi / 2, Mathf.Pi / 2);
|
||||
Eye.Quaternion = new Quaternion(Vector3.Right, CurrentPitch);
|
||||
CurrentPitch = Mathf.Clamp(CurrentPitch, -Mathf.Pi * 0.49f, Mathf.Pi * 0.49f);
|
||||
}
|
||||
Eye.Quaternion = new Quaternion(Vector3.Up, CurrentYaw) * new Quaternion(Vector3.Right, CurrentPitch);
|
||||
|
||||
if (JumpBufferTime > 0) {
|
||||
JumpBufferTime -= (float)delta;
|
||||
}
|
||||
if (Input.IsActionJustPressed("jump")) {
|
||||
JumpBufferTime = JumpBufferLengthSeconds;
|
||||
}
|
||||
}
|
||||
|
||||
@ -47,11 +62,17 @@ namespace Gmtk24 {
|
||||
if (Input.IsActionPressed("sprint")) {
|
||||
move *= SprintMultiplier;
|
||||
}
|
||||
|
||||
Vector3 vel = Velocity;
|
||||
vel.X = move.X;
|
||||
vel.Z = move.Z;
|
||||
vel += GetGravity() * (float)delta;
|
||||
if (IsOnFloor() && JumpBufferTime > 0) {
|
||||
JumpBufferTime = 0;
|
||||
vel += Vector3.Up * JumpVelocity;
|
||||
}
|
||||
Velocity = vel;
|
||||
|
||||
MoveAndSlide();
|
||||
}
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user