初步支持读取Script
不支持导出,sf中Data暂不支持解析
This commit is contained in:
parent
ec42590b0e
commit
71e99f86d4
@ -4,33 +4,40 @@
|
|||||||
{
|
{
|
||||||
static void Main(string[] args)
|
static void Main(string[] args)
|
||||||
{
|
{
|
||||||
if (Directory.Exists(args[0]))
|
ScriptManager smr = new();
|
||||||
{
|
smr.LoadScriptFile(args[0]);
|
||||||
string[] files = Directory.GetFiles(args[0], "db_*.bin");
|
if(args.Length == 2)
|
||||||
DatabaseManager dm = new();
|
smr.LoadScriptMess(args[1]);
|
||||||
foreach (string file in files)
|
return;
|
||||||
{
|
|
||||||
if (dm.LoadDatabase(file))
|
|
||||||
{
|
|
||||||
Console.WriteLine($"Load {file} Success");
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
Console.WriteLine($"Load {file} Failed");
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (dm.ExportDatabase(0, Path.GetDirectoryName(args[0])))
|
|
||||||
Console.WriteLine("Export Database Success");
|
|
||||||
else
|
|
||||||
{
|
|
||||||
Console.WriteLine("Export Database Failed");
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
//if (Directory.Exists(args[0]))
|
||||||
|
//{
|
||||||
|
// string[] files = Directory.GetFiles(args[0], "db_*.bin");
|
||||||
|
// DatabaseManager dm = new();
|
||||||
|
// foreach (string file in files)
|
||||||
|
// {
|
||||||
|
// if (dm.LoadDatabase(file))
|
||||||
|
// {
|
||||||
|
// Console.WriteLine($"Load {file} Success");
|
||||||
|
// }
|
||||||
|
// else
|
||||||
|
// {
|
||||||
|
// Console.WriteLine($"Load {file} Failed");
|
||||||
|
// return;
|
||||||
|
// }
|
||||||
|
|
||||||
}
|
// if (dm.ExportDatabase(0, Path.GetDirectoryName(args[0])))
|
||||||
|
// Console.WriteLine("Export Database Success");
|
||||||
|
// else
|
||||||
|
// {
|
||||||
|
// Console.WriteLine("Export Database Failed");
|
||||||
|
// return;
|
||||||
|
// }
|
||||||
|
|
||||||
|
// }
|
||||||
|
|
||||||
|
//}
|
||||||
|
|
||||||
|
|
||||||
// if (args.Length == 0 || args.Length > 2)
|
// if (args.Length == 0 || args.Length > 2)
|
||||||
|
@ -2,7 +2,7 @@
|
|||||||
"profiles": {
|
"profiles": {
|
||||||
"EscudeTools": {
|
"EscudeTools": {
|
||||||
"commandName": "Project",
|
"commandName": "Project",
|
||||||
"commandLineArgs": "G:\\x221.local\\lab\\db"
|
"commandLineArgs": "G:\\x221.local\\lab\\a_prologue_01.bin \r\nG:\\x221.local\\lab\\a_prologue_01.001"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
@ -7,10 +7,11 @@ namespace EscudeTools
|
|||||||
{
|
{
|
||||||
public class ScriptMessage
|
public class ScriptMessage
|
||||||
{
|
{
|
||||||
public byte[] Data { get; set; } // MESS領域 (消息区域)
|
public byte[] Data { get; set; } // MESS領域 (消息区域) //这个还不知道怎么解析成人能看懂的
|
||||||
public uint Size { get; set; } // MESS領域サイズ (消息区域大小)
|
public uint Size { get; set; } // MESS領域サイズ (消息区域大小)
|
||||||
public List<uint> Offset { get; set; } // MESSオフセット (消息偏移)
|
public List<uint> Offset { get; set; } // MESSオフセット (消息偏移)
|
||||||
public uint Count { get; set; } // MESS数 (消息数量)
|
public uint Count { get; set; } // MESS数 (消息数量)
|
||||||
|
public string[] DataString { get; set; } // 给人看的Data内容
|
||||||
}
|
}
|
||||||
|
|
||||||
public class ScriptFile
|
public class ScriptFile
|
||||||
@ -24,6 +25,7 @@ namespace EscudeTools
|
|||||||
public uint TextCount { get; set; } // TEXT数 (文本数量)
|
public uint TextCount { get; set; } // TEXT数 (文本数量)
|
||||||
|
|
||||||
public uint MessCount { get; set; } // MESS数 (消息数量)
|
public uint MessCount { get; set; } // MESS数 (消息数量)
|
||||||
|
public string[] TextString { get; set; } // 给人看的Text内容
|
||||||
}
|
}
|
||||||
|
|
||||||
public class ScriptManager
|
public class ScriptManager
|
||||||
@ -72,6 +74,11 @@ namespace EscudeTools
|
|||||||
sf.TextOffset[i] = br.ReadUInt32();
|
sf.TextOffset[i] = br.ReadUInt32();
|
||||||
}
|
}
|
||||||
sf.Text = br.ReadBytes((int)sf.TextSize);
|
sf.Text = br.ReadBytes((int)sf.TextSize);
|
||||||
|
sf.TextString = new string[sf.TextCount];
|
||||||
|
for (int i = 0; i < sf.TextCount; i++)
|
||||||
|
{
|
||||||
|
sf.TextString[i] = ReadStringFromTextData(sf.Text, (int)sf.TextOffset[i]);
|
||||||
|
}
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -103,7 +110,7 @@ namespace EscudeTools
|
|||||||
sm.Offset.Add(br.ReadUInt32());
|
sm.Offset.Add(br.ReadUInt32());
|
||||||
}
|
}
|
||||||
byte[] encryptData = br.ReadBytes((int)sm.Size);
|
byte[] encryptData = br.ReadBytes((int)sm.Size);
|
||||||
for (int i = 0; i <= encryptData.Length; i++)
|
for (int i = 0; i < encryptData.Length; i++)
|
||||||
{
|
{
|
||||||
encryptData[i] ^= 0x55;
|
encryptData[i] ^= 0x55;
|
||||||
}
|
}
|
||||||
@ -147,6 +154,11 @@ namespace EscudeTools
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
sm.DataString = new string[sm.Count];
|
||||||
|
for (int i = 0; i < sm.Count; i++)
|
||||||
|
{
|
||||||
|
sm.DataString[i] = ReadStringFromTextData(sm.Data, (int)sm.Offset[i]);
|
||||||
|
}
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -341,5 +353,19 @@ namespace EscudeTools
|
|||||||
};
|
};
|
||||||
throw new NotImplementedException();
|
throw new NotImplementedException();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private static string ReadStringFromTextData(byte[] sheet_text, int offset)
|
||||||
|
{
|
||||||
|
List<byte> stringBytes = [];
|
||||||
|
for (int i = offset; i < sheet_text.Length && sheet_text[i] != 0x00; i++)
|
||||||
|
{
|
||||||
|
stringBytes.Add(sheet_text[i]);
|
||||||
|
}
|
||||||
|
EncodingProvider provider = CodePagesEncodingProvider.Instance;
|
||||||
|
Encoding? shiftJis = provider.GetEncoding("shift-jis");
|
||||||
|
return shiftJis == null
|
||||||
|
? throw new InvalidOperationException("Shift-JIS encoding not supported.")
|
||||||
|
: shiftJis.GetString(stringBytes.ToArray());
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user