10
4

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 1 year has passed since last update.

[UE5] Lyra のバックエンドにEOS を使ってみる + OnlineServices (Experimental) を使ってみる

Last updated at Posted at 2022-08-08

記事概要

UE5 では、ゲームのサンプルとして Lyra という TPS ゲームが提供されています。
image.png

このゲームでは、UnrealEngine の様々な機能を使って実装されていますが、もちろんネットワーク対戦機能も含まれています。

デフォルトでは LAN 対戦のみですが、Epic Games が提供しているオンラインプラットフォーム Epic Online Services にバックエンドを載せ替えることで、簡単にインターネット経由での対戦が可能となります。

Lyra ではOnline 機能を CommonUser というプラグインの形で実装しています。
CommonUser プラグインでは、設定により内部で利用する Online Subsystem を切り替えることが可能です。

CommonUser プラグインはプリミティブなオンライン機能を提供することが目的のOSS ではカバーしきれなかった高レベルなゲームプレイセッションのフローをサポートしています。
詳細は、下記をご確認ください。
https://docs.unrealengine.com/5.0/ja/common-user-plugin-in-unreal-engine-for-lyra-sample-game/

Lyra ではEOS 用の設定が用意されており、こちらを有効化することで簡単に EOS へ載せ替えることが可能です。
本記事では、下記ブログで解説されている内容を日本語化して、EOS をバックエンドとして Lyra を動作させる手順を解説します。
https://dev.epicgames.com/community/learning/tutorials/375e/using-epic-online-services-with-lyra-starter-game

また、UE5 では OnlineSubsystem の改善が予定されており、現在 Experimental ですが OnlineServices Plugin として実装されています。
こちらに載せ替える手順についても合わせてご紹介します。

EOS Developer Portal の設定

EOS を利用するためには、Developer PortalというEpic Games が提供する開発者用 Web サイト(Developer Portal)で必要なリソースを作成/設定する必要があります。

  1. Developer Portal にアクセスして、自分の組織を作成します.
    1.1 各組織内では、ゲームに対応した「製品」を作成することで、各ゲームからEOS サービスにアクセスすることができるようになります
    image.png

  2. DevPortal上で製品を新規作成
    2.1 今回は "LyraTestProduct" という名前で製品を作成

  3. 作成した製品の詳細ページを開き、"製品の設定" から各種リソースを作成する
    3.1 クライアントタブから "新たなクライアントポリシーを追加" をクリック
    3.2 ポリシーのタイプは "Peer2Peer" を選択
    image.png
    3.3 "新たなクライアントを追加" をクリック
    3.4 3.2 で作成したクライアントポリシーを設定する
    image.png

  4. Epic アカウントサービスを設定する
    4.1 Epic アカウントサービス詳細ページから、"アプリケーションを作成" をクリック
    image.png
    4.2 "パーミッション"で、 "Online Presence", "Friends" を有効化
    4.3 "リンクされているクライアント"で、3 で作成したクライアントをリンク

ここまでで、EOS 側で必要な設定は完了です。
"製品の設定" ページから、OSS の設定に必要な各パラメータを一覧することが可能となっています。

実際にマーケットにリリースするゲームの場合は、Epic アカウントサービスでの "ブランドの設定" を完了する必要がありますが、今回のようなテスト利用であれば不要です。

UE5 のソースを取得する

Lyra をパッケージ化する際にビルドプロセスに手を加えるため、Unreal Engine をソースコードからビルドする必要があります。
Perforce へのアクセス権を持っている方はそちらから、持っていない場合は GitHub からソースコードを入手可能です。

詳細な手順については、下記を参照してください。
https://docs.unrealengine.com/5.0/ja/downloading-unreal-engine-source-code/

※GitHub からソースをダウンロードする場合の注意点

"ue5-main" ブランチの最新のソースコードを使うと、現時点でダウンロード可能なLyra (Apr 5, 2022) ではコンパイルエラーが発生します。
ブランチからではなく、tag "5.0.3-release" から zip もしくは tar.gz の形でダウンロードしてください。
https://github.com/EpicGames/UnrealEngine/releases/tag/5.0.3-release

Visual Studio をインストール

ソースをビルドするために、Visual Studio の 2019 または 2022 をインストールしてください。
インストールする際に下記コンポーネントを含めるようにしてください。

  • C++ profiling tools
  • C++ AddressSanitizer (optional)
  • Windows 10 SDK (10.0.18362 or newer)
  • Unreal Engine Installer

なお、UnrealVS extension をインストールしておくと開発に便利です。
前項でダウンロードしたUE のソースフォルダ以下の、Engine\Extras\UnrealVS\ にインストーラがおいてあります。
詳細手順は下記を参照してください。
https://docs.unrealengine.com/5.0/ja/using-the-unrealvs-extension-for-unreal-engine-cplusplus-projects/

Lyra をインストールする

Perforce からUE5 のソースをダウンロードした場合

Samples 以下に Lyra プロジェクトが存在しているので、こちらをビルドしてください。

GitHub からUE5 のソースをダウンロードした場合

別途Epic Games Launcher からLyra Starter Game をダウンロードする必要があります。
image.png

  1. "Unreal Engine" => "Samples" から、Lyra Starter Game を選択
  2. "Create Project" をクリック
  3. インストールフォルダを、前項でダウンロードした UE のソースのルートフォルダにする
  4. UE のルートフォルダで setup.bat を実行
  5. UE のルートフォルダで GenerateProjectFiles.bat を実行
  6. UE5.sln を Visual Studio で開く

