SlimeoosOdyssey/godot/Player.gd

59 lines
1.9 KiB
GDScript3
Raw Normal View History

2023-08-18 20:59:38 -06:00
extends CharacterBody3D
const SPEED = 5.0
const JUMP_VELOCITY = 4.5
2023-08-18 23:15:14 -06:00
@export var horiz_sens = 0.25
@export var vert_sens = 0.25
2023-08-18 20:59:38 -06:00
2023-08-19 14:49:36 -06:00
var holding: WeakRef = weakref(null)
2023-08-18 20:59:38 -06:00
# Get the gravity from the project settings to be synced with RigidBody nodes.
var gravity = ProjectSettings.get_setting("physics/3d/default_gravity")
2023-08-18 21:27:39 -06:00
func _ready():
Input.mouse_mode = Input.MOUSE_MODE_CAPTURED
2023-08-19 12:27:23 -06:00
$CameraMount.global_rotation.x = clampf($CameraMount.global_rotation.x, deg_to_rad(-60), deg_to_rad(-11))
2023-08-18 23:15:14 -06:00
2023-08-19 11:58:20 -06:00
func _process(_delta):
2023-08-18 23:15:14 -06:00
# Brings your mouse out of the window if you press escape. Add pause screen function here?
if Input.is_action_pressed("ui_cancel"):
Input.mouse_mode = Input.MOUSE_MODE_VISIBLE
2023-08-18 21:27:39 -06:00
func _input(event):
# Handle the rotation of the camera using mouse movement.
if event is InputEventMouseMotion:
2023-08-18 23:15:14 -06:00
rotate_y(deg_to_rad(-event.relative.x * horiz_sens))
2023-08-19 12:27:23 -06:00
$CameraMount.rotate_x(deg_to_rad(-event.relative.y * vert_sens))
$grape_man.rotate_y(deg_to_rad(event.relative.x * horiz_sens))
2023-08-19 11:51:06 -06:00
$CameraMount.global_rotation.x = clampf($CameraMount.global_rotation.x, deg_to_rad(-60), deg_to_rad(-11))
2023-08-19 14:49:36 -06:00
2023-08-18 20:59:38 -06:00
func _physics_process(delta):
# Add the gravity.
if not is_on_floor():
velocity.y -= gravity * delta
# Get the input direction and handle the movement/deceleration.
# As good practice, you should replace UI actions with custom gameplay actions.
var input_dir = Input.get_vector("ui_left", "ui_right", "ui_up", "ui_down")
var direction = (transform.basis * Vector3(input_dir.x, 0, input_dir.y)).normalized()
if direction:
velocity.x = direction.x * SPEED
velocity.z = direction.z * SPEED
2023-08-19 12:27:23 -06:00
$grape_man.look_at(Vector3(
$grape_man.global_position.x - velocity.x,
$grape_man.global_position.y,
$grape_man.global_position.z - velocity.z,
))
2023-08-19 14:49:36 -06:00
$grape_man.walk_empty()
2023-08-18 20:59:38 -06:00
else:
2023-08-19 14:49:36 -06:00
$grape_man.idle_empty()
2023-08-18 20:59:38 -06:00
velocity.x = move_toward(velocity.x, 0, SPEED)
velocity.z = move_toward(velocity.z, 0, SPEED)
move_and_slide()