ai_behavior data:image/s3,"s3://crabby-images/8cfd9/8cfd975766c1339dadb9c73a349c926c8057e7cc" alt="code/datums/ai/ai_behavior.dm 2"
Abstract class for an action an AI can take. Can range from movement to grabbing a nearby weapon.
Vars | |
action_cooldown | Cooldown between actions performances, defaults to the value of CLICK_CD_MELEE because that seemed like a nice standard for the speed of AI behavior |
---|---|
behavior_flags | Flags for extra behavior |
required_distance | What distance you need to be from the target to perform the action. |
Procs | |
clear_movement_target | Clear the controller's movement target only if it was us who last set it |
finish_action | Called when the action is finished. This needs the same args as perform
besides the default ones. This should be used to clear up the blackboard of
any unnecessary or obsolete data, and update the state of the pawn if
necessary once we know whether or not the AI action was successful.
succeeded is TRUE or FALSE depending on whether
/datum/ai_behavior/proc/perform returns AI_BEHAVIOR_SUCCEEDED or
AI_BEHAVIOR_FAILED. |
get_cooldown | Returns the delay to use for this behavior in the moment. The default
behavior cooldown is CLICK_CD_MELEE , but can be customized; for example,
you may want a mob crawling through vents to move slowly and at a random
pace between pipes. |
perform | Called by the AI controller when this action is performed. This will
typically require consulting the blackboard for information on the specific
actions desired from this behavior, by passing the relevant blackboard data
keys to this proc. Returns a combination of AI_BEHAVIOR_DELAY or
[AI_BEHAVIOR_INSTANT], determining whether or not a cooldown occurs, and
AI_BEHAVIOR_SUCCEEDED or AI_BEHAVIOR_FAILED. The behavior's
finish_action proc is given TRUE or FALSE depending on whether or not the
return value of perform is marked as successful or unsuccessful. |
set_movement_target | Helper proc to ensure consistency in setting the source of the movement target |
setup | Called by the AI controller when first being added. Additional arguments depend on the behavior type. For example, if the behavior involves attacking a mob, you may require an argument naming the blackboard key which points to the target. Return FALSE to cancel. |
Var Details
action_cooldown data:image/s3,"s3://crabby-images/8cfd9/8cfd975766c1339dadb9c73a349c926c8057e7cc" alt="code/datums/ai/ai_behavior.dm 10"
Cooldown between actions performances, defaults to the value of CLICK_CD_MELEE because that seemed like a nice standard for the speed of AI behavior
behavior_flags data:image/s3,"s3://crabby-images/8cfd9/8cfd975766c1339dadb9c73a349c926c8057e7cc" alt="code/datums/ai/ai_behavior.dm 6"
Flags for extra behavior
required_distance data:image/s3,"s3://crabby-images/8cfd9/8cfd975766c1339dadb9c73a349c926c8057e7cc" alt="code/datums/ai/ai_behavior.dm 4"
What distance you need to be from the target to perform the action.
Proc Details
clear_movement_target
Clear the controller's movement target only if it was us who last set it
finish_action
Called when the action is finished. This needs the same args as perform
besides the default ones. This should be used to clear up the blackboard of
any unnecessary or obsolete data, and update the state of the pawn if
necessary once we know whether or not the AI action was successful.
succeeded
is TRUE
or FALSE
depending on whether
/datum/ai_behavior/proc/perform returns AI_BEHAVIOR_SUCCEEDED or
AI_BEHAVIOR_FAILED.
get_cooldown
Returns the delay to use for this behavior in the moment. The default
behavior cooldown is CLICK_CD_MELEE
, but can be customized; for example,
you may want a mob crawling through vents to move slowly and at a random
pace between pipes.
perform
Called by the AI controller when this action is performed. This will
typically require consulting the blackboard for information on the specific
actions desired from this behavior, by passing the relevant blackboard data
keys to this proc. Returns a combination of AI_BEHAVIOR_DELAY or
[AI_BEHAVIOR_INSTANT], determining whether or not a cooldown occurs, and
AI_BEHAVIOR_SUCCEEDED or AI_BEHAVIOR_FAILED. The behavior's
finish_action
proc is given TRUE or FALSE depending on whether or not the
return value of perform
is marked as successful or unsuccessful.
set_movement_target
Helper proc to ensure consistency in setting the source of the movement target
setup
Called by the AI controller when first being added. Additional arguments depend on the behavior type. For example, if the behavior involves attacking a mob, you may require an argument naming the blackboard key which points to the target. Return FALSE to cancel.