2021-10-11 11:30:59 +02:00
|
|
|
# meta-description: Classic movement for gravity games (platformer, ...)
|
|
|
|
|
|
|
|
extends _BASE_
|
|
|
|
|
|
|
|
const SPEED: float = 300.0
|
2022-02-07 11:46:30 +01:00
|
|
|
const JUMP_VELOCITY: float = -400.0
|
2021-10-11 11:30:59 +02:00
|
|
|
|
|
|
|
# Get the gravity from the project settings to be synced with RigidDynamicBody nodes.
|
|
|
|
var gravity: int = ProjectSettings.get_setting("physics/2d/default_gravity")
|
|
|
|
|
|
|
|
|
|
|
|
func _physics_process(delta: float) -> void:
|
|
|
|
# Add the gravity.
|
|
|
|
if not is_on_floor():
|
2022-02-21 23:08:57 +01:00
|
|
|
velocity.y += gravity * delta
|
2021-10-11 11:30:59 +02:00
|
|
|
|
|
|
|
# Handle Jump.
|
|
|
|
if Input.is_action_just_pressed("ui_accept") and is_on_floor():
|
2022-02-21 23:08:57 +01:00
|
|
|
velocity.y = JUMP_VELOCITY
|
2021-10-11 11:30:59 +02:00
|
|
|
|
|
|
|
# Get the input direction and handle the movement/deceleration.
|
|
|
|
# As good practice, you should replace UI actions with custom gameplay actions.
|
|
|
|
var direction := Input.get_axis("ui_left", "ui_right")
|
|
|
|
if direction:
|
2022-02-21 23:08:57 +01:00
|
|
|
velocity.x = direction * SPEED
|
2021-10-11 11:30:59 +02:00
|
|
|
else:
|
2022-02-21 23:08:57 +01:00
|
|
|
velocity.x = move_toward(velocity.x, 0, SPEED)
|
2021-10-11 11:30:59 +02:00
|
|
|
|
|
|
|
move_and_slide()
|