ここまでの手順を完了するとVisual Studio のSolution Explore 上で、"Games" 以下に LyraStarterGame というプロジェクトが見えるようになっているはずですので、こちらをビルドしましょう。
image.png

EOS のパラメータを設定をする

Lyra には、EOS を利用するための設定がされている、専用のカスタムコンフィグがあります。
Config/Custom/EOS フォルダ以下に入っており、OnlineSubsystemEOS の有効化や、NetDriver の置き換えなどの設定が含まれています。

起動時の引数に "-customconfig=EOS" を指定することでこちらのコンフィグファイルから設定を読み込むようになります。

デフォルトではEOS のアーティファクト設定を書く行がコメントアウトされているため、下記行の先頭のコロン(;) を削除して、設定を有効にします。
";+Artifacts=(ArtifactName=...”

設定を有効化したあと、各種ID/Secret の値を EOS Developer Portal で作成したリソースの値に置き換えてください。
image.png

EOS Developer Authentication Toolの設定

ゲーム起動後に EOS へログインする方法は複数ありますが、今回は Developer Authentication Tool を利用します。
これは、ローカルで動作する Webサーバであり、本ツール上でEpic アカウントにログインすることで、ログインに必要な認証情報を HTTP を使って取得可能とするものです。

  1. Developer Portal のSDK ページから、最新のEOS SDK をダウンロード
  2. zip を展開
  3. SDK\Tools\EOS_DevAuthTool-win32-x64-1.1.0.zip を更に展開
  4. EOS_DevAuthTool.exe を起動

こちらのツールを起動すると、ローカルで動作するポートを指定するよう要求されるので、今回は 8080 としておきます。
その後、任意のEpic アカウントに対してログインし、認証情報を取得するための名前を指定してください。 (例では "Player1")
image.png

Lyra with EOS で起動する

Visual Studio 上で、コマンドラインに以下の引数を追加して、デバッグ実行してください。
(-AUTH_LOGIN のポート番号、-AUTH_PASSWORD のユーザ名は適宜前項で指定した値に書き換えてください)

-game -customconfig=EOS -AUTH_LOGIN=localhost:8080 -AUTH_PASSWORD=Player1 -AUTH_TYPE=developer

image.png

正しく設定されていれば、Lyra が無事に起動し、自動的にEOS へのログインが実行されます。
ログイン完了のポップアップが右上に表示されたあとは、"Shift + F3" で下記のようにソーシャルオーバレイを表示することができるようになっています。
image.png

LyraGameEOS のパッケージ化

デバッグ実行で問題なくEOS へのログインができるようになったら、LyraGameEOS をパッケージ化してみましょう。

  1. Visual Studio の Command-line から、プロジェクト名以降の引数をすべて削除してからデバッグ実行して、Lyra プロジェクトをエディタで起動
  2. "プラットフォーム" => "Windows" => から、ビルドターゲットに "LyraGameEOS" を選択
    image.png
  3. "プラットフォーム" => "Windows" => "プロジェクトをパッケージ化" を選択し、適切な出力フォルダを指定

ビルドターゲットに "LyraGameEOS" を選択することで、引数として -CustomConfig=EOS が実行ファイルに埋め込まれた形でパッケージ化されます。

なお、パッケージ化したゲームは、認証情報を取得するために Developer Authentication Tool を動作させた上で起動する必要があります。
デバッグ実行と同様に、ゲームを起動時に適切な引数を渡すことで認証が可能となっています。
-AUTH_LOGIN=localhost:8080 -AUTH_PASSWORD=Player1 -AUTH_TYPE=developer

以上の手順で、Lyra のバックエンドとして EOS を利用することが可能となります。
指定する EOS リソース (ID/Secret)を揃えれば、インターネットを通じての対戦も出来ますので、是非試してみてください。

image.png
image.png
image.png

Appendix: OnlineServices への置き換え

現在、UE5 ではOnlineSubsystem を改善した (BP対応、記述方法の簡易化、etc) OnlineServices プラグインが開発されています。
まだExperimental ではありますが、設定を変更することで CommonUser プラグインの中で、OnlineSubsystem の代わりに利用可能となっています。

Lyra で Online Services interface を利用する手順は以下になります。

  1. LyraStarterGame\Plugins\CommonUser\Source\CommonUser\CommonUser.Build.cs で、 bUseOnlineSubsystemV1 を false に変更
    image.png
  2. Config/Custom/EOS 以下の DefaultEngine.ini で、OnlineSubsystemEOS を Disable する
[OnlineSubsystemEOS]
bEnabled=false

[OnlineSubsystemEOSPlus]
bEnabled=false
  1. OSSv1 の設定をコメントアウトする
;For OSSv1, fill in the following line ...
;+Artifacts=...
  1. [OnlineServices.EOS] の設定を有効化し、適切なEOS リソースを指定する。
    (※ 5.0.3 のソースをダウンロードしている場合、"+" が[OnlineServices.EOS] の前にも入ってしまっているので削除してください)
;For OSSv2, fill in the following lines with actual details and then uncomment
[OnlineServices.EOS]
+ProductId=PRODUCTID
+SandboxId=SANDBOXID
+DeploymentId=DEPLOYTMENTID
+ClientId=CLIENTID
+ClientSecret=CLIENTSECRET

以上の設定変更で CommonUserSubsystem 内で OnlineSubsystemEOS ではなく OnlineServicesEOS プラグインが利用されるようになります。
ゲーム画面上は特に変わらないのですが、CommonUserSubsystem/CommonSessionSubsystem 等を見ると、実装の違いなどを確認できるかと思います。

10
4
2

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
10
4

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?