mirror of https://github.com/AxioDL/metaforce.git
More CRasterFont work, CParticleElectric stub
This commit is contained in:
parent
b3859c4476
commit
b496ec643b
|
@ -28,7 +28,7 @@ CFactoryFnReturn CFactoryMgr::MakeObjectFromMemory(const SObjectTag& tag, void*
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
athena::io::MemoryReader r(buf, size);
|
CMemoryInStream r(buf, size);
|
||||||
return search->second(tag, r, paramXfer);
|
return search->second(tag, r, paramXfer);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -4,6 +4,73 @@ namespace urde
|
||||||
{
|
{
|
||||||
CRasterFont::CRasterFont(urde::CInputStream& in, urde::IObjectStore& store)
|
CRasterFont::CRasterFont(urde::CInputStream& in, urde::IObjectStore& store)
|
||||||
{
|
{
|
||||||
|
u32 magic = in.readUint32Big();
|
||||||
|
if (magic != SBIG('FONT'))
|
||||||
|
return;
|
||||||
|
|
||||||
|
u32 version = in.readUint32Big();
|
||||||
|
x4_monoWidth = in.readUint32Big();
|
||||||
|
x8_monoHeight = in.readUint32Big();
|
||||||
|
|
||||||
|
if (version >= 1)
|
||||||
|
x8c_baseline = in.readUint32Big();
|
||||||
|
else
|
||||||
|
x8c_baseline = x8_monoHeight;
|
||||||
|
|
||||||
|
if (version >= 2)
|
||||||
|
x90_ = in.readUint32Big();
|
||||||
|
|
||||||
|
bool tmp1 = in.readBool();
|
||||||
|
bool tmp2 = in.readBool();
|
||||||
|
|
||||||
|
u32 tmp3 = in.readUint32Big();
|
||||||
|
u32 tmp4 = in.readUint32Big();
|
||||||
|
std::string name= in.readString();
|
||||||
|
u32 txtrId = in.readUint32Big();
|
||||||
|
x80_texture = store.GetObj({'TXTR', txtrId});
|
||||||
|
x30_fontInfo = CFontInfo(tmp1, tmp2, tmp3, tmp4, name.c_str());
|
||||||
|
u32 mode = in.readUint32Big();
|
||||||
|
/* TODO: Make an enum */
|
||||||
|
if (mode == 1)
|
||||||
|
x2c_mode = 1;
|
||||||
|
else if (mode == 0)
|
||||||
|
x2c_mode = 0;
|
||||||
|
|
||||||
|
u32 glyphCount = in.readUint32Big();
|
||||||
|
xc_glyphs.reserve(glyphCount);
|
||||||
|
|
||||||
|
for (u32 i = 0 ; i < glyphCount ; ++i)
|
||||||
|
{
|
||||||
|
wchar_t chr = in.readUint16Big();
|
||||||
|
float startU = in.readFloatBig();
|
||||||
|
float startV = in.readFloatBig();
|
||||||
|
float endU = in.readFloatBig();
|
||||||
|
float endV = in.readFloatBig();
|
||||||
|
s32 a = in.readInt32Big();
|
||||||
|
s32 b = in.readInt32Big();
|
||||||
|
s32 c = in.readInt32Big();
|
||||||
|
s32 cellWidth = in.readInt32Big();
|
||||||
|
s32 cellHeight = in.readInt32Big();
|
||||||
|
s32 baseline = in.readInt32Big();
|
||||||
|
s32 kernStart = in.readUint32();
|
||||||
|
xc_glyphs[i] = std::make_pair(chr, CGlyph(a, b, c, startU, startV, endU, endV,
|
||||||
|
cellWidth, cellHeight, baseline, kernStart));
|
||||||
|
}
|
||||||
|
|
||||||
|
std::sort(xc_glyphs.begin(), xc_glyphs.end(), [=](auto& a, auto& b) -> bool{
|
||||||
|
return a.first < b.first;
|
||||||
|
});
|
||||||
|
|
||||||
|
u32 kernCount = in.readUint32Big();
|
||||||
|
x1c_kerning.reserve(kernCount);
|
||||||
|
|
||||||
|
for (u32 i = 0 ; i < kernCount ; ++i)
|
||||||
|
{
|
||||||
|
wchar_t first = in.readUint16Big();
|
||||||
|
wchar_t second = in.readUint16Big();
|
||||||
|
s32 howMuch = in.readUint32Big();
|
||||||
|
x1c_kerning[i] = CKernPair(first, second, howMuch);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
std::unique_ptr<IObj> FRasterFontFactory(const SObjectTag& tag, CInputStream& in, const CVParamTransfer& vparms)
|
std::unique_ptr<IObj> FRasterFontFactory(const SObjectTag& tag, CInputStream& in, const CVParamTransfer& vparms)
|
||||||
|
|
|
@ -12,10 +12,10 @@ class CTexture;
|
||||||
|
|
||||||
class CGlyph
|
class CGlyph
|
||||||
{
|
{
|
||||||
wchar_t x0_char;
|
private:
|
||||||
s16 x2_leftPadding;
|
s16 x0_leftPadding;
|
||||||
s16 x4_advance;
|
s16 x2_advance;
|
||||||
s16 x6_rightPadding;
|
s16 x4_rightPadding;
|
||||||
float x8_startU;
|
float x8_startU;
|
||||||
float xc_startV;
|
float xc_startV;
|
||||||
float x10_endU;
|
float x10_endU;
|
||||||
|
@ -24,10 +24,19 @@ class CGlyph
|
||||||
s16 x1a_cellHeight;
|
s16 x1a_cellHeight;
|
||||||
s16 x1c_baseline;
|
s16 x1c_baseline;
|
||||||
s16 x1e_kernStart;
|
s16 x1e_kernStart;
|
||||||
|
public:
|
||||||
|
CGlyph() = default;
|
||||||
|
CGlyph(s16 a, s16 b, s32 c, float startU, float startV, float endU, float endV,
|
||||||
|
s16 cellWidth, s16 cellHeight, s16 baseline, s16 kernStart)
|
||||||
|
: x0_leftPadding(a), x2_advance(b), x4_rightPadding(c),
|
||||||
|
x8_startU(startU), xc_startV(startV), x10_endU(endU), x14_endV(endV),
|
||||||
|
x18_cellWidth(cellWidth), x1a_cellHeight(cellHeight),
|
||||||
|
x1c_baseline(baseline), x1e_kernStart(kernStart)
|
||||||
|
{}
|
||||||
|
|
||||||
s16 GetA() const { return x2_leftPadding; }
|
s16 GetA() const { return x0_leftPadding; }
|
||||||
s16 GetB() const { return x4_advance; }
|
s16 GetB() const { return x2_advance; }
|
||||||
s16 GetC() const { return x6_rightPadding; }
|
s16 GetC() const { return x4_rightPadding; }
|
||||||
float GetStartU() const { return x8_startU; }
|
float GetStartU() const { return x8_startU; }
|
||||||
float GetStartV() const { return xc_startV; }
|
float GetStartV() const { return xc_startV; }
|
||||||
float GetEndU() const { return x10_endU; }
|
float GetEndU() const { return x10_endU; }
|
||||||
|
@ -36,38 +45,67 @@ class CGlyph
|
||||||
s16 GetCellHeight() const { return x1a_cellHeight; }
|
s16 GetCellHeight() const { return x1a_cellHeight; }
|
||||||
s16 GetBaseline() const { return x1c_baseline; }
|
s16 GetBaseline() const { return x1c_baseline; }
|
||||||
s16 GetKernStart() const { return x1e_kernStart; }
|
s16 GetKernStart() const { return x1e_kernStart; }
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
struct CKernPair
|
class CKernPair
|
||||||
{
|
{
|
||||||
|
private:
|
||||||
wchar_t x0_first;
|
wchar_t x0_first;
|
||||||
wchar_t x2_second;
|
wchar_t x2_second;
|
||||||
s32 x4_howMuch;
|
s32 x4_howMuch;
|
||||||
|
|
||||||
|
public:
|
||||||
|
CKernPair() = default;
|
||||||
|
CKernPair(wchar_t first, wchar_t second, s32 howMuch)
|
||||||
|
: x0_first(first), x2_second(second), x4_howMuch(howMuch)
|
||||||
|
{}
|
||||||
|
|
||||||
wchar_t GetFirst() const { return x0_first; }
|
wchar_t GetFirst() const { return x0_first; }
|
||||||
wchar_t GetSecond() const { return x2_second; }
|
wchar_t GetSecond() const { return x2_second; }
|
||||||
s32 GetHowMuch() const { return x4_howMuch; }
|
s32 GetHowMuch() const { return x4_howMuch; }
|
||||||
};
|
};
|
||||||
|
|
||||||
class CRasterFont
|
class CFontInfo
|
||||||
{
|
{
|
||||||
bool x0_ = false;
|
bool x0_ = false;
|
||||||
|
bool x1_ = false;
|
||||||
|
s32 x4_ = 0;
|
||||||
|
s32 x8_fontSize = 0;
|
||||||
|
char* xc_name = 0;
|
||||||
|
|
||||||
|
public:
|
||||||
|
CFontInfo() = default;
|
||||||
|
CFontInfo(bool a, bool b, s32 c, s32 fontSize, const char* name)
|
||||||
|
: x0_(a), x1_(b), x4_(c), x8_fontSize(fontSize)
|
||||||
|
{
|
||||||
|
strcpy(xc_name, name);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
class CRasterFont
|
||||||
|
{
|
||||||
s32 x4_monoWidth = 16;
|
s32 x4_monoWidth = 16;
|
||||||
s32 x8_monoHeight = 16;
|
s32 x8_monoHeight = 16;
|
||||||
std::unordered_map<wchar_t, CGlyph> xc_glyphs;
|
std::vector<std::pair<wchar_t, CGlyph>> xc_glyphs;
|
||||||
std::vector<CKernPair> x1c_kerning;
|
std::vector<CKernPair> x1c_kerning;
|
||||||
s32 x2c_mode;
|
s32 x28_lineMargin = 0;
|
||||||
s32 x30_;
|
s32 x2c_mode = 0;
|
||||||
|
CFontInfo x30_fontInfo;
|
||||||
TToken<CTexture> x80_texture;
|
TToken<CTexture> x80_texture;
|
||||||
|
bool x88_ = false;
|
||||||
s32 x8c_baseline;
|
s32 x8c_baseline;
|
||||||
s32 x90_;
|
s32 x90_ = 0;
|
||||||
|
char* fontName;
|
||||||
|
|
||||||
CGlyph* InternalGetGlyph(wchar_t chr)
|
CGlyph* InternalGetGlyph(wchar_t chr)
|
||||||
{
|
{
|
||||||
if (xc_glyphs.find(chr) == xc_glyphs.end())
|
u32 i = 0;
|
||||||
return nullptr;
|
for (; i < xc_glyphs.size(); ++i)
|
||||||
|
if (chr == xc_glyphs[i].first)
|
||||||
|
break;
|
||||||
|
|
||||||
return &xc_glyphs[chr];
|
return &xc_glyphs[i].second;
|
||||||
}
|
}
|
||||||
|
|
||||||
public:
|
public:
|
||||||
|
|
|
@ -4,6 +4,46 @@
|
||||||
namespace urde
|
namespace urde
|
||||||
{
|
{
|
||||||
|
|
||||||
|
s32 DecryptionCtx::DecryptRead(CInputStream& in, s32 key)
|
||||||
|
{
|
||||||
|
int ret = 0;
|
||||||
|
if (x20_encShift >= key)
|
||||||
|
{
|
||||||
|
int diff = x20_encShift - 0x20;
|
||||||
|
int baseVal = -1;
|
||||||
|
if (x20_encShift != 0x20)
|
||||||
|
baseVal = 1 << (x20_encShift - 1);
|
||||||
|
x20_encShift = key - x20_encShift;
|
||||||
|
ret = baseVal | (x1c_encVal >> diff);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
int diff = x20_encShift - key;
|
||||||
|
int rem = x20_encShift - 0x20;
|
||||||
|
int baseVal1 = -1;
|
||||||
|
if (x20_encShift != 0x20)
|
||||||
|
baseVal1 = 1 << (x20_encShift - 1);
|
||||||
|
|
||||||
|
int bit = diff & 7;
|
||||||
|
x20_encShift = 0;
|
||||||
|
int count = (diff >> 3) + ((-bit | bit) >> 31);
|
||||||
|
int baseVal2 = (baseVal1 & (x1c_encVal >> rem)) << diff;
|
||||||
|
in.readBytesToBuf(&x1c_encVal, count);
|
||||||
|
|
||||||
|
int baseVal3 = -1;
|
||||||
|
if (diff != 0x20)
|
||||||
|
baseVal3 = 1 << (diff - 1);
|
||||||
|
|
||||||
|
int tmpShift = x20_encShift;
|
||||||
|
x20_encShift = (count << 3);
|
||||||
|
ret = baseVal2 | (baseVal3 & (x1c_encVal >> (diff - 0x20))) << tmpShift;
|
||||||
|
x20_encShift = diff - x20_encShift;
|
||||||
|
x1c_encVal = x1c_encVal >> diff;
|
||||||
|
}
|
||||||
|
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
class CZipSupport
|
class CZipSupport
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
|
|
|
@ -9,10 +9,16 @@
|
||||||
|
|
||||||
namespace urde
|
namespace urde
|
||||||
{
|
{
|
||||||
|
|
||||||
using CInputStream = athena::io::IStreamReader;
|
using CInputStream = athena::io::IStreamReader;
|
||||||
using COutputStream = athena::io::IStreamWriter;
|
using COutputStream = athena::io::IStreamWriter;
|
||||||
|
|
||||||
|
struct DecryptionCtx
|
||||||
|
{
|
||||||
|
s32 x1c_encVal;
|
||||||
|
s32 x20_encShift;
|
||||||
|
s32 DecryptRead(CInputStream& in, s32 key);
|
||||||
|
};
|
||||||
|
|
||||||
using CMemoryInStream = athena::io::MemoryReader;
|
using CMemoryInStream = athena::io::MemoryReader;
|
||||||
|
|
||||||
class CZipInputStream : public CInputStream
|
class CZipInputStream : public CInputStream
|
||||||
|
|
|
@ -10,6 +10,10 @@
|
||||||
namespace urde
|
namespace urde
|
||||||
{
|
{
|
||||||
|
|
||||||
|
void CParticleElectric::RenderSwooshes()
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
CParticleElectric::CParticleElectric(const TToken<CElectricDescription>& token)
|
CParticleElectric::CParticleElectric(const TToken<CElectricDescription>& token)
|
||||||
: x1c_elecDesc(token)
|
: x1c_elecDesc(token)
|
||||||
{
|
{
|
||||||
|
|
|
@ -70,6 +70,8 @@ private:
|
||||||
};
|
};
|
||||||
u8 dummy = 0;
|
u8 dummy = 0;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
void RenderSwooshes();
|
||||||
public:
|
public:
|
||||||
|
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue