一つ前の記事ではArborのビヘイビアツリーを使うときに大事なポイントを紹介しました。
この記事では、ビヘイビアツリーにて敵AIロジックを使い回すための方法を解説します!
環境
Unity 2020.2.1f1
Arbor 3.7.8
Arborのビヘイビアツリーでは「Sub Behaviour Tree Reference」とパラメーターを使うと、行動の使い回しができて便利です pic.twitter.com/VW3WGHz9xa
— asiram@unityゲーム開発 (@asiramasiram) February 10, 2021
どういうときに役立つの?
普通ゲームで作成する敵のロジックは複数になります。
Arborでは作成したビヘイビアツリーは、コンポーネントをコピー・ペーストすることで、グラフのコピーができます。
が、こうやってコピーされた敵AI達は、全てに影響する変更をしたくなった際に、コピペしたグラフを一つ一つ開いて修整せねばなりません。
これはツライ…

そこで、今回紹介する方法を使えば、敵AIの行動単位で部品化して使い回せるようになります。
こうすると、一つの行動部品を修整すれば参照している敵全ての行動を修正することができます。
工数削減です!

使い回すために使用するArborの機能
使い回す方法を説明する前に、必要なArborの機能を紹介します。
ざっとこんなところでしょうか。
(アクションとはみたいな基本的なことは説明しません。前回の記事を参照してください
- 外部参照のビヘイビアツリーを再生するためのアクション:
Sub Behaviour Tree Reference - 参照先のビヘイビアツリーに情報を渡すためのパラメーター
Sub Behaviour Tree Reference アクション
このアクションが使い回しのポイントです。
Sub Behaviour Tree Reference アクションは、外部のビヘイビアツリーを再生するためのアクションです。
「外部のビヘイビアツリー」とは言っていますが、ほとんどプレハブ化したビヘイビアツリーを使用するのが一般的かなと思います。

これは、「SoloTargetCastAttack」というビヘイビアツリーがアタッチされたプレハブを読み込ませているSub Behaviour Tree Reference アクションです。
こちらの例ではプレハブを読み込ませていますが、他の方法(階層から取得など)を選択することもできるようです。
ちなみに、下にずらずら並んでいるのはパラメーターです。
こちらは後で触れるので覚えておくとよいです!
パラメーター
Arborにはパラメーターをとる手段がいくつか用意されていますが、今回扱うのはグラフに紐づくパラメーターです。
今回のパラメーターの用途は、使い回しする行動にパラメーターを与えて、挙動をある程度変える目的で使用します(例えば、攻撃力を変えるなど)。

グラフのパラメーターは、Arbor Editorの左側で設定することができます。
+マークを押して型を選択、型名の横にパラメーター名を定義して、その下に値を設定できます。
上の例だと、Stringが型名、attack_nameがパラメーター名、突撃が設定された値ですね。
敵AIデータを使い回す方法
では実際に敵AIデータを使い回す方法を見ていきましょう。
手順はこんな感じです。
1. 部品化させたいAI行動を作成、プレハブ化する(必要であればパラメータを定義)
2. 敵A本体のビヘイビアツリーを作成する
3. 2.のビヘイビアツリー内にSub Behaviour Tree Reference アクションを組み込む
4. 3.に1.で作成したプレハブを設定する
5. 必要であれば3.にパラメータの設定を追加する
順番に見ていきましょう。
1. 部品化させたいAI行動を作成、プレハブ化する
まずはこんな感じで、BehaviourTreeコンポーネントがアタッチされただけのGameObjectを作成、プレハブ化しましょう。

(画像だとPlay On StartとかUpdate Settingsとかいじってありますが、普通に使う分にはそのままの設定で良いと思います)
次に、このプレハブに設定されているビヘイビアツリーの中身を作成しましょう。
これが使いまわせる部品になります。
つまり、「SoloTargetCastAttack」という行動が敵A、敵B、敵Cにも参照させて使いまわせるようになります。

今回はこんな感じにして、Sequencerに複数のアクションが紐づく構成にしています。
再利用しやすいように、分岐処理などは避けてシンプルに組みました。
メンテナンスのしやすさも考えて、あんまり複雑にしないほうがいいかなと思います。
ワンポイント:パラメータを追加する
パラメータは必要なければ特に追加しなくてもOKですが、再利用性を高めるためにもパラメータを使用して各値を外部から変更できるようにすると使いやすくなります。

先ほどのグラフの一部です。
パラメータを定義して、アクションの各設定値に割り当てることができます。
今回は、「Enemy Action Cast Start」のSkillNameにパラメーターのattack_name(名前がよくないかも)、CastTimeにパラメーターのcast_timeが割り当たっています。
パラメーター名の右隣にある色のついた場所からドラッグ&ドロップで、アクションの設定値に割り当てることができます。
こうすることで、外部からこれらのパラメーターが設定された時に値が各アクションに反映されるようになり、例えば敵キャラによって攻撃力を変えるなどができるようになります。
ちなみに、このような使い方をしたときパラメーターに設定されている具体的な値は、デフォルト値扱いになり、外部からパラメーターとして渡されない場合に使用される値になります。
2. 敵A本体のビヘイビアツリーを作成する
この手順は単純にいつも通りビヘイビアツリーを対象のオブジェクト(敵)に対して作成すればOKです。
3. 手順2.のビヘイビアツリー内にSub Behaviour Tree Reference アクションを組み込む
とりあえずこんな感じにしました。

(自作デコレーターをつけて、HP条件を満たしていないときは通常攻撃。みたいなニュアンスの設定にしてみましたよ
4. 手順3.に手順1.で作成したプレハブを設定する
最初の手順で作成したプレハブをSub Behaviour Tree Reference アクションに設定します。
ExternalBTにプレハブをドラッグ&ドロップで設定できます!

こんな感じ。
パラメーターが必要なければこれで終わりです。
ゲームを実行して挙動を確かめてみましょう。
条件を満たしていれば、Sub Behaviour Tree Reference アクションに処理が流れて、設定したビヘイビアツリーに処理が移っていくことがわかると思います!
5. パラメータの設定を追加する
Sub Behaviour Tree Reference アクションの下の方の+マークから、パラメーターを設定することができます。

最終的にこんな感じになりました。
これでAI行動を部品化して、さらにパラメータによって挙動を変えることができるようになりました!
異なる敵に同じ行動をさせたい場合は、2~5の手順を繰り返してSub Behaviour Tree Reference アクションにプレハブ化したビヘイビアツリーを設定しましょう。
今回部品化した行動に修正を加えたいときは、手順1.で作成したビヘイビアツリー一つを修正すれば全ての参照している敵に反映されます。
まとめ
敵AIデータを使い回すために必要なArborの機能、手順を解説しました。
これで悲しいコピペ地獄は避けられそうです。
自分はまだ試していませんが、ステートマシンの方でもおそらく同じような使い方ができると思うので、興味がある方は試してみると良さそうです。