158 lines
4.8 KiB
C#
Raw Normal View History

// Copyright (c) Pixel Crushers. All rights reserved.
using UnityEngine;
using System;
using System.Collections.Generic;
using System.Linq;
namespace PixelCrushers
{
/// <summary>
/// Holds the data for a saved game.
/// </summary>
[Serializable]
public class SavedGameData : ISerializationCallbackReceiver
{
/// <summary>
/// Holds the data returned by a Saver along with the Saver's key
/// and the index of the scene that the Saver was in.
/// </summary>
[Serializable]
public class SaveRecord
{
public string key;
public int sceneIndex;
public string data;
public SaveRecord() { }
public SaveRecord(string key, int sceneIndex, string data)
{
this.key = key;
this.sceneIndex = sceneIndex;
this.data = data;
}
}
[SerializeField]
private int m_version = 0;
[SerializeField]
private string m_sceneName;
private Dictionary<string, SaveRecord> m_dict = new Dictionary<string, SaveRecord>();
[SerializeField]
private List<SaveRecord> m_list = new List<SaveRecord>();
/// <summary>
/// The save file format version. This is an arbitrary value that you
/// can assign by setting SaveSystem.version.
/// </summary>
public int version
{
get { return m_version; }
set { m_version = value; }
}
/// <summary>
/// The scene in which the game was saved.
/// </summary>
public string sceneName
{
get { return m_sceneName; }
set { m_sceneName = value; }
}
/// <summary>
/// Provides direct access to the dictionary of save records.
/// Use with caution.
/// </summary>
public Dictionary<string, SaveRecord> Dict { get { return m_dict; } }
public void OnBeforeSerialize()
{
m_list.Clear();
foreach (var kvp in m_dict)
{
m_list.Add(kvp.Value);
}
}
public void OnAfterDeserialize()
{
m_dict = new Dictionary<string, SaveRecord>();
for (int i = 0; i < m_list.Count; i++)
{
if (m_list[i] == null) continue;
m_dict.Add(m_list[i].key, m_list[i]);
}
}
/// <summary>
/// Retrieves info about the previously-saved data for a Saver.
/// </summary>
/// <param name="key">Saver's unique key.</param>
/// <returns>Returns the Save Record stored under the Saver's key, or null if no data is stored.</returns>
public SaveRecord GetDataInfo(string key)
{
return m_dict.ContainsKey(key) ? m_dict[key] : null;
}
/// <summary>
/// Retrieves the previously-saved data for a Saver.
/// </summary>
/// <param name="key">Saver's unique key.</param>
/// <returns>Returns the data stored under the Saver's key, or null if no data is stored.</returns>
public string GetData(string key)
{
return m_dict.ContainsKey(key) ? m_dict[key].data : null;
}
/// <summary>
/// Stores a Saver's data.
/// </summary>
/// <param name="key">Saver's unique key.</param>
/// <param name="sceneIndex">Scene in which Saver exists.</param>
/// <param name="data">Data to set.</param>
public void SetData(string key, int sceneIndex, string data)
{
if (m_dict.ContainsKey(key))
{
m_dict[key].sceneIndex = sceneIndex;
m_dict[key].data = data;
}
else
{
m_dict.Add(key, new SaveRecord(key, sceneIndex, data));
}
}
/// <summary>
/// Removes a Saver's data.
/// </summary>
/// <param name="key">Saver's unique key.</param>
public void DeleteData(string key)
{
if (m_dict.ContainsKey(key))
{
m_dict.Remove(key);
}
}
/// <summary>
/// Removes all save records except those in the current scene and those that are
/// configured to remember across scene changes.
/// </summary>
/// <param name="currentSceneIndex">Don't clear out Savers in this scene.</param>
public void DeleteObsoleteSaveData(int currentSceneIndex)
{
m_dict = m_dict.Where(element => element.Value.sceneIndex == currentSceneIndex || element.Value.sceneIndex == SaveSystem.NoSceneIndex)
.ToDictionary(element => element.Key, element => element.Value);
}
}
}