네트워크 상에서 각 플레이어들의 커스터마이징을 적용시키기 위해 SetCustomProperties를 사용하였다.
하지만 계속해서 캐릭터 더미들이 남거나 연동되지 않는 문제거 발생하였고, 모든 부분을 차근차근 디버그를 찍어보며 확인하였다.
하지만 모든 기능은 잘 작동하였고, 문제를 고민해보다 생각난 것이 어떠한 photonView를 참조하는가???이다.
‼문제 발견
참조하는 photonView가 원하던 대상인지 살펴보자.
처음에 기능을 기존에 존재하던 커스텀 프로퍼티와 같은 메서드에 넣었는데, 해당 photonView는 canvas가 대상으로 되어있었다.
당시에는 photonView의 원리를 제대로 이해하지 못하여 실수하였다.
‼해결 방법
해당 기능을 적용 할 대상인 player prefab의 PlayerController script의 상속을 MonoBehavior에서 MonoBehaviorPun으로 바꾸고 기능을 옮겨왔다.
using ExitGames.Client.Photon;
using ExitGames.Client.Photon.StructWrapping;
using Photon.Pun;
using Photon.Realtime;
using SeongMin;
using System.Collections;
using System.Collections.Generic;
using TMPro;
using UnityEngine;
using static TreeEditor.TextureAtlas;
using HashTable = ExitGames.Client.Photon.Hashtable;
namespace NHR
{
public class PlayerController : MonoBehaviourPunCallbacks
{
private string customKey = "playerCustom";
[Header("캐릭터 커스텀")]
public Character[] characters;
public SmartWatchCustomInteractable watch;
private void Awake()
{
GameDB.Instance.playerController = this;
if (this.watch == null) this.watch = GetComponentInChildren<SmartWatchCustomInteractable>();
}
private void Start()
{
if(photonView.IsMine)this.SetPlayer(InfoManager.Instance.PlayerInfo.nowCharacterId, InfoManager.Instance.PlayerInfo.nowClothesColorName);
}
/// <summary>
/// 플레이어 접속 시커스텀프로퍼티에 플레이어 캐릭터 커스텀 정보 동기화
/// </summary>
/// <param name="characterId"></param>
/// <param name="textureName"></param>
public void SetPlayer(int characterId, string textureName)
{
Debug.Log("<color=white>PlayerOn SetCustomProperties</color>");
//playerCustom["playerCustom"] = (InfoManager.Instance.PlayerInfo.nowCharacterId, InfoManager.Instance.PlayerInfo.nowClothesColorName);
HashTable props = new HashTable()
{
{customKey, (characterId, textureName) }
};
PhotonNetwork.LocalPlayer.SetCustomProperties(props);
}
public override void OnPlayerPropertiesUpdate(Player _player, HashTable _changedProps) // 커스텀 프로퍼티 변경시 콜백 받는 함수
{
//캐릭터 커스텀
if (_changedProps.ContainsKey(customKey) && _player == photonView.Owner)
{
var customPlayer = ((int, string))_changedProps[customKey];
int characterId = customPlayer.Item1;
string textureName = customPlayer.Item2;
Debug.LogFormat("<color=white>playerCustom {0}</color>", customPlayer);
Debug.LogFormat("<color=green>photonView.Owner {0}</color>", this.photonView.Owner.IsLocal);
if (_player == this.photonView.Owner)
{
Debug.Log("<color=white>playerCustom success</color>");
Debug.LogFormat("<color=green>photonView.Owner {0}</color>", this.name);
this.ApplyCustom(characterId, textureName);
}
}
}
public void ApplyCustom(int id, string textureName)
{
Debug.LogFormat("<color=yellow>Set id {0}</color>", id);
foreach (var character in this.characters)
{
character.gameObject.SetActive(false);
}
this.characters[id].gameObject.SetActive(true);
var mat = this.characters[id].material;
Debug.LogFormat("<color=yellow>character : {0}, texture : {1}</color>", id, textureName);
mat.mainTexture = Resources.Load<Texture>("ClothesTexture/" + id + textureName);
}
//public void Init()
//{
// //인포에 저장된 캐릭터 불러오기
// PhotonView photonview = null;
// if (GameManager.Instance.roundManager != null) photonview = GameManager.Instance.roundManager.GetComponent<PhotonView>();
// else if(GameManager.Instance.lobbySceneManager != null) photonview = GameManager.Instance.lobbySceneManager.GetComponent<PhotonView>();
// var playerCustom = ((int, string))photonview.Owner.CustomProperties["playerCustom"];
// var selectedCharacterID = playerCustom.Item1;
// var selectedClothesColorName = playerCustom.Item2;
// //캐릭터 설정
// //this.characters = this.GetComponentsInChildren<Character>();
// foreach (var character in this.characters)
// {
// character.gameObject.SetActive(false);
// }
// this.characters[selectedCharacterID].gameObject.SetActive(true);
// var mat = this.characters[selectedCharacterID].material;
// Debug.LogFormat("<color=yellow>character : {0}, texture : {1}</color>", selectedCharacterID, selectedClothesColorName);
// mat.mainTexture = Resources.Load<Texture>("ClothesTexture/" + selectedCharacterID + selectedClothesColorName);
//}
public override void OnJoinedRoom()
{
foreach (Player player in PhotonNetwork.PlayerList)
{
if (player.CustomProperties.ContainsKey(this.customKey))
{
var custom = ((int, string))player.CustomProperties[this.customKey];
int id = custom.Item1;
string textureName = custom.Item2;
// 커스텀 적용
if (player == PhotonNetwork.LocalPlayer)
{
ApplyCustom(id, textureName);
}
}
}
}
}
}
'Project > <teamECHO> 4-1' 카테고리의 다른 글
[METAVERSE EXPO 2024] 4-1 프로젝트 부스 참여 후기 (0) | 2024.07.19 |
---|---|
[문제해결/PJ] PhotonView Character Customizing 동기화 문제2 (0) | 2024.07.19 |
[PJ] VR 환경에서 UI Camera 만들기 in URP (0) | 2024.06.05 |
[PJ] EventDispatcher 사용하기 (1) | 2024.06.02 |
[PJ/디자인패턴] Observer 패턴과 간단한 CharacterCustom (0) | 2024.06.02 |