Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/akikurisu/akibt

Powerful Behavior Tree Editor using GraphView for Unity
https://github.com/akikurisu/akibt

behavior-tree behaviortree graphview unity unity3d visualscripting

Last synced: 2 days ago
JSON representation

Powerful Behavior Tree Editor using GraphView for Unity

Awesome Lists containing this project

README

        

[![GitHub release](https://img.shields.io/github/release/AkiKurisu/AkiBT.svg?style=social)](https://github.com/AkiKurisu/AkiBT/releases)
[![Star on GitHub](https://img.shields.io/github/stars/AkiKurisu/AkiBT.svg)](https://github.com/AkiKurisu/AkiBT/stargazers)

# AkiBT Version 1.5.0

***Read this document in Chinese: [中文文档](./README_ZH.md)***

AkiBT is a behavior tree node editor based on [UniBT](https://github.com/yoshidan/UniBT) and a large number of modern behavior tree editor functions are enriched.

## Setup
1. Download [Release Package](https://github.com/AkiKurisu/AkiBT/releases)
2. Using git URL to download package by Unity PackageManager ```https://github.com/AkiKurisu/AkiBT.git```

## Supported Version

* Unity 2021.3 or later.

## Dependencies

* Newtonsoft.Json

## Features
* Supports constructing behavior tree by visual node editor.
* Support visualizing node status and debugging behavior tree during runtime
* Based on the GraphView framework, it is very convenient to expand the editor and customize new behaviors
* What you see is what you get, all fields are on the graph, this is also the biggest difference between the design of AkiBT and other editors.

## Quick Start

1. Add `AkiBT.BehaviorTreeComponent` for any GameObject.

2. `Open Graph Editor` button opens GraphView for Behavior Tree.
3. Add behaviors and set parameters.

4. Finally press save button on tool bar of the editor window. (If invalid node found the color of the node become red.)

5. Run the unity application. you can see node status in the editor window.


* The red node means that last `Update` returned `Status.Failure`.
* The green node means that last `Update` returned `Status.Success`.
* The yellow node means that last `Update` returned `Status.Running`.
6. You can save the GameObject with `AkiBT.BehaviorTreeComponent` as prefab or save to ScriptableObject or save to json file.

7. Tutorial Video On BiliBili (The version in video is older and needs to be updated)

[开源行为树AkiBT使用教程](https://www.bilibili.com/video/BV1Jd4y187XL/)

## How It Works

* `AkiBT.BehaviorTree` updates child nodes in `Update` timing when the UpdateType is `UpdateType.Auto`.
* If you want to update at any time, change UpdateType to `UpdateType.Manual` and call `BehaviorTree.Tick()`;
* Only `AkiBT.BehaviorTreeComponent` is the `MonoBehavior`. Each node is just a C# Serializable class.


## Editor Advanced

This part will explain the advanced skills and knowledge related to using AkiBT Editor:

### Save, copy and paste

You can click on the node Ctrl+C&&Ctrl+V or right-click and select Duplicate to copy the node. You can also batch select to copy and paste.

You can select `Copy from Asset` from the upper toolbar, or drag and drop `BehaviorTreeAsset`, `BehaviorTreeComponent`, or GameObject and Json files that mount `BehaviorTreeComponent` into the editor to copy and paste.

### Edit shared variables in the editor

SharedVariable can be added in the blackboard.

* For SharedVariable in the field, check ``Is Shared`` and a drop-down menu will appear for binding shared variables in the behavior tree blackboard.

* SharedObject supports type restrictions, see [SharedVariable](./Docs/runtime-extensions.md#SharedVariable) for details

* Double-click the shared variable to modify the name, delete it if it is empty, and update the node field that references the variable after modification.

* Inspector can modify and delete shared variables

### Filter nodes

You can set the search mask for the AkiBT editor or other editors inherited from AkiBT in ProjectSetting. You can set the Group type required in the workflow (see above for Group attributes). Nodes without Group attributes will not be filtered.

### Subtree

When open node search window, you can find all `BehaviorTreeAsset` in your project and import it to editor view as a subtree.

All shared variables in subtree marked with `IsExposed` will be bound to parent behavior tree instance.

### Class Missing

If change node class, namespace and assembly, serialization will be broken. Currently, editor will convert them to `InvalidNode` and keep their serialized data as string.

## Runtime Advanced

This part will explain the advanced skills and knowledge related to using AkiBT's Runtime:

### Use global shared variables

For shared variables across Prefabs in the same scene, you can use ``SceneVariableScope`` (MonoBehaviour) to create ``Global Variables`` that are effective within the scene.

For shared variables across scenes, you can use ``GameVariableScope`` (ScriptableObject) to create ``Global Variables`` that are effective within the application. For packaged games, you need to manually load the ScriptableObject from the resource loading scheme, such as using ``Resources. Load()`` to load

Different scopes can depend on each other. For example, ``SceneVariableScope`` can set ``GameVariableScope`` to ParentScope to obtain global shared variables within the application.

#### How to bind global shared variables?

View the field in the Inspector and click ``Is Global`` to mark it. The behavior tree will bind the global shared variable before the shared variable is initialized.

* The button text is green after marking
### Generic object shared variable SharedTObject

In a custom node, you can use `SharedTObject` to create a generic object (UnityEngine.Object) shared variable. Its binding logic is the same as `SharedObject`, as shown in `IBindableVariable`, The benefit is that you can have safer type checking

### Debugging behavior tree

Shared variables can be modified in the Inspector or editor during runtime to debug the behavior tree. Global variables need to be modified in their corresponding scopes.

### Json serialization

Using Json serialization in the Editor will save the GUID that refers to the ``UnityEngine.Object`` (hereinafter referred to as UObject) object. However, the UObject object cannot be obtained when Json is deserialized at Runtime. You need to load the required objects in other ways at Runtime. UObject objects, for example, change all references to UObject in the behavior tree to ``SharedTObject`` and ``SharedObject``, and obtain them from your resource loading scheme through their names at runtime, such as `Addressable` resources Address or file path of `AssetBundle`.

## Extend Node

***See [Runtime Extensions](./Docs/runtime-extensions.md)***

## Extend Editor

***See [Editor Extensions](./Docs/editor-extensions.md)***

## DSL

You can use [AkiBTDSL](./Docs/dsl.md) to make it easier to edit the behavior tree at runtime or outside the project. It can be exported to a DSL (domain specific language) format that is easy to read and modify, such as it is convenient to establish unified editing of Excel tables.

## User Service

The plugin currently has a new User Service (Tools/AkiBT/AkiBT User Service) built in, which provides two functions Serialize Service and Search Service

### Serialize Service
Since AkiBT uses ScriptableObject for data storage, data loss will occur when modifying the field name of the node (this problem can be avoided by adding `FormerlySerializedAsAttribute` to the modified field). However, after modifying the name and namespace of the node, the entire node cannot be deserialized, thus losing all data of the node and subsequent nodes. After serializing to Json, you can use a text editor to modify the nodes in batches, and then re-deserialize to ScriptableObject.

It should be noted that not all fields of ScriptableObject are serialized. Serialize Service only serializes the nodes and shared variables of the behavior tree, and the deserialization is the same.

### Search Service
Select a node type to quickly find all behavior trees using the node, and combine with Serialize Service to find the corresponding Json file at the same time.