tiny_plane.gd 1.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061
  1. class_name TinyPlane
  2. extends RigidBody3D
  3. @export var thrust_power: float = 10000.0
  4. @export var turn_to_torque: float = 2000.0
  5. @export var move_to_pitch: float = 4000.0
  6. @export var lift: float = 10000.0
  7. var target_torque: float = 0.0
  8. var target_pitch: float = 0.0
  9. var target_rotation := Vector3.ZERO
  10. var target_thrust := Vector3.ZERO
  11. var _current_commander: LocalInput = null
  12. func trigger_thrust(activate: bool) -> void:
  13. if activate:
  14. target_thrust = Vector3.FORWARD * thrust_power + Vector3.UP * lift
  15. else:
  16. target_thrust = Vector3.ZERO
  17. func trigger_direction(dir: Vector2) -> void:
  18. target_torque = -dir.x * turn_to_torque
  19. target_pitch = -dir.y * move_to_pitch
  20. ## Make the vehicle responds to driver commands
  21. func drive_with(commander: LocalInput) -> void:
  22. commander.dir_changed.connect(_on_dir_changed)
  23. commander.main_action.connect(_on_main_action)
  24. _current_commander = commander
  25. func get_out() -> void:
  26. _current_commander.dir_changed.disconnect(_on_dir_changed)
  27. _current_commander.main_action.disconnect(_on_main_action)
  28. func _physics_process(delta: float) -> void:
  29. _apply_plane_rotation()
  30. _apply_plane_thrust()
  31. func _apply_plane_rotation() -> void:
  32. var torque: Vector3 = transform.basis * Vector3(target_pitch, 0.0, target_torque)
  33. apply_torque(torque)
  34. func _apply_plane_thrust() -> void:
  35. var force: Vector3 = transform.basis * target_thrust
  36. apply_central_force(force)
  37. func _on_dir_changed(dir: Vector2) -> void:
  38. trigger_direction(dir)
  39. func _on_main_action(pressed: bool) -> void:
  40. trigger_thrust(pressed)