fix: 장착 스킬 업데이트 로직 오류 수정

This commit is contained in:
aube.lee
2025-02-11 21:01:15 +09:00
parent fd7627cd3f
commit c719103ee9
3 changed files with 81 additions and 42 deletions

View File

@@ -82,7 +82,6 @@ namespace TON
// 일반 객체는 그대로 JSON 변환
json = JsonUtility.ToJson(data, true);
}
Debug.Log("SaveToFile ::: " + json);
File.WriteAllText(path, json);
Debug.Log($"파일 저장 성공 ::: {fileName}.json");
@@ -95,7 +94,7 @@ namespace TON
}
/// <summary> Resources.Load 로 읽어온 파일을 persistentDataPath 경로에 저장 </summary>
public static bool SaveJsonToPersistentData(string fileName)
public static void SaveJsonToPersistentData(string fileName)
{
if (fileName.EndsWith(".json"))
{
@@ -104,35 +103,36 @@ namespace TON
string persistentPath = GetPersistentPath(fileName);
#if UNITY_ANDROID
// 📌 Step 1: persistentDataPath에 파일이 있는지 체크
// Android에서는 파일이 이미 존재하면 덮어쓰지 않도록 함
if (File.Exists(persistentPath))
{
Debug.Log($"⚠ {fileName}.json 파일이 이미 존재합니다. 덮어쓰지 않습니다. ({persistentPath})");
return false;
}
#endif
// 📌 Step 2: Resources에서 JSON 불러오기
string path = "GameData/" + fileName; // Resources 폴더 내 경로
string path = DATA_PATH + fileName; // Resources 폴더 내 경로
TextAsset jsonFile = Resources.Load<TextAsset>(path);
if (jsonFile != null)
{
File.WriteAllText(persistentPath, jsonFile.text);
Debug.Log($"✅ JSON 저장 완료 (처음 저장됨): {persistentPath}");
return true;
}
else
{
Debug.LogError($"❌ Resources에서 JSON 파일을 찾을 수 없음: {path}");
return false;
Debug.LogError($"❌ Resources에서 JSON 파일을 찾을 s수 없음: {path}");
}
}
/// <summary> persistentDataPath 경로의 파일 읽어오기 </summary>
public static T LoadJsonFromPersistentData<T>(string fileName)
{
string path = GetPersistentPath(fileName);
Debug.Log($"LoadJsonFromPersistentData : {path}");
if (!File.Exists(path))
{
@@ -162,24 +162,37 @@ namespace TON
}
/// <summary> persistentDataPath 경로의 파일 데이터 업데이트 </summary>
public static void SaveUpdatedJsonToPersistentData<T>(T updatedData, string fileName)
public static bool SaveUpdatedJsonToPersistentData<T>(T updatedData, string fileName)
{
string path = GetPersistentPath(fileName);
string json;
// 리스트인지 확인 후 JSON 변환
if (typeof(T).IsGenericType && typeof(T).GetGenericTypeDefinition() == typeof(List<>))
try
{
Wrapper<T> wrapper = new Wrapper<T> { items = updatedData };
json = JsonUtility.ToJson(wrapper, true);
}
else
{
json = JsonUtility.ToJson(updatedData, true);
}
string path = GetPersistentPath(fileName);
string json;
File.WriteAllText(path, json);
Debug.Log($"✅ JSON 데이터 업데이트 완료: {path}");
// 리스트인지 확인 후 JSON 변환
if (typeof(T).IsGenericType && typeof(T).GetGenericTypeDefinition() == typeof(List<>))
{
Wrapper<T> wrapper = new Wrapper<T> { items = updatedData };
json = JsonUtility.ToJson(wrapper, true);
}
else
{
json = JsonUtility.ToJson(updatedData, true);
}
Debug.Log($"SaveUpdatedJsonToPersistentData : {json}");
// 파일 저장
File.WriteAllText(path, json);
Debug.Log($"✅ JSON 데이터 업데이트 완료: {path}");
return true; // 저장 성공
}
catch (Exception ex)
{
Debug.LogError($"❌ JSON 저장 실패: {ex.Message}");
return false; // 저장 실패
}
}

View File

@@ -35,7 +35,8 @@ namespace TON
skillDatas.Clear();
}
skillDatas = JSONLoader.LoadFromResources<List<SkillData>>("skill");
JSONLoader.SaveJsonToPersistentData("skill");
skillDatas = JSONLoader.LoadJsonFromPersistentData<List<SkillData>>("skill");
if (skillDatas == null)
{
@@ -43,6 +44,24 @@ namespace TON
}
}
public void UpdateSkillData(string skillId, int slotNumber)
{
foreach (var skill in skillDatas)
{
if (skill.id == skillId)
{
skill.slotNumber = slotNumber;
}
if (skill.slotNumber == slotNumber && skill.id != skillId)
{
skill.slotNumber = 0;
}
}
Assert.IsTrue(JSONLoader.SaveUpdatedJsonToPersistentData(skillDatas, "skill"));
Initalize();
}
public void SetSkillInstances()
{
skillInstances = new SerializableDictionary<string, SkillBase>();
@@ -159,21 +178,6 @@ namespace TON
return result;
}
public void UpdateSkillData(string skillId, int slotNumber)
{
foreach (var skill in skillDatas)
{
if (skill.id == skillId)
{
skill.slotNumber = slotNumber;
}
if (skill.slotNumber == slotNumber && skill.id != skillId)
{
skill.slotNumber = 0;
}
}
JSONLoader.SaveToFile(skillDatas, "skill");
}
}
}

