mirror of
https://github.com/crskycode/GARbro.git
synced 2024-11-30 17:05:37 +08:00
(GraFormat): recognize images without 'gra' signature.
This commit is contained in:
parent
0f9c679b8c
commit
d63bb19338
@ -35,6 +35,7 @@ namespace GameRes.Formats.MnoViolet
|
|||||||
{
|
{
|
||||||
public int PackedSize;
|
public int PackedSize;
|
||||||
public int UnpackedSize;
|
public int UnpackedSize;
|
||||||
|
public long DataOffset;
|
||||||
}
|
}
|
||||||
|
|
||||||
[Export(typeof(ImageFormat))]
|
[Export(typeof(ImageFormat))]
|
||||||
@ -46,7 +47,7 @@ namespace GameRes.Formats.MnoViolet
|
|||||||
|
|
||||||
public GraFormat ()
|
public GraFormat ()
|
||||||
{
|
{
|
||||||
Signatures = new uint[] { 0x00617267, 0x0073616d }; // 'gra', 'mas'
|
Signatures = new uint[] { 0x00617267, 0x0073616d, 0 }; // 'gra', 'mas'
|
||||||
}
|
}
|
||||||
|
|
||||||
public override void Write (Stream file, ImageData image)
|
public override void Write (Stream file, ImageData image)
|
||||||
@ -61,6 +62,19 @@ namespace GameRes.Formats.MnoViolet
|
|||||||
uint sign = input.ReadUInt32();
|
uint sign = input.ReadUInt32();
|
||||||
uint width = input.ReadUInt32();
|
uint width = input.ReadUInt32();
|
||||||
uint height = input.ReadUInt32();
|
uint height = input.ReadUInt32();
|
||||||
|
if (0 == width || width > 0x8000 || 0 == height || height > 0x8000)
|
||||||
|
return null;
|
||||||
|
int bpp;
|
||||||
|
if (0x617267 == sign) // 'gra'
|
||||||
|
bpp = 24;
|
||||||
|
else if (0x73616D == sign) // 'mas'
|
||||||
|
bpp = 8;
|
||||||
|
else if (1 == sign)
|
||||||
|
bpp = input.ReadInt32();
|
||||||
|
else
|
||||||
|
return null;
|
||||||
|
if (bpp != 32 && bpp != 24 && bpp != 8)
|
||||||
|
return null;
|
||||||
int packed_size = input.ReadInt32();
|
int packed_size = input.ReadInt32();
|
||||||
int data_size = input.ReadInt32();
|
int data_size = input.ReadInt32();
|
||||||
return new GraMetaData
|
return new GraMetaData
|
||||||
@ -69,7 +83,8 @@ namespace GameRes.Formats.MnoViolet
|
|||||||
Height = height,
|
Height = height,
|
||||||
PackedSize = packed_size,
|
PackedSize = packed_size,
|
||||||
UnpackedSize = data_size,
|
UnpackedSize = data_size,
|
||||||
BPP = 0x617267 == sign ? 24 : 8,
|
BPP = bpp,
|
||||||
|
DataOffset = stream.Position,
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -77,13 +92,15 @@ namespace GameRes.Formats.MnoViolet
|
|||||||
public override ImageData Read (Stream stream, ImageMetaData info)
|
public override ImageData Read (Stream stream, ImageMetaData info)
|
||||||
{
|
{
|
||||||
var meta = (GraMetaData)info;
|
var meta = (GraMetaData)info;
|
||||||
stream.Position = 0x14;
|
stream.Position = meta.DataOffset;
|
||||||
using (var reader = new LzssReader (stream, meta.PackedSize, meta.UnpackedSize))
|
using (var reader = new LzssReader (stream, meta.PackedSize, meta.UnpackedSize))
|
||||||
{
|
{
|
||||||
reader.Unpack();
|
reader.Unpack();
|
||||||
int stride = ((int)info.Width*info.BPP/8 + 3) & ~3;
|
int stride = ((int)info.Width*info.BPP/8 + 3) & ~3;
|
||||||
PixelFormat format;
|
PixelFormat format;
|
||||||
if (24 == info.BPP)
|
if (32 == info.BPP)
|
||||||
|
format = PixelFormats.Bgra32;
|
||||||
|
else if (24 == info.BPP)
|
||||||
format = PixelFormats.Bgr24;
|
format = PixelFormats.Bgr24;
|
||||||
else
|
else
|
||||||
format = PixelFormats.Gray8;
|
format = PixelFormats.Gray8;
|
||||||
|
Loading…
Reference in New Issue
Block a user