Boltのアップデート
Boltのアップグレードの手順を説明します。
Bolt 1.3へのアップグレード
Photon Bolt v1.3 への更新には、いくつかの破壊的な変更が含まれています。複数のネームスペースが変更されているほか、一部のスクリプトの可視性が変更され、またプレハブ上でいくつかの参照が欠落していることがあります。以下の説明は、このアップデートの影響を最小限に抑えることを目的としていますが、これらの記述に注意してください。
- 変更を開始する前に、プロジェクトのバックアップがある点、および/またはプロジェクトがソース管理システム(Git, SVN, Hg)内にあることを確認してください。この点は十分に留意してください。
- 新しいSDKのバージョンをプロジェクトにインポートする前に、更新用にBoltプレハブを準備する必要があります。v1.3での変更には一部のネームスペースの変更が含まれているため、一部のコンポーネントが移動された結果としてゲームオブジェクトの参照が不足していました。このため、この作業を支援するアップデートスクリプトを作成しました。
- サンプルレポジトリからBolt Updater scriptをダウンロードします。
- それをプロジェクトの
Assets/Editorフォルダの中にインポートします。これにより、Unityがスクリプトを読み込み、適切なメニューアイテムを含むようになります。 - Bolt (
Bolt/Compile Assembly) のコンパイルが完了し、Bolt Prefab Database(Assets\Photon\PhotonBolt\resources\BoltPrefabDatabase.asset)にすべてのプレハブがリストされている点を確認してください。 Bolt/Utils/Update/Save Prefabsメニューのタスクを実行します。Save DONE!というログメッセージを受信するはずです。Assets\Photon\PhotonBolt\resourcesフォルダを参照し、entity_data.jsonがある点を確認してください。このファイルにはBoltエンティティプレハブの主要な設定がすべて含まれています。たとえば、BoltEntityコンポーネント自体やBolt Hitboxなどです。- 後で使用するために、このファイルを任意の場所に保存します。この点は重要です、もし保存していない場合には手動で設定をおこなう必要があります。
- BoltRuntimeSettingsに関する注意: Scriptable Objectでは、参照の変更は簡単には修正できません。
BoltRuntimeSettingsの場合、アップデート後は、表すクラスの参照を失います。そのため、Boltの設定はいくつかの値なので、現在の設定をどこかに注釈するか、スクリーンショットなどを撮ることをお勧めします。後日、再び値を設定する必要があります。
- Photon Bolt に関連するすべてのフォルダを削除します:
Assets/Photon;Assets/samples;Assets/Gizmos;
- [アセットストアから最新のBoltパッケージ] をダウンロードし、プロジェクトにインポートします;
- 通常どおり、パッケージのすべての内容をインポートできます。 Project Settingsに新しいScripting Define Symbolsを含めます。これによって、コードの一部のセクションが有効かされます:
-BOLT_1_3_OR_NEWER- 以下のファイルをバックアップまたはソースコントロールから復元します:
Assets/Photon/PhotonBolt/project.json: すべてのBoltアセットです;project.jsonに記載されたシリアル化データからSDK v1.3上での新しい場所への正しい参照を取得するには、手動で編集する必要があります。ただし、非常に簡単な作業です:- 任意のエディタで
project.jsonファイルを開きます。 Bolt.Compiler.をすべてPhoton.Bolt.Compiler.で置換します - 末尾のドットも含めて、すべてのテキストを置換する点に留意してください。- ファイルを保存します。
Photon Bolt/SettingsでBolt Settingsウィンドウを開き、先ほど保存した値をもとに再度設定します。- 設定の編集中にエラーが発生した場合は:
Assets\Photon\PhotonBolt\resourcesに移動し、BoltRuntimeSettings.assetを削除します。- 新しいBolt Settingsを作成します:(i) 右クリックして、(ii)
Create/Bolt/Create BoltRuntimeSettingsを選択します。 - 再び
Bolt Settingsウィンドウを開きます。
- 設定の編集中にエラーが発生した場合は:
- 任意のエディタで
- 前述のとおり、一部のネームスペースは特定のスクリプトの名前と場所に最適となるよう移動されています。プロジェクトには多くの壊れた参照が含まれていることに留意してください。これらを修正するには、以下のネームスペースを変更してソースコードを修正する必要があります。
- クラスのほとんどは
Photon.Boltネームスペースに含まれています、このため Boltコードに触れているすべてのスクリプトでusing Photon.Bolt;を含む必要があります。 - スクリプトから以下のネームスペースを削除します:
using Bolt;using Bolt.Matchmaking;using Bolt.Photon;
- 直接参照では、スクリプトにネームスペース
Photon.Boltを含めている場合に参照のBolt.部分のみを削除します。 例:
Bolt.CommandtoPhoton.Bolt.Command;Bolt.ScopeModetoPhoton.Bolt.ScopeMode;Bolt.GlobalTargetstoPhoton.Bolt.GlobalTargets;Bolt.IProtocolTokentoPhoton.Bolt.IProtocolToken;Bolt.EntityBehaviourtoPhoton.Bolt.EntityBehaviour;Bolt.ReliabilityModestoPhoton.Bolt.ReliabilityModes;Bolt.GlobalEventListenertoPhoton.Bolt.GlobalEventListener;
- 多くの場合に使用できる追加のネームスペースは以下のとおりです:
Photon.Bolt.Utils:BoltLogやその他のユーティリティクラスを含みます。Photon.Bolt.Collections:BoltRingBufferなど、Bolt独自のコレクションの実装を含みます。Photon.Bolt.Matchmaking: PhotonマッチメイキングAPI;
- これでエラーがなく、また欠落した参照のないプロジェクトになりました。プロジェクトのサイズによって若干時間がかかる場合がありますが、完全に実行可能です。
- クラスのほとんどは
- プロジェクトは、プレハブデータをリセット可能な状態になりました。
- 使用しているUnityのバージョン(具体的には2019 LTS以降)によっては、スクリプト参照が欠落している場合にプレハブの修正および保存ができません。これを解決するには、まずそれらの参照を削除する必要があります:
Bolt/Utils/Find Missing Scriptsメニュー上のタスクを実行します。これによって、欠落するスクリプト参照のあるすべてのプレハブがリスト表示されます。1つずつ確認してスクリプトを削除するか、または8.1.2のように自動化された方法を使用します。Bolt/Utils/Remove Missing Scriptsでタスクを実行し、欠落する参照を削除します。このコードはプロジェクトのすべてのプレハブに対して実行されるため、すべての欠落するスクリプトコンポーネントへの参照を削除する点に留意してください。- 手順8.1.1のタスクを実行し、欠落するコンポーネントを持つプレハブがない点を確認します。
- 手順2で移動されたため、
entity_data.jsonファイルをAssets\Photon\PhotonBolt\resourcesにコピー/移動します。 Bolt/Utils/Update/Load Prefabsでタスクを実行します。これによって、entity_data.jsonからシリアル化されたデータが読まれ、プレハブの詳細情報が設定しなおされます。影響のあったプレハブが、コンソール上ですべてリスト表示されます。例:Updating Player (UnityEngine.GameObject).- 最後に、
Load DONE!のメッセージが表示されますーこれで、すべてが正常に実行されたことを確認できます。
- 使用しているUnityのバージョン(具体的には2019 LTS以降)によっては、スクリプト参照が欠落している場合にプレハブの修正および保存ができません。これを解決するには、まずそれらの参照を削除する必要があります:
- Boltをリコンパイルしたら (
Bolt/Compile Assembly) 、完了です。
Bolt 1.2.9以降へのアップグレード
- プロジェクトがソースコントロールシステム(Git、SVN、Hg)内にあり、バックアップされていることを確認してください。
Assets/boltおよびその他の Bolt に関連するファイルを削除します:Assets/Photon;Assets/samples;Assets/Plugins;
- Asset Storeから最新の[Boltパッケージ]をダウンロードします。
- ウィザードウィンドウが表示されない場合には、以下で開いてください:
Bolt/Wizard; - ウィザードの手順にしたがってください:
1.Photon Cloud証明書を設定します。
2. 必要なパッケージをすべてインストールします。Coreパッケージは必要なくなりました。
3. 不明点がある場合には、弊社の Discordコミュニティにご相談ください。 - Unityを停止します。
- 以下のファイルを復元します:
- Bolt 1.2.5 以前のバージョンからアップデートする場合:
Assets/bolt/project.bytesまたはAssets/bolt/project.xml;- AssetsがJSONフォーマットに変換できるよう、この場合は
Assets/Photon/PhotonBolt/project.jsonファイルも 削除 します。
- Bolt 1.2.7 以降のバージョンからアップデートする場合:
1.Assets/bolt/project.json Assets/bolt/assemblies/bolt.user.dll;Assets/bolt/resources/BoltRuntimeSettings.asset;
- Bolt 1.2.5 以前のバージョンからアップデートする場合:
- 以下のファイルを移動します:
Assets/bolt/project.jsonをAssets/Photon/PhotonBolt/project.jsonへ移動します。;Assets/bolt/assemblies/bolt.user.dllをAssets/Photon/PhotonBolt/assemblies/bolt.user.dllへ移動します。;Assets/bolt/resources/BoltRuntimeSettings.assetをAssets/Photon/PhotonBolt/resources/BoltRuntimeSettings.assetへ移動します。;
- Unityを開き、Boltをコンパイルします。:
Bolt/Compile Assemblyメニューでコンパイルを実行します。Bolt Assetsウィンドウを開き (Bolt/Assetsメニュー)、アセットがすべて想定通りにあることを確認します。
- これで Photon Bolt を使用できるようになりました。
Bolt 1.2.0.0から1.2.8へのアップグレード
- プロジェクトがソースコントロール(Git、SVN、Hg)内にあり、バックアップされていることを確認してください。
Assets/bolt、およびその他のBoltに関連するファイルを削除します:Assets/Photon;Assets/bolt_samples;Assets/Plugins/;
- Asset Storeから最新の[Boltパッケージ]をダウンロードします。
- ウィザードウィンドウが表示されない場合は、以下から開いてください:
Window/Bolt/Wizard - ウィザードの手順にしたがってください:
Photon Cloud証明書を設定します。- 必要なパッケージをすべてインストールします。
Coreパッケージは必ずインストールしてください。 - 不明点がある場合には、弊社の Discordコミュニティにご相談ください。
- Unityを停止します。
- 以下のファイルを復元します。
1. Bolt 1.2.5以前のバージョンからアップデートする場合:Assets/bolt/project.bytesまたはAssets/bolt/project.xml;
1. この場合、AssetがJSONフォーマットに変換されるよう、Assets/Photon/PhotonBolt/project.jsonファイルも 削除 してください。
2. Bolt 1.2.7以降のバージョンからアップデートする場合:Assets/bolt/project.json
3.Assets/bolt/assemblies/bolt.user.dll;
4.Assets/bolt/resources/BoltRuntimeSettings.asset; - Unityを開き、Boltをコンパイルします:
Assets/Bolt/Compile Assemblyメニューで、コンパイルを実行してください。Bolt Assetsウィンドウを開き (Bolt/Assetsメニュー)、アセットが全て想定通りにあることを確認します。想定通りであれば、古いプロジェクトファイル (Assets/bolt/project.bytesまたはAssets/bolt/project.xml)を削除できます。
- これで Bolt を使用できるようになりました。
Boltの設定とアセットの移行
Boltはそのすべてのオブジェクト、状態、コマンド、イベントを Assets/bolt/project.jsonファイルに保存します。
アセットからすべての情報を定義するJSONファイルです。
このファイルを直接変更することはお勧めしません。変更すると、逆シリアル化プロセスが中断する可能性があります。
新しいプロジェクトに移行するには、このファイルを新しいプロジェクト内の同じ場所にコピーします。これは、Boltデータをチームの他のメンバーと共有する場合にも便利です。
Bolt FreeからBolt Proへのアップグレード
Photon Bolt Proにアクセスできるようになった場合、SDKをこの新しいバージョンに簡単に更新できます。
最初に、セクションUpgrading Boltの指示に従ってください。バージョンを変更するので、アップグレードする他順と同じです。
更新の重要な側面は、変更やバックアップを行う前に、「SVN」や「GitHub」などの「バージョン管理システム」を使用してプロジェクトを維持する必要があることです。
アップデート後にゲームで適切に機能する最も重要なファイルがいくつかあります。
Assets/Photon/PhotonBolt/project.json: これには、すべてのBoltアセットの説明が含まれます。Assets/Photon/PhotonBolt/assemblies/bolt.user.dll: これは、Boltをコンパイルするたびに生成されるDLLです。保存しておくと便利です。更新後にエラーが発生することを防ぎます。Assets/Photon/PhotonBolt/resources/BoltRuntimeSettings.asset: ゲームに設定したすべてのボルト設定を含むスクリプト可能なオブジェクト。
要約すると、更新プロセスは次のとおりです。
- 上記のファイルをバックアップします。
- すべてのボルト関連ファイルを削除します。
- Boltの新しいバージョンをインポートします。
- ファイルを正しい場所に戻します。
- 完了。
また、Unityを少なくとも1回再起動する必要があるため、すべてのBolt DLLが再ロードされます。
また、コンパイルの問題がある場合にのみ、プロジェクトフォルダーのルートにある Library、obj、および Tempフォルダーを削除することをお勧めします(これらのフォルダーはAssetsフォルダー内にありません)。
これらのフォルダーを削除すると、プロジェクトがUnityによって完全に再コンパイルされることに注意してください。プロジェクトのサイズによっては、時間がかかる場合があります。
コードやスクリプトの変更に関係なく、更新は最小限です。
主な違いは、IP/ポートを使用してサーバーに直接接続できるようになったことです。
SDKをインポートすると、 samples_proフォルダー表示されます。そこにBoltPro/BoltProInit.csスクリプトがあります。
このスクリプトは、 DotNetPlatform(直接接続を可能にする)を使用してゲームサーバーを起動する方法と、サーバーEndPointを使用して BoltNetwork.Connectを使用してクライアントからサーバーに接続する方法を示しています。
その他のコードと動作は無料版と同じです。