2019-12-19 20:04:08 +01:00
|
|
|
class_name GSTSteeringBehavior
|
2020-01-28 00:31:10 +01:00
|
|
|
# Base class for all steering behaviors.
|
|
|
|
#
|
|
|
|
# Steering behaviors calculate the linear and the angular acceleration to be
|
|
|
|
# to the agent that owns them.
|
|
|
|
#
|
|
|
|
# The `calculate_steering` function is the entry point for all behaviors.
|
|
|
|
# Individual steering behaviors encapsulate the steering logic.
|
2019-12-19 20:04:08 +01:00
|
|
|
|
|
|
|
|
2020-01-28 00:31:10 +01:00
|
|
|
# If `false`, all calculations return zero amounts of acceleration.
|
2020-01-16 09:44:44 +01:00
|
|
|
var enabled := true
|
2020-01-28 00:31:10 +01:00
|
|
|
# The AI agent on which the steering behavior bases its calculations.
|
2019-12-19 20:04:08 +01:00
|
|
|
var agent: GSTSteeringAgent
|
|
|
|
|
|
|
|
|
|
|
|
func _init(agent: GSTSteeringAgent) -> void:
|
|
|
|
self.agent = agent
|
|
|
|
|
|
|
|
|
2020-01-28 00:31:10 +01:00
|
|
|
# Returns the `acceleration` modified with the behavior's desired amount of
|
|
|
|
# acceleration.
|
2019-12-19 20:04:08 +01:00
|
|
|
func calculate_steering(acceleration: GSTTargetAcceleration) -> GSTTargetAcceleration:
|
|
|
|
if enabled:
|
|
|
|
return _calculate_steering(acceleration)
|
|
|
|
else:
|
|
|
|
acceleration.set_zero()
|
|
|
|
return acceleration
|
|
|
|
|
|
|
|
|
|
|
|
func _calculate_steering(acceleration: GSTTargetAcceleration) -> GSTTargetAcceleration:
|
|
|
|
acceleration.set_zero()
|
|
|
|
return acceleration
|