【发布时间】:2014-10-03 08:46:29
【问题描述】:
我被要求修复一个在 Unity 中构建的 iPhone 游戏,导致 iOS 8 出现问题。该游戏在所有早期版本的 iOS 中都可以运行,但在 iOS 8 中,它会加载所有初始屏幕,然后卡在以下 LoadGameData 函数上我在 Xcode 6 中出现了这个错误:
IsolatedStorageException: Could not find a part of the path "/private/var/mobile/Containers/Bundle/Application/D9F47ED4-40E1-420E-A5A8-836F52BC301C/Documents/GameSave3.dat".
at System.IO.FileStream..ctor (System.String path, FileMode mode, FileAccess access, FileShare share, Int32 bufferSize, Boolean anonymous, FileOptions options) [0x00000] in <filename unknown>:0
at System.IO.FileStream..ctor (System.String path, FileMode mode, FileAccess access, FileShare share, Int32 bufferSize, Boolean isAsync, Boolean anonymous) [0x00000] in <filename unknown>:0
at System.IO.FileStream..ctor (System.String path, FileMode mode, FileAccess access) [0x00000] in <filename unknown>:0
at LoadSave.LoadGameData () [0x00000] in <filename unknown>:0
at MainLoop.Update () [0x00000] in <filename unknown>:0
(Filename: Line: -1)
这是包含 LoadGameData() 函数的 LoadSave.cs 文件:
using UnityEngine;
using System.Collections;
using System.IO;
public class LoadSave : MonoBehaviour {
void Start ()
{
Debug.Log ("Start LoadSave");
Globals.g_loadSave = this;
}
void Update () {
}
void SetGameDataDefaults ()
{
for (int i = 0; i < (int)World.ActivityType.kNum; i++)
{
Globals.g_main.world.notification_day[i] = -1;
Globals.g_main.world.notification_hour[i] = -1;
Globals.g_main.world.notification_minute[i] = -1;
}
}
string pathForDocumentsFile( string filename )
{
if (Application.platform == RuntimePlatform.IPhonePlayer)
{
string path = Application.dataPath.Substring( 0, Application.dataPath.Length - 5 );
path = path.Substring( 0, path.LastIndexOf( '/' ) );
return Path.Combine( Path.Combine( path, "Documents" ), filename );
}
else if(Application.platform == RuntimePlatform.Android)
{
string path = Application.persistentDataPath;
path = path.Substring(0, path.LastIndexOf( '/' ) );
return Path.Combine (path, filename);
}
else
{
string path = Application.dataPath;
path = path.Substring(0, path.LastIndexOf( '/' ) );
return Path.Combine (path, filename);
}
}
public void SaveGameData()
{
Utilities.Log("Write to GameSave File");
string path = this.pathForDocumentsFile("GameSave3.dat" );
FileStream file = new FileStream (path, FileMode.Open, FileAccess.Write);
this.WriteGameDataToFile(file);
file.Close();
}
public void LoadGameData()
{
string path = pathForDocumentsFile( "GameSave3.dat" );
//if the file has not been made yet then set defaults and create it...
if (!File.Exists(path))
{
Utilities.Log("Create GameSave File");
this.SetGameDataDefaults();
FileStream newFile = new FileStream (path, FileMode.Create, FileAccess.Write);
this.WriteGameDataToFile(newFile);
newFile.Close();
return;
}
//Otherwise just read it
Utilities.Log("Read GameSave File");
FileStream file = new FileStream (path, FileMode.Open, FileAccess.Read);
this.ReadGameDataFromFile(file);
file.Close();
}
void ReadGameDataFromFile(FileStream filestream)
{
BinaryReader reader = new BinaryReader(filestream);
for (int i = 0; i < World.kNumOpenPlayGamesRemembered; i++)
{
Globals.g_main.world.lastOpenPlayGames[i] = (GameType)reader.ReadInt32();
}
Globals.g_main.world.openPlayRememberIndex = reader.ReadInt32();
for (int i = 0; i < (int)World.ActivityType.kNum; i++)
{
Globals.g_main.world.numBadges[i] = reader.ReadInt32();
}
//stored local notification info
for (int i = 0; i < (int)World.ActivityType.kNum; i++)
{
Globals.g_main.world.notification_day[i] = reader.ReadInt32();
Globals.g_main.world.notification_hour[i] = reader.ReadInt32();
Globals.g_main.world.notification_minute[i] = reader.ReadInt32();
}
}
void WriteGameDataToFile(FileStream filestream)
{
BinaryWriter writer = new BinaryWriter(filestream);
for (int i = 0; i < World.kNumOpenPlayGamesRemembered; i++)
{
writer.Write((int)Globals.g_main.world.lastOpenPlayGames[i]);
}
writer.Write(Globals.g_main.world.openPlayRememberIndex);
for (int i = 0; i < (int)World.ActivityType.kNum; i++)
{
writer.Write((int)Globals.g_main.world.numBadges[i]);
}
//stored local notification info
for (int i = 0; i < (int)World.ActivityType.kNum; i++)
{
writer.Write((int)Globals.g_main.world.notification_day[i]);
writer.Write((int)Globals.g_main.world.notification_hour[i]);
writer.Write((int)Globals.g_main.world.notification_minute[i]);
}
}
}
让我感到困惑的是为什么它在除 iOS 8 之外的所有 iOS 版本中都能正常工作。任何想法可能是什么问题?谢谢。
【问题讨论】:
标签: c# objective-c xcode unity3d ios8