2020-01-02 23:42:41 +01:00
|
|
|
# Calculates angular acceleration to rotate a target to face its target's position.
|
|
|
|
# The acceleration will attempt to arrive with zero remaining angular velocity.
|
2020-01-29 05:56:10 +01:00
|
|
|
class_name GSTFace
|
|
|
|
extends GSTMatchOrientation
|
2019-12-19 20:04:08 +01:00
|
|
|
|
|
|
|
|
|
|
|
func _init(agent: GSTSteeringAgent, target: GSTAgentLocation).(agent, target) -> void:
|
|
|
|
pass
|
|
|
|
|
|
|
|
|
|
|
|
func _face(acceleration: GSTTargetAcceleration, target_position: Vector3) -> GSTTargetAcceleration:
|
2020-01-16 09:44:44 +01:00
|
|
|
var to_target := target_position - agent.position
|
|
|
|
var distance_squared := to_target.length_squared()
|
2019-12-19 20:04:08 +01:00
|
|
|
|
|
|
|
if distance_squared < agent.zero_linear_speed_threshold:
|
|
|
|
acceleration.set_zero()
|
|
|
|
return acceleration
|
|
|
|
else:
|
2020-01-29 16:04:47 +01:00
|
|
|
var orientation = GSTUtils.vector3_to_angle(to_target)
|
2019-12-19 20:04:08 +01:00
|
|
|
return _match_orientation(acceleration, orientation)
|
|
|
|
|
|
|
|
|
|
|
|
func _calculate_steering(acceleration: GSTTargetAcceleration) -> GSTTargetAcceleration:
|
|
|
|
return _face(acceleration, target.position)
|