UnityベースのXRフレームワークであるExtrealを試す
Unityについて調べていたら表題のUnityベースのXRフレームワークであるExtreal(エクストリアル)というものがあるらしいので、試してみた。
Extreal(エクストリアル)とは
TIS株式会社が公開したUnityベースのXRフレームワークであり、人々が集まってコミュニケーションできるバーチャル空間を開発するための土台を提供するものとのこと。詳細は下記のリンクを参照。
サンプルアプリケーションを動かしてみる
リンクのREADMEに従って、実際にサンプルアプリケーションを動かしてみる。
まずは上記のGitHubのリポジトリをローカルにクローンする。クローンしたプロジェクトを開く前に、Assets/Holiday/App/AssetWorkflow/Customのディレクトリに以下のファイルを作成する。
namespace Extreal.SampleApp.Holiday.App.AssetWorkflow.Custom
{
public static class SecretVariables
{
public static string ServerAddress => "test";
public static string CryptAssetIv => "initialization-vector";
public static string CryptAssetPassword => "password";
}
}
次にVivoxのアカウントを作成する。Vivox Developer Portalからアカウントを作成しようとすると、Unity Gaming Servicesからアカウントを作るように指示があるので、そちらでアカウントを作成。
data:image/s3,"s3://crabby-images/06fa6/06fa6a6e52ba763030f212a0362946a37c9c4a58" alt=""
アカウントが出来たらプロジェクトを作成して、Main MenuのMultiplayerを選択。
data:image/s3,"s3://crabby-images/bd3fa/bd3faddfe0c05c3da11bc0c846518a73e335df99" alt=""
Voice and Text ChatからSetup Guideを選択し、ガイドに従ってVivoxのセットアップを行う。
data:image/s3,"s3://crabby-images/090d1/090d13f35b953aa67b9fb061453f462ab7f55ae9" alt=""
セットアップの際にUnityとLinkするための情報が出てくるので、案内に従って設定を実施。
data:image/s3,"s3://crabby-images/10822/10822d16328b22da1fb540fb7899edf7612efec7" alt=""
次はリンクを参考にMixamoの無料3DモデルをUnityにインポートする。
補足するとMixamoの上部メニューのCharctersからAmyとMichelleを検索して、リンクで指定の形式でダウンロード。アニメーションは不要とあるので、スキップ。
data:image/s3,"s3://crabby-images/2f873/2f87393943189542d77edc96990d35738084ccf7" alt=""
ダウンロードしたfbxファイルをRenameして(e.g. Amy.fbx)、指定のフォルダにインポート。
data:image/s3,"s3://crabby-images/65c90/65c905a9bda2a413dd2cc66e5dd60c641640e86d" alt=""
そして/Assets/Holiday/App/Avatarsのディレクトリで、avatarのprefabsを作成する。詳細の手順はReadmeを参照。
data:image/s3,"s3://crabby-images/57888/57888e19735d92756c9516a9568d302295fc25b9" alt=""
作成したPrefabのAddressablesにチェックを入れ、AvatarAmyと設定する。またPrefabのPositionを(0, 0, 0)にしておかないと、動かしたときに動作が変になるので注意する。同様の手順でMichelleのPrefabも作成する。
data:image/s3,"s3://crabby-images/4cad8/4cad8a609d1555483509466cf99d2be878b6b728" alt=""
/Assets/Holiday/App/ConfigのディレクトリでChatConfigファイルを作成。プロジェクトで右クリック > Create > Holiday > ChatConfig で作成。VivoxのCredentialsの内容を設定する。
data:image/s3,"s3://crabby-images/b0a31/b0a31aac4d9d3007c90f4bc41e56365f2931e28d" alt=""
同様の手順でMultiplayConfigを作成する。こちらはデフォルト値でOK.。
そしてParrelSyncを使って複数のUnity Editorを起動する。ParrelSyncの使い方はリンクを参照。
起動したUnity Editorの一つでMultiPlayServerのシーンを実行し、他の複数のUnity EditorでAppシーンを実行する。複数のAppシーンを実行して簡単に動かしてみたデモ動画がこちら。
data:image/s3,"s3://crabby-images/e3453/e3453750e39b30968e3d04542a4454a2fb2045b8" alt=""
感想
Extrealのサンプルを動かしてみて、実際のUnity開発に使われるサービスやライブラリ(Unity Gaming ServiceやParrelSyncなど)を知れて良かった。