Install Asset
Install via Godot
To maintain one source of truth, Godot Asset Library is just a mirror of the old asset library so you can download directly on Godot via the integrated asset library browser
Quick Information
( Join Discord ! https://discord.gg/SWg6vgcw3F )This plugin is an implementation of well-known Behavior Trees, allowing game developers to create AI-Like behaviors for their NPCs.In addition to provide all behavior tree base nodes, this plugin also brings additional helper nodes that avoid to create custom ones.BE CAREFULL : Due to breaking change in GDScript annotations,- Versions 1.X.X are compatible with Godot 4 beta 12 and inferior- Versions 2.X.X are compatible with Godot 4 beta 13 and superiorYou can manually download old releases on Github at https://github.com/AdrienQuillet/godot-yet-another-behavior-tree/releases*Changelog*========**3.2.0****Enhancements:**- #35 : Create a reset function on BTRoot and Blackboard**Bug fixes:**- #37: Not working on Godot 4.1 beta 3- #36: Can not export project in release mode**3.1.0****Enhancements:**- #27 : Add a way to disable BT nodes- #28 : Improve Behavior Trees core performance up to 2 times- #29 : update gitattributes to exclude unneeded files when addon is exported**Bug fixes:**- #26 : fix orphan nodes generated by behavior trees**3.0.0****BREAKING CHANGES:**- #11 : 3D game compatibilityIf you have created your own behavior tree node, like extending `BTAction` or `BTCondition`, `tick` methods should now be`func tick(actor:Node, blackboard:BTBlackboard) -> int`**Enhancements:**- #22 : Add node description in the editor- #23 Provide BTNode script template**Bug fixes:**- #21 : Godot 4 Beta 17 breaks typed arrays **2.0.1****Enhancements**- Add examples in Github Repository- Add Discord server to request support, share things**Bug fixes**- #12 BTSequence save_progression is not working- #15 BTRoot : when added to a Scene tree, enabled is always false- #16 BTConditionBlackboardValuesComparison : exported enum operator is broken using Godot 4 beta 16- #19 BTRoot : setting blackboard from script does not use the given blackboard instance**2.0.0****BREAKING CHANGES:**- #10 : Godot 4 beta 13 broke annotation placement in GDScript**1.1.2****Bug fixes:**- #9 : BTBlackboard : can get a reference to an invalid node when getting data**1.1.1****Bug fixes:**- #8 : BTActionCallable : expression result not working when returning an int**1.1.0***Enhancements:*- In nodes that can use Godot expressions, the variable `delta` can now be used. It makes reference to the delta value, as `float`, that is passed to `_process` and `_physics_process` methods. Affected nodes: - BTConditionCallable - BTActionCallable - BTActionBlackboardSet- #7 : Add a condition node that can call an existing function and take this function result as condition result- #6 : Add an action node that make a call to an existing function**1.0.3***Bug fixes:*- #5 BTRoot : when setting actor_path from script, it's not possible to set a path outside the current scene- #4 BTRoot : set actor_path from script instead of Inpesctor cause underlying _actor to be always null**1.0.2***Bug fixes:*- #3 Custom performance monitor in BTRoot produces erros when node is removed from tree**1.0.1***Bug fixes*:- #1 : BTRoot doesn't work : StringName behavior change in Godot 4 beta**1.0.0**- Initial release
Yet Another Behavior Tree
A Behavior Tree implementation for Godot Engine
📄 Yet Another Behavior Tree in a nutshell
This behavior tree is a Godot node that can be added to your Scene tree. The logic inside tree nodes will be run every frame, during process or physics process, depending on tree process mode.
At each frame, the tick
function of tree nodes will be run. This function has access to the actor (the node the tree is describing behavior for), and a blackboard (allowing to share data between nodes). The tick function can either returns:
- SUCCESS, indicating that node execution is successful,
- RUNNING, indicating that node is doing a long computation/action/whatever you want, that is not finished yet,
- FAILURE, indicating that something went wrong during child execution (condition not met, ...).
Depending on your tree structure, node result will produce various behaviors. See node documentation for mor details.
📄 Features
➡️ This plugin is an implementation of well-known Behavior Trees, allowing game developers to create AI-Like behaviors for their NPCs. In addition to provide all behavior tree base nodes, this plugin also brings additional helper nodes that avoid to create custom ones.
➡️ As all behavior trees, this implementation provides a tree root called BTRoot
. This node will contains all your AI logic. Root node only accept a unique behavior tree node as child, which is a composite node. Composite nodes defines the root of a tree branch : each branch can be seen as a rule for your AI. They accept any kind of behavior tree nodes as children. It can either be a composite, decorator or leaf nodes. Decorator nodes allow to customize result of its only child node. Leaf nodes, as their name implies, do not have any child. They represents basic unit of work of your AI, which can be separated into two notions: conditions and actions.
➡️ In some cases, you will need to share information between your AI nodes. To avoid to create side scripts and/or stateful entities, this behavior tree also provides the notion of Blackboard. In a blackboard, you can store key-value datas. They can be retrieve and updated from any node in your tree. Blackboard is not erased between tree execution, meaning you can store persistent datas in it.
(See below for full node documentation)
➡️ Having nice features is cool, but beeing able to use them in an easy way is cooler 😎. Yet Another Behavior Tree provides a nice Godot Editor integration throught
- A set on uniform and beautiful (😂) node icons, that make it easier to identify what each node is and what it is doing in the Scene view,
- Configuration warning in Scene view if your behavior tree is not well configured,
- Easy node configuration through exported variables
📄 Nodes Documentation
BTBlackboard
Blackboard allows to share data across nodes and behavior trees. You can create/retreieve/erase pairs of key-value. Keys and values are variants and can be anything.
Some well-known properties are already fed by the root tree during execution :
delta
: the float value of delta from process or physics process (depending on root tree process mode).
🔑 Properties list:
data
: a dictionnary allowing to specifies default entries before tree first execution.
BTRoot
Its the entry point of your behavior tree. It can only have a unique child of type BTComposite
.
🔑 Properties list:
enabled
: indicates if tree should run or non. Default is on,root_process_mode
: indicates whether tree should execute during process or physics process. Default is physics process,actor_path
: path to the node that the tree is drescribing actions for. This is the node that will be passed to all tree nodes, allowing you to manipulate the actor at every tree step. Default is empty.blackboard
: path to the blackboard node. This allows to share a same blackboard between several trees, for example to code a group of enemies acting together, or to spécify some default entries using the editor. If empty, a default empty blackboard will be used during tree execution. Default is empty.
BTSelector
The selector node is a composite node that executes its children from the first one to the last one, in order, until one of them returns SUCCESS. If a selector child succeeds, the selector succeed too. If all selector children failed, the selector fails too.
🔑 Properties list:
save_progression
: indicates whether the selector should resume to the last running child on next tree execution (on), or restart from its first child (off). Its usefull to describe a non-interruptible action, or to optimize process time. Default is off.
BTRandomSelector
The random selector node is a composite node behaves like the BTSelector
node, except that it executes its children in random order.
🔑 Properties list:
save_progression
: indicates whether the random selector should resume to the last running child on next tree execution (on), or restart from its first child (off). Its usefull to describe a non-interruptible action, or to optimize process time. Default is off.
BTSequence
The sequence node is a composite node that executes its children from the first one to the last one, until all children succeed or one of its children fails. Il all children succedd, the sequence succeeds too ; if one child fails, the sequence fails too.
🔑 Properties list:
save_progression
: indicates whether the sequence should resume to the last running child on next tree execution (on), or restart from its first child (off). Its usefull to describe a non-interruptible action, or to optimize process time. Default is off.
BTSuccess
The success node is a decorator node that always returns success on child execution.
BTFailure
The failure node is a decorator node that always returns failed on child execution.
BTInverter
The inverter node is a decorator node returns success when its child fails its execution, and failure when its child succeeds its execution. When its child is running, it returns running too.
BTLimiter
The limiter node is a decorator node that limits the total number of execution of its child node. When the limit is not reachs, the limiter nodes reports its child execution status. Once the limit is reachs, it never executs its child and always report a failed execution.
🔑 Properties list:
limit
: number of allowed child execution. Default is 1,include_limit
: whether or not thelimit
value is included into the number of times the child can run. It clarifies the usage of the limit. Default is on.
BTRepeatUntil
The repeat until node is a decorator node that loop its child execution until child execution result is as excepted. It is possible to specifies the maximum number of loop execution allowed to obtain the desired result. If desired result is obtained before the loop execution limit, the repeat until node returns the obtained result. If not, its returns a failure.
🔑 Properties list:
stop_condition
: expected child result to stop the loop. Default is SUCCESS,max_iteration
: maximum number of child execution to obtain the desired result. If value is 0, there is no limit to the number of times the loop can run (⚠️ be careful to not create an infinite loop). If value is more than zero, its represents the maximum number of loop execution. Default is 0.
BTRandom
The random node is a decorator node randomly execute its child. If the child is executed, the node result is the same as its child result. Otherwise, result is *failure.
🔑 Properties list:
probability
: a float between 0 (included) and 1 (included) indicating the probability of child execution. Default is 0.5.
BTCondition
The condition node is a leaf node. Its purpose is to return success when a condition is meet, failure otherwise. This node should never return *running.
Users must subclass this node to implements their own condititions.
BTConditionBlackboardKeyExists
The blackboard key exists condition node is a leaf node. It returns success if a certain key is present in the tree blackboard during its execution, failure otherwise.
🔑 Properties list:
blackboard_key
: name of the key that must exists in the blackboard.
⚠️ Due to GDScript 2.0 restrictions, only string type keys can be set, since its not possible to export Variant variables.
BTConditionBlackboardValuesComparison
The blackboard values comparison condition node is a leaf node. It returns success both values represented by specified keys returns true when compared using the given operator.
🔑 Properties list:
first_operand_blackboard_key
: name of the key that old the first value to compare.operator
: operator used to compare valuessecond_operand_blackboard_key
: name of the key that old the second value to compare.
⚠️ Due to GDScript 2.0 restrictions, only string type keys can be set, since its not possible to export Variant variables.
BTAction
The action node is a leaf node. Its purpose is to return success when an action is completed, failure if its fails to execute, and running if the action is occuring but is not completed yet.
Users must subclass this node to implements their own actions.
BTActionWait
The wait action node is a leaf node. Its execution returns running during the specified wait time, then returns success when specified time is elapsed. After succeeded, the wait time is rearmed for next tree execution.
🔑 Properties list:
wait_time_ms
: number of milliseconds to wait before returning success. Default is 1000,random_deviation_ms
: indicates if a random deviation should be applied to the wait time. 0 means theire is no deviation et the wait time will be strictyl respected. Random deviation may change after each node rearm. Default is 0, meaning no deviation at all.
BTActionBlackboardSet
The blackboard set action node is a leaf node. It allows to set a value in the blackboard. Its execution always returns success.
🔑 Properties list:
blackboard_key
: name of the key that must be set,expression
: an expression representing the value to associated to the given key. The expression will be evaluated by Godot Engine during child execution. It should be simple. See Godot Expression for details. In expression, user has access to two predefined variables:actor
: the node the tree is describing action for,blackboard
: the tree blackboard
can_overwrite_value
: a boolean indicating if the value must be overwritten if it already exists.
⚠️ Due to GDScript 2.0 restrictions, only string type keys can be set, since its not possible to export Variant variables.
BTActionBlackboardDelete
The blackboard delete action node is a leaf node. It allows to erase a key from the tree blackboard.
🔑 Properties list:
blackboard_key
: name of the key that must be erased from blackboard.
⚠️ Due to GDScript 2.0 restrictions, only string type keys can be set, since its not possible to export Variant variables.
📄 Creating your own nodes
Even if the provided node set is wonderful and all (😁), you will need to create your own nodes to describe your own behavior, your functional actions and conditions, or whatever you want.
Creating your own composite and decorator nodes is off-topic here, and should be reserved for advanced users. But creating your own actions and conditions is required, and is quite simple.
Empty-shell nodes BTAction and BTCondition are your entry-points. You just need to create a GDScript that extends one of this node, depending on what you want to do, and overrick the tick
function, then code your functional stuff in it !
Exemple of condition
extends BTCondition
class_name ConditionPlayerIsInRange
@icon("res://addons/yet_another_behavior_tree/src/Assets/Icons/btcondition.png")
@export var player_detection_distance:int = 50
func tick(actor:Node2D, _blackboard:BTBlackboard) -> int:
var player_position:Vector2 = get_tree().get_nodes_in_group("player")[0].global_position
var actor_position:Vector2 = actor.global_position
var player_distance:float = actor_position.distance_to(player_position)
if player_distance <= player_detection_distance:
return BTTickResult.SUCCESS
return BTTickResult.FAILURE
Exemple of action
extends BTAction
class_name ActionWander
@icon("res://addons/yet_another_behavior_tree/src/Assets/Icons/btaction.png")
func tick(actor:Node2D, blackboard:BTBlackboard) -> int:
var current_position:Vector2 = actor.global_position
var target_position:Vector2 = blackboard.get_data("wander_position")
if current_position.distance_to(target_position) < 5:
return BTTickResult.SUCCESS
else:
var direction:Vector2 = (target_position - current_position).normalized()
actor.velocity = direction
return BTTickResult.RUNNING
( Join Discord ! https://discord.gg/SWg6vgcw3F )
This plugin is an implementation of well-known Behavior Trees, allowing game developers to create AI-Like behaviors for their NPCs.
In addition to provide all behavior tree base nodes, this plugin also brings additional helper nodes that avoid to create custom ones.
BE CAREFULL :
Due to breaking change in GDScript annotations,
- Versions 1.X.X are compatible with Godot 4 beta 12 and inferior
- Versions 2.X.X are compatible with Godot 4 beta 13 and superior
You can manually download old releases on Github at https://github.com/AdrienQuillet/godot-yet-another-behavior-tree/releases
*Changelog*
========
**3.2.0**
**Enhancements:**
- #35 : Create a reset function on BTRoot and Blackboard
**Bug fixes:**
- #37: Not working on Godot 4.1 beta 3
- #36: Can not export project in release mode
**3.1.0**
**Enhancements:**
- #27 : Add a way to disable BT nodes
- #28 : Improve Behavior Trees core performance up to 2 times
- #29 : update gitattributes to exclude unneeded files when addon is exported
**Bug fixes:**
- #26 : fix orphan nodes generated by behavior trees
**3.0.0**
**BREAKING CHANGES:**
- #11 : 3D game compatibility
If you have created your own behavior tree node, like extending `BTAction` or `BTCondition`, `tick` methods should now be
`func tick(actor:Node, blackboard:BTBlackboard) -> int`
**Enhancements:**
- #22 : Add node description in the editor
- #23 Provide BTNode script template
**Bug fixes:**
- #21 : Godot 4 Beta 17 breaks typed arrays
**2.0.1**
**Enhancements**
- Add examples in Github Repository
- Add Discord server to request support, share things
**Bug fixes**
- #12 BTSequence save_progression is not working
- #15 BTRoot : when added to a Scene tree, enabled is always false
- #16 BTConditionBlackboardValuesComparison : exported enum operator is broken using Godot 4 beta 16
- #19 BTRoot : setting blackboard from script does not use the given blackboard instance
**2.0.0**
**BREAKING CHANGES:**
- #10 : Godot 4 beta 13 broke annotation placement in GDScript
**1.1.2**
**Bug fixes:**
- #9 : BTBlackboard : can get a reference to an invalid node when getting data
**1.1.1**
**Bug fixes:**
- #8 : BTActionCallable : expression result not working when returning an int
**1.1.0**
*Enhancements:*
- In nodes that can use Godot expressions, the variable `delta` can now be used. It makes reference to the delta value, as `float`, that is passed to `_process` and `_physics_process` methods. Affected nodes:
- BTConditionCallable
- BTActionCallable
- BTActionBlackboardSet
- #7 : Add a condition node that can call an existing function and take this function result as condition result
- #6 : Add an action node that make a call to an existing function
**1.0.3**
*Bug fixes:*
- #5 BTRoot : when setting actor_path from script, it's not possible to set a path outside the current scene
- #4 BTRoot : set actor_path from script instead of Inpesctor cause underlying _actor to be always null
**1.0.2**
*Bug fixes:*
- #3 Custom performance monitor in BTRoot produces erros when node is removed from tree
**1.0.1**
*Bug fixes*:
- #1 : BTRoot doesn't work : StringName behavior change in Godot 4 beta
**1.0.0**
- Initial release
Reviews
Quick Information
( Join Discord ! https://discord.gg/SWg6vgcw3F )This plugin is an implementation of well-known Behavior Trees, allowing game developers to create AI-Like behaviors for their NPCs.In addition to provide all behavior tree base nodes, this plugin also brings additional helper nodes that avoid to create custom ones.BE CAREFULL : Due to breaking change in GDScript annotations,- Versions 1.X.X are compatible with Godot 4 beta 12 and inferior- Versions 2.X.X are compatible with Godot 4 beta 13 and superiorYou can manually download old releases on Github at https://github.com/AdrienQuillet/godot-yet-another-behavior-tree/releases*Changelog*========**3.2.0****Enhancements:**- #35 : Create a reset function on BTRoot and Blackboard**Bug fixes:**- #37: Not working on Godot 4.1 beta 3- #36: Can not export project in release mode**3.1.0****Enhancements:**- #27 : Add a way to disable BT nodes- #28 : Improve Behavior Trees core performance up to 2 times- #29 : update gitattributes to exclude unneeded files when addon is exported**Bug fixes:**- #26 : fix orphan nodes generated by behavior trees**3.0.0****BREAKING CHANGES:**- #11 : 3D game compatibilityIf you have created your own behavior tree node, like extending `BTAction` or `BTCondition`, `tick` methods should now be`func tick(actor:Node, blackboard:BTBlackboard) -> int`**Enhancements:**- #22 : Add node description in the editor- #23 Provide BTNode script template**Bug fixes:**- #21 : Godot 4 Beta 17 breaks typed arrays **2.0.1****Enhancements**- Add examples in Github Repository- Add Discord server to request support, share things**Bug fixes**- #12 BTSequence save_progression is not working- #15 BTRoot : when added to a Scene tree, enabled is always false- #16 BTConditionBlackboardValuesComparison : exported enum operator is broken using Godot 4 beta 16- #19 BTRoot : setting blackboard from script does not use the given blackboard instance**2.0.0****BREAKING CHANGES:**- #10 : Godot 4 beta 13 broke annotation placement in GDScript**1.1.2****Bug fixes:**- #9 : BTBlackboard : can get a reference to an invalid node when getting data**1.1.1****Bug fixes:**- #8 : BTActionCallable : expression result not working when returning an int**1.1.0***Enhancements:*- In nodes that can use Godot expressions, the variable `delta` can now be used. It makes reference to the delta value, as `float`, that is passed to `_process` and `_physics_process` methods. Affected nodes: - BTConditionCallable - BTActionCallable - BTActionBlackboardSet- #7 : Add a condition node that can call an existing function and take this function result as condition result- #6 : Add an action node that make a call to an existing function**1.0.3***Bug fixes:*- #5 BTRoot : when setting actor_path from script, it's not possible to set a path outside the current scene- #4 BTRoot : set actor_path from script instead of Inpesctor cause underlying _actor to be always null**1.0.2***Bug fixes:*- #3 Custom performance monitor in BTRoot produces erros when node is removed from tree**1.0.1***Bug fixes*:- #1 : BTRoot doesn't work : StringName behavior change in Godot 4 beta**1.0.0**- Initial release