事前準備
新規Unityアプリケーションを作成する
新規アプリケーションを作成して開発を行うための準備を行います。
Unityを起動して、ページ上部にあるNEWを選択してください。
Project name の入力欄に、「photontest」と入力してください。Locationが指定のフォルダ以下になっていることを確認します。3Dを選択した後、「Create project
」を選択し、Projectを作成してください。
Asset Storeで必要なアセットをインポート
Unityちゃんのインポート
Asset Storeを起動してください。 以下の画像のようになっていれば、大丈夫です。
Asset Storeの検索窓に**「Unity-chan」**と打ち込み、虫眼鏡マークをクリックしてください。
下に行くと、今回使用するassetがあるので、クリックしてください。
アセットの個別ページに遷移をしたら、**「ダウンロード」**をクリックします。
「ダウンロード」が「インポート」に変わるので、クリックをします。
全てにチェックが入っていることを確認して、importをクリックします。
Projectビューに以下の画像と同じものが追加されていれば大丈夫です。
Photon Voiceのインポート
Asset Storeの検索窓に**「Photon Voice」**と打ち込み、虫眼鏡マークをクリックしてください。
下に行くと、今回使用するassetがあるので、クリックしてください。
アセットの個別ページに遷移をしたら、**「ダウンロード」**をクリックします。
「ダウンロード」が「インポート」に変わるので、クリックをします。
全てにチェックが入っていることを確認して、importをクリックします。
※以下のようなビューが表示されても気にしないでください。
Projectビューに以下の画像と同じものが追加されていれば大丈夫です。
不必要なフォルダを削除
ProjectビューのPUNVoice以下にある、「DemoVoice」は今回は不要なので削除してください。
削除する方法は、右クリック→削除 または ⌘(コマンド)+vで可能です。
以下の動画も参考にしてください。
AppIDの取得
IDを2つメモしていただきます。2つの判別がつかなくならないように注意してください。
Photon realtimeのAppIDの取得
Photon Realtimeは無料のアカウントを取得するとすぐに利用できます。
アカウントの取得は下記URLからメールアドレスを登録するとできます。
https://www-jp.exitgames.com/ja/Realtime
完了すると、登録したメールアドレスにURLが記載されていますので、そちらを押下し登録を完了してください。
次に、以下のURLに行き、ダッシュボードからRealtimeをクリックしてください。
https://www.photonengine.com/ja/Photon
すると、以下のような画面に行くので、「新しくReaktimeアプリを作成する」をクリックしてください。
以下のように入力をし、「作成する」を押してください。
アプリケーション名は任意のもので構いません。
すると以下のような画面に行くので、IDをメモしておいてください。
Photon Voiceの取得
以下のURLに行き、ダッシュボードからVoiceをクリックしてください。
https://www.photonengine.com/ja/Photon
右下の「新しくVoiceアプリを作成する」をクリックしてください。
すると以下のような画面に行くので、画像を参考に入力してください。
アプリケーション名は任意のもので構いません。
入力できたら、「作成する」をクリックしてください。
すると以下のような画面に行くので、IDをメモしておいてください。
PUNによる通信
開発用のフォルダーを作成
Assets以下に以下の3つのフォルダを作成してください。
・Scenesフォルダ
・Prefabsフォルダ
・Scriptsフォルダ
以下のようになっていれば大丈夫です。
UnityちゃんをPrefab化
Projectビューのunitychanフォルダ内のPrefabsフォルダにある、unitychanプレファブをHierarchyビューにドラッグ&ドロップしてください。
以下の動画も参考にしてください。
HierarchyビューにあるunitychanをAssets以下のPrefabsフォルダにドラッグ&ドロップしてください。
以下の動画も参考にしてください。
シーンを保存
Projectビューにある、UnityChanフォルダ内にあるScenesフォルダの**「Locomotion」**をダブルクリックしてSceneを変えてください。
Hierarchyビューにあるunitychanを削除してください。
以下の様になっていれば大丈夫です。
次にシーンを保存します。左上のファイルから「Save Scene as ...」選択し、シーン名をDemosとしてください。
保存先は、Assets以下のScenesフォルダにしてください。
以下の動画も参考にしてください。
コンポーネントの追加
Prefab化したunitychanに同期するためのコンポーネントを追加します。
Prefab化したunitychanを選択し、Inspectorビューの「Add Component」から以下の3つのコンポーネントを追加してください。
PhotonView : ゲーム内に必ず1つ必要。メッセージの送信を行う。
Photon Transform View : オブジェクトのTransformを同期するためのコンポーネント
Photon Animator View : オブジェクトのアニメーションを同期するためのコンポーネント
以上の手順を残りの2つのコンポーネントについても行いましょう。
終了後、以下のようになっていれば大丈夫です。
PhotonViewの設定
Unityちゃんを同期するための手順として、PhotonViewの設定を行います。
現在PhotonViewは以下のようになっていると思います。
上から順に説明します。
言葉 | 意味 |
---|---|
Owner | アタッチしているゲームオブジェクトを所有する人 |
View ID | Photon ViewのID番号 |
Observe option | 同期の方法(いつ、どのように) |
Observed Components | 同期させたいオブジェクト |
今回は、監視対象(Observed Components)にPhoton Transform ViewとPhoton Animator Viewを追加します。
これは、アタッチするときと同じように、ドラッグ&ドロップで可能です。以下の動画を参考にしてください。
以上で、Photon Viewの設定は終わりです。
Photon Transform Viewを設定
Transformコンポーネントのうち同期させたいものにチェックをいれます。
今回は、以下2つにチェックしてください。
・Synchronized Position
・Synchronized Rotation
Synchronized Positionを以下のように設定してください。
項目 | 値 |
---|---|
Interpolate Option | Lerp |
Lerp Speed | 3 |
Interpolate Option
補完処理を行うための設定。これにより、オブジェクトの動きが滑らかに同期される。
各オプションの詳細は以下の通りです。
・Disable
補完を行いません。こちらに設定すると、同期させたいオブジェクトの動きが滑らかになリません。
・Fixed Speed
一定速度でオブジェクトを追従し補完します。
同期させたいオブジェクトの動きが一定のときに有効です。
・Estimated Speed
受け取った「直前の座標」と「現在の座標」の差分を現在の速度と仮定してオブジェクトを移動させて補間します。
ゆっくりと加速/減速するオブジェクトに有効です。
・Synchronize Values
スクリプトで直接Transformを指定し、これを用いて補完します。
動きの激しいオブジェクトの同期に有効です。
・Lerp
線形補完をします。
激しく動くオブジェクトも滑らかに同期できるが、タイムラグが生じる。
選択すると出てくる、Lerp Speedは線形補間を行う速さを表します。
Extrapolate Option
補外処理。未来の座標を予測してオブジェクトを予め移動させておくことで同期による遅延を低減することができます。
急激に速度が変化したり、予測不能な動きをするオブジェクトには向いていません。
Draw synchronized position error
ONにするとSceneViewに同期座標が描画されるようになります。
Synchronized Rotationを以下のように設定してください。
項目 | 値 |
---|---|
Interpolate Option | Lerp |
Interpolate Option
・Rotate Towards
指定速度で補完します。
以上で、Photon Transform Viewの設定は終了です。
Photon Transform Viewの設定
同期するパラメータの設定を行います。
各項目を以下のように設定してください。
項目 | 設定値 |
---|---|
Speed | Continuous |
Direction | Continuous |
Jump | Discrete |
Rest | Discrete |
JumpHight | Continuous |
GravityControl | Continuous |
設定値の意味は以下の通りです。
・Disable:同期しない
・Discrete:1秒間に10回のペースで同期を行う
・Continuous:1秒間に10回のペースでの同期は同じです。ただしこちらは毎フレームのパラメータ値を保存し、同期のタイミングでまとめて送信します。受信側では送られてきたパラメータ値を1フレームに1つずつ読み込んで再現します。
Photon Serverの設定を編集
ProjectビューにあるPhoton Unity Networkingをクリックしてください。
Resourcesフォルダ内にある、PhotonServerSettingsをクリックしてください。
各項目を以下のように設定してください。
項目 | 設定値 |
---|---|
Hosting | PhotonCloud |
Region | Jp |
Appid | 先程取得したPUNのID |
Protocol | Udp |
Client Settings | Auto-join Lobbyにチェック |
ここで、Appidに入力するidはphotonvoiceのidではなく、photon realtimeのidなので注意してください。
PhotonControllerを作成
HierarchyビューのCreateを選択した後、Create Empty を選択してください。
すると、空のゲームオブジェクトが生成されるので、名前を「PhotonController」にしてください。
以下の動画も参考にしてください。
スクリプトの作成
ProjectビューのScriptsフォルダを選択した後、右クリックから「Create」→「C# Script」と選択してください。
作成したC#スクリプトの名前をRandomMatchmakerとしてください。
以下のようになっていれば大丈夫です。
RandomMatchmaker.csを以下のように編集してください。
using System.Collections;
using System.Collections.Generic;
using UnityEngine;
public class RandomMatchmaker : MonoBehaviour {
public GameObject photonObject;
void Start(){
PhotonNetwork.ConnectUsingSettings("0.1");
}
void OnJoinedLobby(){
PhotonNetwork.JoinRandomRoom();
}
void OnPhotonRandomJoinFailed(){
PhotonNetwork.CreateRoom(null);
}
void OnJoinedRoom(){
PhotonNetwork.Instantiate(
photonObject.name,
new Vector3(0f, 1f, 0f),
Quaternion.identity, 0
);
GameObject mainCamera =
GameObject.FindWithTag("MainCamera");
mainCamera.GetComponent<ThirdPersonCamera>().enabled = true;
}
void OnGUI(){
GUILayout.Label(PhotonNetwork.connectionStateDetailed.ToString());
}
}
PhotonNetwork.ConnectUsingSettings(string gameVersion)
エディタで設定するためにPhotonと接続します。
引数のgameVersionとはクライアントのバージョン番号です。ユーザーはゲームバージョンで個々に分断されます。
OnJoinedLobby()
ロビーに入ったときに呼ばれるメソッド。
今回は、Auto-join Lobbyにチェックを入れているので、ロビーが存在すると自動でロビーに入ります。
PhotonNetwork.JoinRandomRoom()
現在使われているロビーの、有効なRoomのどれかに入室します。有効なRoomがなければ失敗します。
OnPhotonRandomJoinFailed()
Roomが存在せず、入室に失敗した時に呼ばれるメソッドです。
PhotonNetwork.CreateRoom(string roomName)
Roomを作成するメソッドです。同一名のRoomがすでに存在している場合は失敗します。マスターサーバでのみ呼び出し可能。
固有のルーム名を作成しない場合は、nullまたは ""を名前として渡します。この場合、マスターサーバが割り当てをします。
Roomの作成に成功した場合、OnCreatedRoomとOnJoinedRoomコールバックを呼び出します。 Roomを作成できない場合、OnPhotonCreateRoomFailedが呼び出されます。
OnJoinedRoom()
Roomに入室したときに呼ばれるメソッド。
PhotonNetwork.Instantiate (string prefabName, Vector3 position, Quaternion rotation, int group)
同期したいオブジェクトをInstantiateするときに使用します。
第4引数はPhotonViewのグループの番号がはいります。
スクリプトのアタッチ
PhotonControllerにRandomMatchmakerスクリプトをドラッグ&ドロップして、アタッチしてください
Photon Objectの部分にProjctビューのPrefabsフォルダにあるunitychanをアタッチしてください。
以下の動画も参考にしてください。
Unityちゃんのスクリプトを編集
ProjectビューのUnityChanフォルダ内のScriptsフォルダにあるUnityChanControlscriptWithRigdBody.cdを編集します。
はじめに14行目を以下のように変更してください。
public class UnityChanControlScriptWithRgidBody : Photon.MonoBehaviour
Photon.MonoBehaviourクラスを継承することで、photonViewプロパティを追加します。
次にFixedUpdate関数内に以下の記述を追加してください。
if (!(photonView.isMine)) {
return;
}
photonView.isMine
PhotonViewが自分の物であるか、他のプレイヤーの物であるかを判定します。
自分の物である場合、trueが返されます。
今回の場合、自分がinstantiateしたもの以外は操作できないようにしています。
メインカメラの設定を変更
Hierarchyビューにある「Main Camera」の「Third Person Camera」のチェックを外してください。
実行
複数人で同じ作業を行い、実行ボタンを押して実行してみましょう。
PhotonVoiceの設定
Photon Serverの設定を編集
ProjectビューにあるPhoton Unity Networkingをクリックしてください。
Resourcesフォルダ内にある、PhotonServerSettingsをクリックしてください。
Photon Voice Settingsに Photon VoiceのAppIDを入力してください。
※リアルタイム同期とVoiceチャットのAppIDは分ける必要があるので、注意してください。
Voice機能をつける
unityちゃんにコンポーネントを追加
Assets以下のPrefanbsフォルダにあるunitychanに「Photon Voice Recorder」を追加します。
まず、unitychanプレファブを選択してください。Inspectorビューにある「Add Component」をクリックし、「Photon Voice Recorder」を追加してください。
クリックをすると、下記のコンポーネントも自動で追加されます。
・Audio Source
・Photon Voice Speaker
以上でVoice機能の追加は終わりです。
実行
複数人で同じ作業を行い、実行ボタンを押して実行してみましょう。