Skip to content

Latest commit

 

History

History
222 lines (156 loc) · 9.68 KB

README.md

File metadata and controls

222 lines (156 loc) · 9.68 KB

xBehavior

A behavior tree editor and runtime

安装

打开IDEA插件管理器,搜索xbehavior,选择并安装。xBehavior依赖IDEA GEF插件,如果有提示,请一并安装

使用

创建模型

选择想要创建模型的resource目录,从File New里面选择Xross Behavior Model,在对话框中修改模型文件名。

放置节点

在左侧菜单选择想要放置的节点,单击该节点,再单击编辑器主窗口相应位置

节点类型

节点类型分为三种大类:

  • 复合节点。包括Sequence,Selector和Parallel
  • 装饰节点。包括Inverter,Repeat,Retry,Wait,Force success,Force failure
  • 基础节点。包括Condition,Action,Fixed status,Sleep和Subtree

节点连接

新建连接

单击Connection,再依次单击想要连接的两个节点即可

节点重连

通过鼠标选中连接后,拖拽连接两端的方形锚点到新的位置

注意事项

  • 组合节点类型允许有多个节点
  • 装饰节点只允许有一个子节点
  • 基础节点不允许有子节点

进行节点连接或重连接时,如果不满足上述约束,连接将无法建立

修改属性

点击节点,下方属性窗口会显示该节点类型对应的属性,根据需要进行修改

调整顺序

行为树的节点顺序直接影响运行逻辑,为了调整顺序,可以简单的进行拖动,系统会自动进行重排。

  • 复合节点的子节点可以通过左右拖动到新的位置完成调整
  • 模型中各行为树可以通过上下拖动顶层节点来调整顺序

生成帮助文件

点击Helper可以生成针对当前模型的factory代码。所有子树都会根据name属性进行生成,如果子树顶层节点没有name属性,将忽略该子树。

模型属性

行为树模型本身属性

  • Description。模型描述
  • Evaluator。用于解析属性和Condition包含的表达式的求值器。缺省为com.xrosstools.xbehavior.XpressionEvaluator。依赖xpression。

复合节点属性

Sequence

Sequence节点会顺序执行每个子节点,当所有子节点返回StatusEnum.SUCCESS时,将返回StatusEnum.SUCCESS;如果任何一个节点返回FAILURE,则返回FAILURE;如果某节点返回RUNNING,则返回RUNNING。其属性为:

  • Name。节点名字
  • Description。节点描述
  • Reactive。是否采用Reactive模式,如果为true,则当子节点返回StatusEnum.RUNNING时,下一次tick从第一个子节点开始依次tick,否则从上一次返回RUNNING的子节点开始tick 注意Name和Description是所有行为节点的通用属性,下面不再重复介绍

Selector

Selector节点会顺序执行每个子节点,当任意子节点返回StatusEnum.SUCCESS时,将返回StatusEnum.SUCCESS;如果所有节点返回FAILURE,则返回FAILURE;如果某节点返回RUNNING,则返回RUNNING。其属性为:

  • Reactive。是否采用Reactive模式,如果为true,则当子节点返回StatusEnum.RUNNING时,下一次tick从第一个子节点开始依次tick,否则从上一次返回RUNNING的子节点开始tick

Parallel

Parallel节点会“并发”(内部实现为顺序)执行所有子节点,根据Mode的选择,当满足数量的节点返回SUCCESS时,将返回SUCCESS,否则返回FAILURE;如果数量不满足,且子节点返回RUNNING,则返回RUNNING

  • Mode。满足条件的模式,共有三种:ALL,所有节点都返回SUCCESS;ANY,任一节点返回SUCCESS;SOME,给定Count数量的节点都返回SUCCESS
  • Count。当Mode为SOME时,会显示Count属性,其值为需要返回SUCCESS的子节点的最小数值

装饰节点

Inverter

对子节点的返回值取反,子节点返回SUCCESS时,返回FAILURE;子节点返回FAILURE时,返回SUCCESS;子节点返回RUNNING时。返回RUNNING

Repeat

Repeat节点会根据所选Mode重复调用子节点,直到节点返回FAILURE或满足一定条件

  • Mode。节点调用模式,有两种。MAX_ATTEMPT,重复调用直到给定的最大重复次数;TIMEOUT,重复调用直到给定的时间用完,此选项将额外显示Time unit属性
  • Repeat until failure。是否重复调用直到子节点返回FAILURE。为true时,子节点返回FAILURE时结束调用并返回FAILURE;为false时,忽略子节点状态并重复调用
  • Count。重复的次数或者时间长度。如果Mode为MAX_ATTEMPT,则子节点返回RUNNING时,不会导致数量增加
  • Time unit。重复时长对应的时间单位,选项从NANOSECONDS一直到DAYS

注意虽然Time unit提供了NANOSECONDS和MICROSECONDS,但实际测量这两种精度似乎都不太准,建议从MILLISECOND开始选取。

Retry