View File

@@ -2,6 +2,7 @@ using System.Collections;
using System.Collections.Generic;
using UnityEditor.PackageManager;
using UnityEngine;
using UnityEngine.Assertions;
using UnityEngine.EventSystems;
using UnityEngine.UI;
@@ -61,6 +62,7 @@ namespace TON
// 스킬 버튼을 생성
List<SkillBase> activatedSkills = SkillDataManager.Singleton.GetEquippedSkills();
int maxEquipSkillCount = SkillDataManager.Singleton.GetActiveSkillCount();
for (int i = 0; i < 3; i++)
{
SkillSettingUI_SkillSlot newSkillSlot = Instantiate(skillSlotPrefab, skillSlotGroup);
@@ -72,8 +74,15 @@ namespace TON
}
else
{
// 복제 됐을때 기본 상태가 잠금 상태
newSkillSlot.GetComponent<Button>().interactable = false;
if (i == maxEquipSkillCount - 1)
{
// 만약 스킬을 배치할 수 있는 슬롯이지만 지정된 스킬이 없다면
newSkillSlot.Initalize(null, i);
}
else
{
newSkillSlot.GetComponent<Button>().interactable = false;
}
}
createSkillSlots.Add(newSkillSlot);
}
@@ -81,6 +90,20 @@ namespace TON
private void SetSkillInfoItem()
{
// 이미 기존에 UI가 생성되어 있다면 삭제
if (createSkillInfo.Count > 0)
{
foreach (var button in createSkillInfo)
{
Destroy(button.gameObject);
}
createSkillInfo.Clear();
}
if (uiPrefabList.Count > 0)
{
uiPrefabList.Clear();
}
List<SkillData> skillDatas = SkillDataManager.Singleton.skillDatas;
float y = 0;
@@ -140,7 +163,6 @@ namespace TON
public void OnClickSettingButton()
{
Debug.Log($"OnClickSettingButton() : {selectedSkillId} , {selectedSlotIndex}");
// 스킬 데이터 업데이트 할때 selectedSlotIndex +1 해서 넘겨줘야함
SkillDataManager.Singleton.UpdateSkillData(selectedSkillId, selectedSlotIndex + 1);