Retry节点会根据所选Mode重复调用子节点,直到节点返回SUCCESS或满足一定条件

  • Mode。节点调用模式,有两种。MAX_ATTEMPT,重复调用直到给定的最大重复次数;TIMEOUT,重复调用直到给定的时间用完,此选项将额外显示Time unit属性
  • Count。重复的次数或者时间长度。如果Mode为MAX_ATTEMPT,则子节点返回RUNNING时,不会导致数量增加
  • Time unit。重复时长对应的时间单位,选项从NANOSECONDS一直到DAYS

Wait

Wait节点会在等待给定时间后再调用子节点

  • Timeout。等待的时间长度
  • Time unit。等待时长对应的时间单位,选项从NANOSECONDS一直到DAYS

Force success

无论子节点返回SUCCESS或FAILURE,都返回SUCCESS;子节点返回RUNNING时将返回RUNNING

Force failure

无论子节点返回SUCCESS或FAILURE,都返回FAILURE;子节点返回RUNNING时将返回RUNNING

基础节点

Condition

Condition节点根据回调函数返回的或表达式的值是true还是false来决定返回SUCCESS或者FAILURE。

  • Mode。求值模式,有两种。CALLBACK方式,通过调用Implementation指定类实例类来判断;EXPRESSION,根据Left expression,Operator和Right expression相结合的表达式进行判断
  • Implementation。CALLBACK模式时,需要调用的实现com.xrosstools.xbehavior.Condition接口的回调函数
  • Left expression。左侧表达式,表达式介绍见下
  • Operator。连接左右表达式的操作符。选项具体见下
  • Right expression。右侧表达式

表达式介绍

支持对Blackboard中变量的引用,支持一般Java表达式语法,例如变量引用A;变量运算A+(B+C)*E;变量方法调用A.method(para1, para2);基于方括号的数组元素调用等 数字可以直接写,例如1234.5678 字符串需要单引号进行标注,以和变量名区分,例如‘abcd’

Operator的类型

  • 比较操作。==,<>,>,>=,<,<=
  • 字符串操作。STARTS WITH,ENDS WITH,CONTAINS,MATCHES(正则表达式匹配),NOT STARTS WITH,NOT ENDS WITH,NOT CONTAINS,NOT MATCHES(正则表达式匹配)
  • NULL判断。IS NULL,IS NOT NULL
  • TRUE/FALSE判断。IS TRUE,IS FALSE
  • 范围判断。BETWEEN,NOT BETWEEN,IN,NOT IN。用法同SQL语句相同语法

Action

返回StatusEnum的用户自定义行为类。接口为com.xrosstools.xbehavior.Action,需实现以下方法:

StatusEnum tick(Blackboard context);

/**
 * Reset current node, like stopping running node when necessary
 * rest is usually invoked by parent node or self when tick completed 
 */
void reset();
  • Asynchronous。是否异步执行。缺省为false,如果用户选择true,系统将对其进行异步调用,以避免阻塞主线程。此时则需要额外设置Timeout和Time unit属性
  • Implementation。实现Action接口的用户自定义类
  • Timeout。异步执行的最大超时时间。超时将返回FAILURE
  • Time unit。超时时间单位

如果设置了Implementation,则双击Action或Condition节点会打开对应实现代码。

Fixed status

返回给定

Sleep

Subtree

Subtree节点将调用给定的子树。

  • Subtree。给定子树的名称,当前模型所有设置了Name属性的顶层节点都可以选择

双击Subtree将定位到指定的子树

运行时依赖

运行行为树依赖xbehavior 如果使用了缺省的Evaluator来处理表达式,那么需要xpression 如果还要支持spring,需要添加spring-context和spring-beans:

    <dependency>
        <groupId>com.xrosstools</groupId>
        <artifactId>xbehavior</artifactId>
        <version>1.0.0</version>
    </dependency>
    <dependency>
        <groupId>com.xrosstools</groupId>
        <artifactId>xpression</artifactId>
        <version>1.0.0</version>
    </dependency>
    <dependency>
        <groupId>junit</groupId>
        <artifactId>junit</artifactId>
        <version>4.4</version>
    </dependency>
    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-context</artifactId>
        <version>5.3.10</version>
    </dependency>
    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-beans</artifactId>
        <version>5.3.10</version>
    </dependency>

使用Spring

如果用户自定义Action或Condition想通过Spring加载,或者里面使用了Spring的组装机制,可以使用XbehaviorSpring类来进行支持。方法有2

  • 定义Bean的方式,代码见下
  • 直接调用XbehaviorSpring.enable(ApplicationContext applicationContext)方法

以上两种均可

  @Configuration
  @ComponentScan
  public class SpringSupportTest {
      @Bean
      XbehaviorSpring createSpringBeanFactory() {
          return new XbehaviorSpring();
      }
  
      @BeforeClass
      public static void setup() throws Exception {
          ApplicationContext context = new AnnotationConfigApplicationContext(SpringSupportTest.class);
      }